aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net/wireless/iwlwifi/iwl-3945.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/net/wireless/iwlwifi/iwl-3945.c')
-rw-r--r--drivers/net/wireless/iwlwifi/iwl-3945.c528
1 files changed, 264 insertions, 264 deletions
diff --git a/drivers/net/wireless/iwlwifi/iwl-3945.c b/drivers/net/wireless/iwlwifi/iwl-3945.c
index 36867a18d5b4..953a9bec0639 100644
--- a/drivers/net/wireless/iwlwifi/iwl-3945.c
+++ b/drivers/net/wireless/iwlwifi/iwl-3945.c
@@ -63,7 +63,7 @@
63 * maps to IWL_RATE_INVALID 63 * maps to IWL_RATE_INVALID
64 * 64 *
65 */ 65 */
66const struct iwl_rate_info iwl_rates[IWL_RATE_COUNT] = { 66const struct iwl3945_rate_info iwl3945_rates[IWL_RATE_COUNT] = {
67 IWL_DECLARE_RATE_INFO(1, INV, 2, INV, 2, INV, 2), /* 1mbps */ 67 IWL_DECLARE_RATE_INFO(1, INV, 2, INV, 2, INV, 2), /* 1mbps */
68 IWL_DECLARE_RATE_INFO(2, 1, 5, 1, 5, 1, 5), /* 2mbps */ 68 IWL_DECLARE_RATE_INFO(2, 1, 5, 1, 5, 1, 5), /* 2mbps */
69 IWL_DECLARE_RATE_INFO(5, 2, 6, 2, 11, 2, 11), /*5.5mbps */ 69 IWL_DECLARE_RATE_INFO(5, 2, 6, 2, 11, 2, 11), /*5.5mbps */
@@ -78,12 +78,12 @@ const struct iwl_rate_info iwl_rates[IWL_RATE_COUNT] = {
78 IWL_DECLARE_RATE_INFO(54, 48, INV, 48, INV, 48, INV),/* 54mbps */ 78 IWL_DECLARE_RATE_INFO(54, 48, INV, 48, INV, 48, INV),/* 54mbps */
79}; 79};
80 80
81/* 1 = enable the iwl_disable_events() function */ 81/* 1 = enable the iwl3945_disable_events() function */
82#define IWL_EVT_DISABLE (0) 82#define IWL_EVT_DISABLE (0)
83#define IWL_EVT_DISABLE_SIZE (1532/32) 83#define IWL_EVT_DISABLE_SIZE (1532/32)
84 84
85/** 85/**
86 * iwl_disable_events - Disable selected events in uCode event log 86 * iwl3945_disable_events - Disable selected events in uCode event log
87 * 87 *
88 * Disable an event by writing "1"s into "disable" 88 * Disable an event by writing "1"s into "disable"
89 * bitmap in SRAM. Bit position corresponds to Event # (id/type). 89 * bitmap in SRAM. Bit position corresponds to Event # (id/type).
@@ -91,7 +91,7 @@ const struct iwl_rate_info iwl_rates[IWL_RATE_COUNT] = {
91 * Use for only special debugging. This function is just a placeholder as-is, 91 * Use for only special debugging. This function is just a placeholder as-is,
92 * you'll need to provide the special bits! ... 92 * you'll need to provide the special bits! ...
93 * ... and set IWL_EVT_DISABLE to 1. */ 93 * ... and set IWL_EVT_DISABLE to 1. */
94void iwl_disable_events(struct iwl_priv *priv) 94void iwl3945_disable_events(struct iwl3945_priv *priv)
95{ 95{
96 int ret; 96 int ret;
97 int i; 97 int i;
@@ -149,31 +149,31 @@ void iwl_disable_events(struct iwl_priv *priv)
149 }; 149 };
150 150
151 base = le32_to_cpu(priv->card_alive.log_event_table_ptr); 151 base = le32_to_cpu(priv->card_alive.log_event_table_ptr);
152 if (!iwl_hw_valid_rtc_data_addr(base)) { 152 if (!iwl3945_hw_valid_rtc_data_addr(base)) {
153 IWL_ERROR("Invalid event log pointer 0x%08X\n", base); 153 IWL_ERROR("Invalid event log pointer 0x%08X\n", base);
154 return; 154 return;
155 } 155 }
156 156
157 ret = iwl_grab_nic_access(priv); 157 ret = iwl3945_grab_nic_access(priv);
158 if (ret) { 158 if (ret) {
159 IWL_WARNING("Can not read from adapter at this time.\n"); 159 IWL_WARNING("Can not read from adapter at this time.\n");
160 return; 160 return;
161 } 161 }
162 162
163 disable_ptr = iwl_read_targ_mem(priv, base + (4 * sizeof(u32))); 163 disable_ptr = iwl3945_read_targ_mem(priv, base + (4 * sizeof(u32)));
164 array_size = iwl_read_targ_mem(priv, base + (5 * sizeof(u32))); 164 array_size = iwl3945_read_targ_mem(priv, base + (5 * sizeof(u32)));
165 iwl_release_nic_access(priv); 165 iwl3945_release_nic_access(priv);
166 166
167 if (IWL_EVT_DISABLE && (array_size == IWL_EVT_DISABLE_SIZE)) { 167 if (IWL_EVT_DISABLE && (array_size == IWL_EVT_DISABLE_SIZE)) {
168 IWL_DEBUG_INFO("Disabling selected uCode log events at 0x%x\n", 168 IWL_DEBUG_INFO("Disabling selected uCode log events at 0x%x\n",
169 disable_ptr); 169 disable_ptr);
170 ret = iwl_grab_nic_access(priv); 170 ret = iwl3945_grab_nic_access(priv);
171 for (i = 0; i < IWL_EVT_DISABLE_SIZE; i++) 171 for (i = 0; i < IWL_EVT_DISABLE_SIZE; i++)
172 iwl_write_targ_mem(priv, 172 iwl3945_write_targ_mem(priv,
173 disable_ptr + (i * sizeof(u32)), 173 disable_ptr + (i * sizeof(u32)),
174 evt_disable[i]); 174 evt_disable[i]);
175 175
176 iwl_release_nic_access(priv); 176 iwl3945_release_nic_access(priv);
177 } else { 177 } else {
178 IWL_DEBUG_INFO("Selected uCode log events may be disabled\n"); 178 IWL_DEBUG_INFO("Selected uCode log events may be disabled\n");
179 IWL_DEBUG_INFO(" by writing \"1\"s into disable bitmap\n"); 179 IWL_DEBUG_INFO(" by writing \"1\"s into disable bitmap\n");
@@ -194,7 +194,7 @@ void iwl_disable_events(struct iwl_priv *priv)
194 * IWL_ANTENNA_MAIN - Force MAIN antenna 194 * IWL_ANTENNA_MAIN - Force MAIN antenna
195 * IWL_ANTENNA_AUX - Force AUX antenna 195 * IWL_ANTENNA_AUX - Force AUX antenna
196 */ 196 */
197__le32 iwl3945_get_antenna_flags(const struct iwl_priv *priv) 197__le32 iwl3945_get_antenna_flags(const struct iwl3945_priv *priv)
198{ 198{
199 switch (priv->antenna) { 199 switch (priv->antenna) {
200 case IWL_ANTENNA_DIVERSITY: 200 case IWL_ANTENNA_DIVERSITY:
@@ -226,11 +226,11 @@ __le32 iwl3945_get_antenna_flags(const struct iwl_priv *priv)
226 * 226 *
227 *****************************************************************************/ 227 *****************************************************************************/
228 228
229void iwl_hw_rx_statistics(struct iwl_priv *priv, struct iwl_rx_mem_buffer *rxb) 229void iwl3945_hw_rx_statistics(struct iwl3945_priv *priv, struct iwl3945_rx_mem_buffer *rxb)
230{ 230{
231 struct iwl_rx_packet *pkt = (void *)rxb->skb->data; 231 struct iwl3945_rx_packet *pkt = (void *)rxb->skb->data;
232 IWL_DEBUG_RX("Statistics notification received (%d vs %d).\n", 232 IWL_DEBUG_RX("Statistics notification received (%d vs %d).\n",
233 (int)sizeof(struct iwl_notif_statistics), 233 (int)sizeof(struct iwl3945_notif_statistics),
234 le32_to_cpu(pkt->len)); 234 le32_to_cpu(pkt->len));
235 235
236 memcpy(&priv->statistics, pkt->u.raw, sizeof(priv->statistics)); 236 memcpy(&priv->statistics, pkt->u.raw, sizeof(priv->statistics));
@@ -238,15 +238,15 @@ void iwl_hw_rx_statistics(struct iwl_priv *priv, struct iwl_rx_mem_buffer *rxb)
238 priv->last_statistics_time = jiffies; 238 priv->last_statistics_time = jiffies;
239} 239}
240 240
241static void iwl3945_handle_data_packet(struct iwl_priv *priv, int is_data, 241static void iwl3945_handle_data_packet(struct iwl3945_priv *priv, int is_data,
242 struct iwl_rx_mem_buffer *rxb, 242 struct iwl3945_rx_mem_buffer *rxb,
243 struct ieee80211_rx_status *stats, 243 struct ieee80211_rx_status *stats,
244 u16 phy_flags) 244 u16 phy_flags)
245{ 245{
246 struct ieee80211_hdr *hdr; 246 struct ieee80211_hdr *hdr;
247 struct iwl_rx_packet *pkt = (struct iwl_rx_packet *)rxb->skb->data; 247 struct iwl3945_rx_packet *pkt = (struct iwl3945_rx_packet *)rxb->skb->data;
248 struct iwl_rx_frame_hdr *rx_hdr = IWL_RX_HDR(pkt); 248 struct iwl3945_rx_frame_hdr *rx_hdr = IWL_RX_HDR(pkt);
249 struct iwl_rx_frame_end *rx_end = IWL_RX_END(pkt); 249 struct iwl3945_rx_frame_end *rx_end = IWL_RX_END(pkt);
250 short len = le16_to_cpu(rx_hdr->len); 250 short len = le16_to_cpu(rx_hdr->len);
251 251
252 /* We received data from the HW, so stop the watchdog */ 252 /* We received data from the HW, so stop the watchdog */
@@ -262,11 +262,11 @@ static void iwl3945_handle_data_packet(struct iwl_priv *priv, int is_data,
262 return; 262 return;
263 } 263 }
264 if (priv->iw_mode == IEEE80211_IF_TYPE_MNTR) { 264 if (priv->iw_mode == IEEE80211_IF_TYPE_MNTR) {
265 if (iwl_param_hwcrypto) 265 if (iwl3945_param_hwcrypto)
266 iwl_set_decrypted_flag(priv, rxb->skb, 266 iwl3945_set_decrypted_flag(priv, rxb->skb,
267 le32_to_cpu(rx_end->status), 267 le32_to_cpu(rx_end->status),
268 stats); 268 stats);
269 iwl_handle_data_packet_monitor(priv, rxb, IWL_RX_DATA(pkt), 269 iwl3945_handle_data_packet_monitor(priv, rxb, IWL_RX_DATA(pkt),
270 len, stats, phy_flags); 270 len, stats, phy_flags);
271 return; 271 return;
272 } 272 }
@@ -277,21 +277,21 @@ static void iwl3945_handle_data_packet(struct iwl_priv *priv, int is_data,
277 277
278 hdr = (void *)rxb->skb->data; 278 hdr = (void *)rxb->skb->data;
279 279
280 if (iwl_param_hwcrypto) 280 if (iwl3945_param_hwcrypto)
281 iwl_set_decrypted_flag(priv, rxb->skb, 281 iwl3945_set_decrypted_flag(priv, rxb->skb,
282 le32_to_cpu(rx_end->status), stats); 282 le32_to_cpu(rx_end->status), stats);
283 283
284 ieee80211_rx_irqsafe(priv->hw, rxb->skb, stats); 284 ieee80211_rx_irqsafe(priv->hw, rxb->skb, stats);
285 rxb->skb = NULL; 285 rxb->skb = NULL;
286} 286}
287 287
288static void iwl3945_rx_reply_rx(struct iwl_priv *priv, 288static void iwl3945_rx_reply_rx(struct iwl3945_priv *priv,
289 struct iwl_rx_mem_buffer *rxb) 289 struct iwl3945_rx_mem_buffer *rxb)
290{ 290{
291 struct iwl_rx_packet *pkt = (void *)rxb->skb->data; 291 struct iwl3945_rx_packet *pkt = (void *)rxb->skb->data;
292 struct iwl_rx_frame_stats *rx_stats = IWL_RX_STATS(pkt); 292 struct iwl3945_rx_frame_stats *rx_stats = IWL_RX_STATS(pkt);
293 struct iwl_rx_frame_hdr *rx_hdr = IWL_RX_HDR(pkt); 293 struct iwl3945_rx_frame_hdr *rx_hdr = IWL_RX_HDR(pkt);
294 struct iwl_rx_frame_end *rx_end = IWL_RX_END(pkt); 294 struct iwl3945_rx_frame_end *rx_end = IWL_RX_END(pkt);
295 struct ieee80211_hdr *header; 295 struct ieee80211_hdr *header;
296 u16 phy_flags = le16_to_cpu(rx_hdr->phy_flags); 296 u16 phy_flags = le16_to_cpu(rx_hdr->phy_flags);
297 u16 rx_stats_sig_avg = le16_to_cpu(rx_stats->sig_avg); 297 u16 rx_stats_sig_avg = le16_to_cpu(rx_stats->sig_avg);
@@ -347,14 +347,14 @@ static void iwl3945_rx_reply_rx(struct iwl_priv *priv,
347 * Calculate stats.signal (quality indicator in %) based on SNR. */ 347 * Calculate stats.signal (quality indicator in %) based on SNR. */
348 if (rx_stats_noise_diff) { 348 if (rx_stats_noise_diff) {
349 snr = rx_stats_sig_avg / rx_stats_noise_diff; 349 snr = rx_stats_sig_avg / rx_stats_noise_diff;
350 stats.noise = stats.ssi - iwl_calc_db_from_ratio(snr); 350 stats.noise = stats.ssi - iwl3945_calc_db_from_ratio(snr);
351 stats.signal = iwl_calc_sig_qual(stats.ssi, stats.noise); 351 stats.signal = iwl3945_calc_sig_qual(stats.ssi, stats.noise);
352 352
353 /* If noise info not available, calculate signal quality indicator (%) 353 /* If noise info not available, calculate signal quality indicator (%)
354 * using just the dBm signal level. */ 354 * using just the dBm signal level. */
355 } else { 355 } else {
356 stats.noise = priv->last_rx_noise; 356 stats.noise = priv->last_rx_noise;
357 stats.signal = iwl_calc_sig_qual(stats.ssi, 0); 357 stats.signal = iwl3945_calc_sig_qual(stats.ssi, 0);
358 } 358 }
359 359
360 360
@@ -364,24 +364,24 @@ static void iwl3945_rx_reply_rx(struct iwl_priv *priv,
364 364
365 stats.freq = ieee80211chan2mhz(stats.channel); 365 stats.freq = ieee80211chan2mhz(stats.channel);
366 366
367 /* can be covered by iwl_report_frame() in most cases */ 367 /* can be covered by iwl3945_report_frame() in most cases */
368/* IWL_DEBUG_RX("RX status: 0x%08X\n", rx_end->status); */ 368/* IWL_DEBUG_RX("RX status: 0x%08X\n", rx_end->status); */
369 369
370 header = (struct ieee80211_hdr *)IWL_RX_DATA(pkt); 370 header = (struct ieee80211_hdr *)IWL_RX_DATA(pkt);
371 371
372 network_packet = iwl_is_network_packet(priv, header); 372 network_packet = iwl3945_is_network_packet(priv, header);
373 373
374#ifdef CONFIG_IWL3945_DEBUG 374#ifdef CONFIG_IWL3945_DEBUG
375 if (iwl_debug_level & IWL_DL_STATS && net_ratelimit()) 375 if (iwl3945_debug_level & IWL_DL_STATS && net_ratelimit())
376 IWL_DEBUG_STATS 376 IWL_DEBUG_STATS
377 ("[%c] %d RSSI: %d Signal: %u, Noise: %u, Rate: %u\n", 377 ("[%c] %d RSSI: %d Signal: %u, Noise: %u, Rate: %u\n",
378 network_packet ? '*' : ' ', 378 network_packet ? '*' : ' ',
379 stats.channel, stats.ssi, stats.ssi, 379 stats.channel, stats.ssi, stats.ssi,
380 stats.ssi, stats.rate); 380 stats.ssi, stats.rate);
381 381
382 if (iwl_debug_level & (IWL_DL_RX)) 382 if (iwl3945_debug_level & (IWL_DL_RX))
383 /* Set "1" to report good data frames in groups of 100 */ 383 /* Set "1" to report good data frames in groups of 100 */
384 iwl_report_frame(priv, pkt, header, 1); 384 iwl3945_report_frame(priv, pkt, header, 1);
385#endif 385#endif
386 386
387 if (network_packet) { 387 if (network_packet) {
@@ -481,7 +481,7 @@ static void iwl3945_rx_reply_rx(struct iwl_priv *priv,
481 DECLARE_MAC_BUF(mac2); 481 DECLARE_MAC_BUF(mac2);
482 DECLARE_MAC_BUF(mac3); 482 DECLARE_MAC_BUF(mac3);
483 483
484 if (unlikely(is_duplicate_packet(priv, header))) 484 if (unlikely(iwl3945_is_duplicate_packet(priv, header)))
485 IWL_DEBUG_DROP("Dropping (dup): %s, %s, %s\n", 485 IWL_DEBUG_DROP("Dropping (dup): %s, %s, %s\n",
486 print_mac(mac1, header->addr1), 486 print_mac(mac1, header->addr1),
487 print_mac(mac2, header->addr2), 487 print_mac(mac2, header->addr2),
@@ -494,12 +494,12 @@ static void iwl3945_rx_reply_rx(struct iwl_priv *priv,
494 } 494 }
495} 495}
496 496
497int iwl_hw_txq_attach_buf_to_tfd(struct iwl_priv *priv, void *ptr, 497int iwl3945_hw_txq_attach_buf_to_tfd(struct iwl3945_priv *priv, void *ptr,
498 dma_addr_t addr, u16 len) 498 dma_addr_t addr, u16 len)
499{ 499{
500 int count; 500 int count;
501 u32 pad; 501 u32 pad;
502 struct iwl_tfd_frame *tfd = (struct iwl_tfd_frame *)ptr; 502 struct iwl3945_tfd_frame *tfd = (struct iwl3945_tfd_frame *)ptr;
503 503
504 count = TFD_CTL_COUNT_GET(le32_to_cpu(tfd->control_flags)); 504 count = TFD_CTL_COUNT_GET(le32_to_cpu(tfd->control_flags));
505 pad = TFD_CTL_PAD_GET(le32_to_cpu(tfd->control_flags)); 505 pad = TFD_CTL_PAD_GET(le32_to_cpu(tfd->control_flags));
@@ -522,14 +522,14 @@ int iwl_hw_txq_attach_buf_to_tfd(struct iwl_priv *priv, void *ptr,
522} 522}
523 523
524/** 524/**
525 * iwl_hw_txq_free_tfd - Free one TFD, those at index [txq->q.read_ptr] 525 * iwl3945_hw_txq_free_tfd - Free one TFD, those at index [txq->q.read_ptr]
526 * 526 *
527 * Does NOT advance any indexes 527 * Does NOT advance any indexes
528 */ 528 */
529int iwl_hw_txq_free_tfd(struct iwl_priv *priv, struct iwl_tx_queue *txq) 529int iwl3945_hw_txq_free_tfd(struct iwl3945_priv *priv, struct iwl3945_tx_queue *txq)
530{ 530{
531 struct iwl_tfd_frame *bd_tmp = (struct iwl_tfd_frame *)&txq->bd[0]; 531 struct iwl3945_tfd_frame *bd_tmp = (struct iwl3945_tfd_frame *)&txq->bd[0];
532 struct iwl_tfd_frame *bd = &bd_tmp[txq->q.read_ptr]; 532 struct iwl3945_tfd_frame *bd = &bd_tmp[txq->q.read_ptr];
533 struct pci_dev *dev = priv->pci_dev; 533 struct pci_dev *dev = priv->pci_dev;
534 int i; 534 int i;
535 int counter; 535 int counter;
@@ -564,7 +564,7 @@ int iwl_hw_txq_free_tfd(struct iwl_priv *priv, struct iwl_tx_queue *txq)
564 return 0; 564 return 0;
565} 565}
566 566
567u8 iwl_hw_find_station(struct iwl_priv *priv, const u8 *addr) 567u8 iwl3945_hw_find_station(struct iwl3945_priv *priv, const u8 *addr)
568{ 568{
569 int i; 569 int i;
570 int ret = IWL_INVALID_STATION; 570 int ret = IWL_INVALID_STATION;
@@ -588,11 +588,11 @@ u8 iwl_hw_find_station(struct iwl_priv *priv, const u8 *addr)
588} 588}
589 589
590/** 590/**
591 * iwl_hw_build_tx_cmd_rate - Add rate portion to TX_CMD: 591 * iwl3945_hw_build_tx_cmd_rate - Add rate portion to TX_CMD:
592 * 592 *
593*/ 593*/
594void iwl_hw_build_tx_cmd_rate(struct iwl_priv *priv, 594void iwl3945_hw_build_tx_cmd_rate(struct iwl3945_priv *priv,
595 struct iwl_cmd *cmd, 595 struct iwl3945_cmd *cmd,
596 struct ieee80211_tx_control *ctrl, 596 struct ieee80211_tx_control *ctrl,
597 struct ieee80211_hdr *hdr, int sta_id, int tx_id) 597 struct ieee80211_hdr *hdr, int sta_id, int tx_id)
598{ 598{
@@ -605,7 +605,7 @@ void iwl_hw_build_tx_cmd_rate(struct iwl_priv *priv,
605 __le32 tx_flags; 605 __le32 tx_flags;
606 u16 fc = le16_to_cpu(hdr->frame_control); 606 u16 fc = le16_to_cpu(hdr->frame_control);
607 607
608 rate = iwl_rates[rate_index].plcp; 608 rate = iwl3945_rates[rate_index].plcp;
609 tx_flags = cmd->cmd.tx.tx_flags; 609 tx_flags = cmd->cmd.tx.tx_flags;
610 610
611 /* We need to figure out how to get the sta->supp_rates while 611 /* We need to figure out how to get the sta->supp_rates while
@@ -672,10 +672,10 @@ void iwl_hw_build_tx_cmd_rate(struct iwl_priv *priv,
672 cmd->cmd.tx.supp_rates[1], cmd->cmd.tx.supp_rates[0]); 672 cmd->cmd.tx.supp_rates[1], cmd->cmd.tx.supp_rates[0]);
673} 673}
674 674
675u8 iwl3945_sync_sta(struct iwl_priv *priv, int sta_id, u16 tx_rate, u8 flags) 675u8 iwl3945_sync_sta(struct iwl3945_priv *priv, int sta_id, u16 tx_rate, u8 flags)
676{ 676{
677 unsigned long flags_spin; 677 unsigned long flags_spin;
678 struct iwl_station_entry *station; 678 struct iwl3945_station_entry *station;
679 679
680 if (sta_id == IWL_INVALID_STATION) 680 if (sta_id == IWL_INVALID_STATION)
681 return IWL_INVALID_STATION; 681 return IWL_INVALID_STATION;
@@ -690,19 +690,19 @@ u8 iwl3945_sync_sta(struct iwl_priv *priv, int sta_id, u16 tx_rate, u8 flags)
690 690
691 spin_unlock_irqrestore(&priv->sta_lock, flags_spin); 691 spin_unlock_irqrestore(&priv->sta_lock, flags_spin);
692 692
693 iwl_send_add_station(priv, &station->sta, flags); 693 iwl3945_send_add_station(priv, &station->sta, flags);
694 IWL_DEBUG_RATE("SCALE sync station %d to rate %d\n", 694 IWL_DEBUG_RATE("SCALE sync station %d to rate %d\n",
695 sta_id, tx_rate); 695 sta_id, tx_rate);
696 return sta_id; 696 return sta_id;
697} 697}
698 698
699static int iwl3945_nic_set_pwr_src(struct iwl_priv *priv, int pwr_max) 699static int iwl3945_nic_set_pwr_src(struct iwl3945_priv *priv, int pwr_max)
700{ 700{
701 int rc; 701 int rc;
702 unsigned long flags; 702 unsigned long flags;
703 703
704 spin_lock_irqsave(&priv->lock, flags); 704 spin_lock_irqsave(&priv->lock, flags);
705 rc = iwl_grab_nic_access(priv); 705 rc = iwl3945_grab_nic_access(priv);
706 if (rc) { 706 if (rc) {
707 spin_unlock_irqrestore(&priv->lock, flags); 707 spin_unlock_irqrestore(&priv->lock, flags);
708 return rc; 708 return rc;
@@ -714,23 +714,23 @@ static int iwl3945_nic_set_pwr_src(struct iwl_priv *priv, int pwr_max)
714 rc = pci_read_config_dword(priv->pci_dev, 714 rc = pci_read_config_dword(priv->pci_dev,
715 PCI_POWER_SOURCE, &val); 715 PCI_POWER_SOURCE, &val);
716 if (val & PCI_CFG_PMC_PME_FROM_D3COLD_SUPPORT) { 716 if (val & PCI_CFG_PMC_PME_FROM_D3COLD_SUPPORT) {
717 iwl_set_bits_mask_prph(priv, APMG_PS_CTRL_REG, 717 iwl3945_set_bits_mask_prph(priv, APMG_PS_CTRL_REG,
718 APMG_PS_CTRL_VAL_PWR_SRC_VAUX, 718 APMG_PS_CTRL_VAL_PWR_SRC_VAUX,
719 ~APMG_PS_CTRL_MSK_PWR_SRC); 719 ~APMG_PS_CTRL_MSK_PWR_SRC);
720 iwl_release_nic_access(priv); 720 iwl3945_release_nic_access(priv);
721 721
722 iwl_poll_bit(priv, CSR_GPIO_IN, 722 iwl3945_poll_bit(priv, CSR_GPIO_IN,
723 CSR_GPIO_IN_VAL_VAUX_PWR_SRC, 723 CSR_GPIO_IN_VAL_VAUX_PWR_SRC,
724 CSR_GPIO_IN_BIT_AUX_POWER, 5000); 724 CSR_GPIO_IN_BIT_AUX_POWER, 5000);
725 } else 725 } else
726 iwl_release_nic_access(priv); 726 iwl3945_release_nic_access(priv);
727 } else { 727 } else {
728 iwl_set_bits_mask_prph(priv, APMG_PS_CTRL_REG, 728 iwl3945_set_bits_mask_prph(priv, APMG_PS_CTRL_REG,
729 APMG_PS_CTRL_VAL_PWR_SRC_VMAIN, 729 APMG_PS_CTRL_VAL_PWR_SRC_VMAIN,
730 ~APMG_PS_CTRL_MSK_PWR_SRC); 730 ~APMG_PS_CTRL_MSK_PWR_SRC);
731 731
732 iwl_release_nic_access(priv); 732 iwl3945_release_nic_access(priv);
733 iwl_poll_bit(priv, CSR_GPIO_IN, CSR_GPIO_IN_VAL_VMAIN_PWR_SRC, 733 iwl3945_poll_bit(priv, CSR_GPIO_IN, CSR_GPIO_IN_VAL_VMAIN_PWR_SRC,
734 CSR_GPIO_IN_BIT_AUX_POWER, 5000); /* uS */ 734 CSR_GPIO_IN_BIT_AUX_POWER, 5000); /* uS */
735 } 735 }
736 spin_unlock_irqrestore(&priv->lock, flags); 736 spin_unlock_irqrestore(&priv->lock, flags);
@@ -738,24 +738,24 @@ static int iwl3945_nic_set_pwr_src(struct iwl_priv *priv, int pwr_max)
738 return rc; 738 return rc;
739} 739}
740 740
741static int iwl3945_rx_init(struct iwl_priv *priv, struct iwl_rx_queue *rxq) 741static int iwl3945_rx_init(struct iwl3945_priv *priv, struct iwl3945_rx_queue *rxq)
742{ 742{
743 int rc; 743 int rc;
744 unsigned long flags; 744 unsigned long flags;
745 745
746 spin_lock_irqsave(&priv->lock, flags); 746 spin_lock_irqsave(&priv->lock, flags);
747 rc = iwl_grab_nic_access(priv); 747 rc = iwl3945_grab_nic_access(priv);
748 if (rc) { 748 if (rc) {
749 spin_unlock_irqrestore(&priv->lock, flags); 749 spin_unlock_irqrestore(&priv->lock, flags);
750 return rc; 750 return rc;
751 } 751 }
752 752
753 iwl_write_direct32(priv, FH_RCSR_RBD_BASE(0), rxq->dma_addr); 753 iwl3945_write_direct32(priv, FH_RCSR_RBD_BASE(0), rxq->dma_addr);
754 iwl_write_direct32(priv, FH_RCSR_RPTR_ADDR(0), 754 iwl3945_write_direct32(priv, FH_RCSR_RPTR_ADDR(0),
755 priv->hw_setting.shared_phys + 755 priv->hw_setting.shared_phys +
756 offsetof(struct iwl_shared, rx_read_ptr[0])); 756 offsetof(struct iwl3945_shared, rx_read_ptr[0]));
757 iwl_write_direct32(priv, FH_RCSR_WPTR(0), 0); 757 iwl3945_write_direct32(priv, FH_RCSR_WPTR(0), 0);
758 iwl_write_direct32(priv, FH_RCSR_CONFIG(0), 758 iwl3945_write_direct32(priv, FH_RCSR_CONFIG(0),
759 ALM_FH_RCSR_RX_CONFIG_REG_VAL_DMA_CHNL_EN_ENABLE | 759 ALM_FH_RCSR_RX_CONFIG_REG_VAL_DMA_CHNL_EN_ENABLE |
760 ALM_FH_RCSR_RX_CONFIG_REG_VAL_RDRBD_EN_ENABLE | 760 ALM_FH_RCSR_RX_CONFIG_REG_VAL_RDRBD_EN_ENABLE |
761 ALM_FH_RCSR_RX_CONFIG_REG_BIT_WR_STTS_EN | 761 ALM_FH_RCSR_RX_CONFIG_REG_BIT_WR_STTS_EN |
@@ -766,44 +766,44 @@ static int iwl3945_rx_init(struct iwl_priv *priv, struct iwl_rx_queue *rxq)
766 ALM_FH_RCSR_RX_CONFIG_REG_VAL_MSG_MODE_FH); 766 ALM_FH_RCSR_RX_CONFIG_REG_VAL_MSG_MODE_FH);
767 767
768 /* fake read to flush all prev I/O */ 768 /* fake read to flush all prev I/O */
769 iwl_read_direct32(priv, FH_RSSR_CTRL); 769 iwl3945_read_direct32(priv, FH_RSSR_CTRL);
770 770
771 iwl_release_nic_access(priv); 771 iwl3945_release_nic_access(priv);
772 spin_unlock_irqrestore(&priv->lock, flags); 772 spin_unlock_irqrestore(&priv->lock, flags);
773 773
774 return 0; 774 return 0;
775} 775}
776 776
777static int iwl3945_tx_reset(struct iwl_priv *priv) 777static int iwl3945_tx_reset(struct iwl3945_priv *priv)
778{ 778{
779 int rc; 779 int rc;
780 unsigned long flags; 780 unsigned long flags;
781 781
782 spin_lock_irqsave(&priv->lock, flags); 782 spin_lock_irqsave(&priv->lock, flags);
783 rc = iwl_grab_nic_access(priv); 783 rc = iwl3945_grab_nic_access(priv);
784 if (rc) { 784 if (rc) {
785 spin_unlock_irqrestore(&priv->lock, flags); 785 spin_unlock_irqrestore(&priv->lock, flags);
786 return rc; 786 return rc;
787 } 787 }
788 788
789 /* bypass mode */ 789 /* bypass mode */
790 iwl_write_prph(priv, ALM_SCD_MODE_REG, 0x2); 790 iwl3945_write_prph(priv, ALM_SCD_MODE_REG, 0x2);
791 791
792 /* RA 0 is active */ 792 /* RA 0 is active */
793 iwl_write_prph(priv, ALM_SCD_ARASTAT_REG, 0x01); 793 iwl3945_write_prph(priv, ALM_SCD_ARASTAT_REG, 0x01);
794 794
795 /* all 6 fifo are active */ 795 /* all 6 fifo are active */
796 iwl_write_prph(priv, ALM_SCD_TXFACT_REG, 0x3f); 796 iwl3945_write_prph(priv, ALM_SCD_TXFACT_REG, 0x3f);
797 797
798 iwl_write_prph(priv, ALM_SCD_SBYP_MODE_1_REG, 0x010000); 798 iwl3945_write_prph(priv, ALM_SCD_SBYP_MODE_1_REG, 0x010000);
799 iwl_write_prph(priv, ALM_SCD_SBYP_MODE_2_REG, 0x030002); 799 iwl3945_write_prph(priv, ALM_SCD_SBYP_MODE_2_REG, 0x030002);
800 iwl_write_prph(priv, ALM_SCD_TXF4MF_REG, 0x000004); 800 iwl3945_write_prph(priv, ALM_SCD_TXF4MF_REG, 0x000004);
801 iwl_write_prph(priv, ALM_SCD_TXF5MF_REG, 0x000005); 801 iwl3945_write_prph(priv, ALM_SCD_TXF5MF_REG, 0x000005);
802 802
803 iwl_write_direct32(priv, FH_TSSR_CBB_BASE, 803 iwl3945_write_direct32(priv, FH_TSSR_CBB_BASE,
804 priv->hw_setting.shared_phys); 804 priv->hw_setting.shared_phys);
805 805
806 iwl_write_direct32(priv, FH_TSSR_MSG_CONFIG, 806 iwl3945_write_direct32(priv, FH_TSSR_MSG_CONFIG,
807 ALM_FH_TSSR_TX_MSG_CONFIG_REG_VAL_SNOOP_RD_TXPD_ON | 807 ALM_FH_TSSR_TX_MSG_CONFIG_REG_VAL_SNOOP_RD_TXPD_ON |
808 ALM_FH_TSSR_TX_MSG_CONFIG_REG_VAL_ORDER_RD_TXPD_ON | 808 ALM_FH_TSSR_TX_MSG_CONFIG_REG_VAL_ORDER_RD_TXPD_ON |
809 ALM_FH_TSSR_TX_MSG_CONFIG_REG_VAL_MAX_FRAG_SIZE_128B | 809 ALM_FH_TSSR_TX_MSG_CONFIG_REG_VAL_MAX_FRAG_SIZE_128B |
@@ -812,7 +812,7 @@ static int iwl3945_tx_reset(struct iwl_priv *priv)
812 ALM_FH_TSSR_TX_MSG_CONFIG_REG_VAL_ORDER_RSP_WAIT_TH | 812 ALM_FH_TSSR_TX_MSG_CONFIG_REG_VAL_ORDER_RSP_WAIT_TH |
813 ALM_FH_TSSR_TX_MSG_CONFIG_REG_VAL_RSP_WAIT_TH); 813 ALM_FH_TSSR_TX_MSG_CONFIG_REG_VAL_RSP_WAIT_TH);
814 814
815 iwl_release_nic_access(priv); 815 iwl3945_release_nic_access(priv);
816 spin_unlock_irqrestore(&priv->lock, flags); 816 spin_unlock_irqrestore(&priv->lock, flags);
817 817
818 return 0; 818 return 0;
@@ -823,12 +823,12 @@ static int iwl3945_tx_reset(struct iwl_priv *priv)
823 * 823 *
824 * Destroys all DMA structures and initialize them again 824 * Destroys all DMA structures and initialize them again
825 */ 825 */
826static int iwl3945_txq_ctx_reset(struct iwl_priv *priv) 826static int iwl3945_txq_ctx_reset(struct iwl3945_priv *priv)
827{ 827{
828 int rc; 828 int rc;
829 int txq_id, slots_num; 829 int txq_id, slots_num;
830 830
831 iwl_hw_txq_ctx_free(priv); 831 iwl3945_hw_txq_ctx_free(priv);
832 832
833 /* Tx CMD queue */ 833 /* Tx CMD queue */
834 rc = iwl3945_tx_reset(priv); 834 rc = iwl3945_tx_reset(priv);
@@ -839,7 +839,7 @@ static int iwl3945_txq_ctx_reset(struct iwl_priv *priv)
839 for (txq_id = 0; txq_id < TFD_QUEUE_MAX; txq_id++) { 839 for (txq_id = 0; txq_id < TFD_QUEUE_MAX; txq_id++) {
840 slots_num = (txq_id == IWL_CMD_QUEUE_NUM) ? 840 slots_num = (txq_id == IWL_CMD_QUEUE_NUM) ?
841 TFD_CMD_SLOTS : TFD_TX_CMD_SLOTS; 841 TFD_CMD_SLOTS : TFD_TX_CMD_SLOTS;
842 rc = iwl_tx_queue_init(priv, &priv->txq[txq_id], slots_num, 842 rc = iwl3945_tx_queue_init(priv, &priv->txq[txq_id], slots_num,
843 txq_id); 843 txq_id);
844 if (rc) { 844 if (rc) {
845 IWL_ERROR("Tx %d queue init failed\n", txq_id); 845 IWL_ERROR("Tx %d queue init failed\n", txq_id);
@@ -850,26 +850,26 @@ static int iwl3945_txq_ctx_reset(struct iwl_priv *priv)
850 return rc; 850 return rc;
851 851
852 error: 852 error:
853 iwl_hw_txq_ctx_free(priv); 853 iwl3945_hw_txq_ctx_free(priv);
854 return rc; 854 return rc;
855} 855}
856 856
857int iwl_hw_nic_init(struct iwl_priv *priv) 857int iwl3945_hw_nic_init(struct iwl3945_priv *priv)
858{ 858{
859 u8 rev_id; 859 u8 rev_id;
860 int rc; 860 int rc;
861 unsigned long flags; 861 unsigned long flags;
862 struct iwl_rx_queue *rxq = &priv->rxq; 862 struct iwl3945_rx_queue *rxq = &priv->rxq;
863 863
864 iwl_power_init_handle(priv); 864 iwl3945_power_init_handle(priv);
865 865
866 spin_lock_irqsave(&priv->lock, flags); 866 spin_lock_irqsave(&priv->lock, flags);
867 iwl_set_bit(priv, CSR_ANA_PLL_CFG, (1 << 24)); 867 iwl3945_set_bit(priv, CSR_ANA_PLL_CFG, (1 << 24));
868 iwl_set_bit(priv, CSR_GIO_CHICKEN_BITS, 868 iwl3945_set_bit(priv, CSR_GIO_CHICKEN_BITS,
869 CSR_GIO_CHICKEN_BITS_REG_BIT_L1A_NO_L0S_RX); 869 CSR_GIO_CHICKEN_BITS_REG_BIT_L1A_NO_L0S_RX);
870 870
871 iwl_set_bit(priv, CSR_GP_CNTRL, CSR_GP_CNTRL_REG_FLAG_INIT_DONE); 871 iwl3945_set_bit(priv, CSR_GP_CNTRL, CSR_GP_CNTRL_REG_FLAG_INIT_DONE);
872 rc = iwl_poll_bit(priv, CSR_GP_CNTRL, 872 rc = iwl3945_poll_bit(priv, CSR_GP_CNTRL,
873 CSR_GP_CNTRL_REG_FLAG_MAC_CLOCK_READY, 873 CSR_GP_CNTRL_REG_FLAG_MAC_CLOCK_READY,
874 CSR_GP_CNTRL_REG_FLAG_MAC_CLOCK_READY, 25000); 874 CSR_GP_CNTRL_REG_FLAG_MAC_CLOCK_READY, 25000);
875 if (rc < 0) { 875 if (rc < 0) {
@@ -878,18 +878,18 @@ int iwl_hw_nic_init(struct iwl_priv *priv)
878 return rc; 878 return rc;
879 } 879 }
880 880
881 rc = iwl_grab_nic_access(priv); 881 rc = iwl3945_grab_nic_access(priv);
882 if (rc) { 882 if (rc) {
883 spin_unlock_irqrestore(&priv->lock, flags); 883 spin_unlock_irqrestore(&priv->lock, flags);
884 return rc; 884 return rc;
885 } 885 }
886 iwl_write_prph(priv, APMG_CLK_EN_REG, 886 iwl3945_write_prph(priv, APMG_CLK_EN_REG,
887 APMG_CLK_VAL_DMA_CLK_RQT | 887 APMG_CLK_VAL_DMA_CLK_RQT |
888 APMG_CLK_VAL_BSM_CLK_RQT); 888 APMG_CLK_VAL_BSM_CLK_RQT);
889 udelay(20); 889 udelay(20);
890 iwl_set_bits_prph(priv, APMG_PCIDEV_STT_REG, 890 iwl3945_set_bits_prph(priv, APMG_PCIDEV_STT_REG,
891 APMG_PCIDEV_STT_VAL_L1_ACT_DIS); 891 APMG_PCIDEV_STT_VAL_L1_ACT_DIS);
892 iwl_release_nic_access(priv); 892 iwl3945_release_nic_access(priv);
893 spin_unlock_irqrestore(&priv->lock, flags); 893 spin_unlock_irqrestore(&priv->lock, flags);
894 894
895 /* Determine HW type */ 895 /* Determine HW type */
@@ -905,25 +905,25 @@ int iwl_hw_nic_init(struct iwl_priv *priv)
905 IWL_DEBUG_INFO("RTP type \n"); 905 IWL_DEBUG_INFO("RTP type \n");
906 else if (rev_id & PCI_CFG_REV_ID_BIT_BASIC_SKU) { 906 else if (rev_id & PCI_CFG_REV_ID_BIT_BASIC_SKU) {
907 IWL_DEBUG_INFO("ALM-MB type\n"); 907 IWL_DEBUG_INFO("ALM-MB type\n");
908 iwl_set_bit(priv, CSR_HW_IF_CONFIG_REG, 908 iwl3945_set_bit(priv, CSR_HW_IF_CONFIG_REG,
909 CSR_HW_IF_CONFIG_REG_BIT_ALMAGOR_MB); 909 CSR_HW_IF_CONFIG_REG_BIT_ALMAGOR_MB);
910 } else { 910 } else {
911 IWL_DEBUG_INFO("ALM-MM type\n"); 911 IWL_DEBUG_INFO("ALM-MM type\n");
912 iwl_set_bit(priv, CSR_HW_IF_CONFIG_REG, 912 iwl3945_set_bit(priv, CSR_HW_IF_CONFIG_REG,
913 CSR_HW_IF_CONFIG_REG_BIT_ALMAGOR_MM); 913 CSR_HW_IF_CONFIG_REG_BIT_ALMAGOR_MM);
914 } 914 }
915 915
916 spin_unlock_irqrestore(&priv->lock, flags); 916 spin_unlock_irqrestore(&priv->lock, flags);
917 917
918 /* Initialize the EEPROM */ 918 /* Initialize the EEPROM */
919 rc = iwl_eeprom_init(priv); 919 rc = iwl3945_eeprom_init(priv);
920 if (rc) 920 if (rc)
921 return rc; 921 return rc;
922 922
923 spin_lock_irqsave(&priv->lock, flags); 923 spin_lock_irqsave(&priv->lock, flags);
924 if (EEPROM_SKU_CAP_OP_MODE_MRC == priv->eeprom.sku_cap) { 924 if (EEPROM_SKU_CAP_OP_MODE_MRC == priv->eeprom.sku_cap) {
925 IWL_DEBUG_INFO("SKU OP mode is mrc\n"); 925 IWL_DEBUG_INFO("SKU OP mode is mrc\n");
926 iwl_set_bit(priv, CSR_HW_IF_CONFIG_REG, 926 iwl3945_set_bit(priv, CSR_HW_IF_CONFIG_REG,
927 CSR_HW_IF_CONFIG_REG_BIT_SKU_MRC); 927 CSR_HW_IF_CONFIG_REG_BIT_SKU_MRC);
928 } else 928 } else
929 IWL_DEBUG_INFO("SKU OP mode is basic\n"); 929 IWL_DEBUG_INFO("SKU OP mode is basic\n");
@@ -931,24 +931,24 @@ int iwl_hw_nic_init(struct iwl_priv *priv)
931 if ((priv->eeprom.board_revision & 0xF0) == 0xD0) { 931 if ((priv->eeprom.board_revision & 0xF0) == 0xD0) {
932 IWL_DEBUG_INFO("3945ABG revision is 0x%X\n", 932 IWL_DEBUG_INFO("3945ABG revision is 0x%X\n",
933 priv->eeprom.board_revision); 933 priv->eeprom.board_revision);
934 iwl_set_bit(priv, CSR_HW_IF_CONFIG_REG, 934 iwl3945_set_bit(priv, CSR_HW_IF_CONFIG_REG,
935 CSR_HW_IF_CONFIG_REG_BIT_BOARD_TYPE); 935 CSR_HW_IF_CONFIG_REG_BIT_BOARD_TYPE);
936 } else { 936 } else {
937 IWL_DEBUG_INFO("3945ABG revision is 0x%X\n", 937 IWL_DEBUG_INFO("3945ABG revision is 0x%X\n",
938 priv->eeprom.board_revision); 938 priv->eeprom.board_revision);
939 iwl_clear_bit(priv, CSR_HW_IF_CONFIG_REG, 939 iwl3945_clear_bit(priv, CSR_HW_IF_CONFIG_REG,
940 CSR_HW_IF_CONFIG_REG_BIT_BOARD_TYPE); 940 CSR_HW_IF_CONFIG_REG_BIT_BOARD_TYPE);
941 } 941 }
942 942
943 if (priv->eeprom.almgor_m_version <= 1) { 943 if (priv->eeprom.almgor_m_version <= 1) {
944 iwl_set_bit(priv, CSR_HW_IF_CONFIG_REG, 944 iwl3945_set_bit(priv, CSR_HW_IF_CONFIG_REG,
945 CSR_HW_IF_CONFIG_REG_BITS_SILICON_TYPE_A); 945 CSR_HW_IF_CONFIG_REG_BITS_SILICON_TYPE_A);
946 IWL_DEBUG_INFO("Card M type A version is 0x%X\n", 946 IWL_DEBUG_INFO("Card M type A version is 0x%X\n",
947 priv->eeprom.almgor_m_version); 947 priv->eeprom.almgor_m_version);
948 } else { 948 } else {
949 IWL_DEBUG_INFO("Card M type B version is 0x%X\n", 949 IWL_DEBUG_INFO("Card M type B version is 0x%X\n",
950 priv->eeprom.almgor_m_version); 950 priv->eeprom.almgor_m_version);
951 iwl_set_bit(priv, CSR_HW_IF_CONFIG_REG, 951 iwl3945_set_bit(priv, CSR_HW_IF_CONFIG_REG,
952 CSR_HW_IF_CONFIG_REG_BITS_SILICON_TYPE_B); 952 CSR_HW_IF_CONFIG_REG_BITS_SILICON_TYPE_B);
953 } 953 }
954 spin_unlock_irqrestore(&priv->lock, flags); 954 spin_unlock_irqrestore(&priv->lock, flags);
@@ -961,15 +961,15 @@ int iwl_hw_nic_init(struct iwl_priv *priv)
961 961
962 /* Allocate the RX queue, or reset if it is already allocated */ 962 /* Allocate the RX queue, or reset if it is already allocated */
963 if (!rxq->bd) { 963 if (!rxq->bd) {
964 rc = iwl_rx_queue_alloc(priv); 964 rc = iwl3945_rx_queue_alloc(priv);
965 if (rc) { 965 if (rc) {
966 IWL_ERROR("Unable to initialize Rx queue\n"); 966 IWL_ERROR("Unable to initialize Rx queue\n");
967 return -ENOMEM; 967 return -ENOMEM;
968 } 968 }
969 } else 969 } else
970 iwl_rx_queue_reset(priv, rxq); 970 iwl3945_rx_queue_reset(priv, rxq);
971 971
972 iwl_rx_replenish(priv); 972 iwl3945_rx_replenish(priv);
973 973
974 iwl3945_rx_init(priv, rxq); 974 iwl3945_rx_init(priv, rxq);
975 975
@@ -977,16 +977,16 @@ int iwl_hw_nic_init(struct iwl_priv *priv)
977 977
978 /* Look at using this instead: 978 /* Look at using this instead:
979 rxq->need_update = 1; 979 rxq->need_update = 1;
980 iwl_rx_queue_update_write_ptr(priv, rxq); 980 iwl3945_rx_queue_update_write_ptr(priv, rxq);
981 */ 981 */
982 982
983 rc = iwl_grab_nic_access(priv); 983 rc = iwl3945_grab_nic_access(priv);
984 if (rc) { 984 if (rc) {
985 spin_unlock_irqrestore(&priv->lock, flags); 985 spin_unlock_irqrestore(&priv->lock, flags);
986 return rc; 986 return rc;
987 } 987 }
988 iwl_write_direct32(priv, FH_RCSR_WPTR(0), rxq->write & ~7); 988 iwl3945_write_direct32(priv, FH_RCSR_WPTR(0), rxq->write & ~7);
989 iwl_release_nic_access(priv); 989 iwl3945_release_nic_access(priv);
990 990
991 spin_unlock_irqrestore(&priv->lock, flags); 991 spin_unlock_irqrestore(&priv->lock, flags);
992 992
@@ -1000,49 +1000,49 @@ int iwl_hw_nic_init(struct iwl_priv *priv)
1000} 1000}
1001 1001
1002/** 1002/**
1003 * iwl_hw_txq_ctx_free - Free TXQ Context 1003 * iwl3945_hw_txq_ctx_free - Free TXQ Context
1004 * 1004 *
1005 * Destroy all TX DMA queues and structures 1005 * Destroy all TX DMA queues and structures
1006 */ 1006 */
1007void iwl_hw_txq_ctx_free(struct iwl_priv *priv) 1007void iwl3945_hw_txq_ctx_free(struct iwl3945_priv *priv)
1008{ 1008{
1009 int txq_id; 1009 int txq_id;
1010 1010
1011 /* Tx queues */ 1011 /* Tx queues */
1012 for (txq_id = 0; txq_id < TFD_QUEUE_MAX; txq_id++) 1012 for (txq_id = 0; txq_id < TFD_QUEUE_MAX; txq_id++)
1013 iwl_tx_queue_free(priv, &priv->txq[txq_id]); 1013 iwl3945_tx_queue_free(priv, &priv->txq[txq_id]);
1014} 1014}
1015 1015
1016void iwl_hw_txq_ctx_stop(struct iwl_priv *priv) 1016void iwl3945_hw_txq_ctx_stop(struct iwl3945_priv *priv)
1017{ 1017{
1018 int queue; 1018 int queue;
1019 unsigned long flags; 1019 unsigned long flags;
1020 1020
1021 spin_lock_irqsave(&priv->lock, flags); 1021 spin_lock_irqsave(&priv->lock, flags);
1022 if (iwl_grab_nic_access(priv)) { 1022 if (iwl3945_grab_nic_access(priv)) {
1023 spin_unlock_irqrestore(&priv->lock, flags); 1023 spin_unlock_irqrestore(&priv->lock, flags);
1024 iwl_hw_txq_ctx_free(priv); 1024 iwl3945_hw_txq_ctx_free(priv);
1025 return; 1025 return;
1026 } 1026 }
1027 1027
1028 /* stop SCD */ 1028 /* stop SCD */
1029 iwl_write_prph(priv, ALM_SCD_MODE_REG, 0); 1029 iwl3945_write_prph(priv, ALM_SCD_MODE_REG, 0);
1030 1030
1031 /* reset TFD queues */ 1031 /* reset TFD queues */
1032 for (queue = TFD_QUEUE_MIN; queue < TFD_QUEUE_MAX; queue++) { 1032 for (queue = TFD_QUEUE_MIN; queue < TFD_QUEUE_MAX; queue++) {
1033 iwl_write_direct32(priv, FH_TCSR_CONFIG(queue), 0x0); 1033 iwl3945_write_direct32(priv, FH_TCSR_CONFIG(queue), 0x0);
1034 iwl_poll_direct_bit(priv, FH_TSSR_TX_STATUS, 1034 iwl3945_poll_direct_bit(priv, FH_TSSR_TX_STATUS,
1035 ALM_FH_TSSR_TX_STATUS_REG_MSK_CHNL_IDLE(queue), 1035 ALM_FH_TSSR_TX_STATUS_REG_MSK_CHNL_IDLE(queue),
1036 1000); 1036 1000);
1037 } 1037 }
1038 1038
1039 iwl_release_nic_access(priv); 1039 iwl3945_release_nic_access(priv);
1040 spin_unlock_irqrestore(&priv->lock, flags); 1040 spin_unlock_irqrestore(&priv->lock, flags);
1041 1041
1042 iwl_hw_txq_ctx_free(priv); 1042 iwl3945_hw_txq_ctx_free(priv);
1043} 1043}
1044 1044
1045int iwl_hw_nic_stop_master(struct iwl_priv *priv) 1045int iwl3945_hw_nic_stop_master(struct iwl3945_priv *priv)
1046{ 1046{
1047 int rc = 0; 1047 int rc = 0;
1048 u32 reg_val; 1048 u32 reg_val;
@@ -1051,16 +1051,16 @@ int iwl_hw_nic_stop_master(struct iwl_priv *priv)
1051 spin_lock_irqsave(&priv->lock, flags); 1051 spin_lock_irqsave(&priv->lock, flags);
1052 1052
1053 /* set stop master bit */ 1053 /* set stop master bit */
1054 iwl_set_bit(priv, CSR_RESET, CSR_RESET_REG_FLAG_STOP_MASTER); 1054 iwl3945_set_bit(priv, CSR_RESET, CSR_RESET_REG_FLAG_STOP_MASTER);
1055 1055
1056 reg_val = iwl_read32(priv, CSR_GP_CNTRL); 1056 reg_val = iwl3945_read32(priv, CSR_GP_CNTRL);
1057 1057
1058 if (CSR_GP_CNTRL_REG_FLAG_MAC_POWER_SAVE == 1058 if (CSR_GP_CNTRL_REG_FLAG_MAC_POWER_SAVE ==
1059 (reg_val & CSR_GP_CNTRL_REG_MSK_POWER_SAVE_TYPE)) 1059 (reg_val & CSR_GP_CNTRL_REG_MSK_POWER_SAVE_TYPE))
1060 IWL_DEBUG_INFO("Card in power save, master is already " 1060 IWL_DEBUG_INFO("Card in power save, master is already "
1061 "stopped\n"); 1061 "stopped\n");
1062 else { 1062 else {
1063 rc = iwl_poll_bit(priv, CSR_RESET, 1063 rc = iwl3945_poll_bit(priv, CSR_RESET,
1064 CSR_RESET_REG_FLAG_MASTER_DISABLED, 1064 CSR_RESET_REG_FLAG_MASTER_DISABLED,
1065 CSR_RESET_REG_FLAG_MASTER_DISABLED, 100); 1065 CSR_RESET_REG_FLAG_MASTER_DISABLED, 100);
1066 if (rc < 0) { 1066 if (rc < 0) {
@@ -1075,47 +1075,47 @@ int iwl_hw_nic_stop_master(struct iwl_priv *priv)
1075 return rc; 1075 return rc;
1076} 1076}
1077 1077
1078int iwl_hw_nic_reset(struct iwl_priv *priv) 1078int iwl3945_hw_nic_reset(struct iwl3945_priv *priv)
1079{ 1079{
1080 int rc; 1080 int rc;
1081 unsigned long flags; 1081 unsigned long flags;
1082 1082
1083 iwl_hw_nic_stop_master(priv); 1083 iwl3945_hw_nic_stop_master(priv);
1084 1084
1085 spin_lock_irqsave(&priv->lock, flags); 1085 spin_lock_irqsave(&priv->lock, flags);
1086 1086
1087 iwl_set_bit(priv, CSR_RESET, CSR_RESET_REG_FLAG_SW_RESET); 1087 iwl3945_set_bit(priv, CSR_RESET, CSR_RESET_REG_FLAG_SW_RESET);
1088 1088
1089 rc = iwl_poll_bit(priv, CSR_GP_CNTRL, 1089 rc = iwl3945_poll_bit(priv, CSR_GP_CNTRL,
1090 CSR_GP_CNTRL_REG_FLAG_MAC_CLOCK_READY, 1090 CSR_GP_CNTRL_REG_FLAG_MAC_CLOCK_READY,
1091 CSR_GP_CNTRL_REG_FLAG_MAC_CLOCK_READY, 25000); 1091 CSR_GP_CNTRL_REG_FLAG_MAC_CLOCK_READY, 25000);
1092 1092
1093 rc = iwl_grab_nic_access(priv); 1093 rc = iwl3945_grab_nic_access(priv);
1094 if (!rc) { 1094 if (!rc) {
1095 iwl_write_prph(priv, APMG_CLK_CTRL_REG, 1095 iwl3945_write_prph(priv, APMG_CLK_CTRL_REG,
1096 APMG_CLK_VAL_BSM_CLK_RQT); 1096 APMG_CLK_VAL_BSM_CLK_RQT);
1097 1097
1098 udelay(10); 1098 udelay(10);
1099 1099
1100 iwl_set_bit(priv, CSR_GP_CNTRL, 1100 iwl3945_set_bit(priv, CSR_GP_CNTRL,
1101 CSR_GP_CNTRL_REG_FLAG_INIT_DONE); 1101 CSR_GP_CNTRL_REG_FLAG_INIT_DONE);
1102 1102
1103 iwl_write_prph(priv, APMG_RTC_INT_MSK_REG, 0x0); 1103 iwl3945_write_prph(priv, APMG_RTC_INT_MSK_REG, 0x0);
1104 iwl_write_prph(priv, APMG_RTC_INT_STT_REG, 1104 iwl3945_write_prph(priv, APMG_RTC_INT_STT_REG,
1105 0xFFFFFFFF); 1105 0xFFFFFFFF);
1106 1106
1107 /* enable DMA */ 1107 /* enable DMA */
1108 iwl_write_prph(priv, APMG_CLK_EN_REG, 1108 iwl3945_write_prph(priv, APMG_CLK_EN_REG,
1109 APMG_CLK_VAL_DMA_CLK_RQT | 1109 APMG_CLK_VAL_DMA_CLK_RQT |
1110 APMG_CLK_VAL_BSM_CLK_RQT); 1110 APMG_CLK_VAL_BSM_CLK_RQT);
1111 udelay(10); 1111 udelay(10);
1112 1112
1113 iwl_set_bits_prph(priv, APMG_PS_CTRL_REG, 1113 iwl3945_set_bits_prph(priv, APMG_PS_CTRL_REG,
1114 APMG_PS_CTRL_VAL_RESET_REQ); 1114 APMG_PS_CTRL_VAL_RESET_REQ);
1115 udelay(5); 1115 udelay(5);
1116 iwl_clear_bits_prph(priv, APMG_PS_CTRL_REG, 1116 iwl3945_clear_bits_prph(priv, APMG_PS_CTRL_REG,
1117 APMG_PS_CTRL_VAL_RESET_REQ); 1117 APMG_PS_CTRL_VAL_RESET_REQ);
1118 iwl_release_nic_access(priv); 1118 iwl3945_release_nic_access(priv);
1119 } 1119 }
1120 1120
1121 /* Clear the 'host command active' bit... */ 1121 /* Clear the 'host command active' bit... */
@@ -1128,43 +1128,43 @@ int iwl_hw_nic_reset(struct iwl_priv *priv)
1128} 1128}
1129 1129
1130/** 1130/**
1131 * iwl_hw_reg_adjust_power_by_temp 1131 * iwl3945_hw_reg_adjust_power_by_temp
1132 * return index delta into power gain settings table 1132 * return index delta into power gain settings table
1133*/ 1133*/
1134static int iwl_hw_reg_adjust_power_by_temp(int new_reading, int old_reading) 1134static int iwl3945_hw_reg_adjust_power_by_temp(int new_reading, int old_reading)
1135{ 1135{
1136 return (new_reading - old_reading) * (-11) / 100; 1136 return (new_reading - old_reading) * (-11) / 100;
1137} 1137}
1138 1138
1139/** 1139/**
1140 * iwl_hw_reg_temp_out_of_range - Keep temperature in sane range 1140 * iwl3945_hw_reg_temp_out_of_range - Keep temperature in sane range
1141 */ 1141 */
1142static inline int iwl_hw_reg_temp_out_of_range(int temperature) 1142static inline int iwl3945_hw_reg_temp_out_of_range(int temperature)
1143{ 1143{
1144 return (((temperature < -260) || (temperature > 25)) ? 1 : 0); 1144 return (((temperature < -260) || (temperature > 25)) ? 1 : 0);
1145} 1145}
1146 1146
1147int iwl_hw_get_temperature(struct iwl_priv *priv) 1147int iwl3945_hw_get_temperature(struct iwl3945_priv *priv)
1148{ 1148{
1149 return iwl_read32(priv, CSR_UCODE_DRV_GP2); 1149 return iwl3945_read32(priv, CSR_UCODE_DRV_GP2);
1150} 1150}
1151 1151
1152/** 1152/**
1153 * iwl_hw_reg_txpower_get_temperature 1153 * iwl3945_hw_reg_txpower_get_temperature
1154 * get the current temperature by reading from NIC 1154 * get the current temperature by reading from NIC
1155*/ 1155*/
1156static int iwl_hw_reg_txpower_get_temperature(struct iwl_priv *priv) 1156static int iwl3945_hw_reg_txpower_get_temperature(struct iwl3945_priv *priv)
1157{ 1157{
1158 int temperature; 1158 int temperature;
1159 1159
1160 temperature = iwl_hw_get_temperature(priv); 1160 temperature = iwl3945_hw_get_temperature(priv);
1161 1161
1162 /* driver's okay range is -260 to +25. 1162 /* driver's okay range is -260 to +25.
1163 * human readable okay range is 0 to +285 */ 1163 * human readable okay range is 0 to +285 */
1164 IWL_DEBUG_INFO("Temperature: %d\n", temperature + IWL_TEMP_CONVERT); 1164 IWL_DEBUG_INFO("Temperature: %d\n", temperature + IWL_TEMP_CONVERT);
1165 1165
1166 /* handle insane temp reading */ 1166 /* handle insane temp reading */
1167 if (iwl_hw_reg_temp_out_of_range(temperature)) { 1167 if (iwl3945_hw_reg_temp_out_of_range(temperature)) {
1168 IWL_ERROR("Error bad temperature value %d\n", temperature); 1168 IWL_ERROR("Error bad temperature value %d\n", temperature);
1169 1169
1170 /* if really really hot(?), 1170 /* if really really hot(?),
@@ -1189,11 +1189,11 @@ static int iwl_hw_reg_txpower_get_temperature(struct iwl_priv *priv)
1189 * records new temperature in tx_mgr->temperature. 1189 * records new temperature in tx_mgr->temperature.
1190 * replaces tx_mgr->last_temperature *only* if calib needed 1190 * replaces tx_mgr->last_temperature *only* if calib needed
1191 * (assumes caller will actually do the calibration!). */ 1191 * (assumes caller will actually do the calibration!). */
1192static int is_temp_calib_needed(struct iwl_priv *priv) 1192static int is_temp_calib_needed(struct iwl3945_priv *priv)
1193{ 1193{
1194 int temp_diff; 1194 int temp_diff;
1195 1195
1196 priv->temperature = iwl_hw_reg_txpower_get_temperature(priv); 1196 priv->temperature = iwl3945_hw_reg_txpower_get_temperature(priv);
1197 temp_diff = priv->temperature - priv->last_temperature; 1197 temp_diff = priv->temperature - priv->last_temperature;
1198 1198
1199 /* get absolute value */ 1199 /* get absolute value */
@@ -1225,7 +1225,7 @@ static int is_temp_calib_needed(struct iwl_priv *priv)
1225 1225
1226/* radio and DSP power table, each step is 1/2 dB. 1226/* radio and DSP power table, each step is 1/2 dB.
1227 * 1st number is for RF analog gain, 2nd number is for DSP pre-DAC gain. */ 1227 * 1st number is for RF analog gain, 2nd number is for DSP pre-DAC gain. */
1228static struct iwl_tx_power power_gain_table[2][IWL_MAX_GAIN_ENTRIES] = { 1228static struct iwl3945_tx_power power_gain_table[2][IWL_MAX_GAIN_ENTRIES] = {
1229 { 1229 {
1230 {251, 127}, /* 2.4 GHz, highest power */ 1230 {251, 127}, /* 2.4 GHz, highest power */
1231 {251, 127}, 1231 {251, 127},
@@ -1386,7 +1386,7 @@ static struct iwl_tx_power power_gain_table[2][IWL_MAX_GAIN_ENTRIES] = {
1386 {3, 120} } /* 5.x GHz, lowest power */ 1386 {3, 120} } /* 5.x GHz, lowest power */
1387}; 1387};
1388 1388
1389static inline u8 iwl_hw_reg_fix_power_index(int index) 1389static inline u8 iwl3945_hw_reg_fix_power_index(int index)
1390{ 1390{
1391 if (index < 0) 1391 if (index < 0)
1392 return 0; 1392 return 0;
@@ -1399,17 +1399,17 @@ static inline u8 iwl_hw_reg_fix_power_index(int index)
1399#define REG_RECALIB_PERIOD (60) 1399#define REG_RECALIB_PERIOD (60)
1400 1400
1401/** 1401/**
1402 * iwl_hw_reg_set_scan_power - Set Tx power for scan probe requests 1402 * iwl3945_hw_reg_set_scan_power - Set Tx power for scan probe requests
1403 * 1403 *
1404 * Set (in our channel info database) the direct scan Tx power for 1 Mbit (CCK) 1404 * Set (in our channel info database) the direct scan Tx power for 1 Mbit (CCK)
1405 * or 6 Mbit (OFDM) rates. 1405 * or 6 Mbit (OFDM) rates.
1406 */ 1406 */
1407static void iwl_hw_reg_set_scan_power(struct iwl_priv *priv, u32 scan_tbl_index, 1407static void iwl3945_hw_reg_set_scan_power(struct iwl3945_priv *priv, u32 scan_tbl_index,
1408 s32 rate_index, const s8 *clip_pwrs, 1408 s32 rate_index, const s8 *clip_pwrs,
1409 struct iwl_channel_info *ch_info, 1409 struct iwl3945_channel_info *ch_info,
1410 int band_index) 1410 int band_index)
1411{ 1411{
1412 struct iwl_scan_power_info *scan_power_info; 1412 struct iwl3945_scan_power_info *scan_power_info;
1413 s8 power; 1413 s8 power;
1414 u8 power_index; 1414 u8 power_index;
1415 1415
@@ -1445,7 +1445,7 @@ static void iwl_hw_reg_set_scan_power(struct iwl_priv *priv, u32 scan_tbl_index,
1445 * of the table. */ 1445 * of the table. */
1446 1446
1447 /* don't exceed table bounds for "real" setting */ 1447 /* don't exceed table bounds for "real" setting */
1448 power_index = iwl_hw_reg_fix_power_index(power_index); 1448 power_index = iwl3945_hw_reg_fix_power_index(power_index);
1449 1449
1450 scan_power_info->power_table_index = power_index; 1450 scan_power_info->power_table_index = power_index;
1451 scan_power_info->tpc.tx_gain = 1451 scan_power_info->tpc.tx_gain =
@@ -1455,21 +1455,21 @@ static void iwl_hw_reg_set_scan_power(struct iwl_priv *priv, u32 scan_tbl_index,
1455} 1455}
1456 1456
1457/** 1457/**
1458 * iwl_hw_reg_send_txpower - fill in Tx Power command with gain settings 1458 * iwl3945_hw_reg_send_txpower - fill in Tx Power command with gain settings
1459 * 1459 *
1460 * Configures power settings for all rates for the current channel, 1460 * Configures power settings for all rates for the current channel,
1461 * using values from channel info struct, and send to NIC 1461 * using values from channel info struct, and send to NIC
1462 */ 1462 */
1463int iwl_hw_reg_send_txpower(struct iwl_priv *priv) 1463int iwl3945_hw_reg_send_txpower(struct iwl3945_priv *priv)
1464{ 1464{
1465 int rate_idx, i; 1465 int rate_idx, i;
1466 const struct iwl_channel_info *ch_info = NULL; 1466 const struct iwl3945_channel_info *ch_info = NULL;
1467 struct iwl_txpowertable_cmd txpower = { 1467 struct iwl3945_txpowertable_cmd txpower = {
1468 .channel = priv->active_rxon.channel, 1468 .channel = priv->active_rxon.channel,
1469 }; 1469 };
1470 1470
1471 txpower.band = (priv->phymode == MODE_IEEE80211A) ? 0 : 1; 1471 txpower.band = (priv->phymode == MODE_IEEE80211A) ? 0 : 1;
1472 ch_info = iwl_get_channel_info(priv, 1472 ch_info = iwl3945_get_channel_info(priv,
1473 priv->phymode, 1473 priv->phymode,
1474 le16_to_cpu(priv->active_rxon.channel)); 1474 le16_to_cpu(priv->active_rxon.channel));
1475 if (!ch_info) { 1475 if (!ch_info) {
@@ -1491,7 +1491,7 @@ int iwl_hw_reg_send_txpower(struct iwl_priv *priv)
1491 rate_idx <= IWL_LAST_OFDM_RATE; rate_idx++, i++) { 1491 rate_idx <= IWL_LAST_OFDM_RATE; rate_idx++, i++) {
1492 1492
1493 txpower.power[i].tpc = ch_info->power_info[i].tpc; 1493 txpower.power[i].tpc = ch_info->power_info[i].tpc;
1494 txpower.power[i].rate = iwl_rates[rate_idx].plcp; 1494 txpower.power[i].rate = iwl3945_rates[rate_idx].plcp;
1495 1495
1496 IWL_DEBUG_POWER("ch %d:%d rf %d dsp %3d rate code 0x%02x\n", 1496 IWL_DEBUG_POWER("ch %d:%d rf %d dsp %3d rate code 0x%02x\n",
1497 le16_to_cpu(txpower.channel), 1497 le16_to_cpu(txpower.channel),
@@ -1504,7 +1504,7 @@ int iwl_hw_reg_send_txpower(struct iwl_priv *priv)
1504 for (rate_idx = IWL_FIRST_CCK_RATE; 1504 for (rate_idx = IWL_FIRST_CCK_RATE;
1505 rate_idx <= IWL_LAST_CCK_RATE; rate_idx++, i++) { 1505 rate_idx <= IWL_LAST_CCK_RATE; rate_idx++, i++) {
1506 txpower.power[i].tpc = ch_info->power_info[i].tpc; 1506 txpower.power[i].tpc = ch_info->power_info[i].tpc;
1507 txpower.power[i].rate = iwl_rates[rate_idx].plcp; 1507 txpower.power[i].rate = iwl3945_rates[rate_idx].plcp;
1508 1508
1509 IWL_DEBUG_POWER("ch %d:%d rf %d dsp %3d rate code 0x%02x\n", 1509 IWL_DEBUG_POWER("ch %d:%d rf %d dsp %3d rate code 0x%02x\n",
1510 le16_to_cpu(txpower.channel), 1510 le16_to_cpu(txpower.channel),
@@ -1514,13 +1514,13 @@ int iwl_hw_reg_send_txpower(struct iwl_priv *priv)
1514 txpower.power[i].rate); 1514 txpower.power[i].rate);
1515 } 1515 }
1516 1516
1517 return iwl_send_cmd_pdu(priv, REPLY_TX_PWR_TABLE_CMD, 1517 return iwl3945_send_cmd_pdu(priv, REPLY_TX_PWR_TABLE_CMD,
1518 sizeof(struct iwl_txpowertable_cmd), &txpower); 1518 sizeof(struct iwl3945_txpowertable_cmd), &txpower);
1519 1519
1520} 1520}
1521 1521
1522/** 1522/**
1523 * iwl_hw_reg_set_new_power - Configures power tables at new levels 1523 * iwl3945_hw_reg_set_new_power - Configures power tables at new levels
1524 * @ch_info: Channel to update. Uses power_info.requested_power. 1524 * @ch_info: Channel to update. Uses power_info.requested_power.
1525 * 1525 *
1526 * Replace requested_power and base_power_index ch_info fields for 1526 * Replace requested_power and base_power_index ch_info fields for
@@ -1535,10 +1535,10 @@ int iwl_hw_reg_send_txpower(struct iwl_priv *priv)
1535 * properly fill out the scan powers, and actual h/w gain settings, 1535 * properly fill out the scan powers, and actual h/w gain settings,
1536 * and send changes to NIC 1536 * and send changes to NIC
1537 */ 1537 */
1538static int iwl_hw_reg_set_new_power(struct iwl_priv *priv, 1538static int iwl3945_hw_reg_set_new_power(struct iwl3945_priv *priv,
1539 struct iwl_channel_info *ch_info) 1539 struct iwl3945_channel_info *ch_info)
1540{ 1540{
1541 struct iwl_channel_power_info *power_info; 1541 struct iwl3945_channel_power_info *power_info;
1542 int power_changed = 0; 1542 int power_changed = 0;
1543 int i; 1543 int i;
1544 const s8 *clip_pwrs; 1544 const s8 *clip_pwrs;
@@ -1578,7 +1578,7 @@ static int iwl_hw_reg_set_new_power(struct iwl_priv *priv,
1578 ch_info->power_info[IWL_RATE_12M_INDEX_TABLE]. 1578 ch_info->power_info[IWL_RATE_12M_INDEX_TABLE].
1579 requested_power + IWL_CCK_FROM_OFDM_POWER_DIFF; 1579 requested_power + IWL_CCK_FROM_OFDM_POWER_DIFF;
1580 1580
1581 /* do all CCK rates' iwl_channel_power_info structures */ 1581 /* do all CCK rates' iwl3945_channel_power_info structures */
1582 for (i = IWL_RATE_1M_INDEX_TABLE; i <= IWL_RATE_11M_INDEX_TABLE; i++) { 1582 for (i = IWL_RATE_1M_INDEX_TABLE; i <= IWL_RATE_11M_INDEX_TABLE; i++) {
1583 power_info->requested_power = power; 1583 power_info->requested_power = power;
1584 power_info->base_power_index = 1584 power_info->base_power_index =
@@ -1592,13 +1592,13 @@ static int iwl_hw_reg_set_new_power(struct iwl_priv *priv,
1592} 1592}
1593 1593
1594/** 1594/**
1595 * iwl_hw_reg_get_ch_txpower_limit - returns new power limit for channel 1595 * iwl3945_hw_reg_get_ch_txpower_limit - returns new power limit for channel
1596 * 1596 *
1597 * NOTE: Returned power limit may be less (but not more) than requested, 1597 * NOTE: Returned power limit may be less (but not more) than requested,
1598 * based strictly on regulatory (eeprom and spectrum mgt) limitations 1598 * based strictly on regulatory (eeprom and spectrum mgt) limitations
1599 * (no consideration for h/w clipping limitations). 1599 * (no consideration for h/w clipping limitations).
1600 */ 1600 */
1601static int iwl_hw_reg_get_ch_txpower_limit(struct iwl_channel_info *ch_info) 1601static int iwl3945_hw_reg_get_ch_txpower_limit(struct iwl3945_channel_info *ch_info)
1602{ 1602{
1603 s8 max_power; 1603 s8 max_power;
1604 1604
@@ -1617,7 +1617,7 @@ static int iwl_hw_reg_get_ch_txpower_limit(struct iwl_channel_info *ch_info)
1617} 1617}
1618 1618
1619/** 1619/**
1620 * iwl_hw_reg_comp_txpower_temp - Compensate for temperature 1620 * iwl3945_hw_reg_comp_txpower_temp - Compensate for temperature
1621 * 1621 *
1622 * Compensate txpower settings of *all* channels for temperature. 1622 * Compensate txpower settings of *all* channels for temperature.
1623 * This only accounts for the difference between current temperature 1623 * This only accounts for the difference between current temperature
@@ -1626,9 +1626,9 @@ static int iwl_hw_reg_get_ch_txpower_limit(struct iwl_channel_info *ch_info)
1626 * 1626 *
1627 * If RxOn is "associated", this sends the new Txpower to NIC! 1627 * If RxOn is "associated", this sends the new Txpower to NIC!
1628 */ 1628 */
1629static int iwl_hw_reg_comp_txpower_temp(struct iwl_priv *priv) 1629static int iwl3945_hw_reg_comp_txpower_temp(struct iwl3945_priv *priv)
1630{ 1630{
1631 struct iwl_channel_info *ch_info = NULL; 1631 struct iwl3945_channel_info *ch_info = NULL;
1632 int delta_index; 1632 int delta_index;
1633 const s8 *clip_pwrs; /* array of h/w max power levels for each rate */ 1633 const s8 *clip_pwrs; /* array of h/w max power levels for each rate */
1634 u8 a_band; 1634 u8 a_band;
@@ -1649,7 +1649,7 @@ static int iwl_hw_reg_comp_txpower_temp(struct iwl_priv *priv)
1649 1649
1650 /* get power index adjustment based on curr and factory 1650 /* get power index adjustment based on curr and factory
1651 * temps */ 1651 * temps */
1652 delta_index = iwl_hw_reg_adjust_power_by_temp(temperature, 1652 delta_index = iwl3945_hw_reg_adjust_power_by_temp(temperature,
1653 ref_temp); 1653 ref_temp);
1654 1654
1655 /* set tx power value for all rates, OFDM and CCK */ 1655 /* set tx power value for all rates, OFDM and CCK */
@@ -1662,7 +1662,7 @@ static int iwl_hw_reg_comp_txpower_temp(struct iwl_priv *priv)
1662 power_idx += delta_index; 1662 power_idx += delta_index;
1663 1663
1664 /* stay within table range */ 1664 /* stay within table range */
1665 power_idx = iwl_hw_reg_fix_power_index(power_idx); 1665 power_idx = iwl3945_hw_reg_fix_power_index(power_idx);
1666 ch_info->power_info[rate_index]. 1666 ch_info->power_info[rate_index].
1667 power_table_index = (u8) power_idx; 1667 power_table_index = (u8) power_idx;
1668 ch_info->power_info[rate_index].tpc = 1668 ch_info->power_info[rate_index].tpc =
@@ -1677,19 +1677,19 @@ static int iwl_hw_reg_comp_txpower_temp(struct iwl_priv *priv)
1677 scan_tbl_index < IWL_NUM_SCAN_RATES; scan_tbl_index++) { 1677 scan_tbl_index < IWL_NUM_SCAN_RATES; scan_tbl_index++) {
1678 s32 actual_index = (scan_tbl_index == 0) ? 1678 s32 actual_index = (scan_tbl_index == 0) ?
1679 IWL_RATE_1M_INDEX_TABLE : IWL_RATE_6M_INDEX_TABLE; 1679 IWL_RATE_1M_INDEX_TABLE : IWL_RATE_6M_INDEX_TABLE;
1680 iwl_hw_reg_set_scan_power(priv, scan_tbl_index, 1680 iwl3945_hw_reg_set_scan_power(priv, scan_tbl_index,
1681 actual_index, clip_pwrs, 1681 actual_index, clip_pwrs,
1682 ch_info, a_band); 1682 ch_info, a_band);
1683 } 1683 }
1684 } 1684 }
1685 1685
1686 /* send Txpower command for current channel to ucode */ 1686 /* send Txpower command for current channel to ucode */
1687 return iwl_hw_reg_send_txpower(priv); 1687 return iwl3945_hw_reg_send_txpower(priv);
1688} 1688}
1689 1689
1690int iwl_hw_reg_set_txpower(struct iwl_priv *priv, s8 power) 1690int iwl3945_hw_reg_set_txpower(struct iwl3945_priv *priv, s8 power)
1691{ 1691{
1692 struct iwl_channel_info *ch_info; 1692 struct iwl3945_channel_info *ch_info;
1693 s8 max_power; 1693 s8 max_power;
1694 u8 a_band; 1694 u8 a_band;
1695 u8 i; 1695 u8 i;
@@ -1711,26 +1711,26 @@ int iwl_hw_reg_set_txpower(struct iwl_priv *priv, s8 power)
1711 1711
1712 /* find minimum power of all user and regulatory constraints 1712 /* find minimum power of all user and regulatory constraints
1713 * (does not consider h/w clipping limitations) */ 1713 * (does not consider h/w clipping limitations) */
1714 max_power = iwl_hw_reg_get_ch_txpower_limit(ch_info); 1714 max_power = iwl3945_hw_reg_get_ch_txpower_limit(ch_info);
1715 max_power = min(power, max_power); 1715 max_power = min(power, max_power);
1716 if (max_power != ch_info->curr_txpow) { 1716 if (max_power != ch_info->curr_txpow) {
1717 ch_info->curr_txpow = max_power; 1717 ch_info->curr_txpow = max_power;
1718 1718
1719 /* this considers the h/w clipping limitations */ 1719 /* this considers the h/w clipping limitations */
1720 iwl_hw_reg_set_new_power(priv, ch_info); 1720 iwl3945_hw_reg_set_new_power(priv, ch_info);
1721 } 1721 }
1722 } 1722 }
1723 1723
1724 /* update txpower settings for all channels, 1724 /* update txpower settings for all channels,
1725 * send to NIC if associated. */ 1725 * send to NIC if associated. */
1726 is_temp_calib_needed(priv); 1726 is_temp_calib_needed(priv);
1727 iwl_hw_reg_comp_txpower_temp(priv); 1727 iwl3945_hw_reg_comp_txpower_temp(priv);
1728 1728
1729 return 0; 1729 return 0;
1730} 1730}
1731 1731
1732/* will add 3945 channel switch cmd handling later */ 1732/* will add 3945 channel switch cmd handling later */
1733int iwl_hw_channel_switch(struct iwl_priv *priv, u16 channel) 1733int iwl3945_hw_channel_switch(struct iwl3945_priv *priv, u16 channel)
1734{ 1734{
1735 return 0; 1735 return 0;
1736} 1736}
@@ -1745,17 +1745,17 @@ int iwl_hw_channel_switch(struct iwl_priv *priv, u16 channel)
1745 * -- send new set of gain settings to NIC 1745 * -- send new set of gain settings to NIC
1746 * NOTE: This should continue working, even when we're not associated, 1746 * NOTE: This should continue working, even when we're not associated,
1747 * so we can keep our internal table of scan powers current. */ 1747 * so we can keep our internal table of scan powers current. */
1748void iwl3945_reg_txpower_periodic(struct iwl_priv *priv) 1748void iwl3945_reg_txpower_periodic(struct iwl3945_priv *priv)
1749{ 1749{
1750 /* This will kick in the "brute force" 1750 /* This will kick in the "brute force"
1751 * iwl_hw_reg_comp_txpower_temp() below */ 1751 * iwl3945_hw_reg_comp_txpower_temp() below */
1752 if (!is_temp_calib_needed(priv)) 1752 if (!is_temp_calib_needed(priv))
1753 goto reschedule; 1753 goto reschedule;
1754 1754
1755 /* Set up a new set of temp-adjusted TxPowers, send to NIC. 1755 /* Set up a new set of temp-adjusted TxPowers, send to NIC.
1756 * This is based *only* on current temperature, 1756 * This is based *only* on current temperature,
1757 * ignoring any previous power measurements */ 1757 * ignoring any previous power measurements */
1758 iwl_hw_reg_comp_txpower_temp(priv); 1758 iwl3945_hw_reg_comp_txpower_temp(priv);
1759 1759
1760 reschedule: 1760 reschedule:
1761 queue_delayed_work(priv->workqueue, 1761 queue_delayed_work(priv->workqueue,
@@ -1764,7 +1764,7 @@ void iwl3945_reg_txpower_periodic(struct iwl_priv *priv)
1764 1764
1765static void iwl3945_bg_reg_txpower_periodic(struct work_struct *work) 1765static void iwl3945_bg_reg_txpower_periodic(struct work_struct *work)
1766{ 1766{
1767 struct iwl_priv *priv = container_of(work, struct iwl_priv, 1767 struct iwl3945_priv *priv = container_of(work, struct iwl3945_priv,
1768 thermal_periodic.work); 1768 thermal_periodic.work);
1769 1769
1770 if (test_bit(STATUS_EXIT_PENDING, &priv->status)) 1770 if (test_bit(STATUS_EXIT_PENDING, &priv->status))
@@ -1776,7 +1776,7 @@ static void iwl3945_bg_reg_txpower_periodic(struct work_struct *work)
1776} 1776}
1777 1777
1778/** 1778/**
1779 * iwl_hw_reg_get_ch_grp_index - find the channel-group index (0-4) 1779 * iwl3945_hw_reg_get_ch_grp_index - find the channel-group index (0-4)
1780 * for the channel. 1780 * for the channel.
1781 * 1781 *
1782 * This function is used when initializing channel-info structs. 1782 * This function is used when initializing channel-info structs.
@@ -1786,10 +1786,10 @@ static void iwl3945_bg_reg_txpower_periodic(struct work_struct *work)
1786 * on A-band, EEPROM's "group frequency" entries represent the top 1786 * on A-band, EEPROM's "group frequency" entries represent the top
1787 * channel in each group 1-4. Group 5 All B/G channels are in group 0. 1787 * channel in each group 1-4. Group 5 All B/G channels are in group 0.
1788 */ 1788 */
1789static u16 iwl_hw_reg_get_ch_grp_index(struct iwl_priv *priv, 1789static u16 iwl3945_hw_reg_get_ch_grp_index(struct iwl3945_priv *priv,
1790 const struct iwl_channel_info *ch_info) 1790 const struct iwl3945_channel_info *ch_info)
1791{ 1791{
1792 struct iwl_eeprom_txpower_group *ch_grp = &priv->eeprom.groups[0]; 1792 struct iwl3945_eeprom_txpower_group *ch_grp = &priv->eeprom.groups[0];
1793 u8 group; 1793 u8 group;
1794 u16 group_index = 0; /* based on factory calib frequencies */ 1794 u16 group_index = 0; /* based on factory calib frequencies */
1795 u8 grp_channel; 1795 u8 grp_channel;
@@ -1815,20 +1815,20 @@ static u16 iwl_hw_reg_get_ch_grp_index(struct iwl_priv *priv,
1815} 1815}
1816 1816
1817/** 1817/**
1818 * iwl_hw_reg_get_matched_power_index - Interpolate to get nominal index 1818 * iwl3945_hw_reg_get_matched_power_index - Interpolate to get nominal index
1819 * 1819 *
1820 * Interpolate to get nominal (i.e. at factory calibration temperature) index 1820 * Interpolate to get nominal (i.e. at factory calibration temperature) index
1821 * into radio/DSP gain settings table for requested power. 1821 * into radio/DSP gain settings table for requested power.
1822 */ 1822 */
1823static int iwl_hw_reg_get_matched_power_index(struct iwl_priv *priv, 1823static int iwl3945_hw_reg_get_matched_power_index(struct iwl3945_priv *priv,
1824 s8 requested_power, 1824 s8 requested_power,
1825 s32 setting_index, s32 *new_index) 1825 s32 setting_index, s32 *new_index)
1826{ 1826{
1827 const struct iwl_eeprom_txpower_group *chnl_grp = NULL; 1827 const struct iwl3945_eeprom_txpower_group *chnl_grp = NULL;
1828 s32 index0, index1; 1828 s32 index0, index1;
1829 s32 power = 2 * requested_power; 1829 s32 power = 2 * requested_power;
1830 s32 i; 1830 s32 i;
1831 const struct iwl_eeprom_txpower_sample *samples; 1831 const struct iwl3945_eeprom_txpower_sample *samples;
1832 s32 gains0, gains1; 1832 s32 gains0, gains1;
1833 s32 res; 1833 s32 res;
1834 s32 denominator; 1834 s32 denominator;
@@ -1868,11 +1868,11 @@ static int iwl_hw_reg_get_matched_power_index(struct iwl_priv *priv,
1868 return 0; 1868 return 0;
1869} 1869}
1870 1870
1871static void iwl_hw_reg_init_channel_groups(struct iwl_priv *priv) 1871static void iwl3945_hw_reg_init_channel_groups(struct iwl3945_priv *priv)
1872{ 1872{
1873 u32 i; 1873 u32 i;
1874 s32 rate_index; 1874 s32 rate_index;
1875 const struct iwl_eeprom_txpower_group *group; 1875 const struct iwl3945_eeprom_txpower_group *group;
1876 1876
1877 IWL_DEBUG_POWER("Initializing factory calib info from EEPROM\n"); 1877 IWL_DEBUG_POWER("Initializing factory calib info from EEPROM\n");
1878 1878
@@ -1948,10 +1948,10 @@ static void iwl_hw_reg_init_channel_groups(struct iwl_priv *priv)
1948 * 1948 *
1949 * This does *not* write values to NIC, just sets up our internal table. 1949 * This does *not* write values to NIC, just sets up our internal table.
1950 */ 1950 */
1951int iwl3945_txpower_set_from_eeprom(struct iwl_priv *priv) 1951int iwl3945_txpower_set_from_eeprom(struct iwl3945_priv *priv)
1952{ 1952{
1953 struct iwl_channel_info *ch_info = NULL; 1953 struct iwl3945_channel_info *ch_info = NULL;
1954 struct iwl_channel_power_info *pwr_info; 1954 struct iwl3945_channel_power_info *pwr_info;
1955 int delta_index; 1955 int delta_index;
1956 u8 rate_index; 1956 u8 rate_index;
1957 u8 scan_tbl_index; 1957 u8 scan_tbl_index;
@@ -1964,10 +1964,10 @@ int iwl3945_txpower_set_from_eeprom(struct iwl_priv *priv)
1964 1964
1965 /* save temperature reference, 1965 /* save temperature reference,
1966 * so we can determine next time to calibrate */ 1966 * so we can determine next time to calibrate */
1967 temperature = iwl_hw_reg_txpower_get_temperature(priv); 1967 temperature = iwl3945_hw_reg_txpower_get_temperature(priv);
1968 priv->last_temperature = temperature; 1968 priv->last_temperature = temperature;
1969 1969
1970 iwl_hw_reg_init_channel_groups(priv); 1970 iwl3945_hw_reg_init_channel_groups(priv);
1971 1971
1972 /* initialize Tx power info for each and every channel, 2.4 and 5.x */ 1972 /* initialize Tx power info for each and every channel, 2.4 and 5.x */
1973 for (i = 0, ch_info = priv->channel_info; i < priv->channel_count; 1973 for (i = 0, ch_info = priv->channel_info; i < priv->channel_count;
@@ -1978,14 +1978,14 @@ int iwl3945_txpower_set_from_eeprom(struct iwl_priv *priv)
1978 1978
1979 /* find this channel's channel group (*not* "band") index */ 1979 /* find this channel's channel group (*not* "band") index */
1980 ch_info->group_index = 1980 ch_info->group_index =
1981 iwl_hw_reg_get_ch_grp_index(priv, ch_info); 1981 iwl3945_hw_reg_get_ch_grp_index(priv, ch_info);
1982 1982
1983 /* Get this chnlgrp's rate->max/clip-powers table */ 1983 /* Get this chnlgrp's rate->max/clip-powers table */
1984 clip_pwrs = priv->clip_groups[ch_info->group_index].clip_powers; 1984 clip_pwrs = priv->clip_groups[ch_info->group_index].clip_powers;
1985 1985
1986 /* calculate power index *adjustment* value according to 1986 /* calculate power index *adjustment* value according to
1987 * diff between current temperature and factory temperature */ 1987 * diff between current temperature and factory temperature */
1988 delta_index = iwl_hw_reg_adjust_power_by_temp(temperature, 1988 delta_index = iwl3945_hw_reg_adjust_power_by_temp(temperature,
1989 priv->eeprom.groups[ch_info->group_index]. 1989 priv->eeprom.groups[ch_info->group_index].
1990 temperature); 1990 temperature);
1991 1991
@@ -2008,7 +2008,7 @@ int iwl3945_txpower_set_from_eeprom(struct iwl_priv *priv)
2008 2008
2009 /* get base (i.e. at factory-measured temperature) 2009 /* get base (i.e. at factory-measured temperature)
2010 * power table index for this rate's power */ 2010 * power table index for this rate's power */
2011 rc = iwl_hw_reg_get_matched_power_index(priv, pwr, 2011 rc = iwl3945_hw_reg_get_matched_power_index(priv, pwr,
2012 ch_info->group_index, 2012 ch_info->group_index,
2013 &power_idx); 2013 &power_idx);
2014 if (rc) { 2014 if (rc) {
@@ -2021,9 +2021,9 @@ int iwl3945_txpower_set_from_eeprom(struct iwl_priv *priv)
2021 power_idx += delta_index; 2021 power_idx += delta_index;
2022 2022
2023 /* stay within range of gain table */ 2023 /* stay within range of gain table */
2024 power_idx = iwl_hw_reg_fix_power_index(power_idx); 2024 power_idx = iwl3945_hw_reg_fix_power_index(power_idx);
2025 2025
2026 /* fill 1 OFDM rate's iwl_channel_power_info struct */ 2026 /* fill 1 OFDM rate's iwl3945_channel_power_info struct */
2027 pwr_info->requested_power = pwr; 2027 pwr_info->requested_power = pwr;
2028 pwr_info->power_table_index = (u8) power_idx; 2028 pwr_info->power_table_index = (u8) power_idx;
2029 pwr_info->tpc.tx_gain = 2029 pwr_info->tpc.tx_gain =
@@ -2042,11 +2042,11 @@ int iwl3945_txpower_set_from_eeprom(struct iwl_priv *priv)
2042 IWL_CCK_FROM_OFDM_INDEX_DIFF; 2042 IWL_CCK_FROM_OFDM_INDEX_DIFF;
2043 2043
2044 /* stay within table range */ 2044 /* stay within table range */
2045 pwr_index = iwl_hw_reg_fix_power_index(pwr_index); 2045 pwr_index = iwl3945_hw_reg_fix_power_index(pwr_index);
2046 gain = power_gain_table[a_band][pwr_index].tx_gain; 2046 gain = power_gain_table[a_band][pwr_index].tx_gain;
2047 dsp_atten = power_gain_table[a_band][pwr_index].dsp_atten; 2047 dsp_atten = power_gain_table[a_band][pwr_index].dsp_atten;
2048 2048
2049 /* fill each CCK rate's iwl_channel_power_info structure 2049 /* fill each CCK rate's iwl3945_channel_power_info structure
2050 * NOTE: All CCK-rate Txpwrs are the same for a given chnl! 2050 * NOTE: All CCK-rate Txpwrs are the same for a given chnl!
2051 * NOTE: CCK rates start at end of OFDM rates! */ 2051 * NOTE: CCK rates start at end of OFDM rates! */
2052 for (rate_index = 0; 2052 for (rate_index = 0;
@@ -2064,7 +2064,7 @@ int iwl3945_txpower_set_from_eeprom(struct iwl_priv *priv)
2064 scan_tbl_index < IWL_NUM_SCAN_RATES; scan_tbl_index++) { 2064 scan_tbl_index < IWL_NUM_SCAN_RATES; scan_tbl_index++) {
2065 s32 actual_index = (scan_tbl_index == 0) ? 2065 s32 actual_index = (scan_tbl_index == 0) ?
2066 IWL_RATE_1M_INDEX_TABLE : IWL_RATE_6M_INDEX_TABLE; 2066 IWL_RATE_1M_INDEX_TABLE : IWL_RATE_6M_INDEX_TABLE;
2067 iwl_hw_reg_set_scan_power(priv, scan_tbl_index, 2067 iwl3945_hw_reg_set_scan_power(priv, scan_tbl_index,
2068 actual_index, clip_pwrs, ch_info, a_band); 2068 actual_index, clip_pwrs, ch_info, a_band);
2069 } 2069 }
2070 } 2070 }
@@ -2072,66 +2072,66 @@ int iwl3945_txpower_set_from_eeprom(struct iwl_priv *priv)
2072 return 0; 2072 return 0;
2073} 2073}
2074 2074
2075int iwl_hw_rxq_stop(struct iwl_priv *priv) 2075int iwl3945_hw_rxq_stop(struct iwl3945_priv *priv)
2076{ 2076{
2077 int rc; 2077 int rc;
2078 unsigned long flags; 2078 unsigned long flags;
2079 2079
2080 spin_lock_irqsave(&priv->lock, flags); 2080 spin_lock_irqsave(&priv->lock, flags);
2081 rc = iwl_grab_nic_access(priv); 2081 rc = iwl3945_grab_nic_access(priv);
2082 if (rc) { 2082 if (rc) {
2083 spin_unlock_irqrestore(&priv->lock, flags); 2083 spin_unlock_irqrestore(&priv->lock, flags);
2084 return rc; 2084 return rc;
2085 } 2085 }
2086 2086
2087 iwl_write_direct32(priv, FH_RCSR_CONFIG(0), 0); 2087 iwl3945_write_direct32(priv, FH_RCSR_CONFIG(0), 0);
2088 rc = iwl_poll_direct_bit(priv, FH_RSSR_STATUS, (1 << 24), 1000); 2088 rc = iwl3945_poll_direct_bit(priv, FH_RSSR_STATUS, (1 << 24), 1000);
2089 if (rc < 0) 2089 if (rc < 0)
2090 IWL_ERROR("Can't stop Rx DMA.\n"); 2090 IWL_ERROR("Can't stop Rx DMA.\n");
2091 2091
2092 iwl_release_nic_access(priv); 2092 iwl3945_release_nic_access(priv);
2093 spin_unlock_irqrestore(&priv->lock, flags); 2093 spin_unlock_irqrestore(&priv->lock, flags);
2094 2094
2095 return 0; 2095 return 0;
2096} 2096}
2097 2097
2098int iwl_hw_tx_queue_init(struct iwl_priv *priv, struct iwl_tx_queue *txq) 2098int iwl3945_hw_tx_queue_init(struct iwl3945_priv *priv, struct iwl3945_tx_queue *txq)
2099{ 2099{
2100 int rc; 2100 int rc;
2101 unsigned long flags; 2101 unsigned long flags;
2102 int txq_id = txq->q.id; 2102 int txq_id = txq->q.id;
2103 2103
2104 struct iwl_shared *shared_data = priv->hw_setting.shared_virt; 2104 struct iwl3945_shared *shared_data = priv->hw_setting.shared_virt;
2105 2105
2106 shared_data->tx_base_ptr[txq_id] = cpu_to_le32((u32)txq->q.dma_addr); 2106 shared_data->tx_base_ptr[txq_id] = cpu_to_le32((u32)txq->q.dma_addr);
2107 2107
2108 spin_lock_irqsave(&priv->lock, flags); 2108 spin_lock_irqsave(&priv->lock, flags);
2109 rc = iwl_grab_nic_access(priv); 2109 rc = iwl3945_grab_nic_access(priv);
2110 if (rc) { 2110 if (rc) {
2111 spin_unlock_irqrestore(&priv->lock, flags); 2111 spin_unlock_irqrestore(&priv->lock, flags);
2112 return rc; 2112 return rc;
2113 } 2113 }
2114 iwl_write_direct32(priv, FH_CBCC_CTRL(txq_id), 0); 2114 iwl3945_write_direct32(priv, FH_CBCC_CTRL(txq_id), 0);
2115 iwl_write_direct32(priv, FH_CBCC_BASE(txq_id), 0); 2115 iwl3945_write_direct32(priv, FH_CBCC_BASE(txq_id), 0);
2116 2116
2117 iwl_write_direct32(priv, FH_TCSR_CONFIG(txq_id), 2117 iwl3945_write_direct32(priv, FH_TCSR_CONFIG(txq_id),
2118 ALM_FH_TCSR_TX_CONFIG_REG_VAL_CIRQ_RTC_NOINT | 2118 ALM_FH_TCSR_TX_CONFIG_REG_VAL_CIRQ_RTC_NOINT |
2119 ALM_FH_TCSR_TX_CONFIG_REG_VAL_MSG_MODE_TXF | 2119 ALM_FH_TCSR_TX_CONFIG_REG_VAL_MSG_MODE_TXF |
2120 ALM_FH_TCSR_TX_CONFIG_REG_VAL_CIRQ_HOST_IFTFD | 2120 ALM_FH_TCSR_TX_CONFIG_REG_VAL_CIRQ_HOST_IFTFD |
2121 ALM_FH_TCSR_TX_CONFIG_REG_VAL_DMA_CREDIT_ENABLE_VAL | 2121 ALM_FH_TCSR_TX_CONFIG_REG_VAL_DMA_CREDIT_ENABLE_VAL |
2122 ALM_FH_TCSR_TX_CONFIG_REG_VAL_DMA_CHNL_ENABLE); 2122 ALM_FH_TCSR_TX_CONFIG_REG_VAL_DMA_CHNL_ENABLE);
2123 iwl_release_nic_access(priv); 2123 iwl3945_release_nic_access(priv);
2124 2124
2125 /* fake read to flush all prev. writes */ 2125 /* fake read to flush all prev. writes */
2126 iwl_read32(priv, FH_TSSR_CBB_BASE); 2126 iwl3945_read32(priv, FH_TSSR_CBB_BASE);
2127 spin_unlock_irqrestore(&priv->lock, flags); 2127 spin_unlock_irqrestore(&priv->lock, flags);
2128 2128
2129 return 0; 2129 return 0;
2130} 2130}
2131 2131
2132int iwl_hw_get_rx_read(struct iwl_priv *priv) 2132int iwl3945_hw_get_rx_read(struct iwl3945_priv *priv)
2133{ 2133{
2134 struct iwl_shared *shared_data = priv->hw_setting.shared_virt; 2134 struct iwl3945_shared *shared_data = priv->hw_setting.shared_virt;
2135 2135
2136 return le32_to_cpu(shared_data->rx_read_ptr[0]); 2136 return le32_to_cpu(shared_data->rx_read_ptr[0]);
2137} 2137}
@@ -2139,22 +2139,22 @@ int iwl_hw_get_rx_read(struct iwl_priv *priv)
2139/** 2139/**
2140 * iwl3945_init_hw_rate_table - Initialize the hardware rate fallback table 2140 * iwl3945_init_hw_rate_table - Initialize the hardware rate fallback table
2141 */ 2141 */
2142int iwl3945_init_hw_rate_table(struct iwl_priv *priv) 2142int iwl3945_init_hw_rate_table(struct iwl3945_priv *priv)
2143{ 2143{
2144 int rc, i, index, prev_index; 2144 int rc, i, index, prev_index;
2145 struct iwl_rate_scaling_cmd rate_cmd = { 2145 struct iwl3945_rate_scaling_cmd rate_cmd = {
2146 .reserved = {0, 0, 0}, 2146 .reserved = {0, 0, 0},
2147 }; 2147 };
2148 struct iwl_rate_scaling_info *table = rate_cmd.table; 2148 struct iwl3945_rate_scaling_info *table = rate_cmd.table;
2149 2149
2150 for (i = 0; i < ARRAY_SIZE(iwl_rates); i++) { 2150 for (i = 0; i < ARRAY_SIZE(iwl3945_rates); i++) {
2151 index = iwl_rates[i].table_rs_index; 2151 index = iwl3945_rates[i].table_rs_index;
2152 2152
2153 table[index].rate_n_flags = 2153 table[index].rate_n_flags =
2154 iwl_hw_set_rate_n_flags(iwl_rates[i].plcp, 0); 2154 iwl3945_hw_set_rate_n_flags(iwl3945_rates[i].plcp, 0);
2155 table[index].try_cnt = priv->retry_rate; 2155 table[index].try_cnt = priv->retry_rate;
2156 prev_index = iwl_get_prev_ieee_rate(i); 2156 prev_index = iwl3945_get_prev_ieee_rate(i);
2157 table[index].next_rate_index = iwl_rates[prev_index].table_rs_index; 2157 table[index].next_rate_index = iwl3945_rates[prev_index].table_rs_index;
2158 } 2158 }
2159 2159
2160 switch (priv->phymode) { 2160 switch (priv->phymode) {
@@ -2163,14 +2163,14 @@ int iwl3945_init_hw_rate_table(struct iwl_priv *priv)
2163 /* If one of the following CCK rates is used, 2163 /* If one of the following CCK rates is used,
2164 * have it fall back to the 6M OFDM rate */ 2164 * have it fall back to the 6M OFDM rate */
2165 for (i = IWL_RATE_1M_INDEX_TABLE; i <= IWL_RATE_11M_INDEX_TABLE; i++) 2165 for (i = IWL_RATE_1M_INDEX_TABLE; i <= IWL_RATE_11M_INDEX_TABLE; i++)
2166 table[i].next_rate_index = iwl_rates[IWL_FIRST_OFDM_RATE].table_rs_index; 2166 table[i].next_rate_index = iwl3945_rates[IWL_FIRST_OFDM_RATE].table_rs_index;
2167 2167
2168 /* Don't fall back to CCK rates */ 2168 /* Don't fall back to CCK rates */
2169 table[IWL_RATE_12M_INDEX_TABLE].next_rate_index = IWL_RATE_9M_INDEX_TABLE; 2169 table[IWL_RATE_12M_INDEX_TABLE].next_rate_index = IWL_RATE_9M_INDEX_TABLE;
2170 2170
2171 /* Don't drop out of OFDM rates */ 2171 /* Don't drop out of OFDM rates */
2172 table[IWL_RATE_6M_INDEX_TABLE].next_rate_index = 2172 table[IWL_RATE_6M_INDEX_TABLE].next_rate_index =
2173 iwl_rates[IWL_FIRST_OFDM_RATE].table_rs_index; 2173 iwl3945_rates[IWL_FIRST_OFDM_RATE].table_rs_index;
2174 break; 2174 break;
2175 2175
2176 case MODE_IEEE80211B: 2176 case MODE_IEEE80211B:
@@ -2178,7 +2178,7 @@ int iwl3945_init_hw_rate_table(struct iwl_priv *priv)
2178 /* If an OFDM rate is used, have it fall back to the 2178 /* If an OFDM rate is used, have it fall back to the
2179 * 1M CCK rates */ 2179 * 1M CCK rates */
2180 for (i = IWL_RATE_6M_INDEX_TABLE; i <= IWL_RATE_54M_INDEX_TABLE; i++) 2180 for (i = IWL_RATE_6M_INDEX_TABLE; i <= IWL_RATE_54M_INDEX_TABLE; i++)
2181 table[i].next_rate_index = iwl_rates[IWL_FIRST_CCK_RATE].table_rs_index; 2181 table[i].next_rate_index = iwl3945_rates[IWL_FIRST_CCK_RATE].table_rs_index;
2182 2182
2183 /* CCK shouldn't fall back to OFDM... */ 2183 /* CCK shouldn't fall back to OFDM... */
2184 table[IWL_RATE_11M_INDEX_TABLE].next_rate_index = IWL_RATE_5M_INDEX_TABLE; 2184 table[IWL_RATE_11M_INDEX_TABLE].next_rate_index = IWL_RATE_5M_INDEX_TABLE;
@@ -2191,25 +2191,25 @@ int iwl3945_init_hw_rate_table(struct iwl_priv *priv)
2191 2191
2192 /* Update the rate scaling for control frame Tx */ 2192 /* Update the rate scaling for control frame Tx */
2193 rate_cmd.table_id = 0; 2193 rate_cmd.table_id = 0;
2194 rc = iwl_send_cmd_pdu(priv, REPLY_RATE_SCALE, sizeof(rate_cmd), 2194 rc = iwl3945_send_cmd_pdu(priv, REPLY_RATE_SCALE, sizeof(rate_cmd),
2195 &rate_cmd); 2195 &rate_cmd);
2196 if (rc) 2196 if (rc)
2197 return rc; 2197 return rc;
2198 2198
2199 /* Update the rate scaling for data frame Tx */ 2199 /* Update the rate scaling for data frame Tx */
2200 rate_cmd.table_id = 1; 2200 rate_cmd.table_id = 1;
2201 return iwl_send_cmd_pdu(priv, REPLY_RATE_SCALE, sizeof(rate_cmd), 2201 return iwl3945_send_cmd_pdu(priv, REPLY_RATE_SCALE, sizeof(rate_cmd),
2202 &rate_cmd); 2202 &rate_cmd);
2203} 2203}
2204 2204
2205int iwl_hw_set_hw_setting(struct iwl_priv *priv) 2205int iwl3945_hw_set_hw_setting(struct iwl3945_priv *priv)
2206{ 2206{
2207 memset((void *)&priv->hw_setting, 0, 2207 memset((void *)&priv->hw_setting, 0,
2208 sizeof(struct iwl_driver_hw_info)); 2208 sizeof(struct iwl3945_driver_hw_info));
2209 2209
2210 priv->hw_setting.shared_virt = 2210 priv->hw_setting.shared_virt =
2211 pci_alloc_consistent(priv->pci_dev, 2211 pci_alloc_consistent(priv->pci_dev,
2212 sizeof(struct iwl_shared), 2212 sizeof(struct iwl3945_shared),
2213 &priv->hw_setting.shared_phys); 2213 &priv->hw_setting.shared_phys);
2214 2214
2215 if (!priv->hw_setting.shared_virt) { 2215 if (!priv->hw_setting.shared_virt) {
@@ -2220,7 +2220,7 @@ int iwl_hw_set_hw_setting(struct iwl_priv *priv)
2220 2220
2221 priv->hw_setting.ac_queue_count = AC_NUM; 2221 priv->hw_setting.ac_queue_count = AC_NUM;
2222 priv->hw_setting.rx_buffer_size = IWL_RX_BUF_SIZE; 2222 priv->hw_setting.rx_buffer_size = IWL_RX_BUF_SIZE;
2223 priv->hw_setting.tx_cmd_len = sizeof(struct iwl_tx_cmd); 2223 priv->hw_setting.tx_cmd_len = sizeof(struct iwl3945_tx_cmd);
2224 priv->hw_setting.max_rxq_size = RX_QUEUE_SIZE; 2224 priv->hw_setting.max_rxq_size = RX_QUEUE_SIZE;
2225 priv->hw_setting.max_rxq_log = RX_QUEUE_SIZE_LOG; 2225 priv->hw_setting.max_rxq_log = RX_QUEUE_SIZE_LOG;
2226 priv->hw_setting.max_stations = IWL3945_STATION_COUNT; 2226 priv->hw_setting.max_stations = IWL3945_STATION_COUNT;
@@ -2228,21 +2228,21 @@ int iwl_hw_set_hw_setting(struct iwl_priv *priv)
2228 return 0; 2228 return 0;
2229} 2229}
2230 2230
2231unsigned int iwl_hw_get_beacon_cmd(struct iwl_priv *priv, 2231unsigned int iwl3945_hw_get_beacon_cmd(struct iwl3945_priv *priv,
2232 struct iwl_frame *frame, u8 rate) 2232 struct iwl3945_frame *frame, u8 rate)
2233{ 2233{
2234 struct iwl_tx_beacon_cmd *tx_beacon_cmd; 2234 struct iwl3945_tx_beacon_cmd *tx_beacon_cmd;
2235 unsigned int frame_size; 2235 unsigned int frame_size;
2236 2236
2237 tx_beacon_cmd = (struct iwl_tx_beacon_cmd *)&frame->u; 2237 tx_beacon_cmd = (struct iwl3945_tx_beacon_cmd *)&frame->u;
2238 memset(tx_beacon_cmd, 0, sizeof(*tx_beacon_cmd)); 2238 memset(tx_beacon_cmd, 0, sizeof(*tx_beacon_cmd));
2239 2239
2240 tx_beacon_cmd->tx.sta_id = IWL3945_BROADCAST_ID; 2240 tx_beacon_cmd->tx.sta_id = IWL3945_BROADCAST_ID;
2241 tx_beacon_cmd->tx.stop_time.life_time = TX_CMD_LIFE_TIME_INFINITE; 2241 tx_beacon_cmd->tx.stop_time.life_time = TX_CMD_LIFE_TIME_INFINITE;
2242 2242
2243 frame_size = iwl_fill_beacon_frame(priv, 2243 frame_size = iwl3945_fill_beacon_frame(priv,
2244 tx_beacon_cmd->frame, 2244 tx_beacon_cmd->frame,
2245 BROADCAST_ADDR, 2245 iwl3945_broadcast_addr,
2246 sizeof(frame->u) - sizeof(*tx_beacon_cmd)); 2246 sizeof(frame->u) - sizeof(*tx_beacon_cmd));
2247 2247
2248 BUG_ON(frame_size > MAX_MPDU_SIZE); 2248 BUG_ON(frame_size > MAX_MPDU_SIZE);
@@ -2259,35 +2259,35 @@ unsigned int iwl_hw_get_beacon_cmd(struct iwl_priv *priv,
2259 tx_beacon_cmd->tx.supp_rates[1] = 2259 tx_beacon_cmd->tx.supp_rates[1] =
2260 (IWL_CCK_BASIC_RATES_MASK & 0xF); 2260 (IWL_CCK_BASIC_RATES_MASK & 0xF);
2261 2261
2262 return (sizeof(struct iwl_tx_beacon_cmd) + frame_size); 2262 return (sizeof(struct iwl3945_tx_beacon_cmd) + frame_size);
2263} 2263}
2264 2264
2265void iwl_hw_rx_handler_setup(struct iwl_priv *priv) 2265void iwl3945_hw_rx_handler_setup(struct iwl3945_priv *priv)
2266{ 2266{
2267 priv->rx_handlers[REPLY_3945_RX] = iwl3945_rx_reply_rx; 2267 priv->rx_handlers[REPLY_3945_RX] = iwl3945_rx_reply_rx;
2268} 2268}
2269 2269
2270void iwl_hw_setup_deferred_work(struct iwl_priv *priv) 2270void iwl3945_hw_setup_deferred_work(struct iwl3945_priv *priv)
2271{ 2271{
2272 INIT_DELAYED_WORK(&priv->thermal_periodic, 2272 INIT_DELAYED_WORK(&priv->thermal_periodic,
2273 iwl3945_bg_reg_txpower_periodic); 2273 iwl3945_bg_reg_txpower_periodic);
2274} 2274}
2275 2275
2276void iwl_hw_cancel_deferred_work(struct iwl_priv *priv) 2276void iwl3945_hw_cancel_deferred_work(struct iwl3945_priv *priv)
2277{ 2277{
2278 cancel_delayed_work(&priv->thermal_periodic); 2278 cancel_delayed_work(&priv->thermal_periodic);
2279} 2279}
2280 2280
2281struct pci_device_id iwl_hw_card_ids[] = { 2281struct pci_device_id iwl3945_hw_card_ids[] = {
2282 {PCI_DEVICE(PCI_VENDOR_ID_INTEL, 0x4222)}, 2282 {PCI_DEVICE(PCI_VENDOR_ID_INTEL, 0x4222)},
2283 {PCI_DEVICE(PCI_VENDOR_ID_INTEL, 0x4227)}, 2283 {PCI_DEVICE(PCI_VENDOR_ID_INTEL, 0x4227)},
2284 {0} 2284 {0}
2285}; 2285};
2286 2286
2287inline int iwl_eeprom_acquire_semaphore(struct iwl_priv *priv) 2287inline int iwl3945_eeprom_acquire_semaphore(struct iwl3945_priv *priv)
2288{ 2288{
2289 _iwl_clear_bit(priv, CSR_EEPROM_GP, CSR_EEPROM_GP_IF_OWNER_MSK); 2289 _iwl3945_clear_bit(priv, CSR_EEPROM_GP, CSR_EEPROM_GP_IF_OWNER_MSK);
2290 return 0; 2290 return 0;
2291} 2291}
2292 2292
2293MODULE_DEVICE_TABLE(pci, iwl_hw_card_ids); 2293MODULE_DEVICE_TABLE(pci, iwl3945_hw_card_ids);