diff options
-rw-r--r-- | drivers/net/wireless/iwlwifi/iwl-4965-commands.h | 2 | ||||
-rw-r--r-- | drivers/net/wireless/iwlwifi/iwl-5000-hw.h | 47 | ||||
-rw-r--r-- | drivers/net/wireless/iwlwifi/iwl-5000.c | 51 |
3 files changed, 99 insertions, 1 deletions
diff --git a/drivers/net/wireless/iwlwifi/iwl-4965-commands.h b/drivers/net/wireless/iwlwifi/iwl-4965-commands.h index 6b2d6bfec1e5..d0e3f35d4984 100644 --- a/drivers/net/wireless/iwlwifi/iwl-4965-commands.h +++ b/drivers/net/wireless/iwlwifi/iwl-4965-commands.h | |||
@@ -712,6 +712,8 @@ struct iwl4965_qosparam_cmd { | |||
712 | #define IWL_STA_ID 2 | 712 | #define IWL_STA_ID 2 |
713 | #define IWL4965_BROADCAST_ID 31 | 713 | #define IWL4965_BROADCAST_ID 31 |
714 | #define IWL4965_STATION_COUNT 32 | 714 | #define IWL4965_STATION_COUNT 32 |
715 | #define IWL5000_BROADCAST_ID 15 | ||
716 | #define IWL5000_STATION_COUNT 16 | ||
715 | 717 | ||
716 | #define IWL_STATION_COUNT 32 /* MAX(3945,4965)*/ | 718 | #define IWL_STATION_COUNT 32 /* MAX(3945,4965)*/ |
717 | #define IWL_INVALID_STATION 255 | 719 | #define IWL_INVALID_STATION 255 |
diff --git a/drivers/net/wireless/iwlwifi/iwl-5000-hw.h b/drivers/net/wireless/iwlwifi/iwl-5000-hw.h index 5cf8a684b3e1..31592fb8ddfd 100644 --- a/drivers/net/wireless/iwlwifi/iwl-5000-hw.h +++ b/drivers/net/wireless/iwlwifi/iwl-5000-hw.h | |||
@@ -68,6 +68,11 @@ | |||
68 | #ifndef __iwl_5000_hw_h__ | 68 | #ifndef __iwl_5000_hw_h__ |
69 | #define __iwl_5000_hw_h__ | 69 | #define __iwl_5000_hw_h__ |
70 | 70 | ||
71 | #define IWL50_RTC_INST_UPPER_BOUND (0x020000) | ||
72 | #define IWL50_RTC_DATA_UPPER_BOUND (0x80C000) | ||
73 | #define IWL50_RTC_INST_SIZE (IWL50_RTC_INST_UPPER_BOUND - RTC_INST_LOWER_BOUND) | ||
74 | #define IWL50_RTC_DATA_SIZE (IWL50_RTC_DATA_UPPER_BOUND - RTC_DATA_LOWER_BOUND) | ||
75 | |||
71 | /* EERPROM */ | 76 | /* EERPROM */ |
72 | #define IWL_5000_EEPROM_IMG_SIZE 2048 | 77 | #define IWL_5000_EEPROM_IMG_SIZE 2048 |
73 | 78 | ||
@@ -78,5 +83,47 @@ | |||
78 | #define IWL50_NUM_QUEUES 20 | 83 | #define IWL50_NUM_QUEUES 20 |
79 | #define IWL50_BACK_QUEUE_FIRST_ID 10 | 84 | #define IWL50_BACK_QUEUE_FIRST_ID 10 |
80 | 85 | ||
86 | /* Fixed (non-configurable) rx data from phy */ | ||
87 | |||
88 | /* Base physical address of iwl5000_shared is provided to SCD_DRAM_BASE_ADDR | ||
89 | * and &iwl5000_shared.val0 is provided to FH_RSCSR_CHNL0_STTS_WPTR_REG */ | ||
90 | struct iwl5000_sched_queue_byte_cnt_tbl { | ||
91 | struct iwl4965_queue_byte_cnt_entry tfd_offset[IWL50_QUEUE_SIZE + | ||
92 | IWL50_MAX_WIN_SIZE]; | ||
93 | } __attribute__ ((packed)); | ||
94 | |||
95 | struct iwl5000_shared { | ||
96 | struct iwl5000_sched_queue_byte_cnt_tbl | ||
97 | queues_byte_cnt_tbls[IWL50_NUM_QUEUES]; | ||
98 | __le32 rb_closed; | ||
99 | |||
100 | /* __le32 rb_closed_stts_rb_num:12; */ | ||
101 | #define IWL_rb_closed_stts_rb_num_POS 0 | ||
102 | #define IWL_rb_closed_stts_rb_num_LEN 12 | ||
103 | #define IWL_rb_closed_stts_rb_num_SYM rb_closed | ||
104 | /* __le32 rsrv1:4; */ | ||
105 | /* __le32 rb_closed_stts_rx_frame_num:12; */ | ||
106 | #define IWL_rb_closed_stts_rx_frame_num_POS 16 | ||
107 | #define IWL_rb_closed_stts_rx_frame_num_LEN 12 | ||
108 | #define IWL_rb_closed_stts_rx_frame_num_SYM rb_closed | ||
109 | /* __le32 rsrv2:4; */ | ||
110 | |||
111 | __le32 frm_finished; | ||
112 | /* __le32 frame_finished_stts_rb_num:12; */ | ||
113 | #define IWL_frame_finished_stts_rb_num_POS 0 | ||
114 | #define IWL_frame_finished_stts_rb_num_LEN 12 | ||
115 | #define IWL_frame_finished_stts_rb_num_SYM frm_finished | ||
116 | /* __le32 rsrv3:4; */ | ||
117 | /* __le32 frame_finished_stts_rx_frame_num:12; */ | ||
118 | #define IWL_frame_finished_stts_rx_frame_num_POS 16 | ||
119 | #define IWL_frame_finished_stts_rx_frame_num_LEN 12 | ||
120 | #define IWL_frame_finished_stts_rx_frame_num_SYM frm_finished | ||
121 | /* __le32 rsrv4:4; */ | ||
122 | |||
123 | __le32 padding1; /* so that allocation will be aligned to 16B */ | ||
124 | __le32 padding2; | ||
125 | } __attribute__ ((packed)); | ||
126 | |||
127 | |||
81 | #endif /* __iwl_5000_hw_h__ */ | 128 | #endif /* __iwl_5000_hw_h__ */ |
82 | 129 | ||
diff --git a/drivers/net/wireless/iwlwifi/iwl-5000.c b/drivers/net/wireless/iwlwifi/iwl-5000.c index 91b3e563bbea..545970b0caa1 100644 --- a/drivers/net/wireless/iwlwifi/iwl-5000.c +++ b/drivers/net/wireless/iwlwifi/iwl-5000.c | |||
@@ -133,8 +133,56 @@ static const u8 *iwl5000_eeprom_query_addr(const struct iwl_priv *priv, | |||
133 | return &priv->eeprom[address]; | 133 | return &priv->eeprom[address]; |
134 | } | 134 | } |
135 | 135 | ||
136 | static int iwl5000_hw_set_hw_params(struct iwl_priv *priv) | ||
137 | { | ||
138 | if ((priv->cfg->mod_params->num_of_queues > IWL50_NUM_QUEUES) || | ||
139 | (priv->cfg->mod_params->num_of_queues < IWL_MIN_NUM_QUEUES)) { | ||
140 | IWL_ERROR("invalid queues_num, should be between %d and %d\n", | ||
141 | IWL_MIN_NUM_QUEUES, IWL50_NUM_QUEUES); | ||
142 | return -EINVAL; | ||
143 | } | ||
136 | 144 | ||
137 | 145 | priv->hw_params.max_txq_num = priv->cfg->mod_params->num_of_queues; | |
146 | priv->hw_params.sw_crypto = priv->cfg->mod_params->sw_crypto; | ||
147 | priv->hw_params.tx_cmd_len = sizeof(struct iwl4965_tx_cmd); | ||
148 | priv->hw_params.max_rxq_size = RX_QUEUE_SIZE; | ||
149 | priv->hw_params.max_rxq_log = RX_QUEUE_SIZE_LOG; | ||
150 | if (priv->cfg->mod_params->amsdu_size_8K) | ||
151 | priv->hw_params.rx_buf_size = IWL_RX_BUF_SIZE_8K; | ||
152 | else | ||
153 | priv->hw_params.rx_buf_size = IWL_RX_BUF_SIZE_4K; | ||
154 | priv->hw_params.max_pkt_size = priv->hw_params.rx_buf_size - 256; | ||
155 | priv->hw_params.max_stations = IWL5000_STATION_COUNT; | ||
156 | priv->hw_params.bcast_sta_id = IWL5000_BROADCAST_ID; | ||
157 | priv->hw_params.max_data_size = IWL50_RTC_DATA_SIZE; | ||
158 | priv->hw_params.max_inst_size = IWL50_RTC_INST_SIZE; | ||
159 | priv->hw_params.max_bsm_size = BSM_SRAM_SIZE; | ||
160 | priv->hw_params.fat_channel = BIT(IEEE80211_BAND_2GHZ) | | ||
161 | BIT(IEEE80211_BAND_5GHZ); | ||
162 | |||
163 | switch (priv->hw_rev & CSR_HW_REV_TYPE_MSK) { | ||
164 | case CSR_HW_REV_TYPE_5100: | ||
165 | case CSR_HW_REV_TYPE_5150: | ||
166 | priv->hw_params.tx_chains_num = 1; | ||
167 | priv->hw_params.rx_chains_num = 2; | ||
168 | /* FIXME: move to ANT_A, ANT_B, ANT_C enum */ | ||
169 | priv->hw_params.valid_tx_ant = IWL_ANTENNA_MAIN; | ||
170 | priv->hw_params.valid_rx_ant = (IWL_ANTENNA_MAIN | | ||
171 | IWL_ANTENNA_AUX); | ||
172 | break; | ||
173 | case CSR_HW_REV_TYPE_5300: | ||
174 | case CSR_HW_REV_TYPE_5350: | ||
175 | priv->hw_params.tx_chains_num = 3; | ||
176 | priv->hw_params.rx_chains_num = 3; | ||
177 | /* FIXME: move to ANT_A, ANT_B, ANT_C enum */ | ||
178 | priv->hw_params.valid_tx_ant = (IWL_ANTENNA_MAIN | | ||
179 | IWL_ANTENNA_AUX | 0x04); | ||
180 | priv->hw_params.valid_rx_ant = (IWL_ANTENNA_MAIN | | ||
181 | IWL_ANTENNA_AUX | 0x04); | ||
182 | break; | ||
183 | } | ||
184 | return 0; | ||
185 | } | ||
138 | static struct iwl_hcmd_ops iwl5000_hcmd = { | 186 | static struct iwl_hcmd_ops iwl5000_hcmd = { |
139 | }; | 187 | }; |
140 | 188 | ||
@@ -142,6 +190,7 @@ static struct iwl_hcmd_utils_ops iwl5000_hcmd_utils = { | |||
142 | }; | 190 | }; |
143 | 191 | ||
144 | static struct iwl_lib_ops iwl5000_lib = { | 192 | static struct iwl_lib_ops iwl5000_lib = { |
193 | .set_hw_params = iwl5000_hw_set_hw_params, | ||
145 | .apm_ops = { | 194 | .apm_ops = { |
146 | .init = iwl5000_apm_init, | 195 | .init = iwl5000_apm_init, |
147 | .set_pwr_src = iwl4965_set_pwr_src, | 196 | .set_pwr_src = iwl4965_set_pwr_src, |