|
@@ -71,10 +71,10 @@ struct acx_header {
|
|
struct wl1271_cmd_header cmd;
|
|
struct wl1271_cmd_header cmd;
|
|
|
|
|
|
/* acx (or information element) header */
|
|
/* acx (or information element) header */
|
|
- u16 id;
|
|
|
|
|
|
+ __le16 id;
|
|
|
|
|
|
/* payload length (not including headers */
|
|
/* payload length (not including headers */
|
|
- u16 len;
|
|
|
|
|
|
+ __le16 len;
|
|
} __attribute__ ((packed));
|
|
} __attribute__ ((packed));
|
|
|
|
|
|
struct acx_error_counter {
|
|
struct acx_error_counter {
|
|
@@ -83,21 +83,21 @@ struct acx_error_counter {
|
|
/* The number of PLCP errors since the last time this */
|
|
/* The number of PLCP errors since the last time this */
|
|
/* information element was interrogated. This field is */
|
|
/* information element was interrogated. This field is */
|
|
/* automatically cleared when it is interrogated.*/
|
|
/* automatically cleared when it is interrogated.*/
|
|
- u32 PLCP_error;
|
|
|
|
|
|
+ __le32 PLCP_error;
|
|
|
|
|
|
/* The number of FCS errors since the last time this */
|
|
/* The number of FCS errors since the last time this */
|
|
/* information element was interrogated. This field is */
|
|
/* information element was interrogated. This field is */
|
|
/* automatically cleared when it is interrogated.*/
|
|
/* automatically cleared when it is interrogated.*/
|
|
- u32 FCS_error;
|
|
|
|
|
|
+ __le32 FCS_error;
|
|
|
|
|
|
/* The number of MPDUs without PLCP header errors received*/
|
|
/* The number of MPDUs without PLCP header errors received*/
|
|
/* since the last time this information element was interrogated. */
|
|
/* since the last time this information element was interrogated. */
|
|
/* This field is automatically cleared when it is interrogated.*/
|
|
/* This field is automatically cleared when it is interrogated.*/
|
|
- u32 valid_frame;
|
|
|
|
|
|
+ __le32 valid_frame;
|
|
|
|
|
|
/* the number of missed sequence numbers in the squentially */
|
|
/* the number of missed sequence numbers in the squentially */
|
|
/* values of frames seq numbers */
|
|
/* values of frames seq numbers */
|
|
- u32 seq_num_miss;
|
|
|
|
|
|
+ __le32 seq_num_miss;
|
|
} __attribute__ ((packed));
|
|
} __attribute__ ((packed));
|
|
|
|
|
|
struct acx_revision {
|
|
struct acx_revision {
|
|
@@ -126,7 +126,7 @@ struct acx_revision {
|
|
* (1 = first spin, 2 = second spin, and so on).
|
|
* (1 = first spin, 2 = second spin, and so on).
|
|
* bits 24 - 31: Chip ID - The WiLink chip ID.
|
|
* bits 24 - 31: Chip ID - The WiLink chip ID.
|
|
*/
|
|
*/
|
|
- u32 hw_version;
|
|
|
|
|
|
+ __le32 hw_version;
|
|
} __attribute__ ((packed));
|
|
} __attribute__ ((packed));
|
|
|
|
|
|
enum wl1271_psm_mode {
|
|
enum wl1271_psm_mode {
|
|
@@ -186,7 +186,7 @@ struct acx_rx_msdu_lifetime {
|
|
* The maximum amount of time, in TU, before the
|
|
* The maximum amount of time, in TU, before the
|
|
* firmware discards the MSDU.
|
|
* firmware discards the MSDU.
|
|
*/
|
|
*/
|
|
- u32 lifetime;
|
|
|
|
|
|
+ __le32 lifetime;
|
|
} __attribute__ ((packed));
|
|
} __attribute__ ((packed));
|
|
|
|
|
|
/*
|
|
/*
|
|
@@ -273,14 +273,14 @@ struct acx_rx_msdu_lifetime {
|
|
struct acx_rx_config {
|
|
struct acx_rx_config {
|
|
struct acx_header header;
|
|
struct acx_header header;
|
|
|
|
|
|
- u32 config_options;
|
|
|
|
- u32 filter_options;
|
|
|
|
|
|
+ __le32 config_options;
|
|
|
|
+ __le32 filter_options;
|
|
} __attribute__ ((packed));
|
|
} __attribute__ ((packed));
|
|
|
|
|
|
struct acx_packet_detection {
|
|
struct acx_packet_detection {
|
|
struct acx_header header;
|
|
struct acx_header header;
|
|
|
|
|
|
- u32 threshold;
|
|
|
|
|
|
+ __le32 threshold;
|
|
} __attribute__ ((packed));
|
|
} __attribute__ ((packed));
|
|
|
|
|
|
|
|
|
|
@@ -317,14 +317,14 @@ struct acx_dot11_grp_addr_tbl {
|
|
struct acx_rx_timeout {
|
|
struct acx_rx_timeout {
|
|
struct acx_header header;
|
|
struct acx_header header;
|
|
|
|
|
|
- u16 ps_poll_timeout;
|
|
|
|
- u16 upsd_timeout;
|
|
|
|
|
|
+ __le16 ps_poll_timeout;
|
|
|
|
+ __le16 upsd_timeout;
|
|
} __attribute__ ((packed));
|
|
} __attribute__ ((packed));
|
|
|
|
|
|
struct acx_rts_threshold {
|
|
struct acx_rts_threshold {
|
|
struct acx_header header;
|
|
struct acx_header header;
|
|
|
|
|
|
- u16 threshold;
|
|
|
|
|
|
+ __le16 threshold;
|
|
u8 pad[2];
|
|
u8 pad[2];
|
|
} __attribute__ ((packed));
|
|
} __attribute__ ((packed));
|
|
|
|
|
|
@@ -388,8 +388,8 @@ struct acx_beacon_filter_ie_table {
|
|
struct acx_conn_monit_params {
|
|
struct acx_conn_monit_params {
|
|
struct acx_header header;
|
|
struct acx_header header;
|
|
|
|
|
|
- u32 synch_fail_thold; /* number of beacons missed */
|
|
|
|
- u32 bss_lose_timeout; /* number of TU's from synch fail */
|
|
|
|
|
|
+ __le32 synch_fail_thold; /* number of beacons missed */
|
|
|
|
+ __le32 bss_lose_timeout; /* number of TU's from synch fail */
|
|
} __attribute__ ((packed));
|
|
} __attribute__ ((packed));
|
|
|
|
|
|
enum {
|
|
enum {
|
|
@@ -466,16 +466,16 @@ struct acx_smart_reflex_config_params {
|
|
struct acx_bt_wlan_coex_param {
|
|
struct acx_bt_wlan_coex_param {
|
|
struct acx_header header;
|
|
struct acx_header header;
|
|
|
|
|
|
- u32 per_threshold;
|
|
|
|
- u32 max_scan_compensation_time;
|
|
|
|
- u16 nfs_sample_interval;
|
|
|
|
|
|
+ __le32 per_threshold;
|
|
|
|
+ __le32 max_scan_compensation_time;
|
|
|
|
+ __le16 nfs_sample_interval;
|
|
u8 load_ratio;
|
|
u8 load_ratio;
|
|
u8 auto_ps_mode;
|
|
u8 auto_ps_mode;
|
|
u8 probe_req_compensation;
|
|
u8 probe_req_compensation;
|
|
u8 scan_window_compensation;
|
|
u8 scan_window_compensation;
|
|
u8 antenna_config;
|
|
u8 antenna_config;
|
|
u8 beacon_miss_threshold;
|
|
u8 beacon_miss_threshold;
|
|
- u32 rate_adaptation_threshold;
|
|
|
|
|
|
+ __le32 rate_adaptation_threshold;
|
|
s8 rate_adaptation_snr;
|
|
s8 rate_adaptation_snr;
|
|
u8 padding[3];
|
|
u8 padding[3];
|
|
} __attribute__ ((packed));
|
|
} __attribute__ ((packed));
|
|
@@ -484,7 +484,7 @@ struct acx_energy_detection {
|
|
struct acx_header header;
|
|
struct acx_header header;
|
|
|
|
|
|
/* The RX Clear Channel Assessment threshold in the PHY */
|
|
/* The RX Clear Channel Assessment threshold in the PHY */
|
|
- u16 rx_cca_threshold;
|
|
|
|
|
|
+ __le16 rx_cca_threshold;
|
|
u8 tx_energy_detection;
|
|
u8 tx_energy_detection;
|
|
u8 pad;
|
|
u8 pad;
|
|
} __attribute__ ((packed));
|
|
} __attribute__ ((packed));
|
|
@@ -492,8 +492,8 @@ struct acx_energy_detection {
|
|
struct acx_beacon_broadcast {
|
|
struct acx_beacon_broadcast {
|
|
struct acx_header header;
|
|
struct acx_header header;
|
|
|
|
|
|
- u16 beacon_rx_timeout;
|
|
|
|
- u16 broadcast_timeout;
|
|
|
|
|
|
+ __le16 beacon_rx_timeout;
|
|
|
|
+ __le16 broadcast_timeout;
|
|
|
|
|
|
/* Enables receiving of broadcast packets in PS mode */
|
|
/* Enables receiving of broadcast packets in PS mode */
|
|
u8 rx_broadcast_in_ps;
|
|
u8 rx_broadcast_in_ps;
|
|
@@ -506,8 +506,8 @@ struct acx_beacon_broadcast {
|
|
struct acx_event_mask {
|
|
struct acx_event_mask {
|
|
struct acx_header header;
|
|
struct acx_header header;
|
|
|
|
|
|
- u32 event_mask;
|
|
|
|
- u32 high_event_mask; /* Unused */
|
|
|
|
|
|
+ __le32 event_mask;
|
|
|
|
+ __le32 high_event_mask; /* Unused */
|
|
} __attribute__ ((packed));
|
|
} __attribute__ ((packed));
|
|
|
|
|
|
#define CFG_RX_FCS BIT(2)
|
|
#define CFG_RX_FCS BIT(2)
|
|
@@ -551,8 +551,8 @@ struct acx_event_mask {
|
|
struct acx_feature_config {
|
|
struct acx_feature_config {
|
|
struct acx_header header;
|
|
struct acx_header header;
|
|
|
|
|
|
- u32 options;
|
|
|
|
- u32 data_flow_options;
|
|
|
|
|
|
+ __le32 options;
|
|
|
|
+ __le32 data_flow_options;
|
|
} __attribute__ ((packed));
|
|
} __attribute__ ((packed));
|
|
|
|
|
|
struct acx_current_tx_power {
|
|
struct acx_current_tx_power {
|
|
@@ -576,7 +576,7 @@ struct acx_aid {
|
|
/*
|
|
/*
|
|
* To be set when associated with an AP.
|
|
* To be set when associated with an AP.
|
|
*/
|
|
*/
|
|
- u16 aid;
|
|
|
|
|
|
+ __le16 aid;
|
|
u8 pad[2];
|
|
u8 pad[2];
|
|
} __attribute__ ((packed));
|
|
} __attribute__ ((packed));
|
|
|
|
|
|
@@ -608,152 +608,152 @@ struct acx_ctsprotect {
|
|
} __attribute__ ((packed));
|
|
} __attribute__ ((packed));
|
|
|
|
|
|
struct acx_tx_statistics {
|
|
struct acx_tx_statistics {
|
|
- u32 internal_desc_overflow;
|
|
|
|
|
|
+ __le32 internal_desc_overflow;
|
|
} __attribute__ ((packed));
|
|
} __attribute__ ((packed));
|
|
|
|
|
|
struct acx_rx_statistics {
|
|
struct acx_rx_statistics {
|
|
- u32 out_of_mem;
|
|
|
|
- u32 hdr_overflow;
|
|
|
|
- u32 hw_stuck;
|
|
|
|
- u32 dropped;
|
|
|
|
- u32 fcs_err;
|
|
|
|
- u32 xfr_hint_trig;
|
|
|
|
- u32 path_reset;
|
|
|
|
- u32 reset_counter;
|
|
|
|
|
|
+ __le32 out_of_mem;
|
|
|
|
+ __le32 hdr_overflow;
|
|
|
|
+ __le32 hw_stuck;
|
|
|
|
+ __le32 dropped;
|
|
|
|
+ __le32 fcs_err;
|
|
|
|
+ __le32 xfr_hint_trig;
|
|
|
|
+ __le32 path_reset;
|
|
|
|
+ __le32 reset_counter;
|
|
} __attribute__ ((packed));
|
|
} __attribute__ ((packed));
|
|
|
|
|
|
struct acx_dma_statistics {
|
|
struct acx_dma_statistics {
|
|
- u32 rx_requested;
|
|
|
|
- u32 rx_errors;
|
|
|
|
- u32 tx_requested;
|
|
|
|
- u32 tx_errors;
|
|
|
|
|
|
+ __le32 rx_requested;
|
|
|
|
+ __le32 rx_errors;
|
|
|
|
+ __le32 tx_requested;
|
|
|
|
+ __le32 tx_errors;
|
|
} __attribute__ ((packed));
|
|
} __attribute__ ((packed));
|
|
|
|
|
|
struct acx_isr_statistics {
|
|
struct acx_isr_statistics {
|
|
/* host command complete */
|
|
/* host command complete */
|
|
- u32 cmd_cmplt;
|
|
|
|
|
|
+ __le32 cmd_cmplt;
|
|
|
|
|
|
/* fiqisr() */
|
|
/* fiqisr() */
|
|
- u32 fiqs;
|
|
|
|
|
|
+ __le32 fiqs;
|
|
|
|
|
|
/* (INT_STS_ND & INT_TRIG_RX_HEADER) */
|
|
/* (INT_STS_ND & INT_TRIG_RX_HEADER) */
|
|
- u32 rx_headers;
|
|
|
|
|
|
+ __le32 rx_headers;
|
|
|
|
|
|
/* (INT_STS_ND & INT_TRIG_RX_CMPLT) */
|
|
/* (INT_STS_ND & INT_TRIG_RX_CMPLT) */
|
|
- u32 rx_completes;
|
|
|
|
|
|
+ __le32 rx_completes;
|
|
|
|
|
|
/* (INT_STS_ND & INT_TRIG_NO_RX_BUF) */
|
|
/* (INT_STS_ND & INT_TRIG_NO_RX_BUF) */
|
|
- u32 rx_mem_overflow;
|
|
|
|
|
|
+ __le32 rx_mem_overflow;
|
|
|
|
|
|
/* (INT_STS_ND & INT_TRIG_S_RX_RDY) */
|
|
/* (INT_STS_ND & INT_TRIG_S_RX_RDY) */
|
|
- u32 rx_rdys;
|
|
|
|
|
|
+ __le32 rx_rdys;
|
|
|
|
|
|
/* irqisr() */
|
|
/* irqisr() */
|
|
- u32 irqs;
|
|
|
|
|
|
+ __le32 irqs;
|
|
|
|
|
|
/* (INT_STS_ND & INT_TRIG_TX_PROC) */
|
|
/* (INT_STS_ND & INT_TRIG_TX_PROC) */
|
|
- u32 tx_procs;
|
|
|
|
|
|
+ __le32 tx_procs;
|
|
|
|
|
|
/* (INT_STS_ND & INT_TRIG_DECRYPT_DONE) */
|
|
/* (INT_STS_ND & INT_TRIG_DECRYPT_DONE) */
|
|
- u32 decrypt_done;
|
|
|
|
|
|
+ __le32 decrypt_done;
|
|
|
|
|
|
/* (INT_STS_ND & INT_TRIG_DMA0) */
|
|
/* (INT_STS_ND & INT_TRIG_DMA0) */
|
|
- u32 dma0_done;
|
|
|
|
|
|
+ __le32 dma0_done;
|
|
|
|
|
|
/* (INT_STS_ND & INT_TRIG_DMA1) */
|
|
/* (INT_STS_ND & INT_TRIG_DMA1) */
|
|
- u32 dma1_done;
|
|
|
|
|
|
+ __le32 dma1_done;
|
|
|
|
|
|
/* (INT_STS_ND & INT_TRIG_TX_EXC_CMPLT) */
|
|
/* (INT_STS_ND & INT_TRIG_TX_EXC_CMPLT) */
|
|
- u32 tx_exch_complete;
|
|
|
|
|
|
+ __le32 tx_exch_complete;
|
|
|
|
|
|
/* (INT_STS_ND & INT_TRIG_COMMAND) */
|
|
/* (INT_STS_ND & INT_TRIG_COMMAND) */
|
|
- u32 commands;
|
|
|
|
|
|
+ __le32 commands;
|
|
|
|
|
|
/* (INT_STS_ND & INT_TRIG_RX_PROC) */
|
|
/* (INT_STS_ND & INT_TRIG_RX_PROC) */
|
|
- u32 rx_procs;
|
|
|
|
|
|
+ __le32 rx_procs;
|
|
|
|
|
|
/* (INT_STS_ND & INT_TRIG_PM_802) */
|
|
/* (INT_STS_ND & INT_TRIG_PM_802) */
|
|
- u32 hw_pm_mode_changes;
|
|
|
|
|
|
+ __le32 hw_pm_mode_changes;
|
|
|
|
|
|
/* (INT_STS_ND & INT_TRIG_ACKNOWLEDGE) */
|
|
/* (INT_STS_ND & INT_TRIG_ACKNOWLEDGE) */
|
|
- u32 host_acknowledges;
|
|
|
|
|
|
+ __le32 host_acknowledges;
|
|
|
|
|
|
/* (INT_STS_ND & INT_TRIG_PM_PCI) */
|
|
/* (INT_STS_ND & INT_TRIG_PM_PCI) */
|
|
- u32 pci_pm;
|
|
|
|
|
|
+ __le32 pci_pm;
|
|
|
|
|
|
/* (INT_STS_ND & INT_TRIG_ACM_WAKEUP) */
|
|
/* (INT_STS_ND & INT_TRIG_ACM_WAKEUP) */
|
|
- u32 wakeups;
|
|
|
|
|
|
+ __le32 wakeups;
|
|
|
|
|
|
/* (INT_STS_ND & INT_TRIG_LOW_RSSI) */
|
|
/* (INT_STS_ND & INT_TRIG_LOW_RSSI) */
|
|
- u32 low_rssi;
|
|
|
|
|
|
+ __le32 low_rssi;
|
|
} __attribute__ ((packed));
|
|
} __attribute__ ((packed));
|
|
|
|
|
|
struct acx_wep_statistics {
|
|
struct acx_wep_statistics {
|
|
/* WEP address keys configured */
|
|
/* WEP address keys configured */
|
|
- u32 addr_key_count;
|
|
|
|
|
|
+ __le32 addr_key_count;
|
|
|
|
|
|
/* default keys configured */
|
|
/* default keys configured */
|
|
- u32 default_key_count;
|
|
|
|
|
|
+ __le32 default_key_count;
|
|
|
|
|
|
- u32 reserved;
|
|
|
|
|
|
+ __le32 reserved;
|
|
|
|
|
|
/* number of times that WEP key not found on lookup */
|
|
/* number of times that WEP key not found on lookup */
|
|
- u32 key_not_found;
|
|
|
|
|
|
+ __le32 key_not_found;
|
|
|
|
|
|
/* number of times that WEP key decryption failed */
|
|
/* number of times that WEP key decryption failed */
|
|
- u32 decrypt_fail;
|
|
|
|
|
|
+ __le32 decrypt_fail;
|
|
|
|
|
|
/* WEP packets decrypted */
|
|
/* WEP packets decrypted */
|
|
- u32 packets;
|
|
|
|
|
|
+ __le32 packets;
|
|
|
|
|
|
/* WEP decrypt interrupts */
|
|
/* WEP decrypt interrupts */
|
|
- u32 interrupt;
|
|
|
|
|
|
+ __le32 interrupt;
|
|
} __attribute__ ((packed));
|
|
} __attribute__ ((packed));
|
|
|
|
|
|
#define ACX_MISSED_BEACONS_SPREAD 10
|
|
#define ACX_MISSED_BEACONS_SPREAD 10
|
|
|
|
|
|
struct acx_pwr_statistics {
|
|
struct acx_pwr_statistics {
|
|
/* the amount of enters into power save mode (both PD & ELP) */
|
|
/* the amount of enters into power save mode (both PD & ELP) */
|
|
- u32 ps_enter;
|
|
|
|
|
|
+ __le32 ps_enter;
|
|
|
|
|
|
/* the amount of enters into ELP mode */
|
|
/* the amount of enters into ELP mode */
|
|
- u32 elp_enter;
|
|
|
|
|
|
+ __le32 elp_enter;
|
|
|
|
|
|
/* the amount of missing beacon interrupts to the host */
|
|
/* the amount of missing beacon interrupts to the host */
|
|
- u32 missing_bcns;
|
|
|
|
|
|
+ __le32 missing_bcns;
|
|
|
|
|
|
/* the amount of wake on host-access times */
|
|
/* the amount of wake on host-access times */
|
|
- u32 wake_on_host;
|
|
|
|
|
|
+ __le32 wake_on_host;
|
|
|
|
|
|
/* the amount of wake on timer-expire */
|
|
/* the amount of wake on timer-expire */
|
|
- u32 wake_on_timer_exp;
|
|
|
|
|
|
+ __le32 wake_on_timer_exp;
|
|
|
|
|
|
/* the number of packets that were transmitted with PS bit set */
|
|
/* the number of packets that were transmitted with PS bit set */
|
|
- u32 tx_with_ps;
|
|
|
|
|
|
+ __le32 tx_with_ps;
|
|
|
|
|
|
/* the number of packets that were transmitted with PS bit clear */
|
|
/* the number of packets that were transmitted with PS bit clear */
|
|
- u32 tx_without_ps;
|
|
|
|
|
|
+ __le32 tx_without_ps;
|
|
|
|
|
|
/* the number of received beacons */
|
|
/* the number of received beacons */
|
|
- u32 rcvd_beacons;
|
|
|
|
|
|
+ __le32 rcvd_beacons;
|
|
|
|
|
|
/* the number of entering into PowerOn (power save off) */
|
|
/* the number of entering into PowerOn (power save off) */
|
|
- u32 power_save_off;
|
|
|
|
|
|
+ __le32 power_save_off;
|
|
|
|
|
|
/* the number of entries into power save mode */
|
|
/* the number of entries into power save mode */
|
|
- u16 enable_ps;
|
|
|
|
|
|
+ __le16 enable_ps;
|
|
|
|
|
|
/*
|
|
/*
|
|
* the number of exits from power save, not including failed PS
|
|
* the number of exits from power save, not including failed PS
|
|
* transitions
|
|
* transitions
|
|
*/
|
|
*/
|
|
- u16 disable_ps;
|
|
|
|
|
|
+ __le16 disable_ps;
|
|
|
|
|
|
/*
|
|
/*
|
|
* the number of times the TSF counter was adjusted because
|
|
* the number of times the TSF counter was adjusted because
|
|
* of drift
|
|
* of drift
|
|
*/
|
|
*/
|
|
- u32 fix_tsf_ps;
|
|
|
|
|
|
+ __le32 fix_tsf_ps;
|
|
|
|
|
|
/* Gives statistics about the spread continuous missed beacons.
|
|
/* Gives statistics about the spread continuous missed beacons.
|
|
* The 16 LSB are dedicated for the PS mode.
|
|
* The 16 LSB are dedicated for the PS mode.
|
|
@@ -764,53 +764,53 @@ struct acx_pwr_statistics {
|
|
* ...
|
|
* ...
|
|
* cont_miss_bcns_spread[9] - ten and more continuous missed beacons.
|
|
* cont_miss_bcns_spread[9] - ten and more continuous missed beacons.
|
|
*/
|
|
*/
|
|
- u32 cont_miss_bcns_spread[ACX_MISSED_BEACONS_SPREAD];
|
|
|
|
|
|
+ __le32 cont_miss_bcns_spread[ACX_MISSED_BEACONS_SPREAD];
|
|
|
|
|
|
/* the number of beacons in awake mode */
|
|
/* the number of beacons in awake mode */
|
|
- u32 rcvd_awake_beacons;
|
|
|
|
|
|
+ __le32 rcvd_awake_beacons;
|
|
} __attribute__ ((packed));
|
|
} __attribute__ ((packed));
|
|
|
|
|
|
struct acx_mic_statistics {
|
|
struct acx_mic_statistics {
|
|
- u32 rx_pkts;
|
|
|
|
- u32 calc_failure;
|
|
|
|
|
|
+ __le32 rx_pkts;
|
|
|
|
+ __le32 calc_failure;
|
|
} __attribute__ ((packed));
|
|
} __attribute__ ((packed));
|
|
|
|
|
|
struct acx_aes_statistics {
|
|
struct acx_aes_statistics {
|
|
- u32 encrypt_fail;
|
|
|
|
- u32 decrypt_fail;
|
|
|
|
- u32 encrypt_packets;
|
|
|
|
- u32 decrypt_packets;
|
|
|
|
- u32 encrypt_interrupt;
|
|
|
|
- u32 decrypt_interrupt;
|
|
|
|
|
|
+ __le32 encrypt_fail;
|
|
|
|
+ __le32 decrypt_fail;
|
|
|
|
+ __le32 encrypt_packets;
|
|
|
|
+ __le32 decrypt_packets;
|
|
|
|
+ __le32 encrypt_interrupt;
|
|
|
|
+ __le32 decrypt_interrupt;
|
|
} __attribute__ ((packed));
|
|
} __attribute__ ((packed));
|
|
|
|
|
|
struct acx_event_statistics {
|
|
struct acx_event_statistics {
|
|
- u32 heart_beat;
|
|
|
|
- u32 calibration;
|
|
|
|
- u32 rx_mismatch;
|
|
|
|
- u32 rx_mem_empty;
|
|
|
|
- u32 rx_pool;
|
|
|
|
- u32 oom_late;
|
|
|
|
- u32 phy_transmit_error;
|
|
|
|
- u32 tx_stuck;
|
|
|
|
|
|
+ __le32 heart_beat;
|
|
|
|
+ __le32 calibration;
|
|
|
|
+ __le32 rx_mismatch;
|
|
|
|
+ __le32 rx_mem_empty;
|
|
|
|
+ __le32 rx_pool;
|
|
|
|
+ __le32 oom_late;
|
|
|
|
+ __le32 phy_transmit_error;
|
|
|
|
+ __le32 tx_stuck;
|
|
} __attribute__ ((packed));
|
|
} __attribute__ ((packed));
|
|
|
|
|
|
struct acx_ps_statistics {
|
|
struct acx_ps_statistics {
|
|
- u32 pspoll_timeouts;
|
|
|
|
- u32 upsd_timeouts;
|
|
|
|
- u32 upsd_max_sptime;
|
|
|
|
- u32 upsd_max_apturn;
|
|
|
|
- u32 pspoll_max_apturn;
|
|
|
|
- u32 pspoll_utilization;
|
|
|
|
- u32 upsd_utilization;
|
|
|
|
|
|
+ __le32 pspoll_timeouts;
|
|
|
|
+ __le32 upsd_timeouts;
|
|
|
|
+ __le32 upsd_max_sptime;
|
|
|
|
+ __le32 upsd_max_apturn;
|
|
|
|
+ __le32 pspoll_max_apturn;
|
|
|
|
+ __le32 pspoll_utilization;
|
|
|
|
+ __le32 upsd_utilization;
|
|
} __attribute__ ((packed));
|
|
} __attribute__ ((packed));
|
|
|
|
|
|
struct acx_rxpipe_statistics {
|
|
struct acx_rxpipe_statistics {
|
|
- u32 rx_prep_beacon_drop;
|
|
|
|
- u32 descr_host_int_trig_rx_data;
|
|
|
|
- u32 beacon_buffer_thres_host_int_trig_rx_data;
|
|
|
|
- u32 missed_beacon_host_int_trig_rx_data;
|
|
|
|
- u32 tx_xfr_host_int_trig_rx_data;
|
|
|
|
|
|
+ __le32 rx_prep_beacon_drop;
|
|
|
|
+ __le32 descr_host_int_trig_rx_data;
|
|
|
|
+ __le32 beacon_buffer_thres_host_int_trig_rx_data;
|
|
|
|
+ __le32 missed_beacon_host_int_trig_rx_data;
|
|
|
|
+ __le32 tx_xfr_host_int_trig_rx_data;
|
|
} __attribute__ ((packed));
|
|
} __attribute__ ((packed));
|
|
|
|
|
|
struct acx_statistics {
|
|
struct acx_statistics {
|
|
@@ -830,7 +830,7 @@ struct acx_statistics {
|
|
} __attribute__ ((packed));
|
|
} __attribute__ ((packed));
|
|
|
|
|
|
struct acx_rate_class {
|
|
struct acx_rate_class {
|
|
- u32 enabled_rates;
|
|
|
|
|
|
+ __le32 enabled_rates;
|
|
u8 short_retry_limit;
|
|
u8 short_retry_limit;
|
|
u8 long_retry_limit;
|
|
u8 long_retry_limit;
|
|
u8 aflags;
|
|
u8 aflags;
|
|
@@ -840,7 +840,7 @@ struct acx_rate_class {
|
|
struct acx_rate_policy {
|
|
struct acx_rate_policy {
|
|
struct acx_header header;
|
|
struct acx_header header;
|
|
|
|
|
|
- u32 rate_class_cnt;
|
|
|
|
|
|
+ __le32 rate_class_cnt;
|
|
struct acx_rate_class rate_class[CONF_TX_MAX_RATE_CLASSES];
|
|
struct acx_rate_class rate_class[CONF_TX_MAX_RATE_CLASSES];
|
|
} __attribute__ ((packed));
|
|
} __attribute__ ((packed));
|
|
|
|
|
|
@@ -848,10 +848,10 @@ struct acx_ac_cfg {
|
|
struct acx_header header;
|
|
struct acx_header header;
|
|
u8 ac;
|
|
u8 ac;
|
|
u8 cw_min;
|
|
u8 cw_min;
|
|
- u16 cw_max;
|
|
|
|
|
|
+ __le16 cw_max;
|
|
u8 aifsn;
|
|
u8 aifsn;
|
|
u8 reserved;
|
|
u8 reserved;
|
|
- u16 tx_op_limit;
|
|
|
|
|
|
+ __le16 tx_op_limit;
|
|
} __attribute__ ((packed));
|
|
} __attribute__ ((packed));
|
|
|
|
|
|
struct acx_tid_config {
|
|
struct acx_tid_config {
|
|
@@ -862,19 +862,19 @@ struct acx_tid_config {
|
|
u8 ps_scheme;
|
|
u8 ps_scheme;
|
|
u8 ack_policy;
|
|
u8 ack_policy;
|
|
u8 padding[3];
|
|
u8 padding[3];
|
|
- u32 apsd_conf[2];
|
|
|
|
|
|
+ __le32 apsd_conf[2];
|
|
} __attribute__ ((packed));
|
|
} __attribute__ ((packed));
|
|
|
|
|
|
struct acx_frag_threshold {
|
|
struct acx_frag_threshold {
|
|
struct acx_header header;
|
|
struct acx_header header;
|
|
- u16 frag_threshold;
|
|
|
|
|
|
+ __le16 frag_threshold;
|
|
u8 padding[2];
|
|
u8 padding[2];
|
|
} __attribute__ ((packed));
|
|
} __attribute__ ((packed));
|
|
|
|
|
|
struct acx_tx_config_options {
|
|
struct acx_tx_config_options {
|
|
struct acx_header header;
|
|
struct acx_header header;
|
|
- u16 tx_compl_timeout; /* msec */
|
|
|
|
- u16 tx_compl_threshold; /* number of packets */
|
|
|
|
|
|
+ __le16 tx_compl_timeout; /* msec */
|
|
|
|
+ __le16 tx_compl_threshold; /* number of packets */
|
|
} __attribute__ ((packed));
|
|
} __attribute__ ((packed));
|
|
|
|
|
|
#define ACX_RX_MEM_BLOCKS 64
|
|
#define ACX_RX_MEM_BLOCKS 64
|
|
@@ -889,59 +889,59 @@ struct wl1271_acx_config_memory {
|
|
u8 tx_min_mem_block_num;
|
|
u8 tx_min_mem_block_num;
|
|
u8 num_stations;
|
|
u8 num_stations;
|
|
u8 num_ssid_profiles;
|
|
u8 num_ssid_profiles;
|
|
- u32 total_tx_descriptors;
|
|
|
|
|
|
+ __le32 total_tx_descriptors;
|
|
} __attribute__ ((packed));
|
|
} __attribute__ ((packed));
|
|
|
|
|
|
struct wl1271_acx_mem_map {
|
|
struct wl1271_acx_mem_map {
|
|
struct acx_header header;
|
|
struct acx_header header;
|
|
|
|
|
|
- void *code_start;
|
|
|
|
- void *code_end;
|
|
|
|
|
|
+ __le32 code_start;
|
|
|
|
+ __le32 code_end;
|
|
|
|
|
|
- void *wep_defkey_start;
|
|
|
|
- void *wep_defkey_end;
|
|
|
|
|
|
+ __le32 wep_defkey_start;
|
|
|
|
+ __le32 wep_defkey_end;
|
|
|
|
|
|
- void *sta_table_start;
|
|
|
|
- void *sta_table_end;
|
|
|
|
|
|
+ __le32 sta_table_start;
|
|
|
|
+ __le32 sta_table_end;
|
|
|
|
|
|
- void *packet_template_start;
|
|
|
|
- void *packet_template_end;
|
|
|
|
|
|
+ __le32 packet_template_start;
|
|
|
|
+ __le32 packet_template_end;
|
|
|
|
|
|
/* Address of the TX result interface (control block) */
|
|
/* Address of the TX result interface (control block) */
|
|
- u32 tx_result;
|
|
|
|
- u32 tx_result_queue_start;
|
|
|
|
|
|
+ __le32 tx_result;
|
|
|
|
+ __le32 tx_result_queue_start;
|
|
|
|
|
|
- void *queue_memory_start;
|
|
|
|
- void *queue_memory_end;
|
|
|
|
|
|
+ __le32 queue_memory_start;
|
|
|
|
+ __le32 queue_memory_end;
|
|
|
|
|
|
- u32 packet_memory_pool_start;
|
|
|
|
- u32 packet_memory_pool_end;
|
|
|
|
|
|
+ __le32 packet_memory_pool_start;
|
|
|
|
+ __le32 packet_memory_pool_end;
|
|
|
|
|
|
- void *debug_buffer1_start;
|
|
|
|
- void *debug_buffer1_end;
|
|
|
|
|
|
+ __le32 debug_buffer1_start;
|
|
|
|
+ __le32 debug_buffer1_end;
|
|
|
|
|
|
- void *debug_buffer2_start;
|
|
|
|
- void *debug_buffer2_end;
|
|
|
|
|
|
+ __le32 debug_buffer2_start;
|
|
|
|
+ __le32 debug_buffer2_end;
|
|
|
|
|
|
/* Number of blocks FW allocated for TX packets */
|
|
/* Number of blocks FW allocated for TX packets */
|
|
- u32 num_tx_mem_blocks;
|
|
|
|
|
|
+ __le32 num_tx_mem_blocks;
|
|
|
|
|
|
/* Number of blocks FW allocated for RX packets */
|
|
/* Number of blocks FW allocated for RX packets */
|
|
- u32 num_rx_mem_blocks;
|
|
|
|
|
|
+ __le32 num_rx_mem_blocks;
|
|
|
|
|
|
/* the following 4 fields are valid in SLAVE mode only */
|
|
/* the following 4 fields are valid in SLAVE mode only */
|
|
u8 *tx_cbuf;
|
|
u8 *tx_cbuf;
|
|
u8 *rx_cbuf;
|
|
u8 *rx_cbuf;
|
|
- void *rx_ctrl;
|
|
|
|
- void *tx_ctrl;
|
|
|
|
|
|
+ __le32 rx_ctrl;
|
|
|
|
+ __le32 tx_ctrl;
|
|
} __attribute__ ((packed));
|
|
} __attribute__ ((packed));
|
|
|
|
|
|
struct wl1271_acx_rx_config_opt {
|
|
struct wl1271_acx_rx_config_opt {
|
|
struct acx_header header;
|
|
struct acx_header header;
|
|
|
|
|
|
- u16 mblk_threshold;
|
|
|
|
- u16 threshold;
|
|
|
|
- u16 timeout;
|
|
|
|
|
|
+ __le16 mblk_threshold;
|
|
|
|
+ __le16 threshold;
|
|
|
|
+ __le16 timeout;
|
|
u8 queue_type;
|
|
u8 queue_type;
|
|
u8 reserved;
|
|
u8 reserved;
|
|
} __attribute__ ((packed));
|
|
} __attribute__ ((packed));
|