2 * Copyright (C) 2000, 2001, 2002 Broadcom Corporation
4 * This program is free software; you can redistribute it and/or
5 * modify it under the terms of the GNU General Public License
6 * as published by the Free Software Foundation; either version 2
7 * of the License, or (at your option) any later version.
9 * This program is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 * GNU General Public License for more details.
14 * You should have received a copy of the GNU General Public License
15 * along with this program; if not, write to the Free Software
16 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
24 #define CFE_CMD_FW_GETINFO 0
25 #define CFE_CMD_FW_RESTART 1
26 #define CFE_CMD_FW_BOOT 2
27 #define CFE_CMD_FW_CPUCTL 3
28 #define CFE_CMD_FW_GETTIME 4
29 #define CFE_CMD_FW_MEMENUM 5
30 #define CFE_CMD_FW_FLUSHCACHE 6
32 #define CFE_CMD_DEV_GETHANDLE 9
33 #define CFE_CMD_DEV_ENUM 10
34 #define CFE_CMD_DEV_OPEN 11
35 #define CFE_CMD_DEV_INPSTAT 12
36 #define CFE_CMD_DEV_READ 13
37 #define CFE_CMD_DEV_WRITE 14
38 #define CFE_CMD_DEV_IOCTL 15
39 #define CFE_CMD_DEV_CLOSE 16
40 #define CFE_CMD_DEV_GETINFO 17
42 #define CFE_CMD_ENV_ENUM 20
43 #define CFE_CMD_ENV_GET 22
44 #define CFE_CMD_ENV_SET 23
45 #define CFE_CMD_ENV_DEL 24
47 #define CFE_CMD_MAX 32
49 #define CFE_CMD_VENDOR_USE 0x8000 /* codes above this are for customer use */
55 /* eeek, signed "pointers" */
56 typedef s64 cfe_xptr_t
;
59 u64 buf_offset
; /* offset on device (bytes) */
60 cfe_xptr_t buf_ptr
; /* pointer to a buffer */
61 u64 buf_length
; /* length of this buffer */
62 u64 buf_retlen
; /* returned length (for read ops) */
63 u64 buf_ioctlcmd
; /* IOCTL command (used only for IOCTLs) */
66 struct xiocb_inpstat
{
67 u64 inp_status
; /* 1 means input available */
71 s64 enum_idx
; /* 0-based enumeration index */
72 cfe_xptr_t name_ptr
; /* name string buffer */
73 s64 name_length
; /* size of name buffer */
74 cfe_xptr_t val_ptr
; /* value string buffer */
75 s64 val_length
; /* size of value string buffer */
79 u64 cpu_number
; /* cpu number to control */
80 u64 cpu_command
; /* command to issue to CPU */
81 u64 start_addr
; /* CPU start address */
82 u64 gp_val
; /* starting GP value */
83 u64 sp_val
; /* starting SP value */
84 u64 a1_val
; /* starting A1 value */
88 s64 ticks
; /* current time in ticks */
91 struct xiocb_exitstat
{
95 struct xiocb_meminfo
{
96 s64 mi_idx
; /* 0-based enumeration index */
97 s64 mi_type
; /* type of memory block */
98 u64 mi_addr
; /* physical start address */
99 u64 mi_size
; /* block size */
102 struct xiocb_fwinfo
{
103 s64 fwi_version
; /* major, minor, eco version */
104 s64 fwi_totalmem
; /* total installed mem */
105 s64 fwi_flags
; /* various flags */
106 s64 fwi_boardid
; /* board ID */
107 s64 fwi_bootarea_va
; /* VA of boot area */
108 s64 fwi_bootarea_pa
; /* PA of boot area */
109 s64 fwi_bootarea_size
; /* size of boot area */
116 u64 xiocb_fcode
; /* IOCB function code */
117 s64 xiocb_status
; /* return status */
118 s64 xiocb_handle
; /* file/device handle */
119 u64 xiocb_flags
; /* flags for this IOCB */
120 u64 xiocb_psize
; /* size of parameter list */
122 /* buffer parameters */
123 struct xiocb_buffer xiocb_buffer
;
125 /* input status parameters */
126 struct xiocb_inpstat xiocb_inpstat
;
128 /* environment function parameters */
129 struct xiocb_envbuf xiocb_envbuf
;
131 /* CPU control parameters */
132 struct xiocb_cpuctl xiocb_cpuctl
;
134 /* timer parameters */
135 struct xiocb_time xiocb_time
;
137 /* memory arena info parameters */
138 struct xiocb_meminfo xiocb_meminfo
;
140 /* firmware information */
141 struct xiocb_fwinfo xiocb_fwinfo
;
144 struct xiocb_exitstat xiocb_exitstat
;
148 #endif /* CFE_API_INT_H */