1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121#ifndef __LINUX__WIMAX__I2400M_H__
122#define __LINUX__WIMAX__I2400M_H__
123
124#include <linux/types.h>
125
126
127
128
129
130
131
132
133
134struct i2400m_bcf_hdr {
135 __le32 module_type;
136 __le32 header_len;
137 __le32 header_version;
138 __le32 module_id;
139 __le32 module_vendor;
140 __le32 date;
141 __le32 size;
142 __le32 key_size;
143 __le32 modulus_size;
144 __le32 exponent_size;
145 __u8 reserved[88];
146} __attribute__ ((packed));
147
148
149enum i2400m_brh_opcode {
150 I2400M_BRH_READ = 1,
151 I2400M_BRH_WRITE = 2,
152 I2400M_BRH_JUMP = 3,
153 I2400M_BRH_SIGNED_JUMP = 8,
154 I2400M_BRH_HASH_PAYLOAD_ONLY = 9,
155};
156
157
158enum i2400m_brh {
159 I2400M_BRH_SIGNATURE = 0xcbbc0000,
160 I2400M_BRH_SIGNATURE_MASK = 0xffff0000,
161 I2400M_BRH_SIGNATURE_SHIFT = 16,
162 I2400M_BRH_OPCODE_MASK = 0x0000000f,
163 I2400M_BRH_RESPONSE_MASK = 0x000000f0,
164 I2400M_BRH_RESPONSE_SHIFT = 4,
165 I2400M_BRH_DIRECT_ACCESS = 0x00000400,
166 I2400M_BRH_RESPONSE_REQUIRED = 0x00000200,
167 I2400M_BRH_USE_CHECKSUM = 0x00000100,
168};
169
170
171
172enum i2400m_bcf_mod_id {
173
174
175
176
177 I2400M_BCF_MOD_ID_POKES = 0x000000001,
178};
179
180
181
182
183
184
185
186
187
188
189
190struct i2400m_bootrom_header {
191 __le32 command;
192 __le32 target_addr;
193 __le32 data_size;
194 __le32 block_checksum;
195 char payload[0];
196} __attribute__ ((packed));
197
198
199
200
201
202
203
204enum i2400m_pt {
205 I2400M_PT_DATA = 0,
206 I2400M_PT_CTRL,
207 I2400M_PT_TRACE,
208 I2400M_PT_RESET_WARM,
209 I2400M_PT_RESET_COLD,
210 I2400M_PT_EDATA,
211 I2400M_PT_ILLEGAL
212};
213
214
215
216
217
218
219
220struct i2400m_pl_data_hdr {
221 __le32 reserved;
222} __attribute__((packed));
223
224
225
226
227
228
229
230
231
232
233
234
235
236struct i2400m_pl_edata_hdr {
237 __le32 reorder;
238 __u8 cs;
239 __u8 reserved[11];
240} __attribute__((packed));
241
242enum i2400m_cs {
243 I2400M_CS_IPV4_0 = 0,
244 I2400M_CS_IPV4 = 2,
245};
246
247enum i2400m_ro {
248 I2400M_RO_NEEDED = 0x01,
249 I2400M_RO_TYPE = 0x03,
250 I2400M_RO_TYPE_SHIFT = 1,
251 I2400M_RO_CIN = 0x0f,
252 I2400M_RO_CIN_SHIFT = 4,
253 I2400M_RO_FBN = 0x07ff,
254 I2400M_RO_FBN_SHIFT = 8,
255 I2400M_RO_SN = 0x07ff,
256 I2400M_RO_SN_SHIFT = 21,
257};
258
259enum i2400m_ro_type {
260 I2400M_RO_TYPE_RESET = 0,
261 I2400M_RO_TYPE_PACKET,
262 I2400M_RO_TYPE_WS,
263 I2400M_RO_TYPE_PACKET_WS,
264};
265
266
267
268enum {
269 I2400M_PL_ALIGN = 16,
270 I2400M_PL_SIZE_MAX = 0x3EFF,
271 I2400M_MAX_PLS_IN_MSG = 60,
272
273
274 I2400M_H2D_PREVIEW_BARKER = 0xcafe900d,
275 I2400M_COLD_RESET_BARKER = 0xc01dc01d,
276 I2400M_WARM_RESET_BARKER = 0x50f750f7,
277 I2400M_NBOOT_BARKER = 0xdeadbeef,
278 I2400M_SBOOT_BARKER = 0x0ff1c1a1,
279 I2400M_ACK_BARKER = 0xfeedbabe,
280 I2400M_D2H_MSG_BARKER = 0xbeefbabe,
281};
282
283
284
285
286
287
288
289
290
291struct i2400m_pld {
292 __le32 val;
293} __attribute__ ((packed));
294
295#define I2400M_PLD_SIZE_MASK 0x00003fff
296#define I2400M_PLD_TYPE_SHIFT 16
297#define I2400M_PLD_TYPE_MASK 0x000f0000
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318struct i2400m_msg_hdr {
319 union {
320 __le32 barker;
321 __u32 size;
322 };
323 union {
324 __le32 sequence;
325 __u32 offset;
326 };
327 __le16 num_pls;
328 __le16 rsv1;
329 __le16 padding;
330 __le16 rsv2;
331 struct i2400m_pld pld[0];
332} __attribute__ ((packed));
333
334
335
336
337
338
339
340enum {
341
342 I2400M_L3L4_VERSION = 0x0100,
343};
344
345
346enum i2400m_mt {
347 I2400M_MT_RESERVED = 0x0000,
348 I2400M_MT_INVALID = 0xffff,
349 I2400M_MT_REPORT_MASK = 0x8000,
350
351 I2400M_MT_GET_SCAN_RESULT = 0x4202,
352 I2400M_MT_SET_SCAN_PARAM = 0x4402,
353 I2400M_MT_CMD_RF_CONTROL = 0x4602,
354 I2400M_MT_CMD_SCAN = 0x4603,
355 I2400M_MT_CMD_CONNECT = 0x4604,
356 I2400M_MT_CMD_DISCONNECT = 0x4605,
357 I2400M_MT_CMD_EXIT_IDLE = 0x4606,
358 I2400M_MT_GET_LM_VERSION = 0x5201,
359 I2400M_MT_GET_DEVICE_INFO = 0x5202,
360 I2400M_MT_GET_LINK_STATUS = 0x5203,
361 I2400M_MT_GET_STATISTICS = 0x5204,
362 I2400M_MT_GET_STATE = 0x5205,
363 I2400M_MT_GET_MEDIA_STATUS = 0x5206,
364 I2400M_MT_SET_INIT_CONFIG = 0x5404,
365 I2400M_MT_CMD_INIT = 0x5601,
366 I2400M_MT_CMD_TERMINATE = 0x5602,
367 I2400M_MT_CMD_MODE_OF_OP = 0x5603,
368 I2400M_MT_CMD_RESET_DEVICE = 0x5604,
369 I2400M_MT_CMD_MONITOR_CONTROL = 0x5605,
370 I2400M_MT_CMD_ENTER_POWERSAVE = 0x5606,
371 I2400M_MT_GET_TLS_OPERATION_RESULT = 0x6201,
372 I2400M_MT_SET_EAP_SUCCESS = 0x6402,
373 I2400M_MT_SET_EAP_FAIL = 0x6403,
374 I2400M_MT_SET_EAP_KEY = 0x6404,
375 I2400M_MT_CMD_SEND_EAP_RESPONSE = 0x6602,
376 I2400M_MT_REPORT_SCAN_RESULT = 0xc002,
377 I2400M_MT_REPORT_STATE = 0xd002,
378 I2400M_MT_REPORT_POWERSAVE_READY = 0xd005,
379 I2400M_MT_REPORT_EAP_REQUEST = 0xe002,
380 I2400M_MT_REPORT_EAP_RESTART = 0xe003,
381 I2400M_MT_REPORT_ALT_ACCEPT = 0xe004,
382 I2400M_MT_REPORT_KEY_REQUEST = 0xe005,
383};
384
385
386
387
388
389
390
391enum i2400m_ms {
392 I2400M_MS_DONE_OK = 0,
393 I2400M_MS_DONE_IN_PROGRESS = 1,
394 I2400M_MS_INVALID_OP = 2,
395 I2400M_MS_BAD_STATE = 3,
396 I2400M_MS_ILLEGAL_VALUE = 4,
397 I2400M_MS_MISSING_PARAMS = 5,
398 I2400M_MS_VERSION_ERROR = 6,
399 I2400M_MS_ACCESSIBILITY_ERROR = 7,
400 I2400M_MS_BUSY = 8,
401 I2400M_MS_CORRUPTED_TLV = 9,
402 I2400M_MS_UNINITIALIZED = 10,
403 I2400M_MS_UNKNOWN_ERROR = 11,
404 I2400M_MS_PRODUCTION_ERROR = 12,
405 I2400M_MS_NO_RF = 13,
406 I2400M_MS_NOT_READY_FOR_POWERSAVE = 14,
407 I2400M_MS_THERMAL_CRITICAL = 15,
408 I2400M_MS_MAX
409};
410
411
412
413
414
415
416
417
418
419enum i2400m_tlv {
420 I2400M_TLV_L4_MESSAGE_VERSIONS = 129,
421 I2400M_TLV_SYSTEM_STATE = 141,
422 I2400M_TLV_MEDIA_STATUS = 161,
423 I2400M_TLV_RF_OPERATION = 162,
424 I2400M_TLV_RF_STATUS = 163,
425 I2400M_TLV_DEVICE_RESET_TYPE = 132,
426 I2400M_TLV_CONFIG_IDLE_PARAMETERS = 601,
427 I2400M_TLV_CONFIG_IDLE_TIMEOUT = 611,
428 I2400M_TLV_CONFIG_D2H_DATA_FORMAT = 614,
429 I2400M_TLV_CONFIG_DL_HOST_REORDER = 615,
430};
431
432
433struct i2400m_tlv_hdr {
434 __le16 type;
435 __le16 length;
436 __u8 pl[0];
437} __attribute__((packed));
438
439
440struct i2400m_l3l4_hdr {
441 __le16 type;
442 __le16 length;
443 __le16 version;
444 __le16 resv1;
445 __le16 status;
446 __le16 resv2;
447 struct i2400m_tlv_hdr pl[0];
448} __attribute__((packed));
449
450
451
452
453
454enum i2400m_system_state {
455 I2400M_SS_UNINITIALIZED = 1,
456 I2400M_SS_INIT,
457 I2400M_SS_READY,
458 I2400M_SS_SCAN,
459 I2400M_SS_STANDBY,
460 I2400M_SS_CONNECTING,
461 I2400M_SS_WIMAX_CONNECTED,
462 I2400M_SS_DATA_PATH_CONNECTED,
463 I2400M_SS_IDLE,
464 I2400M_SS_DISCONNECTING,
465 I2400M_SS_OUT_OF_ZONE,
466 I2400M_SS_SLEEPACTIVE,
467 I2400M_SS_PRODUCTION,
468 I2400M_SS_CONFIG,
469 I2400M_SS_RF_OFF,
470 I2400M_SS_RF_SHUTDOWN,
471 I2400M_SS_DEVICE_DISCONNECT,
472 I2400M_SS_MAX,
473};
474
475
476
477
478
479
480
481struct i2400m_tlv_system_state {
482 struct i2400m_tlv_hdr hdr;
483 __le32 state;
484} __attribute__((packed));
485
486
487struct i2400m_tlv_l4_message_versions {
488 struct i2400m_tlv_hdr hdr;
489 __le16 major;
490 __le16 minor;
491 __le16 branch;
492 __le16 reserved;
493} __attribute__((packed));
494
495
496struct i2400m_tlv_detailed_device_info {
497 struct i2400m_tlv_hdr hdr;
498 __u8 reserved1[400];
499 __u8 mac_address[6];
500 __u8 reserved2[2];
501} __attribute__((packed));
502
503
504enum i2400m_rf_switch_status {
505 I2400M_RF_SWITCH_ON = 1,
506 I2400M_RF_SWITCH_OFF = 2,
507};
508
509struct i2400m_tlv_rf_switches_status {
510 struct i2400m_tlv_hdr hdr;
511 __u8 sw_rf_switch;
512 __u8 hw_rf_switch;
513 __u8 reserved[2];
514} __attribute__((packed));
515
516
517enum {
518 i2400m_rf_operation_on = 1,
519 i2400m_rf_operation_off = 2
520};
521
522struct i2400m_tlv_rf_operation {
523 struct i2400m_tlv_hdr hdr;
524 __le32 status;
525} __attribute__((packed));
526
527
528enum i2400m_tlv_reset_type {
529 I2400M_RESET_TYPE_COLD = 1,
530 I2400M_RESET_TYPE_WARM
531};
532
533struct i2400m_tlv_device_reset_type {
534 struct i2400m_tlv_hdr hdr;
535 __le32 reset_type;
536} __attribute__((packed));
537
538
539struct i2400m_tlv_config_idle_parameters {
540 struct i2400m_tlv_hdr hdr;
541 __le32 idle_timeout;
542
543 __le32 idle_paging_interval;
544} __attribute__((packed));
545
546
547enum i2400m_media_status {
548 I2400M_MEDIA_STATUS_LINK_UP = 1,
549 I2400M_MEDIA_STATUS_LINK_DOWN,
550 I2400M_MEDIA_STATUS_LINK_RENEW,
551};
552
553struct i2400m_tlv_media_status {
554 struct i2400m_tlv_hdr hdr;
555 __le32 media_status;
556} __attribute__((packed));
557
558
559
560struct i2400m_tlv_config_idle_timeout {
561 struct i2400m_tlv_hdr hdr;
562 __le32 timeout;
563
564} __attribute__((packed));
565
566
567struct i2400m_tlv_config_d2h_data_format {
568 struct i2400m_tlv_hdr hdr;
569 __u8 format;
570 __u8 reserved[3];
571} __attribute__((packed));
572
573
574struct i2400m_tlv_config_dl_host_reorder {
575 struct i2400m_tlv_hdr hdr;
576 __u8 reorder;
577 __u8 reserved[3];
578} __attribute__((packed));
579
580
581#endif
582