Home | History | Annotate | Download | only in wimax
      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