1e7a85f26SRafal Jaworowski /* 2e7a85f26SRafal Jaworowski * (C) Copyright 2007-2008 Semihalf 3e7a85f26SRafal Jaworowski * 4e7a85f26SRafal Jaworowski * Written by: Rafal Jaworowski <raj@semihalf.com> 5e7a85f26SRafal Jaworowski * 6*933aa017SWolfgang Denk * SPDX-License-Identifier: GPL-2.0+ BSD-2-Clause 7e7a85f26SRafal Jaworowski */ 8e7a85f26SRafal Jaworowski 9500856ebSRafal Jaworowski #ifndef _API_PUBLIC_H_ 10500856ebSRafal Jaworowski #define _API_PUBLIC_H_ 11500856ebSRafal Jaworowski 12500856ebSRafal Jaworowski #define API_EINVAL 1 /* invalid argument(s) */ 13500856ebSRafal Jaworowski #define API_ENODEV 2 /* no device */ 14500856ebSRafal Jaworowski #define API_ENOMEM 3 /* no memory */ 15500856ebSRafal Jaworowski #define API_EBUSY 4 /* busy, occupied etc. */ 16500856ebSRafal Jaworowski #define API_EIO 5 /* I/O error */ 17923aa481SRafal Jaworowski #define API_ESYSC 6 /* syscall error */ 18500856ebSRafal Jaworowski 19500856ebSRafal Jaworowski typedef int (*scp_t)(int, int *, ...); 20500856ebSRafal Jaworowski 21500856ebSRafal Jaworowski #define API_SIG_VERSION 1 22500856ebSRafal Jaworowski #define API_SIG_MAGIC "UBootAPI" 23500856ebSRafal Jaworowski #define API_SIG_MAGLEN 8 24500856ebSRafal Jaworowski 25500856ebSRafal Jaworowski struct api_signature { 26500856ebSRafal Jaworowski char magic[API_SIG_MAGLEN]; /* magic string */ 27500856ebSRafal Jaworowski uint16_t version; /* API version */ 28500856ebSRafal Jaworowski uint32_t checksum; /* checksum of this sig struct */ 29500856ebSRafal Jaworowski scp_t syscall; /* entry point to the API */ 30500856ebSRafal Jaworowski }; 31500856ebSRafal Jaworowski 32500856ebSRafal Jaworowski enum { 33500856ebSRafal Jaworowski API_RSVD = 0, 34500856ebSRafal Jaworowski API_GETC, 35500856ebSRafal Jaworowski API_PUTC, 36500856ebSRafal Jaworowski API_TSTC, 37500856ebSRafal Jaworowski API_PUTS, 38500856ebSRafal Jaworowski API_RESET, 39500856ebSRafal Jaworowski API_GET_SYS_INFO, 40500856ebSRafal Jaworowski API_UDELAY, 41500856ebSRafal Jaworowski API_GET_TIMER, 42500856ebSRafal Jaworowski API_DEV_ENUM, 43500856ebSRafal Jaworowski API_DEV_OPEN, 44500856ebSRafal Jaworowski API_DEV_CLOSE, 45500856ebSRafal Jaworowski API_DEV_READ, 46500856ebSRafal Jaworowski API_DEV_WRITE, 47500856ebSRafal Jaworowski API_ENV_ENUM, 48500856ebSRafal Jaworowski API_ENV_GET, 49500856ebSRafal Jaworowski API_ENV_SET, 50a2a5729fSChe-Liang Chiou API_DISPLAY_GET_INFO, 51a2a5729fSChe-Liang Chiou API_DISPLAY_DRAW_BITMAP, 52a2a5729fSChe-Liang Chiou API_DISPLAY_CLEAR, 53500856ebSRafal Jaworowski API_MAXCALL 54500856ebSRafal Jaworowski }; 55500856ebSRafal Jaworowski 56500856ebSRafal Jaworowski #define MR_ATTR_FLASH 0x0001 57500856ebSRafal Jaworowski #define MR_ATTR_DRAM 0x0002 58500856ebSRafal Jaworowski #define MR_ATTR_SRAM 0x0003 59500856ebSRafal Jaworowski 60500856ebSRafal Jaworowski struct mem_region { 61500856ebSRafal Jaworowski unsigned long start; 62500856ebSRafal Jaworowski unsigned long size; 63500856ebSRafal Jaworowski int flags; 64500856ebSRafal Jaworowski }; 65500856ebSRafal Jaworowski 66500856ebSRafal Jaworowski struct sys_info { 67500856ebSRafal Jaworowski unsigned long clk_bus; 68500856ebSRafal Jaworowski unsigned long clk_cpu; 69500856ebSRafal Jaworowski unsigned long bar; 70500856ebSRafal Jaworowski struct mem_region *mr; 71500856ebSRafal Jaworowski int mr_no; /* number of memory regions */ 72500856ebSRafal Jaworowski }; 73500856ebSRafal Jaworowski 746d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #undef CONFIG_SYS_64BIT_LBA 756d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #ifdef CONFIG_SYS_64BIT_LBA 76500856ebSRafal Jaworowski typedef u_int64_t lbasize_t; 77500856ebSRafal Jaworowski #else 78500856ebSRafal Jaworowski typedef unsigned long lbasize_t; 79500856ebSRafal Jaworowski #endif 80500856ebSRafal Jaworowski typedef unsigned long lbastart_t; 81500856ebSRafal Jaworowski 82500856ebSRafal Jaworowski #define DEV_TYP_NONE 0x0000 83500856ebSRafal Jaworowski #define DEV_TYP_NET 0x0001 84500856ebSRafal Jaworowski 85500856ebSRafal Jaworowski #define DEV_TYP_STOR 0x0002 86500856ebSRafal Jaworowski #define DT_STOR_IDE 0x0010 87500856ebSRafal Jaworowski #define DT_STOR_SCSI 0x0020 88500856ebSRafal Jaworowski #define DT_STOR_USB 0x0040 89500856ebSRafal Jaworowski #define DT_STOR_MMC 0x0080 90f2302d44SStefan Roese #define DT_STOR_SATA 0x0100 91500856ebSRafal Jaworowski 92500856ebSRafal Jaworowski #define DEV_STA_CLOSED 0x0000 /* invalid, closed */ 93500856ebSRafal Jaworowski #define DEV_STA_OPEN 0x0001 /* open i.e. active */ 94500856ebSRafal Jaworowski 95500856ebSRafal Jaworowski struct device_info { 96500856ebSRafal Jaworowski int type; 97500856ebSRafal Jaworowski void *cookie; 98500856ebSRafal Jaworowski 99500856ebSRafal Jaworowski union { 100500856ebSRafal Jaworowski struct { 101500856ebSRafal Jaworowski lbasize_t block_count; /* no of blocks */ 102500856ebSRafal Jaworowski unsigned long block_size; /* size of one block */ 103500856ebSRafal Jaworowski } storage; 104500856ebSRafal Jaworowski 105500856ebSRafal Jaworowski struct { 106500856ebSRafal Jaworowski unsigned char hwaddr[6]; 107500856ebSRafal Jaworowski } net; 108500856ebSRafal Jaworowski } info; 109500856ebSRafal Jaworowski #define di_stor info.storage 110500856ebSRafal Jaworowski #define di_net info.net 111500856ebSRafal Jaworowski 112500856ebSRafal Jaworowski int state; 113500856ebSRafal Jaworowski }; 114500856ebSRafal Jaworowski 115a2a5729fSChe-Liang Chiou #define DISPLAY_TYPE_LCD 0x0001 116a2a5729fSChe-Liang Chiou #define DISPLAY_TYPE_VIDEO 0x0002 117a2a5729fSChe-Liang Chiou 118a2a5729fSChe-Liang Chiou struct display_info { 119a2a5729fSChe-Liang Chiou int type; 120a2a5729fSChe-Liang Chiou /* screen size in pixels */ 121a2a5729fSChe-Liang Chiou int pixel_width; 122a2a5729fSChe-Liang Chiou int pixel_height; 123a2a5729fSChe-Liang Chiou /* screen size in rows and columns of text */ 124a2a5729fSChe-Liang Chiou int screen_rows; 125a2a5729fSChe-Liang Chiou int screen_cols; 126a2a5729fSChe-Liang Chiou }; 127a2a5729fSChe-Liang Chiou 128500856ebSRafal Jaworowski #endif /* _API_PUBLIC_H_ */ 129