1 /****************************************************************************
2  ****************************************************************************
3  ***
4  ***   This header was automatically generated from a Linux kernel header
5  ***   of the same name, to make information necessary for userspace to
6  ***   call into the kernel available to libc.  It contains only constants,
7  ***   structures, and macros generated from the original header, and thus,
8  ***   contains no copyrightable information.
9  ***
10  ***   To edit the content of this header, modify the corresponding
11  ***   source file (e.g. under external/kernel-headers/original/) then
12  ***   run bionic/libc/kernel/tools/update_all.py
13  ***
14  ***   Any manual change here will be lost the next time this script will
15  ***   be run. You've been warned!
16  ***
17  ****************************************************************************
18  ****************************************************************************/
19 #ifndef __LINUX__WIMAX__I2400M_H__
20 #define __LINUX__WIMAX__I2400M_H__
21 #include <linux/types.h>
22 #include <linux/if_ether.h>
23 struct i2400m_bcf_hdr {
24   __le32 module_type;
25   __le32 header_len;
26   __le32 header_version;
27   __le32 module_id;
28   __le32 module_vendor;
29   __le32 date;
30   __le32 size;
31   __le32 key_size;
32   __le32 modulus_size;
33   __le32 exponent_size;
34   __u8 reserved[88];
35 } __attribute__((packed));
36 enum i2400m_brh_opcode {
37   I2400M_BRH_READ = 1,
38   I2400M_BRH_WRITE = 2,
39   I2400M_BRH_JUMP = 3,
40   I2400M_BRH_SIGNED_JUMP = 8,
41   I2400M_BRH_HASH_PAYLOAD_ONLY = 9,
42 };
43 enum i2400m_brh {
44   I2400M_BRH_SIGNATURE = 0xcbbc0000,
45   I2400M_BRH_SIGNATURE_MASK = 0xffff0000,
46   I2400M_BRH_SIGNATURE_SHIFT = 16,
47   I2400M_BRH_OPCODE_MASK = 0x0000000f,
48   I2400M_BRH_RESPONSE_MASK = 0x000000f0,
49   I2400M_BRH_RESPONSE_SHIFT = 4,
50   I2400M_BRH_DIRECT_ACCESS = 0x00000400,
51   I2400M_BRH_RESPONSE_REQUIRED = 0x00000200,
52   I2400M_BRH_USE_CHECKSUM = 0x00000100,
53 };
54 struct i2400m_bootrom_header {
55   __le32 command;
56   __le32 target_addr;
57   __le32 data_size;
58   __le32 block_checksum;
59   char payload[0];
60 } __attribute__((packed));
61 enum i2400m_pt {
62   I2400M_PT_DATA = 0,
63   I2400M_PT_CTRL,
64   I2400M_PT_TRACE,
65   I2400M_PT_RESET_WARM,
66   I2400M_PT_RESET_COLD,
67   I2400M_PT_EDATA,
68   I2400M_PT_ILLEGAL
69 };
70 struct i2400m_pl_data_hdr {
71   __le32 reserved;
72 } __attribute__((packed));
73 struct i2400m_pl_edata_hdr {
74   __le32 reorder;
75   __u8 cs;
76   __u8 reserved[11];
77 } __attribute__((packed));
78 enum i2400m_cs {
79   I2400M_CS_IPV4_0 = 0,
80   I2400M_CS_IPV4 = 2,
81 };
82 enum i2400m_ro {
83   I2400M_RO_NEEDED = 0x01,
84   I2400M_RO_TYPE = 0x03,
85   I2400M_RO_TYPE_SHIFT = 1,
86   I2400M_RO_CIN = 0x0f,
87   I2400M_RO_CIN_SHIFT = 4,
88   I2400M_RO_FBN = 0x07ff,
89   I2400M_RO_FBN_SHIFT = 8,
90   I2400M_RO_SN = 0x07ff,
91   I2400M_RO_SN_SHIFT = 21,
92 };
93 enum i2400m_ro_type {
94   I2400M_RO_TYPE_RESET = 0,
95   I2400M_RO_TYPE_PACKET,
96   I2400M_RO_TYPE_WS,
97   I2400M_RO_TYPE_PACKET_WS,
98 };
99 enum {
100   I2400M_PL_ALIGN = 16,
101   I2400M_PL_SIZE_MAX = 0x3EFF,
102   I2400M_MAX_PLS_IN_MSG = 60,
103   I2400M_H2D_PREVIEW_BARKER = 0xcafe900d,
104   I2400M_COLD_RESET_BARKER = 0xc01dc01d,
105   I2400M_WARM_RESET_BARKER = 0x50f750f7,
106   I2400M_NBOOT_BARKER = 0xdeadbeef,
107   I2400M_SBOOT_BARKER = 0x0ff1c1a1,
108   I2400M_SBOOT_BARKER_6050 = 0x80000001,
109   I2400M_ACK_BARKER = 0xfeedbabe,
110   I2400M_D2H_MSG_BARKER = 0xbeefbabe,
111 };
112 struct i2400m_pld {
113   __le32 val;
114 } __attribute__((packed));
115 #define I2400M_PLD_SIZE_MASK 0x00003fff
116 #define I2400M_PLD_TYPE_SHIFT 16
117 #define I2400M_PLD_TYPE_MASK 0x000f0000
118 struct i2400m_msg_hdr {
119   union {
120     __le32 barker;
121     __u32 size;
122   };
123   union {
124     __le32 sequence;
125     __u32 offset;
126   };
127   __le16 num_pls;
128   __le16 rsv1;
129   __le16 padding;
130   __le16 rsv2;
131   struct i2400m_pld pld[0];
132 } __attribute__((packed));
133 enum {
134   I2400M_L3L4_VERSION = 0x0100,
135 };
136 enum i2400m_mt {
137   I2400M_MT_RESERVED = 0x0000,
138   I2400M_MT_INVALID = 0xffff,
139   I2400M_MT_REPORT_MASK = 0x8000,
140   I2400M_MT_GET_SCAN_RESULT = 0x4202,
141   I2400M_MT_SET_SCAN_PARAM = 0x4402,
142   I2400M_MT_CMD_RF_CONTROL = 0x4602,
143   I2400M_MT_CMD_SCAN = 0x4603,
144   I2400M_MT_CMD_CONNECT = 0x4604,
145   I2400M_MT_CMD_DISCONNECT = 0x4605,
146   I2400M_MT_CMD_EXIT_IDLE = 0x4606,
147   I2400M_MT_GET_LM_VERSION = 0x5201,
148   I2400M_MT_GET_DEVICE_INFO = 0x5202,
149   I2400M_MT_GET_LINK_STATUS = 0x5203,
150   I2400M_MT_GET_STATISTICS = 0x5204,
151   I2400M_MT_GET_STATE = 0x5205,
152   I2400M_MT_GET_MEDIA_STATUS = 0x5206,
153   I2400M_MT_SET_INIT_CONFIG = 0x5404,
154   I2400M_MT_CMD_INIT = 0x5601,
155   I2400M_MT_CMD_TERMINATE = 0x5602,
156   I2400M_MT_CMD_MODE_OF_OP = 0x5603,
157   I2400M_MT_CMD_RESET_DEVICE = 0x5604,
158   I2400M_MT_CMD_MONITOR_CONTROL = 0x5605,
159   I2400M_MT_CMD_ENTER_POWERSAVE = 0x5606,
160   I2400M_MT_GET_TLS_OPERATION_RESULT = 0x6201,
161   I2400M_MT_SET_EAP_SUCCESS = 0x6402,
162   I2400M_MT_SET_EAP_FAIL = 0x6403,
163   I2400M_MT_SET_EAP_KEY = 0x6404,
164   I2400M_MT_CMD_SEND_EAP_RESPONSE = 0x6602,
165   I2400M_MT_REPORT_SCAN_RESULT = 0xc002,
166   I2400M_MT_REPORT_STATE = 0xd002,
167   I2400M_MT_REPORT_POWERSAVE_READY = 0xd005,
168   I2400M_MT_REPORT_EAP_REQUEST = 0xe002,
169   I2400M_MT_REPORT_EAP_RESTART = 0xe003,
170   I2400M_MT_REPORT_ALT_ACCEPT = 0xe004,
171   I2400M_MT_REPORT_KEY_REQUEST = 0xe005,
172 };
173 enum i2400m_ms {
174   I2400M_MS_DONE_OK = 0,
175   I2400M_MS_DONE_IN_PROGRESS = 1,
176   I2400M_MS_INVALID_OP = 2,
177   I2400M_MS_BAD_STATE = 3,
178   I2400M_MS_ILLEGAL_VALUE = 4,
179   I2400M_MS_MISSING_PARAMS = 5,
180   I2400M_MS_VERSION_ERROR = 6,
181   I2400M_MS_ACCESSIBILITY_ERROR = 7,
182   I2400M_MS_BUSY = 8,
183   I2400M_MS_CORRUPTED_TLV = 9,
184   I2400M_MS_UNINITIALIZED = 10,
185   I2400M_MS_UNKNOWN_ERROR = 11,
186   I2400M_MS_PRODUCTION_ERROR = 12,
187   I2400M_MS_NO_RF = 13,
188   I2400M_MS_NOT_READY_FOR_POWERSAVE = 14,
189   I2400M_MS_THERMAL_CRITICAL = 15,
190   I2400M_MS_MAX
191 };
192 enum i2400m_tlv {
193   I2400M_TLV_L4_MESSAGE_VERSIONS = 129,
194   I2400M_TLV_SYSTEM_STATE = 141,
195   I2400M_TLV_MEDIA_STATUS = 161,
196   I2400M_TLV_RF_OPERATION = 162,
197   I2400M_TLV_RF_STATUS = 163,
198   I2400M_TLV_DEVICE_RESET_TYPE = 132,
199   I2400M_TLV_CONFIG_IDLE_PARAMETERS = 601,
200   I2400M_TLV_CONFIG_IDLE_TIMEOUT = 611,
201   I2400M_TLV_CONFIG_D2H_DATA_FORMAT = 614,
202   I2400M_TLV_CONFIG_DL_HOST_REORDER = 615,
203 };
204 struct i2400m_tlv_hdr {
205   __le16 type;
206   __le16 length;
207   __u8 pl[0];
208 } __attribute__((packed));
209 struct i2400m_l3l4_hdr {
210   __le16 type;
211   __le16 length;
212   __le16 version;
213   __le16 resv1;
214   __le16 status;
215   __le16 resv2;
216   struct i2400m_tlv_hdr pl[0];
217 } __attribute__((packed));
218 enum i2400m_system_state {
219   I2400M_SS_UNINITIALIZED = 1,
220   I2400M_SS_INIT,
221   I2400M_SS_READY,
222   I2400M_SS_SCAN,
223   I2400M_SS_STANDBY,
224   I2400M_SS_CONNECTING,
225   I2400M_SS_WIMAX_CONNECTED,
226   I2400M_SS_DATA_PATH_CONNECTED,
227   I2400M_SS_IDLE,
228   I2400M_SS_DISCONNECTING,
229   I2400M_SS_OUT_OF_ZONE,
230   I2400M_SS_SLEEPACTIVE,
231   I2400M_SS_PRODUCTION,
232   I2400M_SS_CONFIG,
233   I2400M_SS_RF_OFF,
234   I2400M_SS_RF_SHUTDOWN,
235   I2400M_SS_DEVICE_DISCONNECT,
236   I2400M_SS_MAX,
237 };
238 struct i2400m_tlv_system_state {
239   struct i2400m_tlv_hdr hdr;
240   __le32 state;
241 } __attribute__((packed));
242 struct i2400m_tlv_l4_message_versions {
243   struct i2400m_tlv_hdr hdr;
244   __le16 major;
245   __le16 minor;
246   __le16 branch;
247   __le16 reserved;
248 } __attribute__((packed));
249 struct i2400m_tlv_detailed_device_info {
250   struct i2400m_tlv_hdr hdr;
251   __u8 reserved1[400];
252   __u8 mac_address[ETH_ALEN];
253   __u8 reserved2[2];
254 } __attribute__((packed));
255 enum i2400m_rf_switch_status {
256   I2400M_RF_SWITCH_ON = 1,
257   I2400M_RF_SWITCH_OFF = 2,
258 };
259 struct i2400m_tlv_rf_switches_status {
260   struct i2400m_tlv_hdr hdr;
261   __u8 sw_rf_switch;
262   __u8 hw_rf_switch;
263   __u8 reserved[2];
264 } __attribute__((packed));
265 enum {
266   i2400m_rf_operation_on = 1,
267   i2400m_rf_operation_off = 2
268 };
269 struct i2400m_tlv_rf_operation {
270   struct i2400m_tlv_hdr hdr;
271   __le32 status;
272 } __attribute__((packed));
273 enum i2400m_tlv_reset_type {
274   I2400M_RESET_TYPE_COLD = 1,
275   I2400M_RESET_TYPE_WARM
276 };
277 struct i2400m_tlv_device_reset_type {
278   struct i2400m_tlv_hdr hdr;
279   __le32 reset_type;
280 } __attribute__((packed));
281 struct i2400m_tlv_config_idle_parameters {
282   struct i2400m_tlv_hdr hdr;
283   __le32 idle_timeout;
284   __le32 idle_paging_interval;
285 } __attribute__((packed));
286 enum i2400m_media_status {
287   I2400M_MEDIA_STATUS_LINK_UP = 1,
288   I2400M_MEDIA_STATUS_LINK_DOWN,
289   I2400M_MEDIA_STATUS_LINK_RENEW,
290 };
291 struct i2400m_tlv_media_status {
292   struct i2400m_tlv_hdr hdr;
293   __le32 media_status;
294 } __attribute__((packed));
295 struct i2400m_tlv_config_idle_timeout {
296   struct i2400m_tlv_hdr hdr;
297   __le32 timeout;
298 } __attribute__((packed));
299 struct i2400m_tlv_config_d2h_data_format {
300   struct i2400m_tlv_hdr hdr;
301   __u8 format;
302   __u8 reserved[3];
303 } __attribute__((packed));
304 struct i2400m_tlv_config_dl_host_reorder {
305   struct i2400m_tlv_hdr hdr;
306   __u8 reorder;
307   __u8 reserved[3];
308 } __attribute__((packed));
309 #endif
310