aboutsummaryrefslogtreecommitdiffstats
path: root/drivers
diff options
context:
space:
mode:
authorStanislaw Gruszka <sgruszka@redhat.com>2011-10-24 10:49:25 -0400
committerStanislaw Gruszka <sgruszka@redhat.com>2011-11-15 05:17:00 -0500
commit46bc8d4b0e73ac75de323646d75a2333f47b84c3 (patch)
treea11a89b1a3480135e1510aacd5909485ab2e5be7 /drivers
parente2ebc8337d116acdc25469ec8547ae665f50a4c1 (diff)
iwlegacy: rename priv to il
Make code shorter. Signed-off-by: Stanislaw Gruszka <sgruszka@redhat.com>
Diffstat (limited to 'drivers')
-rw-r--r--drivers/net/wireless/iwlegacy/iwl-3945-debugfs.c90
-rw-r--r--drivers/net/wireless/iwlegacy/iwl-3945-led.c4
-rw-r--r--drivers/net/wireless/iwlegacy/iwl-3945-rs.c156
-rw-r--r--drivers/net/wireless/iwlegacy/iwl-3945.c786
-rw-r--r--drivers/net/wireless/iwlegacy/iwl-3945.h78
-rw-r--r--drivers/net/wireless/iwlegacy/iwl-4965-calib.c220
-rw-r--r--drivers/net/wireless/iwlegacy/iwl-4965-calib.h10
-rw-r--r--drivers/net/wireless/iwlegacy/iwl-4965-debugfs.c92
-rw-r--r--drivers/net/wireless/iwlegacy/iwl-4965-eeprom.c34
-rw-r--r--drivers/net/wireless/iwlegacy/iwl-4965-led.c12
-rw-r--r--drivers/net/wireless/iwlegacy/iwl-4965-led.h2
-rw-r--r--drivers/net/wireless/iwlegacy/iwl-4965-lib.c378
-rw-r--r--drivers/net/wireless/iwlegacy/iwl-4965-rs.c372
-rw-r--r--drivers/net/wireless/iwlegacy/iwl-4965-rx.c74
-rw-r--r--drivers/net/wireless/iwlegacy/iwl-4965-sta.c390
-rw-r--r--drivers/net/wireless/iwlegacy/iwl-4965-tx.c472
-rw-r--r--drivers/net/wireless/iwlegacy/iwl-4965-ucode.c54
-rw-r--r--drivers/net/wireless/iwlegacy/iwl-4965.c680
-rw-r--r--drivers/net/wireless/iwlegacy/iwl-4965.h120
-rw-r--r--drivers/net/wireless/iwlegacy/iwl-core.c1016
-rw-r--r--drivers/net/wireless/iwlegacy/iwl-core.h264
-rw-r--r--drivers/net/wireless/iwlegacy/iwl-debug.h16
-rw-r--r--drivers/net/wireless/iwlegacy/iwl-debugfs.c338
-rw-r--r--drivers/net/wireless/iwlegacy/iwl-dev.h62
-rw-r--r--drivers/net/wireless/iwlegacy/iwl-eeprom.c158
-rw-r--r--drivers/net/wireless/iwlegacy/iwl-eeprom.h18
-rw-r--r--drivers/net/wireless/iwlegacy/iwl-hcmd.c72
-rw-r--r--drivers/net/wireless/iwlegacy/iwl-helpers.h50
-rw-r--r--drivers/net/wireless/iwlegacy/iwl-io.h324
-rw-r--r--drivers/net/wireless/iwlegacy/iwl-led.c72
-rw-r--r--drivers/net/wireless/iwlegacy/iwl-led.h4
-rw-r--r--drivers/net/wireless/iwlegacy/iwl-legacy-rs.h12
-rw-r--r--drivers/net/wireless/iwlegacy/iwl-power.c76
-rw-r--r--drivers/net/wireless/iwlegacy/iwl-power.h6
-rw-r--r--drivers/net/wireless/iwlegacy/iwl-rx.c42
-rw-r--r--drivers/net/wireless/iwlegacy/iwl-scan.c272
-rw-r--r--drivers/net/wireless/iwlegacy/iwl-sta.c388
-rw-r--r--drivers/net/wireless/iwlegacy/iwl-sta.h38
-rw-r--r--drivers/net/wireless/iwlegacy/iwl-tx.c168
-rw-r--r--drivers/net/wireless/iwlegacy/iwl3945-base.c1868
-rw-r--r--drivers/net/wireless/iwlegacy/iwl4965-base.c1750
41 files changed, 5518 insertions, 5520 deletions
diff --git a/drivers/net/wireless/iwlegacy/iwl-3945-debugfs.c b/drivers/net/wireless/iwlegacy/iwl-3945-debugfs.c
index 954aed4e7b34..b767979c5dbb 100644
--- a/drivers/net/wireless/iwlegacy/iwl-3945-debugfs.c
+++ b/drivers/net/wireless/iwlegacy/iwl-3945-debugfs.c
@@ -29,22 +29,22 @@
29#include "iwl-3945-debugfs.h" 29#include "iwl-3945-debugfs.h"
30 30
31 31
32static int il3945_statistics_flag(struct il_priv *priv, char *buf, int bufsz) 32static int il3945_statistics_flag(struct il_priv *il, char *buf, int bufsz)
33{ 33{
34 int p = 0; 34 int p = 0;
35 35
36 p += scnprintf(buf + p, bufsz - p, "Statistics Flag(0x%X):\n", 36 p += scnprintf(buf + p, bufsz - p, "Statistics Flag(0x%X):\n",
37 le32_to_cpu(priv->_3945.statistics.flag)); 37 le32_to_cpu(il->_3945.statistics.flag));
38 if (le32_to_cpu(priv->_3945.statistics.flag) & 38 if (le32_to_cpu(il->_3945.statistics.flag) &
39 UCODE_STATISTICS_CLEAR_MSK) 39 UCODE_STATISTICS_CLEAR_MSK)
40 p += scnprintf(buf + p, bufsz - p, 40 p += scnprintf(buf + p, bufsz - p,
41 "\tStatistics have been cleared\n"); 41 "\tStatistics have been cleared\n");
42 p += scnprintf(buf + p, bufsz - p, "\tOperational Frequency: %s\n", 42 p += scnprintf(buf + p, bufsz - p, "\tOperational Frequency: %s\n",
43 (le32_to_cpu(priv->_3945.statistics.flag) & 43 (le32_to_cpu(il->_3945.statistics.flag) &
44 UCODE_STATISTICS_FREQUENCY_MSK) 44 UCODE_STATISTICS_FREQUENCY_MSK)
45 ? "2.4 GHz" : "5.2 GHz"); 45 ? "2.4 GHz" : "5.2 GHz");
46 p += scnprintf(buf + p, bufsz - p, "\tTGj Narrow Band: %s\n", 46 p += scnprintf(buf + p, bufsz - p, "\tTGj Narrow Band: %s\n",
47 (le32_to_cpu(priv->_3945.statistics.flag) & 47 (le32_to_cpu(il->_3945.statistics.flag) &
48 UCODE_STATISTICS_NARROW_BAND_MSK) 48 UCODE_STATISTICS_NARROW_BAND_MSK)
49 ? "enabled" : "disabled"); 49 ? "enabled" : "disabled");
50 return p; 50 return p;
@@ -54,7 +54,7 @@ ssize_t il3945_ucode_rx_stats_read(struct file *file,
54 char __user *user_buf, 54 char __user *user_buf,
55 size_t count, loff_t *ppos) 55 size_t count, loff_t *ppos)
56{ 56{
57 struct il_priv *priv = file->private_data; 57 struct il_priv *il = file->private_data;
58 int pos = 0; 58 int pos = 0;
59 char *buf; 59 char *buf;
60 int bufsz = sizeof(struct iwl39_statistics_rx_phy) * 40 + 60 int bufsz = sizeof(struct iwl39_statistics_rx_phy) * 40 +
@@ -66,12 +66,12 @@ ssize_t il3945_ucode_rx_stats_read(struct file *file,
66 struct iwl39_statistics_rx_non_phy *general, *accum_general; 66 struct iwl39_statistics_rx_non_phy *general, *accum_general;
67 struct iwl39_statistics_rx_non_phy *delta_general, *max_general; 67 struct iwl39_statistics_rx_non_phy *delta_general, *max_general;
68 68
69 if (!il_is_alive(priv)) 69 if (!il_is_alive(il))
70 return -EAGAIN; 70 return -EAGAIN;
71 71
72 buf = kzalloc(bufsz, GFP_KERNEL); 72 buf = kzalloc(bufsz, GFP_KERNEL);
73 if (!buf) { 73 if (!buf) {
74 IL_ERR(priv, "Can not allocate Buffer\n"); 74 IL_ERR(il, "Can not allocate Buffer\n");
75 return -ENOMEM; 75 return -ENOMEM;
76 } 76 }
77 77
@@ -80,20 +80,20 @@ ssize_t il3945_ucode_rx_stats_read(struct file *file,
80 * the last statistics notification from uCode 80 * the last statistics notification from uCode
81 * might not reflect the current uCode activity 81 * might not reflect the current uCode activity
82 */ 82 */
83 ofdm = &priv->_3945.statistics.rx.ofdm; 83 ofdm = &il->_3945.statistics.rx.ofdm;
84 cck = &priv->_3945.statistics.rx.cck; 84 cck = &il->_3945.statistics.rx.cck;
85 general = &priv->_3945.statistics.rx.general; 85 general = &il->_3945.statistics.rx.general;
86 accum_ofdm = &priv->_3945.accum_statistics.rx.ofdm; 86 accum_ofdm = &il->_3945.accum_statistics.rx.ofdm;
87 accum_cck = &priv->_3945.accum_statistics.rx.cck; 87 accum_cck = &il->_3945.accum_statistics.rx.cck;
88 accum_general = &priv->_3945.accum_statistics.rx.general; 88 accum_general = &il->_3945.accum_statistics.rx.general;
89 delta_ofdm = &priv->_3945.delta_statistics.rx.ofdm; 89 delta_ofdm = &il->_3945.delta_statistics.rx.ofdm;
90 delta_cck = &priv->_3945.delta_statistics.rx.cck; 90 delta_cck = &il->_3945.delta_statistics.rx.cck;
91 delta_general = &priv->_3945.delta_statistics.rx.general; 91 delta_general = &il->_3945.delta_statistics.rx.general;
92 max_ofdm = &priv->_3945.max_delta.rx.ofdm; 92 max_ofdm = &il->_3945.max_delta.rx.ofdm;
93 max_cck = &priv->_3945.max_delta.rx.cck; 93 max_cck = &il->_3945.max_delta.rx.cck;
94 max_general = &priv->_3945.max_delta.rx.general; 94 max_general = &il->_3945.max_delta.rx.general;
95 95
96 pos += il3945_statistics_flag(priv, buf, bufsz); 96 pos += il3945_statistics_flag(il, buf, bufsz);
97 pos += scnprintf(buf + pos, bufsz - pos, "%-32s current" 97 pos += scnprintf(buf + pos, bufsz - pos, "%-32s current"
98 "acumulative delta max\n", 98 "acumulative delta max\n",
99 "Statistics_Rx - OFDM:"); 99 "Statistics_Rx - OFDM:");
@@ -329,19 +329,19 @@ ssize_t il3945_ucode_tx_stats_read(struct file *file,
329 char __user *user_buf, 329 char __user *user_buf,
330 size_t count, loff_t *ppos) 330 size_t count, loff_t *ppos)
331{ 331{
332 struct il_priv *priv = file->private_data; 332 struct il_priv *il = file->private_data;
333 int pos = 0; 333 int pos = 0;
334 char *buf; 334 char *buf;
335 int bufsz = (sizeof(struct iwl39_statistics_tx) * 48) + 250; 335 int bufsz = (sizeof(struct iwl39_statistics_tx) * 48) + 250;
336 ssize_t ret; 336 ssize_t ret;
337 struct iwl39_statistics_tx *tx, *accum_tx, *delta_tx, *max_tx; 337 struct iwl39_statistics_tx *tx, *accum_tx, *delta_tx, *max_tx;
338 338
339 if (!il_is_alive(priv)) 339 if (!il_is_alive(il))
340 return -EAGAIN; 340 return -EAGAIN;
341 341
342 buf = kzalloc(bufsz, GFP_KERNEL); 342 buf = kzalloc(bufsz, GFP_KERNEL);
343 if (!buf) { 343 if (!buf) {
344 IL_ERR(priv, "Can not allocate Buffer\n"); 344 IL_ERR(il, "Can not allocate Buffer\n");
345 return -ENOMEM; 345 return -ENOMEM;
346 } 346 }
347 347
@@ -350,11 +350,11 @@ ssize_t il3945_ucode_tx_stats_read(struct file *file,
350 * the last statistics notification from uCode 350 * the last statistics notification from uCode
351 * might not reflect the current uCode activity 351 * might not reflect the current uCode activity
352 */ 352 */
353 tx = &priv->_3945.statistics.tx; 353 tx = &il->_3945.statistics.tx;
354 accum_tx = &priv->_3945.accum_statistics.tx; 354 accum_tx = &il->_3945.accum_statistics.tx;
355 delta_tx = &priv->_3945.delta_statistics.tx; 355 delta_tx = &il->_3945.delta_statistics.tx;
356 max_tx = &priv->_3945.max_delta.tx; 356 max_tx = &il->_3945.max_delta.tx;
357 pos += il3945_statistics_flag(priv, buf, bufsz); 357 pos += il3945_statistics_flag(il, buf, bufsz);
358 pos += scnprintf(buf + pos, bufsz - pos, "%-32s current" 358 pos += scnprintf(buf + pos, bufsz - pos, "%-32s current"
359 "acumulative delta max\n", 359 "acumulative delta max\n",
360 "Statistics_Tx:"); 360 "Statistics_Tx:");
@@ -425,7 +425,7 @@ ssize_t il3945_ucode_general_stats_read(struct file *file,
425 char __user *user_buf, 425 char __user *user_buf,
426 size_t count, loff_t *ppos) 426 size_t count, loff_t *ppos)
427{ 427{
428 struct il_priv *priv = file->private_data; 428 struct il_priv *il = file->private_data;
429 int pos = 0; 429 int pos = 0;
430 char *buf; 430 char *buf;
431 int bufsz = sizeof(struct iwl39_statistics_general) * 10 + 300; 431 int bufsz = sizeof(struct iwl39_statistics_general) * 10 + 300;
@@ -435,12 +435,12 @@ ssize_t il3945_ucode_general_stats_read(struct file *file,
435 struct statistics_dbg *dbg, *accum_dbg, *delta_dbg, *max_dbg; 435 struct statistics_dbg *dbg, *accum_dbg, *delta_dbg, *max_dbg;
436 struct iwl39_statistics_div *div, *accum_div, *delta_div, *max_div; 436 struct iwl39_statistics_div *div, *accum_div, *delta_div, *max_div;
437 437
438 if (!il_is_alive(priv)) 438 if (!il_is_alive(il))
439 return -EAGAIN; 439 return -EAGAIN;
440 440
441 buf = kzalloc(bufsz, GFP_KERNEL); 441 buf = kzalloc(bufsz, GFP_KERNEL);
442 if (!buf) { 442 if (!buf) {
443 IL_ERR(priv, "Can not allocate Buffer\n"); 443 IL_ERR(il, "Can not allocate Buffer\n");
444 return -ENOMEM; 444 return -ENOMEM;
445 } 445 }
446 446
@@ -449,19 +449,19 @@ ssize_t il3945_ucode_general_stats_read(struct file *file,
449 * the last statistics notification from uCode 449 * the last statistics notification from uCode
450 * might not reflect the current uCode activity 450 * might not reflect the current uCode activity
451 */ 451 */
452 general = &priv->_3945.statistics.general; 452 general = &il->_3945.statistics.general;
453 dbg = &priv->_3945.statistics.general.dbg; 453 dbg = &il->_3945.statistics.general.dbg;
454 div = &priv->_3945.statistics.general.div; 454 div = &il->_3945.statistics.general.div;
455 accum_general = &priv->_3945.accum_statistics.general; 455 accum_general = &il->_3945.accum_statistics.general;
456 delta_general = &priv->_3945.delta_statistics.general; 456 delta_general = &il->_3945.delta_statistics.general;
457 max_general = &priv->_3945.max_delta.general; 457 max_general = &il->_3945.max_delta.general;
458 accum_dbg = &priv->_3945.accum_statistics.general.dbg; 458 accum_dbg = &il->_3945.accum_statistics.general.dbg;
459 delta_dbg = &priv->_3945.delta_statistics.general.dbg; 459 delta_dbg = &il->_3945.delta_statistics.general.dbg;
460 max_dbg = &priv->_3945.max_delta.general.dbg; 460 max_dbg = &il->_3945.max_delta.general.dbg;
461 accum_div = &priv->_3945.accum_statistics.general.div; 461 accum_div = &il->_3945.accum_statistics.general.div;
462 delta_div = &priv->_3945.delta_statistics.general.div; 462 delta_div = &il->_3945.delta_statistics.general.div;
463 max_div = &priv->_3945.max_delta.general.div; 463 max_div = &il->_3945.max_delta.general.div;
464 pos += il3945_statistics_flag(priv, buf, bufsz); 464 pos += il3945_statistics_flag(il, buf, bufsz);
465 pos += scnprintf(buf + pos, bufsz - pos, "%-32s current" 465 pos += scnprintf(buf + pos, bufsz - pos, "%-32s current"
466 "acumulative delta max\n", 466 "acumulative delta max\n",
467 "Statistics_General:"); 467 "Statistics_General:");
diff --git a/drivers/net/wireless/iwlegacy/iwl-3945-led.c b/drivers/net/wireless/iwlegacy/iwl-3945-led.c
index 69703b07bd69..53ec4637015e 100644
--- a/drivers/net/wireless/iwlegacy/iwl-3945-led.c
+++ b/drivers/net/wireless/iwlegacy/iwl-3945-led.c
@@ -44,7 +44,7 @@
44 44
45 45
46/* Send led command */ 46/* Send led command */
47static int il3945_send_led_cmd(struct il_priv *priv, 47static int il3945_send_led_cmd(struct il_priv *il,
48 struct il_led_cmd *led_cmd) 48 struct il_led_cmd *led_cmd)
49{ 49{
50 struct il_host_cmd cmd = { 50 struct il_host_cmd cmd = {
@@ -55,7 +55,7 @@ static int il3945_send_led_cmd(struct il_priv *priv,
55 .callback = NULL, 55 .callback = NULL,
56 }; 56 };
57 57
58 return il_send_cmd(priv, &cmd); 58 return il_send_cmd(il, &cmd);
59} 59}
60 60
61const struct il_led_ops il3945_led_ops = { 61const struct il_led_ops il3945_led_ops = {
diff --git a/drivers/net/wireless/iwlegacy/iwl-3945-rs.c b/drivers/net/wireless/iwlegacy/iwl-3945-rs.c
index d97f24bfc451..38f1b825af10 100644
--- a/drivers/net/wireless/iwlegacy/iwl-3945-rs.c
+++ b/drivers/net/wireless/iwlegacy/iwl-3945-rs.c
@@ -153,7 +153,7 @@ static int il3945_rate_scale_flush_windows(struct il3945_rs_sta *rs_sta)
153 int unflushed = 0; 153 int unflushed = 0;
154 int i; 154 int i;
155 unsigned long flags; 155 unsigned long flags;
156 struct il_priv *priv __maybe_unused = rs_sta->priv; 156 struct il_priv *il __maybe_unused = rs_sta->il;
157 157
158 /* 158 /*
159 * For each rate, if we have collected data on that rate 159 * For each rate, if we have collected data on that rate
@@ -167,7 +167,7 @@ static int il3945_rate_scale_flush_windows(struct il3945_rs_sta *rs_sta)
167 spin_lock_irqsave(&rs_sta->lock, flags); 167 spin_lock_irqsave(&rs_sta->lock, flags);
168 if (time_after(jiffies, rs_sta->win[i].stamp + 168 if (time_after(jiffies, rs_sta->win[i].stamp +
169 IL_RATE_WIN_FLUSH)) { 169 IL_RATE_WIN_FLUSH)) {
170 IL_DEBUG_RATE(priv, "flushing %d samples of rate " 170 IL_DEBUG_RATE(il, "flushing %d samples of rate "
171 "index %d\n", 171 "index %d\n",
172 rs_sta->win[i].counter, i); 172 rs_sta->win[i].counter, i);
173 il3945_clear_window(&rs_sta->win[i]); 173 il3945_clear_window(&rs_sta->win[i]);
@@ -186,12 +186,12 @@ static int il3945_rate_scale_flush_windows(struct il3945_rs_sta *rs_sta)
186static void il3945_bg_rate_scale_flush(unsigned long data) 186static void il3945_bg_rate_scale_flush(unsigned long data)
187{ 187{
188 struct il3945_rs_sta *rs_sta = (void *)data; 188 struct il3945_rs_sta *rs_sta = (void *)data;
189 struct il_priv *priv __maybe_unused = rs_sta->priv; 189 struct il_priv *il __maybe_unused = rs_sta->il;
190 int unflushed = 0; 190 int unflushed = 0;
191 unsigned long flags; 191 unsigned long flags;
192 u32 packet_count, duration, pps; 192 u32 packet_count, duration, pps;
193 193
194 IL_DEBUG_RATE(priv, "enter\n"); 194 IL_DEBUG_RATE(il, "enter\n");
195 195
196 unflushed = il3945_rate_scale_flush_windows(rs_sta); 196 unflushed = il3945_rate_scale_flush_windows(rs_sta);
197 197
@@ -206,7 +206,7 @@ static void il3945_bg_rate_scale_flush(unsigned long data)
206 duration = 206 duration =
207 jiffies_to_msecs(jiffies - rs_sta->last_partial_flush); 207 jiffies_to_msecs(jiffies - rs_sta->last_partial_flush);
208 208
209 IL_DEBUG_RATE(priv, "Tx'd %d packets in %dms\n", 209 IL_DEBUG_RATE(il, "Tx'd %d packets in %dms\n",
210 packet_count, duration); 210 packet_count, duration);
211 211
212 /* Determine packets per second */ 212 /* Determine packets per second */
@@ -226,7 +226,7 @@ static void il3945_bg_rate_scale_flush(unsigned long data)
226 226
227 rs_sta->flush_time = msecs_to_jiffies(duration); 227 rs_sta->flush_time = msecs_to_jiffies(duration);
228 228
229 IL_DEBUG_RATE(priv, "new flush period: %d msec ave %d\n", 229 IL_DEBUG_RATE(il, "new flush period: %d msec ave %d\n",
230 duration, packet_count); 230 duration, packet_count);
231 231
232 mod_timer(&rs_sta->rate_scale_flush, jiffies + 232 mod_timer(&rs_sta->rate_scale_flush, jiffies +
@@ -244,7 +244,7 @@ static void il3945_bg_rate_scale_flush(unsigned long data)
244 244
245 spin_unlock_irqrestore(&rs_sta->lock, flags); 245 spin_unlock_irqrestore(&rs_sta->lock, flags);
246 246
247 IL_DEBUG_RATE(priv, "leave\n"); 247 IL_DEBUG_RATE(il, "leave\n");
248} 248}
249 249
250/** 250/**
@@ -260,10 +260,10 @@ static void il3945_collect_tx_data(struct il3945_rs_sta *rs_sta,
260{ 260{
261 unsigned long flags; 261 unsigned long flags;
262 s32 fail_count; 262 s32 fail_count;
263 struct il_priv *priv __maybe_unused = rs_sta->priv; 263 struct il_priv *il __maybe_unused = rs_sta->il;
264 264
265 if (!retries) { 265 if (!retries) {
266 IL_DEBUG_RATE(priv, "leave: retries == 0 -- should be at least 1\n"); 266 IL_DEBUG_RATE(il, "leave: retries == 0 -- should be at least 1\n");
267 return; 267 return;
268 } 268 }
269 269
@@ -332,24 +332,24 @@ static void il3945_collect_tx_data(struct il3945_rs_sta *rs_sta,
332/* 332/*
333 * Called after adding a new station to initialize rate scaling 333 * Called after adding a new station to initialize rate scaling
334 */ 334 */
335void il3945_rs_rate_init(struct il_priv *priv, struct ieee80211_sta *sta, u8 sta_id) 335void il3945_rs_rate_init(struct il_priv *il, struct ieee80211_sta *sta, u8 sta_id)
336{ 336{
337 struct ieee80211_hw *hw = priv->hw; 337 struct ieee80211_hw *hw = il->hw;
338 struct ieee80211_conf *conf = &priv->hw->conf; 338 struct ieee80211_conf *conf = &il->hw->conf;
339 struct il3945_sta_priv *psta; 339 struct il3945_sta_priv *psta;
340 struct il3945_rs_sta *rs_sta; 340 struct il3945_rs_sta *rs_sta;
341 struct ieee80211_supported_band *sband; 341 struct ieee80211_supported_band *sband;
342 int i; 342 int i;
343 343
344 IL_DEBUG_INFO(priv, "enter\n"); 344 IL_DEBUG_INFO(il, "enter\n");
345 if (sta_id == priv->contexts[IL_RXON_CTX_BSS].bcast_sta_id) 345 if (sta_id == il->contexts[IL_RXON_CTX_BSS].bcast_sta_id)
346 goto out; 346 goto out;
347 347
348 psta = (struct il3945_sta_priv *) sta->drv_priv; 348 psta = (struct il3945_sta_priv *) sta->drv_priv;
349 rs_sta = &psta->rs_sta; 349 rs_sta = &psta->rs_sta;
350 sband = hw->wiphy->bands[conf->channel->band]; 350 sband = hw->wiphy->bands[conf->channel->band];
351 351
352 rs_sta->priv = priv; 352 rs_sta->il = il;
353 353
354 rs_sta->start_rate = IL_RATE_INVALID; 354 rs_sta->start_rate = IL_RATE_INVALID;
355 355
@@ -379,18 +379,18 @@ void il3945_rs_rate_init(struct il_priv *priv, struct ieee80211_sta *sta, u8 sta
379 } 379 }
380 } 380 }
381 381
382 priv->_3945.sta_supp_rates = sta->supp_rates[sband->band]; 382 il->_3945.sta_supp_rates = sta->supp_rates[sband->band];
383 /* For 5 GHz band it start at IL_FIRST_OFDM_RATE */ 383 /* For 5 GHz band it start at IL_FIRST_OFDM_RATE */
384 if (sband->band == IEEE80211_BAND_5GHZ) { 384 if (sband->band == IEEE80211_BAND_5GHZ) {
385 rs_sta->last_txrate_idx += IL_FIRST_OFDM_RATE; 385 rs_sta->last_txrate_idx += IL_FIRST_OFDM_RATE;
386 priv->_3945.sta_supp_rates = priv->_3945.sta_supp_rates << 386 il->_3945.sta_supp_rates = il->_3945.sta_supp_rates <<
387 IL_FIRST_OFDM_RATE; 387 IL_FIRST_OFDM_RATE;
388 } 388 }
389 389
390out: 390out:
391 priv->stations[sta_id].used &= ~IL_STA_UCODE_INPROGRESS; 391 il->stations[sta_id].used &= ~IL_STA_UCODE_INPROGRESS;
392 392
393 IL_DEBUG_INFO(priv, "leave\n"); 393 IL_DEBUG_INFO(il, "leave\n");
394} 394}
395 395
396static void *il3945_rs_alloc(struct ieee80211_hw *hw, struct dentry *debugfsdir) 396static void *il3945_rs_alloc(struct ieee80211_hw *hw, struct dentry *debugfsdir)
@@ -399,7 +399,7 @@ static void *il3945_rs_alloc(struct ieee80211_hw *hw, struct dentry *debugfsdir)
399} 399}
400 400
401/* rate scale requires free function to be implemented */ 401/* rate scale requires free function to be implemented */
402static void il3945_rs_free(void *priv) 402static void il3945_rs_free(void *il)
403{ 403{
404 return; 404 return;
405} 405}
@@ -408,24 +408,24 @@ static void *il3945_rs_alloc_sta(void *il_priv, struct ieee80211_sta *sta, gfp_t
408{ 408{
409 struct il3945_rs_sta *rs_sta; 409 struct il3945_rs_sta *rs_sta;
410 struct il3945_sta_priv *psta = (void *) sta->drv_priv; 410 struct il3945_sta_priv *psta = (void *) sta->drv_priv;
411 struct il_priv *priv __maybe_unused = il_priv; 411 struct il_priv *il __maybe_unused = il_priv;
412 412
413 IL_DEBUG_RATE(priv, "enter\n"); 413 IL_DEBUG_RATE(il, "enter\n");
414 414
415 rs_sta = &psta->rs_sta; 415 rs_sta = &psta->rs_sta;
416 416
417 spin_lock_init(&rs_sta->lock); 417 spin_lock_init(&rs_sta->lock);
418 init_timer(&rs_sta->rate_scale_flush); 418 init_timer(&rs_sta->rate_scale_flush);
419 419
420 IL_DEBUG_RATE(priv, "leave\n"); 420 IL_DEBUG_RATE(il, "leave\n");
421 421
422 return rs_sta; 422 return rs_sta;
423} 423}
424 424
425static void il3945_rs_free_sta(void *il_priv, struct ieee80211_sta *sta, 425static void il3945_rs_free_sta(void *il_priv, struct ieee80211_sta *sta,
426 void *priv_sta) 426 void *il_sta)
427{ 427{
428 struct il3945_rs_sta *rs_sta = priv_sta; 428 struct il3945_rs_sta *rs_sta = il_sta;
429 429
430 /* 430 /*
431 * Be careful not to use any members of il3945_rs_sta (like trying 431 * Be careful not to use any members of il3945_rs_sta (like trying
@@ -442,18 +442,18 @@ static void il3945_rs_free_sta(void *il_priv, struct ieee80211_sta *sta,
442 * NOTE: Uses il_priv->retry_rate for the # of retries attempted by 442 * NOTE: Uses il_priv->retry_rate for the # of retries attempted by
443 * the hardware for each rate. 443 * the hardware for each rate.
444 */ 444 */
445static void il3945_rs_tx_status(void *priv_rate, struct ieee80211_supported_band *sband, 445static void il3945_rs_tx_status(void *il_rate, struct ieee80211_supported_band *sband,
446 struct ieee80211_sta *sta, void *priv_sta, 446 struct ieee80211_sta *sta, void *il_sta,
447 struct sk_buff *skb) 447 struct sk_buff *skb)
448{ 448{
449 s8 retries = 0, current_count; 449 s8 retries = 0, current_count;
450 int scale_rate_index, first_index, last_index; 450 int scale_rate_index, first_index, last_index;
451 unsigned long flags; 451 unsigned long flags;
452 struct il_priv *priv = (struct il_priv *)priv_rate; 452 struct il_priv *il = (struct il_priv *)il_rate;
453 struct il3945_rs_sta *rs_sta = priv_sta; 453 struct il3945_rs_sta *rs_sta = il_sta;
454 struct ieee80211_tx_info *info = IEEE80211_SKB_CB(skb); 454 struct ieee80211_tx_info *info = IEEE80211_SKB_CB(skb);
455 455
456 IL_DEBUG_RATE(priv, "enter\n"); 456 IL_DEBUG_RATE(il, "enter\n");
457 457
458 retries = info->status.rates[0].count; 458 retries = info->status.rates[0].count;
459 /* Sanity Check for retries */ 459 /* Sanity Check for retries */
@@ -462,18 +462,18 @@ static void il3945_rs_tx_status(void *priv_rate, struct ieee80211_supported_band
462 462
463 first_index = sband->bitrates[info->status.rates[0].idx].hw_value; 463 first_index = sband->bitrates[info->status.rates[0].idx].hw_value;
464 if ((first_index < 0) || (first_index >= IL_RATE_COUNT_3945)) { 464 if ((first_index < 0) || (first_index >= IL_RATE_COUNT_3945)) {
465 IL_DEBUG_RATE(priv, "leave: Rate out of bounds: %d\n", first_index); 465 IL_DEBUG_RATE(il, "leave: Rate out of bounds: %d\n", first_index);
466 return; 466 return;
467 } 467 }
468 468
469 if (!priv_sta) { 469 if (!il_sta) {
470 IL_DEBUG_RATE(priv, "leave: No STA priv data to update!\n"); 470 IL_DEBUG_RATE(il, "leave: No STA il data to update!\n");
471 return; 471 return;
472 } 472 }
473 473
474 /* Treat uninitialized rate scaling data same as non-existing. */ 474 /* Treat uninitialized rate scaling data same as non-existing. */
475 if (!rs_sta->priv) { 475 if (!rs_sta->il) {
476 IL_DEBUG_RATE(priv, "leave: STA priv data uninitialized!\n"); 476 IL_DEBUG_RATE(il, "leave: STA il data uninitialized!\n");
477 return; 477 return;
478 } 478 }
479 479
@@ -487,19 +487,19 @@ static void il3945_rs_tx_status(void *priv_rate, struct ieee80211_supported_band
487 * Update the window for each rate. We determine which rates 487 * Update the window for each rate. We determine which rates
488 * were Tx'd based on the total number of retries vs. the number 488 * were Tx'd based on the total number of retries vs. the number
489 * of retries configured for each rate -- currently set to the 489 * of retries configured for each rate -- currently set to the
490 * priv value 'retry_rate' vs. rate specific 490 * il value 'retry_rate' vs. rate specific
491 * 491 *
492 * On exit from this while loop last_index indicates the rate 492 * On exit from this while loop last_index indicates the rate
493 * at which the frame was finally transmitted (or failed if no 493 * at which the frame was finally transmitted (or failed if no
494 * ACK) 494 * ACK)
495 */ 495 */
496 while (retries > 1) { 496 while (retries > 1) {
497 if ((retries - 1) < priv->retry_rate) { 497 if ((retries - 1) < il->retry_rate) {
498 current_count = (retries - 1); 498 current_count = (retries - 1);
499 last_index = scale_rate_index; 499 last_index = scale_rate_index;
500 } else { 500 } else {
501 current_count = priv->retry_rate; 501 current_count = il->retry_rate;
502 last_index = il3945_rs_next_rate(priv, 502 last_index = il3945_rs_next_rate(il,
503 scale_rate_index); 503 scale_rate_index);
504 } 504 }
505 505
@@ -508,7 +508,7 @@ static void il3945_rs_tx_status(void *priv_rate, struct ieee80211_supported_band
508 il3945_collect_tx_data(rs_sta, 508 il3945_collect_tx_data(rs_sta,
509 &rs_sta->win[scale_rate_index], 509 &rs_sta->win[scale_rate_index],
510 0, current_count, scale_rate_index); 510 0, current_count, scale_rate_index);
511 IL_DEBUG_RATE(priv, "Update rate %d for %d retries.\n", 511 IL_DEBUG_RATE(il, "Update rate %d for %d retries.\n",
512 scale_rate_index, current_count); 512 scale_rate_index, current_count);
513 513
514 retries -= current_count; 514 retries -= current_count;
@@ -518,7 +518,7 @@ static void il3945_rs_tx_status(void *priv_rate, struct ieee80211_supported_band
518 518
519 519
520 /* Update the last index window with success/failure based on ACK */ 520 /* Update the last index window with success/failure based on ACK */
521 IL_DEBUG_RATE(priv, "Update rate %d with %s.\n", 521 IL_DEBUG_RATE(il, "Update rate %d with %s.\n",
522 last_index, 522 last_index,
523 (info->flags & IEEE80211_TX_STAT_ACK) ? 523 (info->flags & IEEE80211_TX_STAT_ACK) ?
524 "success" : "failure"); 524 "success" : "failure");
@@ -543,7 +543,7 @@ static void il3945_rs_tx_status(void *priv_rate, struct ieee80211_supported_band
543 543
544 spin_unlock_irqrestore(&rs_sta->lock, flags); 544 spin_unlock_irqrestore(&rs_sta->lock, flags);
545 545
546 IL_DEBUG_RATE(priv, "leave\n"); 546 IL_DEBUG_RATE(il, "leave\n");
547} 547}
548 548
549static u16 il3945_get_adjacent_rate(struct il3945_rs_sta *rs_sta, 549static u16 il3945_get_adjacent_rate(struct il3945_rs_sta *rs_sta,
@@ -551,7 +551,7 @@ static u16 il3945_get_adjacent_rate(struct il3945_rs_sta *rs_sta,
551{ 551{
552 u8 high = IL_RATE_INVALID; 552 u8 high = IL_RATE_INVALID;
553 u8 low = IL_RATE_INVALID; 553 u8 low = IL_RATE_INVALID;
554 struct il_priv *priv __maybe_unused = rs_sta->priv; 554 struct il_priv *il __maybe_unused = rs_sta->il;
555 555
556 /* 802.11A walks to the next literal adjacent rate in 556 /* 802.11A walks to the next literal adjacent rate in
557 * the rate table */ 557 * the rate table */
@@ -591,7 +591,7 @@ static u16 il3945_get_adjacent_rate(struct il3945_rs_sta *rs_sta,
591 break; 591 break;
592 if (rate_mask & (1 << low)) 592 if (rate_mask & (1 << low))
593 break; 593 break;
594 IL_DEBUG_RATE(priv, "Skipping masked lower rate: %d\n", low); 594 IL_DEBUG_RATE(il, "Skipping masked lower rate: %d\n", low);
595 } 595 }
596 596
597 high = index; 597 high = index;
@@ -604,7 +604,7 @@ static u16 il3945_get_adjacent_rate(struct il3945_rs_sta *rs_sta,
604 break; 604 break;
605 if (rate_mask & (1 << high)) 605 if (rate_mask & (1 << high))
606 break; 606 break;
607 IL_DEBUG_RATE(priv, "Skipping masked higher rate: %d\n", high); 607 IL_DEBUG_RATE(il, "Skipping masked higher rate: %d\n", high);
608 } 608 }
609 609
610 return (high << 8) | low; 610 return (high << 8) | low;
@@ -626,8 +626,8 @@ static u16 il3945_get_adjacent_rate(struct il3945_rs_sta *rs_sta,
626 * rate table and must reference the driver allocated rate table 626 * rate table and must reference the driver allocated rate table
627 * 627 *
628 */ 628 */
629static void il3945_rs_get_rate(void *priv_r, struct ieee80211_sta *sta, 629static void il3945_rs_get_rate(void *il_r, struct ieee80211_sta *sta,
630 void *priv_sta, struct ieee80211_tx_rate_control *txrc) 630 void *il_sta, struct ieee80211_tx_rate_control *txrc)
631{ 631{
632 struct ieee80211_supported_band *sband = txrc->sband; 632 struct ieee80211_supported_band *sband = txrc->sband;
633 struct sk_buff *skb = txrc->skb; 633 struct sk_buff *skb = txrc->skb;
@@ -635,7 +635,7 @@ static void il3945_rs_get_rate(void *priv_r, struct ieee80211_sta *sta,
635 u8 high = IL_RATE_INVALID; 635 u8 high = IL_RATE_INVALID;
636 u16 high_low; 636 u16 high_low;
637 int index; 637 int index;
638 struct il3945_rs_sta *rs_sta = priv_sta; 638 struct il3945_rs_sta *rs_sta = il_sta;
639 struct il3945_rate_scale_data *window = NULL; 639 struct il3945_rate_scale_data *window = NULL;
640 int current_tpt = IL_INVALID_VALUE; 640 int current_tpt = IL_INVALID_VALUE;
641 int low_tpt = IL_INVALID_VALUE; 641 int low_tpt = IL_INVALID_VALUE;
@@ -645,18 +645,18 @@ static void il3945_rs_get_rate(void *priv_r, struct ieee80211_sta *sta,
645 unsigned long flags; 645 unsigned long flags;
646 u16 rate_mask; 646 u16 rate_mask;
647 s8 max_rate_idx = -1; 647 s8 max_rate_idx = -1;
648 struct il_priv *priv __maybe_unused = (struct il_priv *)priv_r; 648 struct il_priv *il __maybe_unused = (struct il_priv *)il_r;
649 struct ieee80211_tx_info *info = IEEE80211_SKB_CB(skb); 649 struct ieee80211_tx_info *info = IEEE80211_SKB_CB(skb);
650 650
651 IL_DEBUG_RATE(priv, "enter\n"); 651 IL_DEBUG_RATE(il, "enter\n");
652 652
653 /* Treat uninitialized rate scaling data same as non-existing. */ 653 /* Treat uninitialized rate scaling data same as non-existing. */
654 if (rs_sta && !rs_sta->priv) { 654 if (rs_sta && !rs_sta->il) {
655 IL_DEBUG_RATE(priv, "Rate scaling information not initialized yet.\n"); 655 IL_DEBUG_RATE(il, "Rate scaling information not initialized yet.\n");
656 priv_sta = NULL; 656 il_sta = NULL;
657 } 657 }
658 658
659 if (rate_control_send_low(sta, priv_sta, txrc)) 659 if (rate_control_send_low(sta, il_sta, txrc))
660 return; 660 return;
661 661
662 rate_mask = sta->supp_rates[sband->band]; 662 rate_mask = sta->supp_rates[sband->band];
@@ -699,7 +699,7 @@ static void il3945_rs_get_rate(void *priv_r, struct ieee80211_sta *sta,
699 (window->success_counter < IL_RATE_MIN_SUCCESS_TH))) { 699 (window->success_counter < IL_RATE_MIN_SUCCESS_TH))) {
700 spin_unlock_irqrestore(&rs_sta->lock, flags); 700 spin_unlock_irqrestore(&rs_sta->lock, flags);
701 701
702 IL_DEBUG_RATE(priv, "Invalid average_tpt on rate %d: " 702 IL_DEBUG_RATE(il, "Invalid average_tpt on rate %d: "
703 "counter: %d, success_counter: %d, " 703 "counter: %d, success_counter: %d, "
704 "expected_tpt is %sNULL\n", 704 "expected_tpt is %sNULL\n",
705 index, 705 index,
@@ -737,7 +737,7 @@ static void il3945_rs_get_rate(void *priv_r, struct ieee80211_sta *sta,
737 737
738 /* Low success ratio , need to drop the rate */ 738 /* Low success ratio , need to drop the rate */
739 if ((window->success_ratio < IL_RATE_DECREASE_TH) || !current_tpt) { 739 if ((window->success_ratio < IL_RATE_DECREASE_TH) || !current_tpt) {
740 IL_DEBUG_RATE(priv, "decrease rate because of low success_ratio\n"); 740 IL_DEBUG_RATE(il, "decrease rate because of low success_ratio\n");
741 scale_action = -1; 741 scale_action = -1;
742 /* No throughput measured yet for adjacent rates, 742 /* No throughput measured yet for adjacent rates,
743 * try increase */ 743 * try increase */
@@ -756,7 +756,7 @@ static void il3945_rs_get_rate(void *priv_r, struct ieee80211_sta *sta,
756 (high_tpt != IL_INVALID_VALUE) && 756 (high_tpt != IL_INVALID_VALUE) &&
757 (low_tpt < current_tpt) && (high_tpt < current_tpt)) { 757 (low_tpt < current_tpt) && (high_tpt < current_tpt)) {
758 758
759 IL_DEBUG_RATE(priv, "No action -- low [%d] & high [%d] < " 759 IL_DEBUG_RATE(il, "No action -- low [%d] & high [%d] < "
760 "current_tpt [%d]\n", 760 "current_tpt [%d]\n",
761 low_tpt, high_tpt, current_tpt); 761 low_tpt, high_tpt, current_tpt);
762 scale_action = 0; 762 scale_action = 0;
@@ -771,13 +771,13 @@ static void il3945_rs_get_rate(void *priv_r, struct ieee80211_sta *sta,
771 window->success_ratio >= IL_RATE_INCREASE_TH) 771 window->success_ratio >= IL_RATE_INCREASE_TH)
772 scale_action = 1; 772 scale_action = 1;
773 else { 773 else {
774 IL_DEBUG_RATE(priv, 774 IL_DEBUG_RATE(il,
775 "decrease rate because of high tpt\n"); 775 "decrease rate because of high tpt\n");
776 scale_action = 0; 776 scale_action = 0;
777 } 777 }
778 } else if (low_tpt != IL_INVALID_VALUE) { 778 } else if (low_tpt != IL_INVALID_VALUE) {
779 if (low_tpt > current_tpt) { 779 if (low_tpt > current_tpt) {
780 IL_DEBUG_RATE(priv, 780 IL_DEBUG_RATE(il,
781 "decrease rate because of low tpt\n"); 781 "decrease rate because of low tpt\n");
782 scale_action = -1; 782 scale_action = -1;
783 } else if (window->success_ratio >= IL_RATE_INCREASE_TH) { 783 } else if (window->success_ratio >= IL_RATE_INCREASE_TH) {
@@ -816,7 +816,7 @@ static void il3945_rs_get_rate(void *priv_r, struct ieee80211_sta *sta,
816 break; 816 break;
817 } 817 }
818 818
819 IL_DEBUG_RATE(priv, "Selected %d (action %d) - low %d high %d\n", 819 IL_DEBUG_RATE(il, "Selected %d (action %d) - low %d high %d\n",
820 index, scale_action, low, high); 820 index, scale_action, low, high);
821 821
822 out: 822 out:
@@ -831,7 +831,7 @@ static void il3945_rs_get_rate(void *priv_r, struct ieee80211_sta *sta,
831 info->control.rates[0].idx = rs_sta->last_txrate_idx; 831 info->control.rates[0].idx = rs_sta->last_txrate_idx;
832 } 832 }
833 833
834 IL_DEBUG_RATE(priv, "leave: %d\n", index); 834 IL_DEBUG_RATE(il, "leave: %d\n", index);
835} 835}
836 836
837#ifdef CONFIG_MAC80211_DEBUGFS 837#ifdef CONFIG_MAC80211_DEBUGFS
@@ -878,10 +878,10 @@ static const struct file_operations rs_sta_dbgfs_stats_table_ops = {
878 .llseek = default_llseek, 878 .llseek = default_llseek,
879}; 879};
880 880
881static void il3945_add_debugfs(void *priv, void *priv_sta, 881static void il3945_add_debugfs(void *il, void *il_sta,
882 struct dentry *dir) 882 struct dentry *dir)
883{ 883{
884 struct il3945_rs_sta *lq_sta = priv_sta; 884 struct il3945_rs_sta *lq_sta = il_sta;
885 885
886 lq_sta->rs_sta_dbgfs_stats_table_file = 886 lq_sta->rs_sta_dbgfs_stats_table_file =
887 debugfs_create_file("rate_stats_table", 0600, dir, 887 debugfs_create_file("rate_stats_table", 0600, dir,
@@ -889,9 +889,9 @@ static void il3945_add_debugfs(void *priv, void *priv_sta,
889 889
890} 890}
891 891
892static void il3945_remove_debugfs(void *priv, void *priv_sta) 892static void il3945_remove_debugfs(void *il, void *il_sta)
893{ 893{
894 struct il3945_rs_sta *lq_sta = priv_sta; 894 struct il3945_rs_sta *lq_sta = il_sta;
895 debugfs_remove(lq_sta->rs_sta_dbgfs_stats_table_file); 895 debugfs_remove(lq_sta->rs_sta_dbgfs_stats_table_file);
896} 896}
897#endif 897#endif
@@ -901,9 +901,9 @@ static void il3945_remove_debugfs(void *priv, void *priv_sta)
901 * the station is added. Since mac80211 calls this function before a 901 * the station is added. Since mac80211 calls this function before a
902 * station is added we ignore it. 902 * station is added we ignore it.
903 */ 903 */
904static void il3945_rs_rate_init_stub(void *priv_r, 904static void il3945_rs_rate_init_stub(void *il_r,
905 struct ieee80211_supported_band *sband, 905 struct ieee80211_supported_band *sband,
906 struct ieee80211_sta *sta, void *priv_sta) 906 struct ieee80211_sta *sta, void *il_sta)
907{ 907{
908} 908}
909 909
@@ -925,21 +925,21 @@ static struct rate_control_ops rs_ops = {
925}; 925};
926void il3945_rate_scale_init(struct ieee80211_hw *hw, s32 sta_id) 926void il3945_rate_scale_init(struct ieee80211_hw *hw, s32 sta_id)
927{ 927{
928 struct il_priv *priv = hw->priv; 928 struct il_priv *il = hw->priv;
929 s32 rssi = 0; 929 s32 rssi = 0;
930 unsigned long flags; 930 unsigned long flags;
931 struct il3945_rs_sta *rs_sta; 931 struct il3945_rs_sta *rs_sta;
932 struct ieee80211_sta *sta; 932 struct ieee80211_sta *sta;
933 struct il3945_sta_priv *psta; 933 struct il3945_sta_priv *psta;
934 934
935 IL_DEBUG_RATE(priv, "enter\n"); 935 IL_DEBUG_RATE(il, "enter\n");
936 936
937 rcu_read_lock(); 937 rcu_read_lock();
938 938
939 sta = ieee80211_find_sta(priv->contexts[IL_RXON_CTX_BSS].vif, 939 sta = ieee80211_find_sta(il->contexts[IL_RXON_CTX_BSS].vif,
940 priv->stations[sta_id].sta.sta.addr); 940 il->stations[sta_id].sta.sta.addr);
941 if (!sta) { 941 if (!sta) {
942 IL_DEBUG_RATE(priv, "Unable to find station to initialize rate scaling.\n"); 942 IL_DEBUG_RATE(il, "Unable to find station to initialize rate scaling.\n");
943 rcu_read_unlock(); 943 rcu_read_unlock();
944 return; 944 return;
945 } 945 }
@@ -950,10 +950,10 @@ void il3945_rate_scale_init(struct ieee80211_hw *hw, s32 sta_id)
950 spin_lock_irqsave(&rs_sta->lock, flags); 950 spin_lock_irqsave(&rs_sta->lock, flags);
951 951
952 rs_sta->tgg = 0; 952 rs_sta->tgg = 0;
953 switch (priv->band) { 953 switch (il->band) {
954 case IEEE80211_BAND_2GHZ: 954 case IEEE80211_BAND_2GHZ:
955 /* TODO: this always does G, not a regression */ 955 /* TODO: this always does G, not a regression */
956 if (priv->contexts[IL_RXON_CTX_BSS].active.flags & 956 if (il->contexts[IL_RXON_CTX_BSS].active.flags &
957 RXON_FLG_TGG_PROTECT_MSK) { 957 RXON_FLG_TGG_PROTECT_MSK) {
958 rs_sta->tgg = 1; 958 rs_sta->tgg = 1;
959 rs_sta->expected_tpt = il3945_expected_tpt_g_prot; 959 rs_sta->expected_tpt = il3945_expected_tpt_g_prot;
@@ -971,15 +971,15 @@ void il3945_rate_scale_init(struct ieee80211_hw *hw, s32 sta_id)
971 971
972 spin_unlock_irqrestore(&rs_sta->lock, flags); 972 spin_unlock_irqrestore(&rs_sta->lock, flags);
973 973
974 rssi = priv->_3945.last_rx_rssi; 974 rssi = il->_3945.last_rx_rssi;
975 if (rssi == 0) 975 if (rssi == 0)
976 rssi = IL_MIN_RSSI_VAL; 976 rssi = IL_MIN_RSSI_VAL;
977 977
978 IL_DEBUG_RATE(priv, "Network RSSI: %d\n", rssi); 978 IL_DEBUG_RATE(il, "Network RSSI: %d\n", rssi);
979 979
980 rs_sta->start_rate = il3945_get_rate_index_by_rssi(rssi, priv->band); 980 rs_sta->start_rate = il3945_get_rate_index_by_rssi(rssi, il->band);
981 981
982 IL_DEBUG_RATE(priv, "leave: rssi %d assign rate index: " 982 IL_DEBUG_RATE(il, "leave: rssi %d assign rate index: "
983 "%d (plcp 0x%x)\n", rssi, rs_sta->start_rate, 983 "%d (plcp 0x%x)\n", rssi, rs_sta->start_rate,
984 il3945_rates[rs_sta->start_rate].plcp); 984 il3945_rates[rs_sta->start_rate].plcp);
985 rcu_read_unlock(); 985 rcu_read_unlock();
diff --git a/drivers/net/wireless/iwlegacy/iwl-3945.c b/drivers/net/wireless/iwlegacy/iwl-3945.c
index 6d1740b051df..c9b5dcf446b4 100644
--- a/drivers/net/wireless/iwlegacy/iwl-3945.c
+++ b/drivers/net/wireless/iwlegacy/iwl-3945.c
@@ -108,7 +108,7 @@ static inline u8 il3945_get_prev_ieee_rate(u8 rate_index)
108 * Use for only special debugging. This function is just a placeholder as-is, 108 * Use for only special debugging. This function is just a placeholder as-is,
109 * you'll need to provide the special bits! ... 109 * you'll need to provide the special bits! ...
110 * ... and set IL_EVT_DISABLE to 1. */ 110 * ... and set IL_EVT_DISABLE to 1. */
111void il3945_disable_events(struct il_priv *priv) 111void il3945_disable_events(struct il_priv *il)
112{ 112{
113 int i; 113 int i;
114 u32 base; /* SRAM address of event log header */ 114 u32 base; /* SRAM address of event log header */
@@ -164,27 +164,27 @@ void il3945_disable_events(struct il_priv *priv)
164 0x00000000, /* 1503 - 1472 */ 164 0x00000000, /* 1503 - 1472 */
165 }; 165 };
166 166
167 base = le32_to_cpu(priv->card_alive.log_event_table_ptr); 167 base = le32_to_cpu(il->card_alive.log_event_table_ptr);
168 if (!il3945_hw_valid_rtc_data_addr(base)) { 168 if (!il3945_hw_valid_rtc_data_addr(base)) {
169 IL_ERR(priv, "Invalid event log pointer 0x%08X\n", base); 169 IL_ERR(il, "Invalid event log pointer 0x%08X\n", base);
170 return; 170 return;
171 } 171 }
172 172
173 disable_ptr = il_read_targ_mem(priv, base + (4 * sizeof(u32))); 173 disable_ptr = il_read_targ_mem(il, base + (4 * sizeof(u32)));
174 array_size = il_read_targ_mem(priv, base + (5 * sizeof(u32))); 174 array_size = il_read_targ_mem(il, base + (5 * sizeof(u32)));
175 175
176 if (IL_EVT_DISABLE && (array_size == IL_EVT_DISABLE_SIZE)) { 176 if (IL_EVT_DISABLE && (array_size == IL_EVT_DISABLE_SIZE)) {
177 IL_DEBUG_INFO(priv, "Disabling selected uCode log events at 0x%x\n", 177 IL_DEBUG_INFO(il, "Disabling selected uCode log events at 0x%x\n",
178 disable_ptr); 178 disable_ptr);
179 for (i = 0; i < IL_EVT_DISABLE_SIZE; i++) 179 for (i = 0; i < IL_EVT_DISABLE_SIZE; i++)
180 il_write_targ_mem(priv, 180 il_write_targ_mem(il,
181 disable_ptr + (i * sizeof(u32)), 181 disable_ptr + (i * sizeof(u32)),
182 evt_disable[i]); 182 evt_disable[i]);
183 183
184 } else { 184 } else {
185 IL_DEBUG_INFO(priv, "Selected uCode log events may be disabled\n"); 185 IL_DEBUG_INFO(il, "Selected uCode log events may be disabled\n");
186 IL_DEBUG_INFO(priv, " by writing \"1\"s into disable bitmap\n"); 186 IL_DEBUG_INFO(il, " by writing \"1\"s into disable bitmap\n");
187 IL_DEBUG_INFO(priv, " in SRAM at 0x%x, size %d u32s\n", 187 IL_DEBUG_INFO(il, " in SRAM at 0x%x, size %d u32s\n",
188 disable_ptr, array_size); 188 disable_ptr, array_size);
189 } 189 }
190 190
@@ -240,11 +240,11 @@ static inline const char *il3945_get_tx_fail_reason(u32 status)
240 * for A and B mode we need to overright prev 240 * for A and B mode we need to overright prev
241 * value 241 * value
242 */ 242 */
243int il3945_rs_next_rate(struct il_priv *priv, int rate) 243int il3945_rs_next_rate(struct il_priv *il, int rate)
244{ 244{
245 int next_rate = il3945_get_prev_ieee_rate(rate); 245 int next_rate = il3945_get_prev_ieee_rate(rate);
246 246
247 switch (priv->band) { 247 switch (il->band) {
248 case IEEE80211_BAND_5GHZ: 248 case IEEE80211_BAND_5GHZ:
249 if (rate == IL_RATE_12M_INDEX) 249 if (rate == IL_RATE_12M_INDEX)
250 next_rate = IL_RATE_9M_INDEX; 250 next_rate = IL_RATE_9M_INDEX;
@@ -252,8 +252,8 @@ int il3945_rs_next_rate(struct il_priv *priv, int rate)
252 next_rate = IL_RATE_6M_INDEX; 252 next_rate = IL_RATE_6M_INDEX;
253 break; 253 break;
254 case IEEE80211_BAND_2GHZ: 254 case IEEE80211_BAND_2GHZ:
255 if (!(priv->_3945.sta_supp_rates & IL_OFDM_RATES_MASK) && 255 if (!(il->_3945.sta_supp_rates & IL_OFDM_RATES_MASK) &&
256 il_is_associated(priv, IL_RXON_CTX_BSS)) { 256 il_is_associated(il, IL_RXON_CTX_BSS)) {
257 if (rate == IL_RATE_11M_INDEX) 257 if (rate == IL_RATE_11M_INDEX)
258 next_rate = IL_RATE_5M_INDEX; 258 next_rate = IL_RATE_5M_INDEX;
259 } 259 }
@@ -274,10 +274,10 @@ int il3945_rs_next_rate(struct il_priv *priv, int rate)
274 * need to be reclaimed. As result, some free space forms. If there is 274 * need to be reclaimed. As result, some free space forms. If there is
275 * enough free space (> low mark), wake the stack that feeds us. 275 * enough free space (> low mark), wake the stack that feeds us.
276 */ 276 */
277static void il3945_tx_queue_reclaim(struct il_priv *priv, 277static void il3945_tx_queue_reclaim(struct il_priv *il,
278 int txq_id, int index) 278 int txq_id, int index)
279{ 279{
280 struct il_tx_queue *txq = &priv->txq[txq_id]; 280 struct il_tx_queue *txq = &il->txq[txq_id];
281 struct il_queue *q = &txq->q; 281 struct il_queue *q = &txq->q;
282 struct il_tx_info *tx_info; 282 struct il_tx_info *tx_info;
283 283
@@ -288,28 +288,28 @@ static void il3945_tx_queue_reclaim(struct il_priv *priv,
288 q->read_ptr = il_queue_inc_wrap(q->read_ptr, q->n_bd)) { 288 q->read_ptr = il_queue_inc_wrap(q->read_ptr, q->n_bd)) {
289 289
290 tx_info = &txq->txb[txq->q.read_ptr]; 290 tx_info = &txq->txb[txq->q.read_ptr];
291 ieee80211_tx_status_irqsafe(priv->hw, tx_info->skb); 291 ieee80211_tx_status_irqsafe(il->hw, tx_info->skb);
292 tx_info->skb = NULL; 292 tx_info->skb = NULL;
293 priv->cfg->ops->lib->txq_free_tfd(priv, txq); 293 il->cfg->ops->lib->txq_free_tfd(il, txq);
294 } 294 }
295 295
296 if (il_queue_space(q) > q->low_mark && (txq_id >= 0) && 296 if (il_queue_space(q) > q->low_mark && (txq_id >= 0) &&
297 (txq_id != IWL39_CMD_QUEUE_NUM) && 297 (txq_id != IWL39_CMD_QUEUE_NUM) &&
298 priv->mac80211_registered) 298 il->mac80211_registered)
299 il_wake_queue(priv, txq); 299 il_wake_queue(il, txq);
300} 300}
301 301
302/** 302/**
303 * il3945_rx_reply_tx - Handle Tx response 303 * il3945_rx_reply_tx - Handle Tx response
304 */ 304 */
305static void il3945_rx_reply_tx(struct il_priv *priv, 305static void il3945_rx_reply_tx(struct il_priv *il,
306 struct il_rx_mem_buffer *rxb) 306 struct il_rx_mem_buffer *rxb)
307{ 307{
308 struct il_rx_packet *pkt = rxb_addr(rxb); 308 struct il_rx_packet *pkt = rxb_addr(rxb);
309 u16 sequence = le16_to_cpu(pkt->hdr.sequence); 309 u16 sequence = le16_to_cpu(pkt->hdr.sequence);
310 int txq_id = SEQ_TO_QUEUE(sequence); 310 int txq_id = SEQ_TO_QUEUE(sequence);
311 int index = SEQ_TO_INDEX(sequence); 311 int index = SEQ_TO_INDEX(sequence);
312 struct il_tx_queue *txq = &priv->txq[txq_id]; 312 struct il_tx_queue *txq = &il->txq[txq_id];
313 struct ieee80211_tx_info *info; 313 struct ieee80211_tx_info *info;
314 struct il3945_tx_resp *tx_resp = (void *)&pkt->u.raw[0]; 314 struct il3945_tx_resp *tx_resp = (void *)&pkt->u.raw[0];
315 u32 status = le32_to_cpu(tx_resp->status); 315 u32 status = le32_to_cpu(tx_resp->status);
@@ -317,7 +317,7 @@ static void il3945_rx_reply_tx(struct il_priv *priv,
317 int fail; 317 int fail;
318 318
319 if ((index >= txq->q.n_bd) || (il_queue_used(&txq->q, index) == 0)) { 319 if ((index >= txq->q.n_bd) || (il_queue_used(&txq->q, index) == 0)) {
320 IL_ERR(priv, "Read index for DMA queue txq_id (%d) index %d " 320 IL_ERR(il, "Read index for DMA queue txq_id (%d) index %d "
321 "is out of range [0-%d] %d %d\n", txq_id, 321 "is out of range [0-%d] %d %d\n", txq_id,
322 index, txq->q.n_bd, txq->q.write_ptr, 322 index, txq->q.n_bd, txq->q.write_ptr,
323 txq->q.read_ptr); 323 txq->q.read_ptr);
@@ -342,15 +342,15 @@ static void il3945_rx_reply_tx(struct il_priv *priv,
342 info->flags |= ((status & TX_STATUS_MSK) == TX_STATUS_SUCCESS) ? 342 info->flags |= ((status & TX_STATUS_MSK) == TX_STATUS_SUCCESS) ?
343 IEEE80211_TX_STAT_ACK : 0; 343 IEEE80211_TX_STAT_ACK : 0;
344 344
345 IL_DEBUG_TX(priv, "Tx queue %d Status %s (0x%08x) plcp rate %d retries %d\n", 345 IL_DEBUG_TX(il, "Tx queue %d Status %s (0x%08x) plcp rate %d retries %d\n",
346 txq_id, il3945_get_tx_fail_reason(status), status, 346 txq_id, il3945_get_tx_fail_reason(status), status,
347 tx_resp->rate, tx_resp->failure_frame); 347 tx_resp->rate, tx_resp->failure_frame);
348 348
349 IL_DEBUG_TX_REPLY(priv, "Tx queue reclaim %d\n", index); 349 IL_DEBUG_TX_REPLY(il, "Tx queue reclaim %d\n", index);
350 il3945_tx_queue_reclaim(priv, txq_id, index); 350 il3945_tx_queue_reclaim(il, txq_id, index);
351 351
352 if (status & TX_ABORT_REQUIRED_MSK) 352 if (status & TX_ABORT_REQUIRED_MSK)
353 IL_ERR(priv, "TODO: Implement Tx ABORT REQUIRED!!!\n"); 353 IL_ERR(il, "TODO: Implement Tx ABORT REQUIRED!!!\n");
354} 354}
355 355
356 356
@@ -363,7 +363,7 @@ static void il3945_rx_reply_tx(struct il_priv *priv,
363 * 363 *
364 *****************************************************************************/ 364 *****************************************************************************/
365#ifdef CONFIG_IWLWIFI_LEGACY_DEBUGFS 365#ifdef CONFIG_IWLWIFI_LEGACY_DEBUGFS
366static void il3945_accumulative_statistics(struct il_priv *priv, 366static void il3945_accumulative_statistics(struct il_priv *il,
367 __le32 *stats) 367 __le32 *stats)
368{ 368{
369 int i; 369 int i;
@@ -371,10 +371,10 @@ static void il3945_accumulative_statistics(struct il_priv *priv,
371 u32 *accum_stats; 371 u32 *accum_stats;
372 u32 *delta, *max_delta; 372 u32 *delta, *max_delta;
373 373
374 prev_stats = (__le32 *)&priv->_3945.statistics; 374 prev_stats = (__le32 *)&il->_3945.statistics;
375 accum_stats = (u32 *)&priv->_3945.accum_statistics; 375 accum_stats = (u32 *)&il->_3945.accum_statistics;
376 delta = (u32 *)&priv->_3945.delta_statistics; 376 delta = (u32 *)&il->_3945.delta_statistics;
377 max_delta = (u32 *)&priv->_3945.max_delta; 377 max_delta = (u32 *)&il->_3945.max_delta;
378 378
379 for (i = sizeof(__le32); i < sizeof(struct il3945_notif_statistics); 379 for (i = sizeof(__le32); i < sizeof(struct il3945_notif_statistics);
380 i += sizeof(__le32), stats++, prev_stats++, delta++, 380 i += sizeof(__le32), stats++, prev_stats++, delta++,
@@ -389,29 +389,29 @@ static void il3945_accumulative_statistics(struct il_priv *priv,
389 } 389 }
390 390
391 /* reset accumulative statistics for "no-counter" type statistics */ 391 /* reset accumulative statistics for "no-counter" type statistics */
392 priv->_3945.accum_statistics.general.temperature = 392 il->_3945.accum_statistics.general.temperature =
393 priv->_3945.statistics.general.temperature; 393 il->_3945.statistics.general.temperature;
394 priv->_3945.accum_statistics.general.ttl_timestamp = 394 il->_3945.accum_statistics.general.ttl_timestamp =
395 priv->_3945.statistics.general.ttl_timestamp; 395 il->_3945.statistics.general.ttl_timestamp;
396} 396}
397#endif 397#endif
398 398
399void il3945_hw_rx_statistics(struct il_priv *priv, 399void il3945_hw_rx_statistics(struct il_priv *il,
400 struct il_rx_mem_buffer *rxb) 400 struct il_rx_mem_buffer *rxb)
401{ 401{
402 struct il_rx_packet *pkt = rxb_addr(rxb); 402 struct il_rx_packet *pkt = rxb_addr(rxb);
403 403
404 IL_DEBUG_RX(priv, "Statistics notification received (%d vs %d).\n", 404 IL_DEBUG_RX(il, "Statistics notification received (%d vs %d).\n",
405 (int)sizeof(struct il3945_notif_statistics), 405 (int)sizeof(struct il3945_notif_statistics),
406 le32_to_cpu(pkt->len_n_flags) & FH_RSCSR_FRAME_SIZE_MSK); 406 le32_to_cpu(pkt->len_n_flags) & FH_RSCSR_FRAME_SIZE_MSK);
407#ifdef CONFIG_IWLWIFI_LEGACY_DEBUGFS 407#ifdef CONFIG_IWLWIFI_LEGACY_DEBUGFS
408 il3945_accumulative_statistics(priv, (__le32 *)&pkt->u.raw); 408 il3945_accumulative_statistics(il, (__le32 *)&pkt->u.raw);
409#endif 409#endif
410 410
411 memcpy(&priv->_3945.statistics, pkt->u.raw, sizeof(priv->_3945.statistics)); 411 memcpy(&il->_3945.statistics, pkt->u.raw, sizeof(il->_3945.statistics));
412} 412}
413 413
414void il3945_reply_statistics(struct il_priv *priv, 414void il3945_reply_statistics(struct il_priv *il,
415 struct il_rx_mem_buffer *rxb) 415 struct il_rx_mem_buffer *rxb)
416{ 416{
417 struct il_rx_packet *pkt = rxb_addr(rxb); 417 struct il_rx_packet *pkt = rxb_addr(rxb);
@@ -419,16 +419,16 @@ void il3945_reply_statistics(struct il_priv *priv,
419 419
420 if (le32_to_cpu(*flag) & UCODE_STATISTICS_CLEAR_MSK) { 420 if (le32_to_cpu(*flag) & UCODE_STATISTICS_CLEAR_MSK) {
421#ifdef CONFIG_IWLWIFI_LEGACY_DEBUGFS 421#ifdef CONFIG_IWLWIFI_LEGACY_DEBUGFS
422 memset(&priv->_3945.accum_statistics, 0, 422 memset(&il->_3945.accum_statistics, 0,
423 sizeof(struct il3945_notif_statistics)); 423 sizeof(struct il3945_notif_statistics));
424 memset(&priv->_3945.delta_statistics, 0, 424 memset(&il->_3945.delta_statistics, 0,
425 sizeof(struct il3945_notif_statistics)); 425 sizeof(struct il3945_notif_statistics));
426 memset(&priv->_3945.max_delta, 0, 426 memset(&il->_3945.max_delta, 0,
427 sizeof(struct il3945_notif_statistics)); 427 sizeof(struct il3945_notif_statistics));
428#endif 428#endif
429 IL_DEBUG_RX(priv, "Statistics have been cleared\n"); 429 IL_DEBUG_RX(il, "Statistics have been cleared\n");
430 } 430 }
431 il3945_hw_rx_statistics(priv, rxb); 431 il3945_hw_rx_statistics(il, rxb);
432} 432}
433 433
434 434
@@ -439,24 +439,24 @@ void il3945_reply_statistics(struct il_priv *priv,
439 ******************************************************************************/ 439 ******************************************************************************/
440 440
441/* This is necessary only for a number of statistics, see the caller. */ 441/* This is necessary only for a number of statistics, see the caller. */
442static int il3945_is_network_packet(struct il_priv *priv, 442static int il3945_is_network_packet(struct il_priv *il,
443 struct ieee80211_hdr *header) 443 struct ieee80211_hdr *header)
444{ 444{
445 /* Filter incoming packets to determine if they are targeted toward 445 /* Filter incoming packets to determine if they are targeted toward
446 * this network, discarding packets coming from ourselves */ 446 * this network, discarding packets coming from ourselves */
447 switch (priv->iw_mode) { 447 switch (il->iw_mode) {
448 case NL80211_IFTYPE_ADHOC: /* Header: Dest. | Source | BSSID */ 448 case NL80211_IFTYPE_ADHOC: /* Header: Dest. | Source | BSSID */
449 /* packets to our IBSS update information */ 449 /* packets to our IBSS update information */
450 return !compare_ether_addr(header->addr3, priv->bssid); 450 return !compare_ether_addr(header->addr3, il->bssid);
451 case NL80211_IFTYPE_STATION: /* Header: Dest. | AP{BSSID} | Source */ 451 case NL80211_IFTYPE_STATION: /* Header: Dest. | AP{BSSID} | Source */
452 /* packets to our IBSS update information */ 452 /* packets to our IBSS update information */
453 return !compare_ether_addr(header->addr2, priv->bssid); 453 return !compare_ether_addr(header->addr2, il->bssid);
454 default: 454 default:
455 return 1; 455 return 1;
456 } 456 }
457} 457}
458 458
459static void il3945_pass_packet_to_mac80211(struct il_priv *priv, 459static void il3945_pass_packet_to_mac80211(struct il_priv *il,
460 struct il_rx_mem_buffer *rxb, 460 struct il_rx_mem_buffer *rxb,
461 struct ieee80211_rx_status *stats) 461 struct ieee80211_rx_status *stats)
462{ 462{
@@ -470,43 +470,43 @@ static void il3945_pass_packet_to_mac80211(struct il_priv *priv,
470 470
471 /* We received data from the HW, so stop the watchdog */ 471 /* We received data from the HW, so stop the watchdog */
472 if (unlikely(len + IWL39_RX_FRAME_SIZE > 472 if (unlikely(len + IWL39_RX_FRAME_SIZE >
473 PAGE_SIZE << priv->hw_params.rx_page_order)) { 473 PAGE_SIZE << il->hw_params.rx_page_order)) {
474 IL_DEBUG_DROP(priv, "Corruption detected!\n"); 474 IL_DEBUG_DROP(il, "Corruption detected!\n");
475 return; 475 return;
476 } 476 }
477 477
478 /* We only process data packets if the interface is open */ 478 /* We only process data packets if the interface is open */
479 if (unlikely(!priv->is_open)) { 479 if (unlikely(!il->is_open)) {
480 IL_DEBUG_DROP_LIMIT(priv, 480 IL_DEBUG_DROP_LIMIT(il,
481 "Dropping packet while interface is not open.\n"); 481 "Dropping packet while interface is not open.\n");
482 return; 482 return;
483 } 483 }
484 484
485 skb = dev_alloc_skb(128); 485 skb = dev_alloc_skb(128);
486 if (!skb) { 486 if (!skb) {
487 IL_ERR(priv, "dev_alloc_skb failed\n"); 487 IL_ERR(il, "dev_alloc_skb failed\n");
488 return; 488 return;
489 } 489 }
490 490
491 if (!il3945_mod_params.sw_crypto) 491 if (!il3945_mod_params.sw_crypto)
492 il_set_decrypted_flag(priv, 492 il_set_decrypted_flag(il,
493 (struct ieee80211_hdr *)rxb_addr(rxb), 493 (struct ieee80211_hdr *)rxb_addr(rxb),
494 le32_to_cpu(rx_end->status), stats); 494 le32_to_cpu(rx_end->status), stats);
495 495
496 skb_add_rx_frag(skb, 0, rxb->page, 496 skb_add_rx_frag(skb, 0, rxb->page,
497 (void *)rx_hdr->payload - (void *)pkt, len); 497 (void *)rx_hdr->payload - (void *)pkt, len);
498 498
499 il_update_stats(priv, false, fc, len); 499 il_update_stats(il, false, fc, len);
500 memcpy(IEEE80211_SKB_RXCB(skb), stats, sizeof(*stats)); 500 memcpy(IEEE80211_SKB_RXCB(skb), stats, sizeof(*stats));
501 501
502 ieee80211_rx(priv->hw, skb); 502 ieee80211_rx(il->hw, skb);
503 priv->alloc_rxb_page--; 503 il->alloc_rxb_page--;
504 rxb->page = NULL; 504 rxb->page = NULL;
505} 505}
506 506
507#define IL_DELAY_NEXT_SCAN_AFTER_ASSOC (HZ*6) 507#define IL_DELAY_NEXT_SCAN_AFTER_ASSOC (HZ*6)
508 508
509static void il3945_rx_reply_rx(struct il_priv *priv, 509static void il3945_rx_reply_rx(struct il_priv *il,
510 struct il_rx_mem_buffer *rxb) 510 struct il_rx_mem_buffer *rxb)
511{ 511{
512 struct ieee80211_hdr *header; 512 struct ieee80211_hdr *header;
@@ -539,14 +539,14 @@ static void il3945_rx_reply_rx(struct il_priv *priv,
539 rx_status.flag |= RX_FLAG_SHORTPRE; 539 rx_status.flag |= RX_FLAG_SHORTPRE;
540 540
541 if ((unlikely(rx_stats->phy_count > 20))) { 541 if ((unlikely(rx_stats->phy_count > 20))) {
542 IL_DEBUG_DROP(priv, "dsp size out of range [0,20]: %d/n", 542 IL_DEBUG_DROP(il, "dsp size out of range [0,20]: %d/n",
543 rx_stats->phy_count); 543 rx_stats->phy_count);
544 return; 544 return;
545 } 545 }
546 546
547 if (!(rx_end->status & RX_RES_STATUS_NO_CRC32_ERROR) 547 if (!(rx_end->status & RX_RES_STATUS_NO_CRC32_ERROR)
548 || !(rx_end->status & RX_RES_STATUS_NO_RXE_OVERFLOW)) { 548 || !(rx_end->status & RX_RES_STATUS_NO_RXE_OVERFLOW)) {
549 IL_DEBUG_RX(priv, "Bad CRC or FIFO: 0x%08X.\n", rx_end->status); 549 IL_DEBUG_RX(il, "Bad CRC or FIFO: 0x%08X.\n", rx_end->status);
550 return; 550 return;
551 } 551 }
552 552
@@ -555,34 +555,34 @@ static void il3945_rx_reply_rx(struct il_priv *priv,
555 /* Convert 3945's rssi indicator to dBm */ 555 /* Convert 3945's rssi indicator to dBm */
556 rx_status.signal = rx_stats->rssi - IWL39_RSSI_OFFSET; 556 rx_status.signal = rx_stats->rssi - IWL39_RSSI_OFFSET;
557 557
558 IL_DEBUG_STATS(priv, "Rssi %d sig_avg %d noise_diff %d\n", 558 IL_DEBUG_STATS(il, "Rssi %d sig_avg %d noise_diff %d\n",
559 rx_status.signal, rx_stats_sig_avg, 559 rx_status.signal, rx_stats_sig_avg,
560 rx_stats_noise_diff); 560 rx_stats_noise_diff);
561 561
562 header = (struct ieee80211_hdr *)IL_RX_DATA(pkt); 562 header = (struct ieee80211_hdr *)IL_RX_DATA(pkt);
563 563
564 network_packet = il3945_is_network_packet(priv, header); 564 network_packet = il3945_is_network_packet(il, header);
565 565
566 IL_DEBUG_STATS_LIMIT(priv, "[%c] %d RSSI:%d Signal:%u, Rate:%u\n", 566 IL_DEBUG_STATS_LIMIT(il, "[%c] %d RSSI:%d Signal:%u, Rate:%u\n",
567 network_packet ? '*' : ' ', 567 network_packet ? '*' : ' ',
568 le16_to_cpu(rx_hdr->channel), 568 le16_to_cpu(rx_hdr->channel),
569 rx_status.signal, rx_status.signal, 569 rx_status.signal, rx_status.signal,
570 rx_status.rate_idx); 570 rx_status.rate_idx);
571 571
572 il_dbg_log_rx_data_frame(priv, le16_to_cpu(rx_hdr->len), 572 il_dbg_log_rx_data_frame(il, le16_to_cpu(rx_hdr->len),
573 header); 573 header);
574 574
575 if (network_packet) { 575 if (network_packet) {
576 priv->_3945.last_beacon_time = 576 il->_3945.last_beacon_time =
577 le32_to_cpu(rx_end->beacon_timestamp); 577 le32_to_cpu(rx_end->beacon_timestamp);
578 priv->_3945.last_tsf = le64_to_cpu(rx_end->timestamp); 578 il->_3945.last_tsf = le64_to_cpu(rx_end->timestamp);
579 priv->_3945.last_rx_rssi = rx_status.signal; 579 il->_3945.last_rx_rssi = rx_status.signal;
580 } 580 }
581 581
582 il3945_pass_packet_to_mac80211(priv, rxb, &rx_status); 582 il3945_pass_packet_to_mac80211(il, rxb, &rx_status);
583} 583}
584 584
585int il3945_hw_txq_attach_buf_to_tfd(struct il_priv *priv, 585int il3945_hw_txq_attach_buf_to_tfd(struct il_priv *il,
586 struct il_tx_queue *txq, 586 struct il_tx_queue *txq,
587 dma_addr_t addr, u16 len, u8 reset, u8 pad) 587 dma_addr_t addr, u16 len, u8 reset, u8 pad)
588{ 588{
@@ -600,7 +600,7 @@ int il3945_hw_txq_attach_buf_to_tfd(struct il_priv *priv,
600 count = TFD_CTL_COUNT_GET(le32_to_cpu(tfd->control_flags)); 600 count = TFD_CTL_COUNT_GET(le32_to_cpu(tfd->control_flags));
601 601
602 if ((count >= NUM_TFD_CHUNKS) || (count < 0)) { 602 if ((count >= NUM_TFD_CHUNKS) || (count < 0)) {
603 IL_ERR(priv, "Error can not send more than %d chunks\n", 603 IL_ERR(il, "Error can not send more than %d chunks\n",
604 NUM_TFD_CHUNKS); 604 NUM_TFD_CHUNKS);
605 return -EINVAL; 605 return -EINVAL;
606 } 606 }
@@ -621,19 +621,19 @@ int il3945_hw_txq_attach_buf_to_tfd(struct il_priv *priv,
621 * 621 *
622 * Does NOT advance any indexes 622 * Does NOT advance any indexes
623 */ 623 */
624void il3945_hw_txq_free_tfd(struct il_priv *priv, struct il_tx_queue *txq) 624void il3945_hw_txq_free_tfd(struct il_priv *il, struct il_tx_queue *txq)
625{ 625{
626 struct il3945_tfd *tfd_tmp = (struct il3945_tfd *)txq->tfds; 626 struct il3945_tfd *tfd_tmp = (struct il3945_tfd *)txq->tfds;
627 int index = txq->q.read_ptr; 627 int index = txq->q.read_ptr;
628 struct il3945_tfd *tfd = &tfd_tmp[index]; 628 struct il3945_tfd *tfd = &tfd_tmp[index];
629 struct pci_dev *dev = priv->pci_dev; 629 struct pci_dev *dev = il->pci_dev;
630 int i; 630 int i;
631 int counter; 631 int counter;
632 632
633 /* sanity check */ 633 /* sanity check */
634 counter = TFD_CTL_COUNT_GET(le32_to_cpu(tfd->control_flags)); 634 counter = TFD_CTL_COUNT_GET(le32_to_cpu(tfd->control_flags));
635 if (counter > NUM_TFD_CHUNKS) { 635 if (counter > NUM_TFD_CHUNKS) {
636 IL_ERR(priv, "Too many chunks: %i\n", counter); 636 IL_ERR(il, "Too many chunks: %i\n", counter);
637 /* @todo issue fatal error, it is quite serious situation */ 637 /* @todo issue fatal error, it is quite serious situation */
638 return; 638 return;
639 } 639 }
@@ -669,13 +669,13 @@ void il3945_hw_txq_free_tfd(struct il_priv *priv, struct il_tx_queue *txq)
669 * il3945_hw_build_tx_cmd_rate - Add rate portion to TX_CMD: 669 * il3945_hw_build_tx_cmd_rate - Add rate portion to TX_CMD:
670 * 670 *
671*/ 671*/
672void il3945_hw_build_tx_cmd_rate(struct il_priv *priv, 672void il3945_hw_build_tx_cmd_rate(struct il_priv *il,
673 struct il_device_cmd *cmd, 673 struct il_device_cmd *cmd,
674 struct ieee80211_tx_info *info, 674 struct ieee80211_tx_info *info,
675 struct ieee80211_hdr *hdr, 675 struct ieee80211_hdr *hdr,
676 int sta_id, int tx_id) 676 int sta_id, int tx_id)
677{ 677{
678 u16 hw_value = ieee80211_get_tx_rate(priv->hw, info)->hw_value; 678 u16 hw_value = ieee80211_get_tx_rate(il->hw, info)->hw_value;
679 u16 rate_index = min(hw_value & 0xffff, IL_RATE_COUNT_3945); 679 u16 rate_index = min(hw_value & 0xffff, IL_RATE_COUNT_3945);
680 u16 rate_mask; 680 u16 rate_mask;
681 int rate; 681 int rate;
@@ -718,13 +718,13 @@ void il3945_hw_build_tx_cmd_rate(struct il_priv *priv,
718 /* CCK */ 718 /* CCK */
719 tx_cmd->supp_rates[1] = (rate_mask & 0xF); 719 tx_cmd->supp_rates[1] = (rate_mask & 0xF);
720 720
721 IL_DEBUG_RATE(priv, "Tx sta id: %d, rate: %d (plcp), flags: 0x%4X " 721 IL_DEBUG_RATE(il, "Tx sta id: %d, rate: %d (plcp), flags: 0x%4X "
722 "cck/ofdm mask: 0x%x/0x%x\n", sta_id, 722 "cck/ofdm mask: 0x%x/0x%x\n", sta_id,
723 tx_cmd->rate, le32_to_cpu(tx_cmd->tx_flags), 723 tx_cmd->rate, le32_to_cpu(tx_cmd->tx_flags),
724 tx_cmd->supp_rates[1], tx_cmd->supp_rates[0]); 724 tx_cmd->supp_rates[1], tx_cmd->supp_rates[0]);
725} 725}
726 726
727static u8 il3945_sync_sta(struct il_priv *priv, int sta_id, u16 tx_rate) 727static u8 il3945_sync_sta(struct il_priv *il, int sta_id, u16 tx_rate)
728{ 728{
729 unsigned long flags_spin; 729 unsigned long flags_spin;
730 struct il_station_entry *station; 730 struct il_station_entry *station;
@@ -732,52 +732,52 @@ static u8 il3945_sync_sta(struct il_priv *priv, int sta_id, u16 tx_rate)
732 if (sta_id == IL_INVALID_STATION) 732 if (sta_id == IL_INVALID_STATION)
733 return IL_INVALID_STATION; 733 return IL_INVALID_STATION;
734 734
735 spin_lock_irqsave(&priv->sta_lock, flags_spin); 735 spin_lock_irqsave(&il->sta_lock, flags_spin);
736 station = &priv->stations[sta_id]; 736 station = &il->stations[sta_id];
737 737
738 station->sta.sta.modify_mask = STA_MODIFY_TX_RATE_MSK; 738 station->sta.sta.modify_mask = STA_MODIFY_TX_RATE_MSK;
739 station->sta.rate_n_flags = cpu_to_le16(tx_rate); 739 station->sta.rate_n_flags = cpu_to_le16(tx_rate);
740 station->sta.mode = STA_CONTROL_MODIFY_MSK; 740 station->sta.mode = STA_CONTROL_MODIFY_MSK;
741 il_send_add_sta(priv, &station->sta, CMD_ASYNC); 741 il_send_add_sta(il, &station->sta, CMD_ASYNC);
742 spin_unlock_irqrestore(&priv->sta_lock, flags_spin); 742 spin_unlock_irqrestore(&il->sta_lock, flags_spin);
743 743
744 IL_DEBUG_RATE(priv, "SCALE sync station %d to rate %d\n", 744 IL_DEBUG_RATE(il, "SCALE sync station %d to rate %d\n",
745 sta_id, tx_rate); 745 sta_id, tx_rate);
746 return sta_id; 746 return sta_id;
747} 747}
748 748
749static void il3945_set_pwr_vmain(struct il_priv *priv) 749static void il3945_set_pwr_vmain(struct il_priv *il)
750{ 750{
751/* 751/*
752 * (for documentation purposes) 752 * (for documentation purposes)
753 * to set power to V_AUX, do 753 * to set power to V_AUX, do
754 754
755 if (pci_pme_capable(priv->pci_dev, PCI_D3cold)) { 755 if (pci_pme_capable(il->pci_dev, PCI_D3cold)) {
756 il_set_bits_mask_prph(priv, APMG_PS_CTRL_REG, 756 il_set_bits_mask_prph(il, APMG_PS_CTRL_REG,
757 APMG_PS_CTRL_VAL_PWR_SRC_VAUX, 757 APMG_PS_CTRL_VAL_PWR_SRC_VAUX,
758 ~APMG_PS_CTRL_MSK_PWR_SRC); 758 ~APMG_PS_CTRL_MSK_PWR_SRC);
759 759
760 il_poll_bit(priv, CSR_GPIO_IN, 760 il_poll_bit(il, CSR_GPIO_IN,
761 CSR_GPIO_IN_VAL_VAUX_PWR_SRC, 761 CSR_GPIO_IN_VAL_VAUX_PWR_SRC,
762 CSR_GPIO_IN_BIT_AUX_POWER, 5000); 762 CSR_GPIO_IN_BIT_AUX_POWER, 5000);
763 } 763 }
764 */ 764 */
765 765
766 il_set_bits_mask_prph(priv, APMG_PS_CTRL_REG, 766 il_set_bits_mask_prph(il, APMG_PS_CTRL_REG,
767 APMG_PS_CTRL_VAL_PWR_SRC_VMAIN, 767 APMG_PS_CTRL_VAL_PWR_SRC_VMAIN,
768 ~APMG_PS_CTRL_MSK_PWR_SRC); 768 ~APMG_PS_CTRL_MSK_PWR_SRC);
769 769
770 il_poll_bit(priv, CSR_GPIO_IN, CSR_GPIO_IN_VAL_VMAIN_PWR_SRC, 770 il_poll_bit(il, CSR_GPIO_IN, CSR_GPIO_IN_VAL_VMAIN_PWR_SRC,
771 CSR_GPIO_IN_BIT_AUX_POWER, 5000); /* uS */ 771 CSR_GPIO_IN_BIT_AUX_POWER, 5000); /* uS */
772} 772}
773 773
774static int il3945_rx_init(struct il_priv *priv, struct il_rx_queue *rxq) 774static int il3945_rx_init(struct il_priv *il, struct il_rx_queue *rxq)
775{ 775{
776 il_write_direct32(priv, FH39_RCSR_RBD_BASE(0), rxq->bd_dma); 776 il_write_direct32(il, FH39_RCSR_RBD_BASE(0), rxq->bd_dma);
777 il_write_direct32(priv, FH39_RCSR_RPTR_ADDR(0), 777 il_write_direct32(il, FH39_RCSR_RPTR_ADDR(0),
778 rxq->rb_stts_dma); 778 rxq->rb_stts_dma);
779 il_write_direct32(priv, FH39_RCSR_WPTR(0), 0); 779 il_write_direct32(il, FH39_RCSR_WPTR(0), 0);
780 il_write_direct32(priv, FH39_RCSR_CONFIG(0), 780 il_write_direct32(il, FH39_RCSR_CONFIG(0),
781 FH39_RCSR_RX_CONFIG_REG_VAL_DMA_CHNL_EN_ENABLE | 781 FH39_RCSR_RX_CONFIG_REG_VAL_DMA_CHNL_EN_ENABLE |
782 FH39_RCSR_RX_CONFIG_REG_VAL_RDRBD_EN_ENABLE | 782 FH39_RCSR_RX_CONFIG_REG_VAL_RDRBD_EN_ENABLE |
783 FH39_RCSR_RX_CONFIG_REG_BIT_WR_STTS_EN | 783 FH39_RCSR_RX_CONFIG_REG_BIT_WR_STTS_EN |
@@ -788,32 +788,32 @@ static int il3945_rx_init(struct il_priv *priv, struct il_rx_queue *rxq)
788 FH39_RCSR_RX_CONFIG_REG_VAL_MSG_MODE_FH); 788 FH39_RCSR_RX_CONFIG_REG_VAL_MSG_MODE_FH);
789 789
790 /* fake read to flush all prev I/O */ 790 /* fake read to flush all prev I/O */
791 il_read_direct32(priv, FH39_RSSR_CTRL); 791 il_read_direct32(il, FH39_RSSR_CTRL);
792 792
793 return 0; 793 return 0;
794} 794}
795 795
796static int il3945_tx_reset(struct il_priv *priv) 796static int il3945_tx_reset(struct il_priv *il)
797{ 797{
798 798
799 /* bypass mode */ 799 /* bypass mode */
800 il_write_prph(priv, ALM_SCD_MODE_REG, 0x2); 800 il_write_prph(il, ALM_SCD_MODE_REG, 0x2);
801 801
802 /* RA 0 is active */ 802 /* RA 0 is active */
803 il_write_prph(priv, ALM_SCD_ARASTAT_REG, 0x01); 803 il_write_prph(il, ALM_SCD_ARASTAT_REG, 0x01);
804 804
805 /* all 6 fifo are active */ 805 /* all 6 fifo are active */
806 il_write_prph(priv, ALM_SCD_TXFACT_REG, 0x3f); 806 il_write_prph(il, ALM_SCD_TXFACT_REG, 0x3f);
807 807
808 il_write_prph(priv, ALM_SCD_SBYP_MODE_1_REG, 0x010000); 808 il_write_prph(il, ALM_SCD_SBYP_MODE_1_REG, 0x010000);
809 il_write_prph(priv, ALM_SCD_SBYP_MODE_2_REG, 0x030002); 809 il_write_prph(il, ALM_SCD_SBYP_MODE_2_REG, 0x030002);
810 il_write_prph(priv, ALM_SCD_TXF4MF_REG, 0x000004); 810 il_write_prph(il, ALM_SCD_TXF4MF_REG, 0x000004);
811 il_write_prph(priv, ALM_SCD_TXF5MF_REG, 0x000005); 811 il_write_prph(il, ALM_SCD_TXF5MF_REG, 0x000005);
812 812
813 il_write_direct32(priv, FH39_TSSR_CBB_BASE, 813 il_write_direct32(il, FH39_TSSR_CBB_BASE,
814 priv->_3945.shared_phys); 814 il->_3945.shared_phys);
815 815
816 il_write_direct32(priv, FH39_TSSR_MSG_CONFIG, 816 il_write_direct32(il, FH39_TSSR_MSG_CONFIG,
817 FH39_TSSR_TX_MSG_CONFIG_REG_VAL_SNOOP_RD_TXPD_ON | 817 FH39_TSSR_TX_MSG_CONFIG_REG_VAL_SNOOP_RD_TXPD_ON |
818 FH39_TSSR_TX_MSG_CONFIG_REG_VAL_ORDER_RD_TXPD_ON | 818 FH39_TSSR_TX_MSG_CONFIG_REG_VAL_ORDER_RD_TXPD_ON |
819 FH39_TSSR_TX_MSG_CONFIG_REG_VAL_MAX_FRAG_SIZE_128B | 819 FH39_TSSR_TX_MSG_CONFIG_REG_VAL_MAX_FRAG_SIZE_128B |
@@ -831,31 +831,31 @@ static int il3945_tx_reset(struct il_priv *priv)
831 * 831 *
832 * Destroys all DMA structures and initialize them again 832 * Destroys all DMA structures and initialize them again
833 */ 833 */
834static int il3945_txq_ctx_reset(struct il_priv *priv) 834static int il3945_txq_ctx_reset(struct il_priv *il)
835{ 835{
836 int rc; 836 int rc;
837 int txq_id, slots_num; 837 int txq_id, slots_num;
838 838
839 il3945_hw_txq_ctx_free(priv); 839 il3945_hw_txq_ctx_free(il);
840 840
841 /* allocate tx queue structure */ 841 /* allocate tx queue structure */
842 rc = il_alloc_txq_mem(priv); 842 rc = il_alloc_txq_mem(il);
843 if (rc) 843 if (rc)
844 return rc; 844 return rc;
845 845
846 /* Tx CMD queue */ 846 /* Tx CMD queue */
847 rc = il3945_tx_reset(priv); 847 rc = il3945_tx_reset(il);
848 if (rc) 848 if (rc)
849 goto error; 849 goto error;
850 850
851 /* Tx queue(s) */ 851 /* Tx queue(s) */
852 for (txq_id = 0; txq_id < priv->hw_params.max_txq_num; txq_id++) { 852 for (txq_id = 0; txq_id < il->hw_params.max_txq_num; txq_id++) {
853 slots_num = (txq_id == IWL39_CMD_QUEUE_NUM) ? 853 slots_num = (txq_id == IWL39_CMD_QUEUE_NUM) ?
854 TFD_CMD_SLOTS : TFD_TX_CMD_SLOTS; 854 TFD_CMD_SLOTS : TFD_TX_CMD_SLOTS;
855 rc = il_tx_queue_init(priv, &priv->txq[txq_id], 855 rc = il_tx_queue_init(il, &il->txq[txq_id],
856 slots_num, txq_id); 856 slots_num, txq_id);
857 if (rc) { 857 if (rc) {
858 IL_ERR(priv, "Tx %d queue init failed\n", txq_id); 858 IL_ERR(il, "Tx %d queue init failed\n", txq_id);
859 goto error; 859 goto error;
860 } 860 }
861 } 861 }
@@ -863,7 +863,7 @@ static int il3945_txq_ctx_reset(struct il_priv *priv)
863 return rc; 863 return rc;
864 864
865 error: 865 error:
866 il3945_hw_txq_ctx_free(priv); 866 il3945_hw_txq_ctx_free(il);
867 return rc; 867 return rc;
868} 868}
869 869
@@ -873,127 +873,127 @@ static int il3945_txq_ctx_reset(struct il_priv *priv)
873 * (e.g. after platform boot, or shutdown via il_apm_stop()) 873 * (e.g. after platform boot, or shutdown via il_apm_stop())
874 * NOTE: This does not load uCode nor start the embedded processor 874 * NOTE: This does not load uCode nor start the embedded processor
875 */ 875 */
876static int il3945_apm_init(struct il_priv *priv) 876static int il3945_apm_init(struct il_priv *il)
877{ 877{
878 int ret = il_apm_init(priv); 878 int ret = il_apm_init(il);
879 879
880 /* Clear APMG (NIC's internal power management) interrupts */ 880 /* Clear APMG (NIC's internal power management) interrupts */
881 il_write_prph(priv, APMG_RTC_INT_MSK_REG, 0x0); 881 il_write_prph(il, APMG_RTC_INT_MSK_REG, 0x0);
882 il_write_prph(priv, APMG_RTC_INT_STT_REG, 0xFFFFFFFF); 882 il_write_prph(il, APMG_RTC_INT_STT_REG, 0xFFFFFFFF);
883 883
884 /* Reset radio chip */ 884 /* Reset radio chip */
885 il_set_bits_prph(priv, APMG_PS_CTRL_REG, 885 il_set_bits_prph(il, APMG_PS_CTRL_REG,
886 APMG_PS_CTRL_VAL_RESET_REQ); 886 APMG_PS_CTRL_VAL_RESET_REQ);
887 udelay(5); 887 udelay(5);
888 il_clear_bits_prph(priv, APMG_PS_CTRL_REG, 888 il_clear_bits_prph(il, APMG_PS_CTRL_REG,
889 APMG_PS_CTRL_VAL_RESET_REQ); 889 APMG_PS_CTRL_VAL_RESET_REQ);
890 890
891 return ret; 891 return ret;
892} 892}
893 893
894static void il3945_nic_config(struct il_priv *priv) 894static void il3945_nic_config(struct il_priv *il)
895{ 895{
896 struct il3945_eeprom *eeprom = (struct il3945_eeprom *)priv->eeprom; 896 struct il3945_eeprom *eeprom = (struct il3945_eeprom *)il->eeprom;
897 unsigned long flags; 897 unsigned long flags;
898 u8 rev_id = priv->pci_dev->revision; 898 u8 rev_id = il->pci_dev->revision;
899 899
900 spin_lock_irqsave(&priv->lock, flags); 900 spin_lock_irqsave(&il->lock, flags);
901 901
902 /* Determine HW type */ 902 /* Determine HW type */
903 IL_DEBUG_INFO(priv, "HW Revision ID = 0x%X\n", rev_id); 903 IL_DEBUG_INFO(il, "HW Revision ID = 0x%X\n", rev_id);
904 904
905 if (rev_id & PCI_CFG_REV_ID_BIT_RTP) 905 if (rev_id & PCI_CFG_REV_ID_BIT_RTP)
906 IL_DEBUG_INFO(priv, "RTP type\n"); 906 IL_DEBUG_INFO(il, "RTP type\n");
907 else if (rev_id & PCI_CFG_REV_ID_BIT_BASIC_SKU) { 907 else if (rev_id & PCI_CFG_REV_ID_BIT_BASIC_SKU) {
908 IL_DEBUG_INFO(priv, "3945 RADIO-MB type\n"); 908 IL_DEBUG_INFO(il, "3945 RADIO-MB type\n");
909 il_set_bit(priv, CSR_HW_IF_CONFIG_REG, 909 il_set_bit(il, CSR_HW_IF_CONFIG_REG,
910 CSR39_HW_IF_CONFIG_REG_BIT_3945_MB); 910 CSR39_HW_IF_CONFIG_REG_BIT_3945_MB);
911 } else { 911 } else {
912 IL_DEBUG_INFO(priv, "3945 RADIO-MM type\n"); 912 IL_DEBUG_INFO(il, "3945 RADIO-MM type\n");
913 il_set_bit(priv, CSR_HW_IF_CONFIG_REG, 913 il_set_bit(il, CSR_HW_IF_CONFIG_REG,
914 CSR39_HW_IF_CONFIG_REG_BIT_3945_MM); 914 CSR39_HW_IF_CONFIG_REG_BIT_3945_MM);
915 } 915 }
916 916
917 if (EEPROM_SKU_CAP_OP_MODE_MRC == eeprom->sku_cap) { 917 if (EEPROM_SKU_CAP_OP_MODE_MRC == eeprom->sku_cap) {
918 IL_DEBUG_INFO(priv, "SKU OP mode is mrc\n"); 918 IL_DEBUG_INFO(il, "SKU OP mode is mrc\n");
919 il_set_bit(priv, CSR_HW_IF_CONFIG_REG, 919 il_set_bit(il, CSR_HW_IF_CONFIG_REG,
920 CSR39_HW_IF_CONFIG_REG_BIT_SKU_MRC); 920 CSR39_HW_IF_CONFIG_REG_BIT_SKU_MRC);
921 } else 921 } else
922 IL_DEBUG_INFO(priv, "SKU OP mode is basic\n"); 922 IL_DEBUG_INFO(il, "SKU OP mode is basic\n");
923 923
924 if ((eeprom->board_revision & 0xF0) == 0xD0) { 924 if ((eeprom->board_revision & 0xF0) == 0xD0) {
925 IL_DEBUG_INFO(priv, "3945ABG revision is 0x%X\n", 925 IL_DEBUG_INFO(il, "3945ABG revision is 0x%X\n",
926 eeprom->board_revision); 926 eeprom->board_revision);
927 il_set_bit(priv, CSR_HW_IF_CONFIG_REG, 927 il_set_bit(il, CSR_HW_IF_CONFIG_REG,
928 CSR39_HW_IF_CONFIG_REG_BIT_BOARD_TYPE); 928 CSR39_HW_IF_CONFIG_REG_BIT_BOARD_TYPE);
929 } else { 929 } else {
930 IL_DEBUG_INFO(priv, "3945ABG revision is 0x%X\n", 930 IL_DEBUG_INFO(il, "3945ABG revision is 0x%X\n",
931 eeprom->board_revision); 931 eeprom->board_revision);
932 il_clear_bit(priv, CSR_HW_IF_CONFIG_REG, 932 il_clear_bit(il, CSR_HW_IF_CONFIG_REG,
933 CSR39_HW_IF_CONFIG_REG_BIT_BOARD_TYPE); 933 CSR39_HW_IF_CONFIG_REG_BIT_BOARD_TYPE);
934 } 934 }
935 935
936 if (eeprom->almgor_m_version <= 1) { 936 if (eeprom->almgor_m_version <= 1) {
937 il_set_bit(priv, CSR_HW_IF_CONFIG_REG, 937 il_set_bit(il, CSR_HW_IF_CONFIG_REG,
938 CSR39_HW_IF_CONFIG_REG_BITS_SILICON_TYPE_A); 938 CSR39_HW_IF_CONFIG_REG_BITS_SILICON_TYPE_A);
939 IL_DEBUG_INFO(priv, "Card M type A version is 0x%X\n", 939 IL_DEBUG_INFO(il, "Card M type A version is 0x%X\n",
940 eeprom->almgor_m_version); 940 eeprom->almgor_m_version);
941 } else { 941 } else {
942 IL_DEBUG_INFO(priv, "Card M type B version is 0x%X\n", 942 IL_DEBUG_INFO(il, "Card M type B version is 0x%X\n",
943 eeprom->almgor_m_version); 943 eeprom->almgor_m_version);
944 il_set_bit(priv, CSR_HW_IF_CONFIG_REG, 944 il_set_bit(il, CSR_HW_IF_CONFIG_REG,
945 CSR39_HW_IF_CONFIG_REG_BITS_SILICON_TYPE_B); 945 CSR39_HW_IF_CONFIG_REG_BITS_SILICON_TYPE_B);
946 } 946 }
947 spin_unlock_irqrestore(&priv->lock, flags); 947 spin_unlock_irqrestore(&il->lock, flags);
948 948
949 if (eeprom->sku_cap & EEPROM_SKU_CAP_SW_RF_KILL_ENABLE) 949 if (eeprom->sku_cap & EEPROM_SKU_CAP_SW_RF_KILL_ENABLE)
950 IL_DEBUG_RF_KILL(priv, "SW RF KILL supported in EEPROM.\n"); 950 IL_DEBUG_RF_KILL(il, "SW RF KILL supported in EEPROM.\n");
951 951
952 if (eeprom->sku_cap & EEPROM_SKU_CAP_HW_RF_KILL_ENABLE) 952 if (eeprom->sku_cap & EEPROM_SKU_CAP_HW_RF_KILL_ENABLE)
953 IL_DEBUG_RF_KILL(priv, "HW RF KILL supported in EEPROM.\n"); 953 IL_DEBUG_RF_KILL(il, "HW RF KILL supported in EEPROM.\n");
954} 954}
955 955
956int il3945_hw_nic_init(struct il_priv *priv) 956int il3945_hw_nic_init(struct il_priv *il)
957{ 957{
958 int rc; 958 int rc;
959 unsigned long flags; 959 unsigned long flags;
960 struct il_rx_queue *rxq = &priv->rxq; 960 struct il_rx_queue *rxq = &il->rxq;
961 961
962 spin_lock_irqsave(&priv->lock, flags); 962 spin_lock_irqsave(&il->lock, flags);
963 priv->cfg->ops->lib->apm_ops.init(priv); 963 il->cfg->ops->lib->apm_ops.init(il);
964 spin_unlock_irqrestore(&priv->lock, flags); 964 spin_unlock_irqrestore(&il->lock, flags);
965 965
966 il3945_set_pwr_vmain(priv); 966 il3945_set_pwr_vmain(il);
967 967
968 priv->cfg->ops->lib->apm_ops.config(priv); 968 il->cfg->ops->lib->apm_ops.config(il);
969 969
970 /* Allocate the RX queue, or reset if it is already allocated */ 970 /* Allocate the RX queue, or reset if it is already allocated */
971 if (!rxq->bd) { 971 if (!rxq->bd) {
972 rc = il_rx_queue_alloc(priv); 972 rc = il_rx_queue_alloc(il);
973 if (rc) { 973 if (rc) {
974 IL_ERR(priv, "Unable to initialize Rx queue\n"); 974 IL_ERR(il, "Unable to initialize Rx queue\n");
975 return -ENOMEM; 975 return -ENOMEM;
976 } 976 }
977 } else 977 } else
978 il3945_rx_queue_reset(priv, rxq); 978 il3945_rx_queue_reset(il, rxq);
979 979
980 il3945_rx_replenish(priv); 980 il3945_rx_replenish(il);
981 981
982 il3945_rx_init(priv, rxq); 982 il3945_rx_init(il, rxq);
983 983
984 984
985 /* Look at using this instead: 985 /* Look at using this instead:
986 rxq->need_update = 1; 986 rxq->need_update = 1;
987 il_rx_queue_update_write_ptr(priv, rxq); 987 il_rx_queue_update_write_ptr(il, rxq);
988 */ 988 */
989 989
990 il_write_direct32(priv, FH39_RCSR_WPTR(0), rxq->write & ~7); 990 il_write_direct32(il, FH39_RCSR_WPTR(0), rxq->write & ~7);
991 991
992 rc = il3945_txq_ctx_reset(priv); 992 rc = il3945_txq_ctx_reset(il);
993 if (rc) 993 if (rc)
994 return rc; 994 return rc;
995 995
996 set_bit(STATUS_INIT, &priv->status); 996 set_bit(STATUS_INIT, &il->status);
997 997
998 return 0; 998 return 0;
999} 999}
@@ -1003,40 +1003,40 @@ int il3945_hw_nic_init(struct il_priv *priv)
1003 * 1003 *
1004 * Destroy all TX DMA queues and structures 1004 * Destroy all TX DMA queues and structures
1005 */ 1005 */
1006void il3945_hw_txq_ctx_free(struct il_priv *priv) 1006void il3945_hw_txq_ctx_free(struct il_priv *il)
1007{ 1007{
1008 int txq_id; 1008 int txq_id;
1009 1009
1010 /* Tx queues */ 1010 /* Tx queues */
1011 if (priv->txq) 1011 if (il->txq)
1012 for (txq_id = 0; txq_id < priv->hw_params.max_txq_num; 1012 for (txq_id = 0; txq_id < il->hw_params.max_txq_num;
1013 txq_id++) 1013 txq_id++)
1014 if (txq_id == IWL39_CMD_QUEUE_NUM) 1014 if (txq_id == IWL39_CMD_QUEUE_NUM)
1015 il_cmd_queue_free(priv); 1015 il_cmd_queue_free(il);
1016 else 1016 else
1017 il_tx_queue_free(priv, txq_id); 1017 il_tx_queue_free(il, txq_id);
1018 1018
1019 /* free tx queue structure */ 1019 /* free tx queue structure */
1020 il_txq_mem(priv); 1020 il_txq_mem(il);
1021} 1021}
1022 1022
1023void il3945_hw_txq_ctx_stop(struct il_priv *priv) 1023void il3945_hw_txq_ctx_stop(struct il_priv *il)
1024{ 1024{
1025 int txq_id; 1025 int txq_id;
1026 1026
1027 /* stop SCD */ 1027 /* stop SCD */
1028 il_write_prph(priv, ALM_SCD_MODE_REG, 0); 1028 il_write_prph(il, ALM_SCD_MODE_REG, 0);
1029 il_write_prph(priv, ALM_SCD_TXFACT_REG, 0); 1029 il_write_prph(il, ALM_SCD_TXFACT_REG, 0);
1030 1030
1031 /* reset TFD queues */ 1031 /* reset TFD queues */
1032 for (txq_id = 0; txq_id < priv->hw_params.max_txq_num; txq_id++) { 1032 for (txq_id = 0; txq_id < il->hw_params.max_txq_num; txq_id++) {
1033 il_write_direct32(priv, FH39_TCSR_CONFIG(txq_id), 0x0); 1033 il_write_direct32(il, FH39_TCSR_CONFIG(txq_id), 0x0);
1034 il_poll_direct_bit(priv, FH39_TSSR_TX_STATUS, 1034 il_poll_direct_bit(il, FH39_TSSR_TX_STATUS,
1035 FH39_TSSR_TX_STATUS_REG_MSK_CHNL_IDLE(txq_id), 1035 FH39_TSSR_TX_STATUS_REG_MSK_CHNL_IDLE(txq_id),
1036 1000); 1036 1000);
1037 } 1037 }
1038 1038
1039 il3945_hw_txq_ctx_free(priv); 1039 il3945_hw_txq_ctx_free(il);
1040} 1040}
1041 1041
1042/** 1042/**
@@ -1056,36 +1056,36 @@ static inline int il3945_hw_reg_temp_out_of_range(int temperature)
1056 return ((temperature < -260) || (temperature > 25)) ? 1 : 0; 1056 return ((temperature < -260) || (temperature > 25)) ? 1 : 0;
1057} 1057}
1058 1058
1059int il3945_hw_get_temperature(struct il_priv *priv) 1059int il3945_hw_get_temperature(struct il_priv *il)
1060{ 1060{
1061 return il_read32(priv, CSR_UCODE_DRV_GP2); 1061 return il_read32(il, CSR_UCODE_DRV_GP2);
1062} 1062}
1063 1063
1064/** 1064/**
1065 * il3945_hw_reg_txpower_get_temperature 1065 * il3945_hw_reg_txpower_get_temperature
1066 * get the current temperature by reading from NIC 1066 * get the current temperature by reading from NIC
1067*/ 1067*/
1068static int il3945_hw_reg_txpower_get_temperature(struct il_priv *priv) 1068static int il3945_hw_reg_txpower_get_temperature(struct il_priv *il)
1069{ 1069{
1070 struct il3945_eeprom *eeprom = (struct il3945_eeprom *)priv->eeprom; 1070 struct il3945_eeprom *eeprom = (struct il3945_eeprom *)il->eeprom;
1071 int temperature; 1071 int temperature;
1072 1072
1073 temperature = il3945_hw_get_temperature(priv); 1073 temperature = il3945_hw_get_temperature(il);
1074 1074
1075 /* driver's okay range is -260 to +25. 1075 /* driver's okay range is -260 to +25.
1076 * human readable okay range is 0 to +285 */ 1076 * human readable okay range is 0 to +285 */
1077 IL_DEBUG_INFO(priv, "Temperature: %d\n", temperature + IL_TEMP_CONVERT); 1077 IL_DEBUG_INFO(il, "Temperature: %d\n", temperature + IL_TEMP_CONVERT);
1078 1078
1079 /* handle insane temp reading */ 1079 /* handle insane temp reading */
1080 if (il3945_hw_reg_temp_out_of_range(temperature)) { 1080 if (il3945_hw_reg_temp_out_of_range(temperature)) {
1081 IL_ERR(priv, "Error bad temperature value %d\n", temperature); 1081 IL_ERR(il, "Error bad temperature value %d\n", temperature);
1082 1082
1083 /* if really really hot(?), 1083 /* if really really hot(?),
1084 * substitute the 3rd band/group's temp measured at factory */ 1084 * substitute the 3rd band/group's temp measured at factory */
1085 if (priv->last_temperature > 100) 1085 if (il->last_temperature > 100)
1086 temperature = eeprom->groups[2].temperature; 1086 temperature = eeprom->groups[2].temperature;
1087 else /* else use most recent "sane" value from driver */ 1087 else /* else use most recent "sane" value from driver */
1088 temperature = priv->last_temperature; 1088 temperature = il->last_temperature;
1089 } 1089 }
1090 1090
1091 return temperature; /* raw, not "human readable" */ 1091 return temperature; /* raw, not "human readable" */
@@ -1102,33 +1102,33 @@ static int il3945_hw_reg_txpower_get_temperature(struct il_priv *priv)
1102 * records new temperature in tx_mgr->temperature. 1102 * records new temperature in tx_mgr->temperature.
1103 * replaces tx_mgr->last_temperature *only* if calib needed 1103 * replaces tx_mgr->last_temperature *only* if calib needed
1104 * (assumes caller will actually do the calibration!). */ 1104 * (assumes caller will actually do the calibration!). */
1105static int il3945_is_temp_calib_needed(struct il_priv *priv) 1105static int il3945_is_temp_calib_needed(struct il_priv *il)
1106{ 1106{
1107 int temp_diff; 1107 int temp_diff;
1108 1108
1109 priv->temperature = il3945_hw_reg_txpower_get_temperature(priv); 1109 il->temperature = il3945_hw_reg_txpower_get_temperature(il);
1110 temp_diff = priv->temperature - priv->last_temperature; 1110 temp_diff = il->temperature - il->last_temperature;
1111 1111
1112 /* get absolute value */ 1112 /* get absolute value */
1113 if (temp_diff < 0) { 1113 if (temp_diff < 0) {
1114 IL_DEBUG_POWER(priv, "Getting cooler, delta %d,\n", temp_diff); 1114 IL_DEBUG_POWER(il, "Getting cooler, delta %d,\n", temp_diff);
1115 temp_diff = -temp_diff; 1115 temp_diff = -temp_diff;
1116 } else if (temp_diff == 0) 1116 } else if (temp_diff == 0)
1117 IL_DEBUG_POWER(priv, "Same temp,\n"); 1117 IL_DEBUG_POWER(il, "Same temp,\n");
1118 else 1118 else
1119 IL_DEBUG_POWER(priv, "Getting warmer, delta %d,\n", temp_diff); 1119 IL_DEBUG_POWER(il, "Getting warmer, delta %d,\n", temp_diff);
1120 1120
1121 /* if we don't need calibration, *don't* update last_temperature */ 1121 /* if we don't need calibration, *don't* update last_temperature */
1122 if (temp_diff < IL_TEMPERATURE_LIMIT_TIMER) { 1122 if (temp_diff < IL_TEMPERATURE_LIMIT_TIMER) {
1123 IL_DEBUG_POWER(priv, "Timed thermal calib not needed\n"); 1123 IL_DEBUG_POWER(il, "Timed thermal calib not needed\n");
1124 return 0; 1124 return 0;
1125 } 1125 }
1126 1126
1127 IL_DEBUG_POWER(priv, "Timed thermal calib needed\n"); 1127 IL_DEBUG_POWER(il, "Timed thermal calib needed\n");
1128 1128
1129 /* assume that caller will actually do calib ... 1129 /* assume that caller will actually do calib ...
1130 * update the "last temperature" value */ 1130 * update the "last temperature" value */
1131 priv->last_temperature = priv->temperature; 1131 il->last_temperature = il->temperature;
1132 return 1; 1132 return 1;
1133} 1133}
1134 1134
@@ -1317,7 +1317,7 @@ static inline u8 il3945_hw_reg_fix_power_index(int index)
1317 * Set (in our channel info database) the direct scan Tx power for 1 Mbit (CCK) 1317 * Set (in our channel info database) the direct scan Tx power for 1 Mbit (CCK)
1318 * or 6 Mbit (OFDM) rates. 1318 * or 6 Mbit (OFDM) rates.
1319 */ 1319 */
1320static void il3945_hw_reg_set_scan_power(struct il_priv *priv, u32 scan_tbl_index, 1320static void il3945_hw_reg_set_scan_power(struct il_priv *il, u32 scan_tbl_index,
1321 s32 rate_index, const s8 *clip_pwrs, 1321 s32 rate_index, const s8 *clip_pwrs,
1322 struct il_channel_info *ch_info, 1322 struct il_channel_info *ch_info,
1323 int band_index) 1323 int band_index)
@@ -1333,7 +1333,7 @@ static void il3945_hw_reg_set_scan_power(struct il_priv *priv, u32 scan_tbl_inde
1333 * based on eeprom channel data) for this channel. */ 1333 * based on eeprom channel data) for this channel. */
1334 power = min(ch_info->scan_power, clip_pwrs[IL_RATE_6M_INDEX_TABLE]); 1334 power = min(ch_info->scan_power, clip_pwrs[IL_RATE_6M_INDEX_TABLE]);
1335 1335
1336 power = min(power, priv->tx_power_user_lmt); 1336 power = min(power, il->tx_power_user_lmt);
1337 scan_power_info->requested_power = power; 1337 scan_power_info->requested_power = power;
1338 1338
1339 /* find difference between new scan *power* and current "normal" 1339 /* find difference between new scan *power* and current "normal"
@@ -1370,32 +1370,32 @@ static void il3945_hw_reg_set_scan_power(struct il_priv *priv, u32 scan_tbl_inde
1370 * Configures power settings for all rates for the current channel, 1370 * Configures power settings for all rates for the current channel,
1371 * using values from channel info struct, and send to NIC 1371 * using values from channel info struct, and send to NIC
1372 */ 1372 */
1373static int il3945_send_tx_power(struct il_priv *priv) 1373static int il3945_send_tx_power(struct il_priv *il)
1374{ 1374{
1375 int rate_idx, i; 1375 int rate_idx, i;
1376 const struct il_channel_info *ch_info = NULL; 1376 const struct il_channel_info *ch_info = NULL;
1377 struct il3945_txpowertable_cmd txpower = { 1377 struct il3945_txpowertable_cmd txpower = {
1378 .channel = priv->contexts[IL_RXON_CTX_BSS].active.channel, 1378 .channel = il->contexts[IL_RXON_CTX_BSS].active.channel,
1379 }; 1379 };
1380 u16 chan; 1380 u16 chan;
1381 1381
1382 if (WARN_ONCE(test_bit(STATUS_SCAN_HW, &priv->status), 1382 if (WARN_ONCE(test_bit(STATUS_SCAN_HW, &il->status),
1383 "TX Power requested while scanning!\n")) 1383 "TX Power requested while scanning!\n"))
1384 return -EAGAIN; 1384 return -EAGAIN;
1385 1385
1386 chan = le16_to_cpu(priv->contexts[IL_RXON_CTX_BSS].active.channel); 1386 chan = le16_to_cpu(il->contexts[IL_RXON_CTX_BSS].active.channel);
1387 1387
1388 txpower.band = (priv->band == IEEE80211_BAND_5GHZ) ? 0 : 1; 1388 txpower.band = (il->band == IEEE80211_BAND_5GHZ) ? 0 : 1;
1389 ch_info = il_get_channel_info(priv, priv->band, chan); 1389 ch_info = il_get_channel_info(il, il->band, chan);
1390 if (!ch_info) { 1390 if (!ch_info) {
1391 IL_ERR(priv, 1391 IL_ERR(il,
1392 "Failed to get channel info for channel %d [%d]\n", 1392 "Failed to get channel info for channel %d [%d]\n",
1393 chan, priv->band); 1393 chan, il->band);
1394 return -EINVAL; 1394 return -EINVAL;
1395 } 1395 }
1396 1396
1397 if (!il_is_channel_valid(ch_info)) { 1397 if (!il_is_channel_valid(ch_info)) {
1398 IL_DEBUG_POWER(priv, "Not calling TX_PWR_TABLE_CMD on " 1398 IL_DEBUG_POWER(il, "Not calling TX_PWR_TABLE_CMD on "
1399 "non-Tx channel.\n"); 1399 "non-Tx channel.\n");
1400 return 0; 1400 return 0;
1401 } 1401 }
@@ -1408,7 +1408,7 @@ static int il3945_send_tx_power(struct il_priv *priv)
1408 txpower.power[i].tpc = ch_info->power_info[i].tpc; 1408 txpower.power[i].tpc = ch_info->power_info[i].tpc;
1409 txpower.power[i].rate = il3945_rates[rate_idx].plcp; 1409 txpower.power[i].rate = il3945_rates[rate_idx].plcp;
1410 1410
1411 IL_DEBUG_POWER(priv, "ch %d:%d rf %d dsp %3d rate code 0x%02x\n", 1411 IL_DEBUG_POWER(il, "ch %d:%d rf %d dsp %3d rate code 0x%02x\n",
1412 le16_to_cpu(txpower.channel), 1412 le16_to_cpu(txpower.channel),
1413 txpower.band, 1413 txpower.band,
1414 txpower.power[i].tpc.tx_gain, 1414 txpower.power[i].tpc.tx_gain,
@@ -1421,7 +1421,7 @@ static int il3945_send_tx_power(struct il_priv *priv)
1421 txpower.power[i].tpc = ch_info->power_info[i].tpc; 1421 txpower.power[i].tpc = ch_info->power_info[i].tpc;
1422 txpower.power[i].rate = il3945_rates[rate_idx].plcp; 1422 txpower.power[i].rate = il3945_rates[rate_idx].plcp;
1423 1423
1424 IL_DEBUG_POWER(priv, "ch %d:%d rf %d dsp %3d rate code 0x%02x\n", 1424 IL_DEBUG_POWER(il, "ch %d:%d rf %d dsp %3d rate code 0x%02x\n",
1425 le16_to_cpu(txpower.channel), 1425 le16_to_cpu(txpower.channel),
1426 txpower.band, 1426 txpower.band,
1427 txpower.power[i].tpc.tx_gain, 1427 txpower.power[i].tpc.tx_gain,
@@ -1429,7 +1429,7 @@ static int il3945_send_tx_power(struct il_priv *priv)
1429 txpower.power[i].rate); 1429 txpower.power[i].rate);
1430 } 1430 }
1431 1431
1432 return il_send_cmd_pdu(priv, REPLY_TX_PWR_TABLE_CMD, 1432 return il_send_cmd_pdu(il, REPLY_TX_PWR_TABLE_CMD,
1433 sizeof(struct il3945_txpowertable_cmd), 1433 sizeof(struct il3945_txpowertable_cmd),
1434 &txpower); 1434 &txpower);
1435 1435
@@ -1451,7 +1451,7 @@ static int il3945_send_tx_power(struct il_priv *priv)
1451 * properly fill out the scan powers, and actual h/w gain settings, 1451 * properly fill out the scan powers, and actual h/w gain settings,
1452 * and send changes to NIC 1452 * and send changes to NIC
1453 */ 1453 */
1454static int il3945_hw_reg_set_new_power(struct il_priv *priv, 1454static int il3945_hw_reg_set_new_power(struct il_priv *il,
1455 struct il_channel_info *ch_info) 1455 struct il_channel_info *ch_info)
1456{ 1456{
1457 struct il3945_channel_power_info *power_info; 1457 struct il3945_channel_power_info *power_info;
@@ -1461,7 +1461,7 @@ static int il3945_hw_reg_set_new_power(struct il_priv *priv,
1461 int power; 1461 int power;
1462 1462
1463 /* Get this chnlgrp's rate-to-max/clip-powers table */ 1463 /* Get this chnlgrp's rate-to-max/clip-powers table */
1464 clip_pwrs = priv->_3945.clip_groups[ch_info->group_index].clip_powers; 1464 clip_pwrs = il->_3945.clip_groups[ch_info->group_index].clip_powers;
1465 1465
1466 /* Get this channel's rate-to-current-power settings table */ 1466 /* Get this channel's rate-to-current-power settings table */
1467 power_info = ch_info->power_info; 1467 power_info = ch_info->power_info;
@@ -1542,10 +1542,10 @@ static int il3945_hw_reg_get_ch_txpower_limit(struct il_channel_info *ch_info)
1542 * 1542 *
1543 * If RxOn is "associated", this sends the new Txpower to NIC! 1543 * If RxOn is "associated", this sends the new Txpower to NIC!
1544 */ 1544 */
1545static int il3945_hw_reg_comp_txpower_temp(struct il_priv *priv) 1545static int il3945_hw_reg_comp_txpower_temp(struct il_priv *il)
1546{ 1546{
1547 struct il_channel_info *ch_info = NULL; 1547 struct il_channel_info *ch_info = NULL;
1548 struct il3945_eeprom *eeprom = (struct il3945_eeprom *)priv->eeprom; 1548 struct il3945_eeprom *eeprom = (struct il3945_eeprom *)il->eeprom;
1549 int delta_index; 1549 int delta_index;
1550 const s8 *clip_pwrs; /* array of h/w max power levels for each rate */ 1550 const s8 *clip_pwrs; /* array of h/w max power levels for each rate */
1551 u8 a_band; 1551 u8 a_band;
@@ -1553,16 +1553,16 @@ static int il3945_hw_reg_comp_txpower_temp(struct il_priv *priv)
1553 u8 scan_tbl_index; 1553 u8 scan_tbl_index;
1554 u8 i; 1554 u8 i;
1555 int ref_temp; 1555 int ref_temp;
1556 int temperature = priv->temperature; 1556 int temperature = il->temperature;
1557 1557
1558 if (priv->disable_tx_power_cal || 1558 if (il->disable_tx_power_cal ||
1559 test_bit(STATUS_SCANNING, &priv->status)) { 1559 test_bit(STATUS_SCANNING, &il->status)) {
1560 /* do not perform tx power calibration */ 1560 /* do not perform tx power calibration */
1561 return 0; 1561 return 0;
1562 } 1562 }
1563 /* set up new Tx power info for each and every channel, 2.4 and 5.x */ 1563 /* set up new Tx power info for each and every channel, 2.4 and 5.x */
1564 for (i = 0; i < priv->channel_count; i++) { 1564 for (i = 0; i < il->channel_count; i++) {
1565 ch_info = &priv->channel_info[i]; 1565 ch_info = &il->channel_info[i];
1566 a_band = il_is_channel_a_band(ch_info); 1566 a_band = il_is_channel_a_band(ch_info);
1567 1567
1568 /* Get this chnlgrp's factory calibration temperature */ 1568 /* Get this chnlgrp's factory calibration temperature */
@@ -1592,43 +1592,43 @@ static int il3945_hw_reg_comp_txpower_temp(struct il_priv *priv)
1592 } 1592 }
1593 1593
1594 /* Get this chnlgrp's rate-to-max/clip-powers table */ 1594 /* Get this chnlgrp's rate-to-max/clip-powers table */
1595 clip_pwrs = priv->_3945.clip_groups[ch_info->group_index].clip_powers; 1595 clip_pwrs = il->_3945.clip_groups[ch_info->group_index].clip_powers;
1596 1596
1597 /* set scan tx power, 1Mbit for CCK, 6Mbit for OFDM */ 1597 /* set scan tx power, 1Mbit for CCK, 6Mbit for OFDM */
1598 for (scan_tbl_index = 0; 1598 for (scan_tbl_index = 0;
1599 scan_tbl_index < IL_NUM_SCAN_RATES; scan_tbl_index++) { 1599 scan_tbl_index < IL_NUM_SCAN_RATES; scan_tbl_index++) {
1600 s32 actual_index = (scan_tbl_index == 0) ? 1600 s32 actual_index = (scan_tbl_index == 0) ?
1601 IL_RATE_1M_INDEX_TABLE : IL_RATE_6M_INDEX_TABLE; 1601 IL_RATE_1M_INDEX_TABLE : IL_RATE_6M_INDEX_TABLE;
1602 il3945_hw_reg_set_scan_power(priv, scan_tbl_index, 1602 il3945_hw_reg_set_scan_power(il, scan_tbl_index,
1603 actual_index, clip_pwrs, 1603 actual_index, clip_pwrs,
1604 ch_info, a_band); 1604 ch_info, a_band);
1605 } 1605 }
1606 } 1606 }
1607 1607
1608 /* send Txpower command for current channel to ucode */ 1608 /* send Txpower command for current channel to ucode */
1609 return priv->cfg->ops->lib->send_tx_power(priv); 1609 return il->cfg->ops->lib->send_tx_power(il);
1610} 1610}
1611 1611
1612int il3945_hw_reg_set_txpower(struct il_priv *priv, s8 power) 1612int il3945_hw_reg_set_txpower(struct il_priv *il, s8 power)
1613{ 1613{
1614 struct il_channel_info *ch_info; 1614 struct il_channel_info *ch_info;
1615 s8 max_power; 1615 s8 max_power;
1616 u8 a_band; 1616 u8 a_band;
1617 u8 i; 1617 u8 i;
1618 1618
1619 if (priv->tx_power_user_lmt == power) { 1619 if (il->tx_power_user_lmt == power) {
1620 IL_DEBUG_POWER(priv, "Requested Tx power same as current " 1620 IL_DEBUG_POWER(il, "Requested Tx power same as current "
1621 "limit: %ddBm.\n", power); 1621 "limit: %ddBm.\n", power);
1622 return 0; 1622 return 0;
1623 } 1623 }
1624 1624
1625 IL_DEBUG_POWER(priv, "Setting upper limit clamp to %ddBm.\n", power); 1625 IL_DEBUG_POWER(il, "Setting upper limit clamp to %ddBm.\n", power);
1626 priv->tx_power_user_lmt = power; 1626 il->tx_power_user_lmt = power;
1627 1627
1628 /* set up new Tx powers for each and every channel, 2.4 and 5.x */ 1628 /* set up new Tx powers for each and every channel, 2.4 and 5.x */
1629 1629
1630 for (i = 0; i < priv->channel_count; i++) { 1630 for (i = 0; i < il->channel_count; i++) {
1631 ch_info = &priv->channel_info[i]; 1631 ch_info = &il->channel_info[i];
1632 a_band = il_is_channel_a_band(ch_info); 1632 a_band = il_is_channel_a_band(ch_info);
1633 1633
1634 /* find minimum power of all user and regulatory constraints 1634 /* find minimum power of all user and regulatory constraints
@@ -1639,19 +1639,19 @@ int il3945_hw_reg_set_txpower(struct il_priv *priv, s8 power)
1639 ch_info->curr_txpow = max_power; 1639 ch_info->curr_txpow = max_power;
1640 1640
1641 /* this considers the h/w clipping limitations */ 1641 /* this considers the h/w clipping limitations */
1642 il3945_hw_reg_set_new_power(priv, ch_info); 1642 il3945_hw_reg_set_new_power(il, ch_info);
1643 } 1643 }
1644 } 1644 }
1645 1645
1646 /* update txpower settings for all channels, 1646 /* update txpower settings for all channels,
1647 * send to NIC if associated. */ 1647 * send to NIC if associated. */
1648 il3945_is_temp_calib_needed(priv); 1648 il3945_is_temp_calib_needed(il);
1649 il3945_hw_reg_comp_txpower_temp(priv); 1649 il3945_hw_reg_comp_txpower_temp(il);
1650 1650
1651 return 0; 1651 return 0;
1652} 1652}
1653 1653
1654static int il3945_send_rxon_assoc(struct il_priv *priv, 1654static int il3945_send_rxon_assoc(struct il_priv *il,
1655 struct il_rxon_context *ctx) 1655 struct il_rxon_context *ctx)
1656{ 1656{
1657 int rc = 0; 1657 int rc = 0;
@@ -1670,7 +1670,7 @@ static int il3945_send_rxon_assoc(struct il_priv *priv,
1670 (rxon1->filter_flags == rxon2->filter_flags) && 1670 (rxon1->filter_flags == rxon2->filter_flags) &&
1671 (rxon1->cck_basic_rates == rxon2->cck_basic_rates) && 1671 (rxon1->cck_basic_rates == rxon2->cck_basic_rates) &&
1672 (rxon1->ofdm_basic_rates == rxon2->ofdm_basic_rates)) { 1672 (rxon1->ofdm_basic_rates == rxon2->ofdm_basic_rates)) {
1673 IL_DEBUG_INFO(priv, "Using current RXON_ASSOC. Not resending.\n"); 1673 IL_DEBUG_INFO(il, "Using current RXON_ASSOC. Not resending.\n");
1674 return 0; 1674 return 0;
1675 } 1675 }
1676 1676
@@ -1680,17 +1680,17 @@ static int il3945_send_rxon_assoc(struct il_priv *priv,
1680 rxon_assoc.cck_basic_rates = ctx->staging.cck_basic_rates; 1680 rxon_assoc.cck_basic_rates = ctx->staging.cck_basic_rates;
1681 rxon_assoc.reserved = 0; 1681 rxon_assoc.reserved = 0;
1682 1682
1683 rc = il_send_cmd_sync(priv, &cmd); 1683 rc = il_send_cmd_sync(il, &cmd);
1684 if (rc) 1684 if (rc)
1685 return rc; 1685 return rc;
1686 1686
1687 pkt = (struct il_rx_packet *)cmd.reply_page; 1687 pkt = (struct il_rx_packet *)cmd.reply_page;
1688 if (pkt->hdr.flags & IL_CMD_FAILED_MSK) { 1688 if (pkt->hdr.flags & IL_CMD_FAILED_MSK) {
1689 IL_ERR(priv, "Bad return from REPLY_RXON_ASSOC command\n"); 1689 IL_ERR(il, "Bad return from REPLY_RXON_ASSOC command\n");
1690 rc = -EIO; 1690 rc = -EIO;
1691 } 1691 }
1692 1692
1693 il_free_pages(priv, cmd.reply_page); 1693 il_free_pages(il, cmd.reply_page);
1694 1694
1695 return rc; 1695 return rc;
1696} 1696}
@@ -1703,7 +1703,7 @@ static int il3945_send_rxon_assoc(struct il_priv *priv,
1703 * function correctly transitions out of the RXON_ASSOC_MSK state if 1703 * function correctly transitions out of the RXON_ASSOC_MSK state if
1704 * a HW tune is required based on the RXON structure changes. 1704 * a HW tune is required based on the RXON structure changes.
1705 */ 1705 */
1706int il3945_commit_rxon(struct il_priv *priv, struct il_rxon_context *ctx) 1706int il3945_commit_rxon(struct il_priv *il, struct il_rxon_context *ctx)
1707{ 1707{
1708 /* cast away the const for active_rxon in this function */ 1708 /* cast away the const for active_rxon in this function */
1709 struct il3945_rxon_cmd *active_rxon = (void *)&ctx->active; 1709 struct il3945_rxon_cmd *active_rxon = (void *)&ctx->active;
@@ -1711,10 +1711,10 @@ int il3945_commit_rxon(struct il_priv *priv, struct il_rxon_context *ctx)
1711 int rc = 0; 1711 int rc = 0;
1712 bool new_assoc = !!(staging_rxon->filter_flags & RXON_FILTER_ASSOC_MSK); 1712 bool new_assoc = !!(staging_rxon->filter_flags & RXON_FILTER_ASSOC_MSK);
1713 1713
1714 if (test_bit(STATUS_EXIT_PENDING, &priv->status)) 1714 if (test_bit(STATUS_EXIT_PENDING, &il->status))
1715 return -EINVAL; 1715 return -EINVAL;
1716 1716
1717 if (!il_is_alive(priv)) 1717 if (!il_is_alive(il))
1718 return -1; 1718 return -1;
1719 1719
1720 /* always get timestamp with Rx frame */ 1720 /* always get timestamp with Rx frame */
@@ -1723,23 +1723,23 @@ int il3945_commit_rxon(struct il_priv *priv, struct il_rxon_context *ctx)
1723 /* select antenna */ 1723 /* select antenna */
1724 staging_rxon->flags &= 1724 staging_rxon->flags &=
1725 ~(RXON_FLG_DIS_DIV_MSK | RXON_FLG_ANT_SEL_MSK); 1725 ~(RXON_FLG_DIS_DIV_MSK | RXON_FLG_ANT_SEL_MSK);
1726 staging_rxon->flags |= il3945_get_antenna_flags(priv); 1726 staging_rxon->flags |= il3945_get_antenna_flags(il);
1727 1727
1728 rc = il_check_rxon_cmd(priv, ctx); 1728 rc = il_check_rxon_cmd(il, ctx);
1729 if (rc) { 1729 if (rc) {
1730 IL_ERR(priv, "Invalid RXON configuration. Not committing.\n"); 1730 IL_ERR(il, "Invalid RXON configuration. Not committing.\n");
1731 return -EINVAL; 1731 return -EINVAL;
1732 } 1732 }
1733 1733
1734 /* If we don't need to send a full RXON, we can use 1734 /* If we don't need to send a full RXON, we can use
1735 * il3945_rxon_assoc_cmd which is used to reconfigure filter 1735 * il3945_rxon_assoc_cmd which is used to reconfigure filter
1736 * and other flags for the current radio configuration. */ 1736 * and other flags for the current radio configuration. */
1737 if (!il_full_rxon_required(priv, 1737 if (!il_full_rxon_required(il,
1738 &priv->contexts[IL_RXON_CTX_BSS])) { 1738 &il->contexts[IL_RXON_CTX_BSS])) {
1739 rc = il_send_rxon_assoc(priv, 1739 rc = il_send_rxon_assoc(il,
1740 &priv->contexts[IL_RXON_CTX_BSS]); 1740 &il->contexts[IL_RXON_CTX_BSS]);
1741 if (rc) { 1741 if (rc) {
1742 IL_ERR(priv, "Error setting RXON_ASSOC " 1742 IL_ERR(il, "Error setting RXON_ASSOC "
1743 "configuration (%d).\n", rc); 1743 "configuration (%d).\n", rc);
1744 return rc; 1744 return rc;
1745 } 1745 }
@@ -1749,7 +1749,7 @@ int il3945_commit_rxon(struct il_priv *priv, struct il_rxon_context *ctx)
1749 * We do not commit tx power settings while channel changing, 1749 * We do not commit tx power settings while channel changing,
1750 * do it now if tx power changed. 1750 * do it now if tx power changed.
1751 */ 1751 */
1752 il_set_tx_power(priv, priv->tx_power_next, false); 1752 il_set_tx_power(il, il->tx_power_next, false);
1753 return 0; 1753 return 0;
1754 } 1754 }
1755 1755
@@ -1757,8 +1757,8 @@ int il3945_commit_rxon(struct il_priv *priv, struct il_rxon_context *ctx)
1757 * an RXON_ASSOC and the new config wants the associated mask enabled, 1757 * an RXON_ASSOC and the new config wants the associated mask enabled,
1758 * we must clear the associated from the active configuration 1758 * we must clear the associated from the active configuration
1759 * before we apply the new config */ 1759 * before we apply the new config */
1760 if (il_is_associated(priv, IL_RXON_CTX_BSS) && new_assoc) { 1760 if (il_is_associated(il, IL_RXON_CTX_BSS) && new_assoc) {
1761 IL_DEBUG_INFO(priv, "Toggling associated bit on current RXON\n"); 1761 IL_DEBUG_INFO(il, "Toggling associated bit on current RXON\n");
1762 active_rxon->filter_flags &= ~RXON_FILTER_ASSOC_MSK; 1762 active_rxon->filter_flags &= ~RXON_FILTER_ASSOC_MSK;
1763 1763
1764 /* 1764 /*
@@ -1767,25 +1767,25 @@ int il3945_commit_rxon(struct il_priv *priv, struct il_rxon_context *ctx)
1767 */ 1767 */
1768 active_rxon->reserved4 = 0; 1768 active_rxon->reserved4 = 0;
1769 active_rxon->reserved5 = 0; 1769 active_rxon->reserved5 = 0;
1770 rc = il_send_cmd_pdu(priv, REPLY_RXON, 1770 rc = il_send_cmd_pdu(il, REPLY_RXON,
1771 sizeof(struct il3945_rxon_cmd), 1771 sizeof(struct il3945_rxon_cmd),
1772 &priv->contexts[IL_RXON_CTX_BSS].active); 1772 &il->contexts[IL_RXON_CTX_BSS].active);
1773 1773
1774 /* If the mask clearing failed then we set 1774 /* If the mask clearing failed then we set
1775 * active_rxon back to what it was previously */ 1775 * active_rxon back to what it was previously */
1776 if (rc) { 1776 if (rc) {
1777 active_rxon->filter_flags |= RXON_FILTER_ASSOC_MSK; 1777 active_rxon->filter_flags |= RXON_FILTER_ASSOC_MSK;
1778 IL_ERR(priv, "Error clearing ASSOC_MSK on current " 1778 IL_ERR(il, "Error clearing ASSOC_MSK on current "
1779 "configuration (%d).\n", rc); 1779 "configuration (%d).\n", rc);
1780 return rc; 1780 return rc;
1781 } 1781 }
1782 il_clear_ucode_stations(priv, 1782 il_clear_ucode_stations(il,
1783 &priv->contexts[IL_RXON_CTX_BSS]); 1783 &il->contexts[IL_RXON_CTX_BSS]);
1784 il_restore_stations(priv, 1784 il_restore_stations(il,
1785 &priv->contexts[IL_RXON_CTX_BSS]); 1785 &il->contexts[IL_RXON_CTX_BSS]);
1786 } 1786 }
1787 1787
1788 IL_DEBUG_INFO(priv, "Sending RXON\n" 1788 IL_DEBUG_INFO(il, "Sending RXON\n"
1789 "* with%s RXON_FILTER_ASSOC_MSK\n" 1789 "* with%s RXON_FILTER_ASSOC_MSK\n"
1790 "* channel = %d\n" 1790 "* channel = %d\n"
1791 "* bssid = %pM\n", 1791 "* bssid = %pM\n",
@@ -1800,38 +1800,38 @@ int il3945_commit_rxon(struct il_priv *priv, struct il_rxon_context *ctx)
1800 staging_rxon->reserved4 = 0; 1800 staging_rxon->reserved4 = 0;
1801 staging_rxon->reserved5 = 0; 1801 staging_rxon->reserved5 = 0;
1802 1802
1803 il_set_rxon_hwcrypto(priv, ctx, !il3945_mod_params.sw_crypto); 1803 il_set_rxon_hwcrypto(il, ctx, !il3945_mod_params.sw_crypto);
1804 1804
1805 /* Apply the new configuration */ 1805 /* Apply the new configuration */
1806 rc = il_send_cmd_pdu(priv, REPLY_RXON, 1806 rc = il_send_cmd_pdu(il, REPLY_RXON,
1807 sizeof(struct il3945_rxon_cmd), 1807 sizeof(struct il3945_rxon_cmd),
1808 staging_rxon); 1808 staging_rxon);
1809 if (rc) { 1809 if (rc) {
1810 IL_ERR(priv, "Error setting new configuration (%d).\n", rc); 1810 IL_ERR(il, "Error setting new configuration (%d).\n", rc);
1811 return rc; 1811 return rc;
1812 } 1812 }
1813 1813
1814 memcpy(active_rxon, staging_rxon, sizeof(*active_rxon)); 1814 memcpy(active_rxon, staging_rxon, sizeof(*active_rxon));
1815 1815
1816 if (!new_assoc) { 1816 if (!new_assoc) {
1817 il_clear_ucode_stations(priv, 1817 il_clear_ucode_stations(il,
1818 &priv->contexts[IL_RXON_CTX_BSS]); 1818 &il->contexts[IL_RXON_CTX_BSS]);
1819 il_restore_stations(priv, 1819 il_restore_stations(il,
1820 &priv->contexts[IL_RXON_CTX_BSS]); 1820 &il->contexts[IL_RXON_CTX_BSS]);
1821 } 1821 }
1822 1822
1823 /* If we issue a new RXON command which required a tune then we must 1823 /* If we issue a new RXON command which required a tune then we must
1824 * send a new TXPOWER command or we won't be able to Tx any frames */ 1824 * send a new TXPOWER command or we won't be able to Tx any frames */
1825 rc = il_set_tx_power(priv, priv->tx_power_next, true); 1825 rc = il_set_tx_power(il, il->tx_power_next, true);
1826 if (rc) { 1826 if (rc) {
1827 IL_ERR(priv, "Error setting Tx power (%d).\n", rc); 1827 IL_ERR(il, "Error setting Tx power (%d).\n", rc);
1828 return rc; 1828 return rc;
1829 } 1829 }
1830 1830
1831 /* Init the hardware's rate fallback order based on the band */ 1831 /* Init the hardware's rate fallback order based on the band */
1832 rc = il3945_init_hw_rate_table(priv); 1832 rc = il3945_init_hw_rate_table(il);
1833 if (rc) { 1833 if (rc) {
1834 IL_ERR(priv, "Error setting HW rate table: %02X\n", rc); 1834 IL_ERR(il, "Error setting HW rate table: %02X\n", rc);
1835 return -EIO; 1835 return -EIO;
1836 } 1836 }
1837 1837
@@ -1848,34 +1848,34 @@ int il3945_commit_rxon(struct il_priv *priv, struct il_rxon_context *ctx)
1848 * -- send new set of gain settings to NIC 1848 * -- send new set of gain settings to NIC
1849 * NOTE: This should continue working, even when we're not associated, 1849 * NOTE: This should continue working, even when we're not associated,
1850 * so we can keep our internal table of scan powers current. */ 1850 * so we can keep our internal table of scan powers current. */
1851void il3945_reg_txpower_periodic(struct il_priv *priv) 1851void il3945_reg_txpower_periodic(struct il_priv *il)
1852{ 1852{
1853 /* This will kick in the "brute force" 1853 /* This will kick in the "brute force"
1854 * il3945_hw_reg_comp_txpower_temp() below */ 1854 * il3945_hw_reg_comp_txpower_temp() below */
1855 if (!il3945_is_temp_calib_needed(priv)) 1855 if (!il3945_is_temp_calib_needed(il))
1856 goto reschedule; 1856 goto reschedule;
1857 1857
1858 /* Set up a new set of temp-adjusted TxPowers, send to NIC. 1858 /* Set up a new set of temp-adjusted TxPowers, send to NIC.
1859 * This is based *only* on current temperature, 1859 * This is based *only* on current temperature,
1860 * ignoring any previous power measurements */ 1860 * ignoring any previous power measurements */
1861 il3945_hw_reg_comp_txpower_temp(priv); 1861 il3945_hw_reg_comp_txpower_temp(il);
1862 1862
1863 reschedule: 1863 reschedule:
1864 queue_delayed_work(priv->workqueue, 1864 queue_delayed_work(il->workqueue,
1865 &priv->_3945.thermal_periodic, REG_RECALIB_PERIOD * HZ); 1865 &il->_3945.thermal_periodic, REG_RECALIB_PERIOD * HZ);
1866} 1866}
1867 1867
1868static void il3945_bg_reg_txpower_periodic(struct work_struct *work) 1868static void il3945_bg_reg_txpower_periodic(struct work_struct *work)
1869{ 1869{
1870 struct il_priv *priv = container_of(work, struct il_priv, 1870 struct il_priv *il = container_of(work, struct il_priv,
1871 _3945.thermal_periodic.work); 1871 _3945.thermal_periodic.work);
1872 1872
1873 if (test_bit(STATUS_EXIT_PENDING, &priv->status)) 1873 if (test_bit(STATUS_EXIT_PENDING, &il->status))
1874 return; 1874 return;
1875 1875
1876 mutex_lock(&priv->mutex); 1876 mutex_lock(&il->mutex);
1877 il3945_reg_txpower_periodic(priv); 1877 il3945_reg_txpower_periodic(il);
1878 mutex_unlock(&priv->mutex); 1878 mutex_unlock(&il->mutex);
1879} 1879}
1880 1880
1881/** 1881/**
@@ -1889,10 +1889,10 @@ static void il3945_bg_reg_txpower_periodic(struct work_struct *work)
1889 * on A-band, EEPROM's "group frequency" entries represent the top 1889 * on A-band, EEPROM's "group frequency" entries represent the top
1890 * channel in each group 1-4. Group 5 All B/G channels are in group 0. 1890 * channel in each group 1-4. Group 5 All B/G channels are in group 0.
1891 */ 1891 */
1892static u16 il3945_hw_reg_get_ch_grp_index(struct il_priv *priv, 1892static u16 il3945_hw_reg_get_ch_grp_index(struct il_priv *il,
1893 const struct il_channel_info *ch_info) 1893 const struct il_channel_info *ch_info)
1894{ 1894{
1895 struct il3945_eeprom *eeprom = (struct il3945_eeprom *)priv->eeprom; 1895 struct il3945_eeprom *eeprom = (struct il3945_eeprom *)il->eeprom;
1896 struct il3945_eeprom_txpower_group *ch_grp = &eeprom->groups[0]; 1896 struct il3945_eeprom_txpower_group *ch_grp = &eeprom->groups[0];
1897 u8 group; 1897 u8 group;
1898 u16 group_index = 0; /* based on factory calib frequencies */ 1898 u16 group_index = 0; /* based on factory calib frequencies */
@@ -1913,7 +1913,7 @@ static u16 il3945_hw_reg_get_ch_grp_index(struct il_priv *priv,
1913 } else 1913 } else
1914 group_index = 0; /* 2.4 GHz, group 0 */ 1914 group_index = 0; /* 2.4 GHz, group 0 */
1915 1915
1916 IL_DEBUG_POWER(priv, "Chnl %d mapped to grp %d\n", ch_info->channel, 1916 IL_DEBUG_POWER(il, "Chnl %d mapped to grp %d\n", ch_info->channel,
1917 group_index); 1917 group_index);
1918 return group_index; 1918 return group_index;
1919} 1919}
@@ -1924,12 +1924,12 @@ static u16 il3945_hw_reg_get_ch_grp_index(struct il_priv *priv,
1924 * Interpolate to get nominal (i.e. at factory calibration temperature) index 1924 * Interpolate to get nominal (i.e. at factory calibration temperature) index
1925 * into radio/DSP gain settings table for requested power. 1925 * into radio/DSP gain settings table for requested power.
1926 */ 1926 */
1927static int il3945_hw_reg_get_matched_power_index(struct il_priv *priv, 1927static int il3945_hw_reg_get_matched_power_index(struct il_priv *il,
1928 s8 requested_power, 1928 s8 requested_power,
1929 s32 setting_index, s32 *new_index) 1929 s32 setting_index, s32 *new_index)
1930{ 1930{
1931 const struct il3945_eeprom_txpower_group *chnl_grp = NULL; 1931 const struct il3945_eeprom_txpower_group *chnl_grp = NULL;
1932 struct il3945_eeprom *eeprom = (struct il3945_eeprom *)priv->eeprom; 1932 struct il3945_eeprom *eeprom = (struct il3945_eeprom *)il->eeprom;
1933 s32 index0, index1; 1933 s32 index0, index1;
1934 s32 power = 2 * requested_power; 1934 s32 power = 2 * requested_power;
1935 s32 i; 1935 s32 i;
@@ -1973,14 +1973,14 @@ static int il3945_hw_reg_get_matched_power_index(struct il_priv *priv,
1973 return 0; 1973 return 0;
1974} 1974}
1975 1975
1976static void il3945_hw_reg_init_channel_groups(struct il_priv *priv) 1976static void il3945_hw_reg_init_channel_groups(struct il_priv *il)
1977{ 1977{
1978 u32 i; 1978 u32 i;
1979 s32 rate_index; 1979 s32 rate_index;
1980 struct il3945_eeprom *eeprom = (struct il3945_eeprom *)priv->eeprom; 1980 struct il3945_eeprom *eeprom = (struct il3945_eeprom *)il->eeprom;
1981 const struct il3945_eeprom_txpower_group *group; 1981 const struct il3945_eeprom_txpower_group *group;
1982 1982
1983 IL_DEBUG_POWER(priv, "Initializing factory calib info from EEPROM\n"); 1983 IL_DEBUG_POWER(il, "Initializing factory calib info from EEPROM\n");
1984 1984
1985 for (i = 0; i < IL_NUM_TX_CALIB_GROUPS; i++) { 1985 for (i = 0; i < IL_NUM_TX_CALIB_GROUPS; i++) {
1986 s8 *clip_pwrs; /* table of power levels for each rate */ 1986 s8 *clip_pwrs; /* table of power levels for each rate */
@@ -1989,7 +1989,7 @@ static void il3945_hw_reg_init_channel_groups(struct il_priv *priv)
1989 1989
1990 /* sanity check on factory saturation power value */ 1990 /* sanity check on factory saturation power value */
1991 if (group->saturation_power < 40) { 1991 if (group->saturation_power < 40) {
1992 IL_WARN(priv, "Error: saturation power is %d, " 1992 IL_WARN(il, "Error: saturation power is %d, "
1993 "less than minimum expected 40\n", 1993 "less than minimum expected 40\n",
1994 group->saturation_power); 1994 group->saturation_power);
1995 return; 1995 return;
@@ -2004,7 +2004,7 @@ static void il3945_hw_reg_init_channel_groups(struct il_priv *priv)
2004 * power peaks, without too much distortion (clipping). 2004 * power peaks, without too much distortion (clipping).
2005 */ 2005 */
2006 /* we'll fill in this array with h/w max power levels */ 2006 /* we'll fill in this array with h/w max power levels */
2007 clip_pwrs = (s8 *) priv->_3945.clip_groups[i].clip_powers; 2007 clip_pwrs = (s8 *) il->_3945.clip_groups[i].clip_powers;
2008 2008
2009 /* divide factory saturation power by 2 to find -3dB level */ 2009 /* divide factory saturation power by 2 to find -3dB level */
2010 satur_pwr = (s8) (group->saturation_power >> 1); 2010 satur_pwr = (s8) (group->saturation_power >> 1);
@@ -2042,7 +2042,7 @@ static void il3945_hw_reg_init_channel_groups(struct il_priv *priv)
2042/** 2042/**
2043 * il3945_txpower_set_from_eeprom - Set channel power info based on EEPROM 2043 * il3945_txpower_set_from_eeprom - Set channel power info based on EEPROM
2044 * 2044 *
2045 * Second pass (during init) to set up priv->channel_info 2045 * Second pass (during init) to set up il->channel_info
2046 * 2046 *
2047 * Set up Tx-power settings in our channel info database for each VALID 2047 * Set up Tx-power settings in our channel info database for each VALID
2048 * (for this geo/SKU) channel, at all Tx data rates, based on eeprom values 2048 * (for this geo/SKU) channel, at all Tx data rates, based on eeprom values
@@ -2054,11 +2054,11 @@ static void il3945_hw_reg_init_channel_groups(struct il_priv *priv)
2054 * 2054 *
2055 * This does *not* write values to NIC, just sets up our internal table. 2055 * This does *not* write values to NIC, just sets up our internal table.
2056 */ 2056 */
2057int il3945_txpower_set_from_eeprom(struct il_priv *priv) 2057int il3945_txpower_set_from_eeprom(struct il_priv *il)
2058{ 2058{
2059 struct il_channel_info *ch_info = NULL; 2059 struct il_channel_info *ch_info = NULL;
2060 struct il3945_channel_power_info *pwr_info; 2060 struct il3945_channel_power_info *pwr_info;
2061 struct il3945_eeprom *eeprom = (struct il3945_eeprom *)priv->eeprom; 2061 struct il3945_eeprom *eeprom = (struct il3945_eeprom *)il->eeprom;
2062 int delta_index; 2062 int delta_index;
2063 u8 rate_index; 2063 u8 rate_index;
2064 u8 scan_tbl_index; 2064 u8 scan_tbl_index;
@@ -2071,13 +2071,13 @@ int il3945_txpower_set_from_eeprom(struct il_priv *priv)
2071 2071
2072 /* save temperature reference, 2072 /* save temperature reference,
2073 * so we can determine next time to calibrate */ 2073 * so we can determine next time to calibrate */
2074 temperature = il3945_hw_reg_txpower_get_temperature(priv); 2074 temperature = il3945_hw_reg_txpower_get_temperature(il);
2075 priv->last_temperature = temperature; 2075 il->last_temperature = temperature;
2076 2076
2077 il3945_hw_reg_init_channel_groups(priv); 2077 il3945_hw_reg_init_channel_groups(il);
2078 2078
2079 /* initialize Tx power info for each and every channel, 2.4 and 5.x */ 2079 /* initialize Tx power info for each and every channel, 2.4 and 5.x */
2080 for (i = 0, ch_info = priv->channel_info; i < priv->channel_count; 2080 for (i = 0, ch_info = il->channel_info; i < il->channel_count;
2081 i++, ch_info++) { 2081 i++, ch_info++) {
2082 a_band = il_is_channel_a_band(ch_info); 2082 a_band = il_is_channel_a_band(ch_info);
2083 if (!il_is_channel_valid(ch_info)) 2083 if (!il_is_channel_valid(ch_info))
@@ -2085,10 +2085,10 @@ int il3945_txpower_set_from_eeprom(struct il_priv *priv)
2085 2085
2086 /* find this channel's channel group (*not* "band") index */ 2086 /* find this channel's channel group (*not* "band") index */
2087 ch_info->group_index = 2087 ch_info->group_index =
2088 il3945_hw_reg_get_ch_grp_index(priv, ch_info); 2088 il3945_hw_reg_get_ch_grp_index(il, ch_info);
2089 2089
2090 /* Get this chnlgrp's rate->max/clip-powers table */ 2090 /* Get this chnlgrp's rate->max/clip-powers table */
2091 clip_pwrs = priv->_3945.clip_groups[ch_info->group_index].clip_powers; 2091 clip_pwrs = il->_3945.clip_groups[ch_info->group_index].clip_powers;
2092 2092
2093 /* calculate power index *adjustment* value according to 2093 /* calculate power index *adjustment* value according to
2094 * diff between current temperature and factory temperature */ 2094 * diff between current temperature and factory temperature */
@@ -2096,7 +2096,7 @@ int il3945_txpower_set_from_eeprom(struct il_priv *priv)
2096 eeprom->groups[ch_info->group_index]. 2096 eeprom->groups[ch_info->group_index].
2097 temperature); 2097 temperature);
2098 2098
2099 IL_DEBUG_POWER(priv, "Delta index for channel %d: %d [%d]\n", 2099 IL_DEBUG_POWER(il, "Delta index for channel %d: %d [%d]\n",
2100 ch_info->channel, delta_index, temperature + 2100 ch_info->channel, delta_index, temperature +
2101 IL_TEMP_CONVERT); 2101 IL_TEMP_CONVERT);
2102 2102
@@ -2115,11 +2115,11 @@ int il3945_txpower_set_from_eeprom(struct il_priv *priv)
2115 2115
2116 /* get base (i.e. at factory-measured temperature) 2116 /* get base (i.e. at factory-measured temperature)
2117 * power table index for this rate's power */ 2117 * power table index for this rate's power */
2118 rc = il3945_hw_reg_get_matched_power_index(priv, pwr, 2118 rc = il3945_hw_reg_get_matched_power_index(il, pwr,
2119 ch_info->group_index, 2119 ch_info->group_index,
2120 &power_idx); 2120 &power_idx);
2121 if (rc) { 2121 if (rc) {
2122 IL_ERR(priv, "Invalid power index\n"); 2122 IL_ERR(il, "Invalid power index\n");
2123 return rc; 2123 return rc;
2124 } 2124 }
2125 pwr_info->base_power_index = (u8) power_idx; 2125 pwr_info->base_power_index = (u8) power_idx;
@@ -2171,7 +2171,7 @@ int il3945_txpower_set_from_eeprom(struct il_priv *priv)
2171 scan_tbl_index < IL_NUM_SCAN_RATES; scan_tbl_index++) { 2171 scan_tbl_index < IL_NUM_SCAN_RATES; scan_tbl_index++) {
2172 s32 actual_index = (scan_tbl_index == 0) ? 2172 s32 actual_index = (scan_tbl_index == 0) ?
2173 IL_RATE_1M_INDEX_TABLE : IL_RATE_6M_INDEX_TABLE; 2173 IL_RATE_1M_INDEX_TABLE : IL_RATE_6M_INDEX_TABLE;
2174 il3945_hw_reg_set_scan_power(priv, scan_tbl_index, 2174 il3945_hw_reg_set_scan_power(il, scan_tbl_index,
2175 actual_index, clip_pwrs, ch_info, a_band); 2175 actual_index, clip_pwrs, ch_info, a_band);
2176 } 2176 }
2177 } 2177 }
@@ -2179,31 +2179,31 @@ int il3945_txpower_set_from_eeprom(struct il_priv *priv)
2179 return 0; 2179 return 0;
2180} 2180}
2181 2181
2182int il3945_hw_rxq_stop(struct il_priv *priv) 2182int il3945_hw_rxq_stop(struct il_priv *il)
2183{ 2183{
2184 int rc; 2184 int rc;
2185 2185
2186 il_write_direct32(priv, FH39_RCSR_CONFIG(0), 0); 2186 il_write_direct32(il, FH39_RCSR_CONFIG(0), 0);
2187 rc = il_poll_direct_bit(priv, FH39_RSSR_STATUS, 2187 rc = il_poll_direct_bit(il, FH39_RSSR_STATUS,
2188 FH39_RSSR_CHNL0_RX_STATUS_CHNL_IDLE, 1000); 2188 FH39_RSSR_CHNL0_RX_STATUS_CHNL_IDLE, 1000);
2189 if (rc < 0) 2189 if (rc < 0)
2190 IL_ERR(priv, "Can't stop Rx DMA.\n"); 2190 IL_ERR(il, "Can't stop Rx DMA.\n");
2191 2191
2192 return 0; 2192 return 0;
2193} 2193}
2194 2194
2195int il3945_hw_tx_queue_init(struct il_priv *priv, struct il_tx_queue *txq) 2195int il3945_hw_tx_queue_init(struct il_priv *il, struct il_tx_queue *txq)
2196{ 2196{
2197 int txq_id = txq->q.id; 2197 int txq_id = txq->q.id;
2198 2198
2199 struct il3945_shared *shared_data = priv->_3945.shared_virt; 2199 struct il3945_shared *shared_data = il->_3945.shared_virt;
2200 2200
2201 shared_data->tx_base_ptr[txq_id] = cpu_to_le32((u32)txq->q.dma_addr); 2201 shared_data->tx_base_ptr[txq_id] = cpu_to_le32((u32)txq->q.dma_addr);
2202 2202
2203 il_write_direct32(priv, FH39_CBCC_CTRL(txq_id), 0); 2203 il_write_direct32(il, FH39_CBCC_CTRL(txq_id), 0);
2204 il_write_direct32(priv, FH39_CBCC_BASE(txq_id), 0); 2204 il_write_direct32(il, FH39_CBCC_BASE(txq_id), 0);
2205 2205
2206 il_write_direct32(priv, FH39_TCSR_CONFIG(txq_id), 2206 il_write_direct32(il, FH39_TCSR_CONFIG(txq_id),
2207 FH39_TCSR_TX_CONFIG_REG_VAL_CIRQ_RTC_NOINT | 2207 FH39_TCSR_TX_CONFIG_REG_VAL_CIRQ_RTC_NOINT |
2208 FH39_TCSR_TX_CONFIG_REG_VAL_MSG_MODE_TXF | 2208 FH39_TCSR_TX_CONFIG_REG_VAL_MSG_MODE_TXF |
2209 FH39_TCSR_TX_CONFIG_REG_VAL_CIRQ_HOST_IFTFD | 2209 FH39_TCSR_TX_CONFIG_REG_VAL_CIRQ_HOST_IFTFD |
@@ -2211,7 +2211,7 @@ int il3945_hw_tx_queue_init(struct il_priv *priv, struct il_tx_queue *txq)
2211 FH39_TCSR_TX_CONFIG_REG_VAL_DMA_CHNL_ENABLE); 2211 FH39_TCSR_TX_CONFIG_REG_VAL_DMA_CHNL_ENABLE);
2212 2212
2213 /* fake read to flush all prev. writes */ 2213 /* fake read to flush all prev. writes */
2214 il_read32(priv, FH39_TSSR_CBB_BASE); 2214 il_read32(il, FH39_TSSR_CBB_BASE);
2215 2215
2216 return 0; 2216 return 0;
2217} 2217}
@@ -2250,10 +2250,10 @@ static u16 il3945_build_addsta_hcmd(const struct il_addsta_cmd *cmd,
2250 return (u16)sizeof(struct il3945_addsta_cmd); 2250 return (u16)sizeof(struct il3945_addsta_cmd);
2251} 2251}
2252 2252
2253static int il3945_add_bssid_station(struct il_priv *priv, 2253static int il3945_add_bssid_station(struct il_priv *il,
2254 const u8 *addr, u8 *sta_id_r) 2254 const u8 *addr, u8 *sta_id_r)
2255{ 2255{
2256 struct il_rxon_context *ctx = &priv->contexts[IL_RXON_CTX_BSS]; 2256 struct il_rxon_context *ctx = &il->contexts[IL_RXON_CTX_BSS];
2257 int ret; 2257 int ret;
2258 u8 sta_id; 2258 u8 sta_id;
2259 unsigned long flags; 2259 unsigned long flags;
@@ -2261,49 +2261,49 @@ static int il3945_add_bssid_station(struct il_priv *priv,
2261 if (sta_id_r) 2261 if (sta_id_r)
2262 *sta_id_r = IL_INVALID_STATION; 2262 *sta_id_r = IL_INVALID_STATION;
2263 2263
2264 ret = il_add_station_common(priv, ctx, addr, 0, NULL, &sta_id); 2264 ret = il_add_station_common(il, ctx, addr, 0, NULL, &sta_id);
2265 if (ret) { 2265 if (ret) {
2266 IL_ERR(priv, "Unable to add station %pM\n", addr); 2266 IL_ERR(il, "Unable to add station %pM\n", addr);
2267 return ret; 2267 return ret;
2268 } 2268 }
2269 2269
2270 if (sta_id_r) 2270 if (sta_id_r)
2271 *sta_id_r = sta_id; 2271 *sta_id_r = sta_id;
2272 2272
2273 spin_lock_irqsave(&priv->sta_lock, flags); 2273 spin_lock_irqsave(&il->sta_lock, flags);
2274 priv->stations[sta_id].used |= IL_STA_LOCAL; 2274 il->stations[sta_id].used |= IL_STA_LOCAL;
2275 spin_unlock_irqrestore(&priv->sta_lock, flags); 2275 spin_unlock_irqrestore(&il->sta_lock, flags);
2276 2276
2277 return 0; 2277 return 0;
2278} 2278}
2279static int il3945_manage_ibss_station(struct il_priv *priv, 2279static int il3945_manage_ibss_station(struct il_priv *il,
2280 struct ieee80211_vif *vif, bool add) 2280 struct ieee80211_vif *vif, bool add)
2281{ 2281{
2282 struct il_vif_priv *vif_priv = (void *)vif->drv_priv; 2282 struct il_vif_priv *vif_priv = (void *)vif->drv_priv;
2283 int ret; 2283 int ret;
2284 2284
2285 if (add) { 2285 if (add) {
2286 ret = il3945_add_bssid_station(priv, vif->bss_conf.bssid, 2286 ret = il3945_add_bssid_station(il, vif->bss_conf.bssid,
2287 &vif_priv->ibss_bssid_sta_id); 2287 &vif_priv->ibss_bssid_sta_id);
2288 if (ret) 2288 if (ret)
2289 return ret; 2289 return ret;
2290 2290
2291 il3945_sync_sta(priv, vif_priv->ibss_bssid_sta_id, 2291 il3945_sync_sta(il, vif_priv->ibss_bssid_sta_id,
2292 (priv->band == IEEE80211_BAND_5GHZ) ? 2292 (il->band == IEEE80211_BAND_5GHZ) ?
2293 IL_RATE_6M_PLCP : IL_RATE_1M_PLCP); 2293 IL_RATE_6M_PLCP : IL_RATE_1M_PLCP);
2294 il3945_rate_scale_init(priv->hw, vif_priv->ibss_bssid_sta_id); 2294 il3945_rate_scale_init(il->hw, vif_priv->ibss_bssid_sta_id);
2295 2295
2296 return 0; 2296 return 0;
2297 } 2297 }
2298 2298
2299 return il_remove_station(priv, vif_priv->ibss_bssid_sta_id, 2299 return il_remove_station(il, vif_priv->ibss_bssid_sta_id,
2300 vif->bss_conf.bssid); 2300 vif->bss_conf.bssid);
2301} 2301}
2302 2302
2303/** 2303/**
2304 * il3945_init_hw_rate_table - Initialize the hardware rate fallback table 2304 * il3945_init_hw_rate_table - Initialize the hardware rate fallback table
2305 */ 2305 */
2306int il3945_init_hw_rate_table(struct il_priv *priv) 2306int il3945_init_hw_rate_table(struct il_priv *il)
2307{ 2307{
2308 int rc, i, index, prev_index; 2308 int rc, i, index, prev_index;
2309 struct il3945_rate_scaling_cmd rate_cmd = { 2309 struct il3945_rate_scaling_cmd rate_cmd = {
@@ -2316,15 +2316,15 @@ int il3945_init_hw_rate_table(struct il_priv *priv)
2316 2316
2317 table[index].rate_n_flags = 2317 table[index].rate_n_flags =
2318 il3945_hw_set_rate_n_flags(il3945_rates[i].plcp, 0); 2318 il3945_hw_set_rate_n_flags(il3945_rates[i].plcp, 0);
2319 table[index].try_cnt = priv->retry_rate; 2319 table[index].try_cnt = il->retry_rate;
2320 prev_index = il3945_get_prev_ieee_rate(i); 2320 prev_index = il3945_get_prev_ieee_rate(i);
2321 table[index].next_rate_index = 2321 table[index].next_rate_index =
2322 il3945_rates[prev_index].table_rs_index; 2322 il3945_rates[prev_index].table_rs_index;
2323 } 2323 }
2324 2324
2325 switch (priv->band) { 2325 switch (il->band) {
2326 case IEEE80211_BAND_5GHZ: 2326 case IEEE80211_BAND_5GHZ:
2327 IL_DEBUG_RATE(priv, "Select A mode rate scale\n"); 2327 IL_DEBUG_RATE(il, "Select A mode rate scale\n");
2328 /* If one of the following CCK rates is used, 2328 /* If one of the following CCK rates is used,
2329 * have it fall back to the 6M OFDM rate */ 2329 * have it fall back to the 6M OFDM rate */
2330 for (i = IL_RATE_1M_INDEX_TABLE; 2330 for (i = IL_RATE_1M_INDEX_TABLE;
@@ -2342,12 +2342,12 @@ int il3945_init_hw_rate_table(struct il_priv *priv)
2342 break; 2342 break;
2343 2343
2344 case IEEE80211_BAND_2GHZ: 2344 case IEEE80211_BAND_2GHZ:
2345 IL_DEBUG_RATE(priv, "Select B/G mode rate scale\n"); 2345 IL_DEBUG_RATE(il, "Select B/G mode rate scale\n");
2346 /* If an OFDM rate is used, have it fall back to the 2346 /* If an OFDM rate is used, have it fall back to the
2347 * 1M CCK rates */ 2347 * 1M CCK rates */
2348 2348
2349 if (!(priv->_3945.sta_supp_rates & IL_OFDM_RATES_MASK) && 2349 if (!(il->_3945.sta_supp_rates & IL_OFDM_RATES_MASK) &&
2350 il_is_associated(priv, IL_RXON_CTX_BSS)) { 2350 il_is_associated(il, IL_RXON_CTX_BSS)) {
2351 2351
2352 index = IL_FIRST_CCK_RATE; 2352 index = IL_FIRST_CCK_RATE;
2353 for (i = IL_RATE_6M_INDEX_TABLE; 2353 for (i = IL_RATE_6M_INDEX_TABLE;
@@ -2368,52 +2368,52 @@ int il3945_init_hw_rate_table(struct il_priv *priv)
2368 2368
2369 /* Update the rate scaling for control frame Tx */ 2369 /* Update the rate scaling for control frame Tx */
2370 rate_cmd.table_id = 0; 2370 rate_cmd.table_id = 0;
2371 rc = il_send_cmd_pdu(priv, REPLY_RATE_SCALE, sizeof(rate_cmd), 2371 rc = il_send_cmd_pdu(il, REPLY_RATE_SCALE, sizeof(rate_cmd),
2372 &rate_cmd); 2372 &rate_cmd);
2373 if (rc) 2373 if (rc)
2374 return rc; 2374 return rc;
2375 2375
2376 /* Update the rate scaling for data frame Tx */ 2376 /* Update the rate scaling for data frame Tx */
2377 rate_cmd.table_id = 1; 2377 rate_cmd.table_id = 1;
2378 return il_send_cmd_pdu(priv, REPLY_RATE_SCALE, sizeof(rate_cmd), 2378 return il_send_cmd_pdu(il, REPLY_RATE_SCALE, sizeof(rate_cmd),
2379 &rate_cmd); 2379 &rate_cmd);
2380} 2380}
2381 2381
2382/* Called when initializing driver */ 2382/* Called when initializing driver */
2383int il3945_hw_set_hw_params(struct il_priv *priv) 2383int il3945_hw_set_hw_params(struct il_priv *il)
2384{ 2384{
2385 memset((void *)&priv->hw_params, 0, 2385 memset((void *)&il->hw_params, 0,
2386 sizeof(struct il_hw_params)); 2386 sizeof(struct il_hw_params));
2387 2387
2388 priv->_3945.shared_virt = 2388 il->_3945.shared_virt =
2389 dma_alloc_coherent(&priv->pci_dev->dev, 2389 dma_alloc_coherent(&il->pci_dev->dev,
2390 sizeof(struct il3945_shared), 2390 sizeof(struct il3945_shared),
2391 &priv->_3945.shared_phys, GFP_KERNEL); 2391 &il->_3945.shared_phys, GFP_KERNEL);
2392 if (!priv->_3945.shared_virt) { 2392 if (!il->_3945.shared_virt) {
2393 IL_ERR(priv, "failed to allocate pci memory\n"); 2393 IL_ERR(il, "failed to allocate pci memory\n");
2394 return -ENOMEM; 2394 return -ENOMEM;
2395 } 2395 }
2396 2396
2397 /* Assign number of Usable TX queues */ 2397 /* Assign number of Usable TX queues */
2398 priv->hw_params.max_txq_num = priv->cfg->base_params->num_of_queues; 2398 il->hw_params.max_txq_num = il->cfg->base_params->num_of_queues;
2399 2399
2400 priv->hw_params.tfd_size = sizeof(struct il3945_tfd); 2400 il->hw_params.tfd_size = sizeof(struct il3945_tfd);
2401 priv->hw_params.rx_page_order = get_order(IL_RX_BUF_SIZE_3K); 2401 il->hw_params.rx_page_order = get_order(IL_RX_BUF_SIZE_3K);
2402 priv->hw_params.max_rxq_size = RX_QUEUE_SIZE; 2402 il->hw_params.max_rxq_size = RX_QUEUE_SIZE;
2403 priv->hw_params.max_rxq_log = RX_QUEUE_SIZE_LOG; 2403 il->hw_params.max_rxq_log = RX_QUEUE_SIZE_LOG;
2404 priv->hw_params.max_stations = IWL3945_STATION_COUNT; 2404 il->hw_params.max_stations = IWL3945_STATION_COUNT;
2405 priv->contexts[IL_RXON_CTX_BSS].bcast_sta_id = IWL3945_BROADCAST_ID; 2405 il->contexts[IL_RXON_CTX_BSS].bcast_sta_id = IWL3945_BROADCAST_ID;
2406 2406
2407 priv->sta_key_max_num = STA_KEY_MAX_NUM; 2407 il->sta_key_max_num = STA_KEY_MAX_NUM;
2408 2408
2409 priv->hw_params.rx_wrt_ptr_reg = FH39_RSCSR_CHNL0_WPTR; 2409 il->hw_params.rx_wrt_ptr_reg = FH39_RSCSR_CHNL0_WPTR;
2410 priv->hw_params.max_beacon_itrvl = IWL39_MAX_UCODE_BEACON_INTERVAL; 2410 il->hw_params.max_beacon_itrvl = IWL39_MAX_UCODE_BEACON_INTERVAL;
2411 priv->hw_params.beacon_time_tsf_bits = IWL3945_EXT_BEACON_TIME_POS; 2411 il->hw_params.beacon_time_tsf_bits = IWL3945_EXT_BEACON_TIME_POS;
2412 2412
2413 return 0; 2413 return 0;
2414} 2414}
2415 2415
2416unsigned int il3945_hw_get_beacon_cmd(struct il_priv *priv, 2416unsigned int il3945_hw_get_beacon_cmd(struct il_priv *il,
2417 struct il3945_frame *frame, u8 rate) 2417 struct il3945_frame *frame, u8 rate)
2418{ 2418{
2419 struct il3945_tx_beacon_cmd *tx_beacon_cmd; 2419 struct il3945_tx_beacon_cmd *tx_beacon_cmd;
@@ -2423,10 +2423,10 @@ unsigned int il3945_hw_get_beacon_cmd(struct il_priv *priv,
2423 memset(tx_beacon_cmd, 0, sizeof(*tx_beacon_cmd)); 2423 memset(tx_beacon_cmd, 0, sizeof(*tx_beacon_cmd));
2424 2424
2425 tx_beacon_cmd->tx.sta_id = 2425 tx_beacon_cmd->tx.sta_id =
2426 priv->contexts[IL_RXON_CTX_BSS].bcast_sta_id; 2426 il->contexts[IL_RXON_CTX_BSS].bcast_sta_id;
2427 tx_beacon_cmd->tx.stop_time.life_time = TX_CMD_LIFE_TIME_INFINITE; 2427 tx_beacon_cmd->tx.stop_time.life_time = TX_CMD_LIFE_TIME_INFINITE;
2428 2428
2429 frame_size = il3945_fill_beacon_frame(priv, 2429 frame_size = il3945_fill_beacon_frame(il,
2430 tx_beacon_cmd->frame, 2430 tx_beacon_cmd->frame,
2431 sizeof(frame->u) - sizeof(*tx_beacon_cmd)); 2431 sizeof(frame->u) - sizeof(*tx_beacon_cmd));
2432 2432
@@ -2447,41 +2447,41 @@ unsigned int il3945_hw_get_beacon_cmd(struct il_priv *priv,
2447 return sizeof(struct il3945_tx_beacon_cmd) + frame_size; 2447 return sizeof(struct il3945_tx_beacon_cmd) + frame_size;
2448} 2448}
2449 2449
2450void il3945_hw_rx_handler_setup(struct il_priv *priv) 2450void il3945_hw_rx_handler_setup(struct il_priv *il)
2451{ 2451{
2452 priv->rx_handlers[REPLY_TX] = il3945_rx_reply_tx; 2452 il->rx_handlers[REPLY_TX] = il3945_rx_reply_tx;
2453 priv->rx_handlers[REPLY_3945_RX] = il3945_rx_reply_rx; 2453 il->rx_handlers[REPLY_3945_RX] = il3945_rx_reply_rx;
2454} 2454}
2455 2455
2456void il3945_hw_setup_deferred_work(struct il_priv *priv) 2456void il3945_hw_setup_deferred_work(struct il_priv *il)
2457{ 2457{
2458 INIT_DELAYED_WORK(&priv->_3945.thermal_periodic, 2458 INIT_DELAYED_WORK(&il->_3945.thermal_periodic,
2459 il3945_bg_reg_txpower_periodic); 2459 il3945_bg_reg_txpower_periodic);
2460} 2460}
2461 2461
2462void il3945_hw_cancel_deferred_work(struct il_priv *priv) 2462void il3945_hw_cancel_deferred_work(struct il_priv *il)
2463{ 2463{
2464 cancel_delayed_work(&priv->_3945.thermal_periodic); 2464 cancel_delayed_work(&il->_3945.thermal_periodic);
2465} 2465}
2466 2466
2467/* check contents of special bootstrap uCode SRAM */ 2467/* check contents of special bootstrap uCode SRAM */
2468static int il3945_verify_bsm(struct il_priv *priv) 2468static int il3945_verify_bsm(struct il_priv *il)
2469 { 2469 {
2470 __le32 *image = priv->ucode_boot.v_addr; 2470 __le32 *image = il->ucode_boot.v_addr;
2471 u32 len = priv->ucode_boot.len; 2471 u32 len = il->ucode_boot.len;
2472 u32 reg; 2472 u32 reg;
2473 u32 val; 2473 u32 val;
2474 2474
2475 IL_DEBUG_INFO(priv, "Begin verify bsm\n"); 2475 IL_DEBUG_INFO(il, "Begin verify bsm\n");
2476 2476
2477 /* verify BSM SRAM contents */ 2477 /* verify BSM SRAM contents */
2478 val = il_read_prph(priv, BSM_WR_DWCOUNT_REG); 2478 val = il_read_prph(il, BSM_WR_DWCOUNT_REG);
2479 for (reg = BSM_SRAM_LOWER_BOUND; 2479 for (reg = BSM_SRAM_LOWER_BOUND;
2480 reg < BSM_SRAM_LOWER_BOUND + len; 2480 reg < BSM_SRAM_LOWER_BOUND + len;
2481 reg += sizeof(u32), image++) { 2481 reg += sizeof(u32), image++) {
2482 val = il_read_prph(priv, reg); 2482 val = il_read_prph(il, reg);
2483 if (val != le32_to_cpu(*image)) { 2483 if (val != le32_to_cpu(*image)) {
2484 IL_ERR(priv, "BSM uCode verification failed at " 2484 IL_ERR(il, "BSM uCode verification failed at "
2485 "addr 0x%08X+%u (of %u), is 0x%x, s/b 0x%x\n", 2485 "addr 0x%08X+%u (of %u), is 0x%x, s/b 0x%x\n",
2486 BSM_SRAM_LOWER_BOUND, 2486 BSM_SRAM_LOWER_BOUND,
2487 reg - BSM_SRAM_LOWER_BOUND, len, 2487 reg - BSM_SRAM_LOWER_BOUND, len,
@@ -2490,7 +2490,7 @@ static int il3945_verify_bsm(struct il_priv *priv)
2490 } 2490 }
2491 } 2491 }
2492 2492
2493 IL_DEBUG_INFO(priv, "BSM bootstrap uCode image OK\n"); 2493 IL_DEBUG_INFO(il, "BSM bootstrap uCode image OK\n");
2494 2494
2495 return 0; 2495 return 0;
2496} 2496}
@@ -2510,14 +2510,14 @@ static int il3945_verify_bsm(struct il_priv *priv)
2510 * simply claims ownership, which should be safe when this function is called 2510 * simply claims ownership, which should be safe when this function is called
2511 * (i.e. before loading uCode!). 2511 * (i.e. before loading uCode!).
2512 */ 2512 */
2513static int il3945_eeprom_acquire_semaphore(struct il_priv *priv) 2513static int il3945_eeprom_acquire_semaphore(struct il_priv *il)
2514{ 2514{
2515 _il_clear_bit(priv, CSR_EEPROM_GP, CSR_EEPROM_GP_IF_OWNER_MSK); 2515 _il_clear_bit(il, CSR_EEPROM_GP, CSR_EEPROM_GP_IF_OWNER_MSK);
2516 return 0; 2516 return 0;
2517} 2517}
2518 2518
2519 2519
2520static void il3945_eeprom_release_semaphore(struct il_priv *priv) 2520static void il3945_eeprom_release_semaphore(struct il_priv *il)
2521{ 2521{
2522 return; 2522 return;
2523} 2523}
@@ -2554,10 +2554,10 @@ static void il3945_eeprom_release_semaphore(struct il_priv *priv)
2554 * the runtime uCode instructions and the backup data cache into SRAM, 2554 * the runtime uCode instructions and the backup data cache into SRAM,
2555 * and re-launches the runtime uCode from where it left off. 2555 * and re-launches the runtime uCode from where it left off.
2556 */ 2556 */
2557static int il3945_load_bsm(struct il_priv *priv) 2557static int il3945_load_bsm(struct il_priv *il)
2558{ 2558{
2559 __le32 *image = priv->ucode_boot.v_addr; 2559 __le32 *image = il->ucode_boot.v_addr;
2560 u32 len = priv->ucode_boot.len; 2560 u32 len = il->ucode_boot.len;
2561 dma_addr_t pinst; 2561 dma_addr_t pinst;
2562 dma_addr_t pdata; 2562 dma_addr_t pdata;
2563 u32 inst_len; 2563 u32 inst_len;
@@ -2567,7 +2567,7 @@ static int il3945_load_bsm(struct il_priv *priv)
2567 u32 done; 2567 u32 done;
2568 u32 reg_offset; 2568 u32 reg_offset;
2569 2569
2570 IL_DEBUG_INFO(priv, "Begin load bsm\n"); 2570 IL_DEBUG_INFO(il, "Begin load bsm\n");
2571 2571
2572 /* make sure bootstrap program is no larger than BSM's SRAM size */ 2572 /* make sure bootstrap program is no larger than BSM's SRAM size */
2573 if (len > IWL39_MAX_BSM_SIZE) 2573 if (len > IWL39_MAX_BSM_SIZE)
@@ -2578,55 +2578,55 @@ static int il3945_load_bsm(struct il_priv *priv)
2578 * NOTE: il3945_initialize_alive_start() will replace these values, 2578 * NOTE: il3945_initialize_alive_start() will replace these values,
2579 * after the "initialize" uCode has run, to point to 2579 * after the "initialize" uCode has run, to point to
2580 * runtime/protocol instructions and backup data cache. */ 2580 * runtime/protocol instructions and backup data cache. */
2581 pinst = priv->ucode_init.p_addr; 2581 pinst = il->ucode_init.p_addr;
2582 pdata = priv->ucode_init_data.p_addr; 2582 pdata = il->ucode_init_data.p_addr;
2583 inst_len = priv->ucode_init.len; 2583 inst_len = il->ucode_init.len;
2584 data_len = priv->ucode_init_data.len; 2584 data_len = il->ucode_init_data.len;
2585 2585
2586 il_write_prph(priv, BSM_DRAM_INST_PTR_REG, pinst); 2586 il_write_prph(il, BSM_DRAM_INST_PTR_REG, pinst);
2587 il_write_prph(priv, BSM_DRAM_DATA_PTR_REG, pdata); 2587 il_write_prph(il, BSM_DRAM_DATA_PTR_REG, pdata);
2588 il_write_prph(priv, BSM_DRAM_INST_BYTECOUNT_REG, inst_len); 2588 il_write_prph(il, BSM_DRAM_INST_BYTECOUNT_REG, inst_len);
2589 il_write_prph(priv, BSM_DRAM_DATA_BYTECOUNT_REG, data_len); 2589 il_write_prph(il, BSM_DRAM_DATA_BYTECOUNT_REG, data_len);
2590 2590
2591 /* Fill BSM memory with bootstrap instructions */ 2591 /* Fill BSM memory with bootstrap instructions */
2592 for (reg_offset = BSM_SRAM_LOWER_BOUND; 2592 for (reg_offset = BSM_SRAM_LOWER_BOUND;
2593 reg_offset < BSM_SRAM_LOWER_BOUND + len; 2593 reg_offset < BSM_SRAM_LOWER_BOUND + len;
2594 reg_offset += sizeof(u32), image++) 2594 reg_offset += sizeof(u32), image++)
2595 _il_write_prph(priv, reg_offset, 2595 _il_write_prph(il, reg_offset,
2596 le32_to_cpu(*image)); 2596 le32_to_cpu(*image));
2597 2597
2598 rc = il3945_verify_bsm(priv); 2598 rc = il3945_verify_bsm(il);
2599 if (rc) 2599 if (rc)
2600 return rc; 2600 return rc;
2601 2601
2602 /* Tell BSM to copy from BSM SRAM into instruction SRAM, when asked */ 2602 /* Tell BSM to copy from BSM SRAM into instruction SRAM, when asked */
2603 il_write_prph(priv, BSM_WR_MEM_SRC_REG, 0x0); 2603 il_write_prph(il, BSM_WR_MEM_SRC_REG, 0x0);
2604 il_write_prph(priv, BSM_WR_MEM_DST_REG, 2604 il_write_prph(il, BSM_WR_MEM_DST_REG,
2605 IWL39_RTC_INST_LOWER_BOUND); 2605 IWL39_RTC_INST_LOWER_BOUND);
2606 il_write_prph(priv, BSM_WR_DWCOUNT_REG, len / sizeof(u32)); 2606 il_write_prph(il, BSM_WR_DWCOUNT_REG, len / sizeof(u32));
2607 2607
2608 /* Load bootstrap code into instruction SRAM now, 2608 /* Load bootstrap code into instruction SRAM now,
2609 * to prepare to load "initialize" uCode */ 2609 * to prepare to load "initialize" uCode */
2610 il_write_prph(priv, BSM_WR_CTRL_REG, 2610 il_write_prph(il, BSM_WR_CTRL_REG,
2611 BSM_WR_CTRL_REG_BIT_START); 2611 BSM_WR_CTRL_REG_BIT_START);
2612 2612
2613 /* Wait for load of bootstrap uCode to finish */ 2613 /* Wait for load of bootstrap uCode to finish */
2614 for (i = 0; i < 100; i++) { 2614 for (i = 0; i < 100; i++) {
2615 done = il_read_prph(priv, BSM_WR_CTRL_REG); 2615 done = il_read_prph(il, BSM_WR_CTRL_REG);
2616 if (!(done & BSM_WR_CTRL_REG_BIT_START)) 2616 if (!(done & BSM_WR_CTRL_REG_BIT_START))
2617 break; 2617 break;
2618 udelay(10); 2618 udelay(10);
2619 } 2619 }
2620 if (i < 100) 2620 if (i < 100)
2621 IL_DEBUG_INFO(priv, "BSM write complete, poll %d iterations\n", i); 2621 IL_DEBUG_INFO(il, "BSM write complete, poll %d iterations\n", i);
2622 else { 2622 else {
2623 IL_ERR(priv, "BSM write did not complete!\n"); 2623 IL_ERR(il, "BSM write did not complete!\n");
2624 return -EIO; 2624 return -EIO;
2625 } 2625 }
2626 2626
2627 /* Enable future boot loads whenever power management unit triggers it 2627 /* Enable future boot loads whenever power management unit triggers it
2628 * (e.g. when powering back up after power-save shutdown) */ 2628 * (e.g. when powering back up after power-save shutdown) */
2629 il_write_prph(priv, BSM_WR_CTRL_REG, 2629 il_write_prph(il, BSM_WR_CTRL_REG,
2630 BSM_WR_CTRL_REG_BIT_START_EN); 2630 BSM_WR_CTRL_REG_BIT_START_EN);
2631 2631
2632 return 0; 2632 return 0;
diff --git a/drivers/net/wireless/iwlegacy/iwl-3945.h b/drivers/net/wireless/iwlegacy/iwl-3945.h
index 167eedcfeb63..abe778b1b424 100644
--- a/drivers/net/wireless/iwlegacy/iwl-3945.h
+++ b/drivers/net/wireless/iwlegacy/iwl-3945.h
@@ -85,7 +85,7 @@ struct il3945_rate_scale_data {
85 85
86struct il3945_rs_sta { 86struct il3945_rs_sta {
87 spinlock_t lock; 87 spinlock_t lock;
88 struct il_priv *priv; 88 struct il_priv *il;
89 s32 *expected_tpt; 89 s32 *expected_tpt;
90 unsigned long last_partial_flush; 90 unsigned long last_partial_flush;
91 unsigned long last_flush; 91 unsigned long last_flush;
@@ -207,12 +207,12 @@ struct il3945_ibss_seq {
207 *****************************************************************************/ 207 *****************************************************************************/
208extern int il3945_calc_db_from_ratio(int sig_ratio); 208extern int il3945_calc_db_from_ratio(int sig_ratio);
209extern void il3945_rx_replenish(void *data); 209extern void il3945_rx_replenish(void *data);
210extern void il3945_rx_queue_reset(struct il_priv *priv, struct il_rx_queue *rxq); 210extern void il3945_rx_queue_reset(struct il_priv *il, struct il_rx_queue *rxq);
211extern unsigned int il3945_fill_beacon_frame(struct il_priv *priv, 211extern unsigned int il3945_fill_beacon_frame(struct il_priv *il,
212 struct ieee80211_hdr *hdr, int left); 212 struct ieee80211_hdr *hdr, int left);
213extern int il3945_dump_nic_event_log(struct il_priv *priv, bool full_log, 213extern int il3945_dump_nic_event_log(struct il_priv *il, bool full_log,
214 char **buf, bool display); 214 char **buf, bool display);
215extern void il3945_dump_nic_error_log(struct il_priv *priv); 215extern void il3945_dump_nic_error_log(struct il_priv *il);
216 216
217/****************************************************************************** 217/******************************************************************************
218 * 218 *
@@ -230,44 +230,44 @@ extern void il3945_dump_nic_error_log(struct il_priv *priv);
230 * il3945_mac_ <-- mac80211 callback 230 * il3945_mac_ <-- mac80211 callback
231 * 231 *
232 ****************************************************************************/ 232 ****************************************************************************/
233extern void il3945_hw_rx_handler_setup(struct il_priv *priv); 233extern void il3945_hw_rx_handler_setup(struct il_priv *il);
234extern void il3945_hw_setup_deferred_work(struct il_priv *priv); 234extern void il3945_hw_setup_deferred_work(struct il_priv *il);
235extern void il3945_hw_cancel_deferred_work(struct il_priv *priv); 235extern void il3945_hw_cancel_deferred_work(struct il_priv *il);
236extern int il3945_hw_rxq_stop(struct il_priv *priv); 236extern int il3945_hw_rxq_stop(struct il_priv *il);
237extern int il3945_hw_set_hw_params(struct il_priv *priv); 237extern int il3945_hw_set_hw_params(struct il_priv *il);
238extern int il3945_hw_nic_init(struct il_priv *priv); 238extern int il3945_hw_nic_init(struct il_priv *il);
239extern int il3945_hw_nic_stop_master(struct il_priv *priv); 239extern int il3945_hw_nic_stop_master(struct il_priv *il);
240extern void il3945_hw_txq_ctx_free(struct il_priv *priv); 240extern void il3945_hw_txq_ctx_free(struct il_priv *il);
241extern void il3945_hw_txq_ctx_stop(struct il_priv *priv); 241extern void il3945_hw_txq_ctx_stop(struct il_priv *il);
242extern int il3945_hw_nic_reset(struct il_priv *priv); 242extern int il3945_hw_nic_reset(struct il_priv *il);
243extern int il3945_hw_txq_attach_buf_to_tfd(struct il_priv *priv, 243extern int il3945_hw_txq_attach_buf_to_tfd(struct il_priv *il,
244 struct il_tx_queue *txq, 244 struct il_tx_queue *txq,
245 dma_addr_t addr, u16 len, 245 dma_addr_t addr, u16 len,
246 u8 reset, u8 pad); 246 u8 reset, u8 pad);
247extern void il3945_hw_txq_free_tfd(struct il_priv *priv, 247extern void il3945_hw_txq_free_tfd(struct il_priv *il,
248 struct il_tx_queue *txq); 248 struct il_tx_queue *txq);
249extern int il3945_hw_get_temperature(struct il_priv *priv); 249extern int il3945_hw_get_temperature(struct il_priv *il);
250extern int il3945_hw_tx_queue_init(struct il_priv *priv, 250extern int il3945_hw_tx_queue_init(struct il_priv *il,
251 struct il_tx_queue *txq); 251 struct il_tx_queue *txq);
252extern unsigned int il3945_hw_get_beacon_cmd(struct il_priv *priv, 252extern unsigned int il3945_hw_get_beacon_cmd(struct il_priv *il,
253 struct il3945_frame *frame, u8 rate); 253 struct il3945_frame *frame, u8 rate);
254void il3945_hw_build_tx_cmd_rate(struct il_priv *priv, 254void il3945_hw_build_tx_cmd_rate(struct il_priv *il,
255 struct il_device_cmd *cmd, 255 struct il_device_cmd *cmd,
256 struct ieee80211_tx_info *info, 256 struct ieee80211_tx_info *info,
257 struct ieee80211_hdr *hdr, 257 struct ieee80211_hdr *hdr,
258 int sta_id, int tx_id); 258 int sta_id, int tx_id);
259extern int il3945_hw_reg_send_txpower(struct il_priv *priv); 259extern int il3945_hw_reg_send_txpower(struct il_priv *il);
260extern int il3945_hw_reg_set_txpower(struct il_priv *priv, s8 power); 260extern int il3945_hw_reg_set_txpower(struct il_priv *il, s8 power);
261extern void il3945_hw_rx_statistics(struct il_priv *priv, 261extern void il3945_hw_rx_statistics(struct il_priv *il,
262 struct il_rx_mem_buffer *rxb); 262 struct il_rx_mem_buffer *rxb);
263void il3945_reply_statistics(struct il_priv *priv, 263void il3945_reply_statistics(struct il_priv *il,
264 struct il_rx_mem_buffer *rxb); 264 struct il_rx_mem_buffer *rxb);
265extern void il3945_disable_events(struct il_priv *priv); 265extern void il3945_disable_events(struct il_priv *il);
266extern int il4965_get_temperature(const struct il_priv *priv); 266extern int il4965_get_temperature(const struct il_priv *il);
267extern void il3945_post_associate(struct il_priv *priv); 267extern void il3945_post_associate(struct il_priv *il);
268extern void il3945_config_ap(struct il_priv *priv); 268extern void il3945_config_ap(struct il_priv *il);
269 269
270extern int il3945_commit_rxon(struct il_priv *priv, 270extern int il3945_commit_rxon(struct il_priv *il,
271 struct il_rxon_context *ctx); 271 struct il_rxon_context *ctx);
272 272
273/** 273/**
@@ -278,26 +278,26 @@ extern int il3945_commit_rxon(struct il_priv *priv,
278 * not yet been merged into a single common layer for managing the 278 * not yet been merged into a single common layer for managing the
279 * station tables. 279 * station tables.
280 */ 280 */
281extern u8 il3945_hw_find_station(struct il_priv *priv, const u8 *bssid); 281extern u8 il3945_hw_find_station(struct il_priv *il, const u8 *bssid);
282 282
283extern struct ieee80211_ops il3945_hw_ops; 283extern struct ieee80211_ops il3945_hw_ops;
284 284
285/* 285/*
286 * Forward declare iwl-3945.c functions for iwl3945-base.c 286 * Forward declare iwl-3945.c functions for iwl3945-base.c
287 */ 287 */
288extern __le32 il3945_get_antenna_flags(const struct il_priv *priv); 288extern __le32 il3945_get_antenna_flags(const struct il_priv *il);
289extern int il3945_init_hw_rate_table(struct il_priv *priv); 289extern int il3945_init_hw_rate_table(struct il_priv *il);
290extern void il3945_reg_txpower_periodic(struct il_priv *priv); 290extern void il3945_reg_txpower_periodic(struct il_priv *il);
291extern int il3945_txpower_set_from_eeprom(struct il_priv *priv); 291extern int il3945_txpower_set_from_eeprom(struct il_priv *il);
292 292
293extern const struct il_channel_info *il3945_get_channel_info( 293extern const struct il_channel_info *il3945_get_channel_info(
294 const struct il_priv *priv, enum ieee80211_band band, u16 channel); 294 const struct il_priv *il, enum ieee80211_band band, u16 channel);
295 295
296extern int il3945_rs_next_rate(struct il_priv *priv, int rate); 296extern int il3945_rs_next_rate(struct il_priv *il, int rate);
297 297
298/* scanning */ 298/* scanning */
299int il3945_request_scan(struct il_priv *priv, struct ieee80211_vif *vif); 299int il3945_request_scan(struct il_priv *il, struct ieee80211_vif *vif);
300void il3945_post_scan(struct il_priv *priv); 300void il3945_post_scan(struct il_priv *il);
301 301
302/* rates */ 302/* rates */
303extern const struct il3945_rate_info il3945_rates[IL_RATE_COUNT_3945]; 303extern const struct il3945_rate_info il3945_rates[IL_RATE_COUNT_3945];
diff --git a/drivers/net/wireless/iwlegacy/iwl-4965-calib.c b/drivers/net/wireless/iwlegacy/iwl-4965-calib.c
index 115eeb3d7c39..7807dc59e9c5 100644
--- a/drivers/net/wireless/iwlegacy/iwl-4965-calib.c
+++ b/drivers/net/wireless/iwlegacy/iwl-4965-calib.c
@@ -80,14 +80,14 @@ struct statistics_general_data {
80 u32 beacon_energy_c; 80 u32 beacon_energy_c;
81}; 81};
82 82
83void il4965_calib_free_results(struct il_priv *priv) 83void il4965_calib_free_results(struct il_priv *il)
84{ 84{
85 int i; 85 int i;
86 86
87 for (i = 0; i < IL_CALIB_MAX; i++) { 87 for (i = 0; i < IL_CALIB_MAX; i++) {
88 kfree(priv->calib_results[i].buf); 88 kfree(il->calib_results[i].buf);
89 priv->calib_results[i].buf = NULL; 89 il->calib_results[i].buf = NULL;
90 priv->calib_results[i].buf_len = 0; 90 il->calib_results[i].buf_len = 0;
91 } 91 }
92} 92}
93 93
@@ -103,7 +103,7 @@ void il4965_calib_free_results(struct il_priv *priv)
103 * enough to receive all of our own network traffic, but not so 103 * enough to receive all of our own network traffic, but not so
104 * high that our DSP gets too busy trying to lock onto non-network 104 * high that our DSP gets too busy trying to lock onto non-network
105 * activity/noise. */ 105 * activity/noise. */
106static int il4965_sens_energy_cck(struct il_priv *priv, 106static int il4965_sens_energy_cck(struct il_priv *il,
107 u32 norm_fa, 107 u32 norm_fa,
108 u32 rx_enable_time, 108 u32 rx_enable_time,
109 struct statistics_general_data *rx_info) 109 struct statistics_general_data *rx_info)
@@ -130,9 +130,9 @@ static int il4965_sens_energy_cck(struct il_priv *priv,
130 u32 max_false_alarms = MAX_FA_CCK * rx_enable_time; 130 u32 max_false_alarms = MAX_FA_CCK * rx_enable_time;
131 u32 min_false_alarms = MIN_FA_CCK * rx_enable_time; 131 u32 min_false_alarms = MIN_FA_CCK * rx_enable_time;
132 struct il_sensitivity_data *data = NULL; 132 struct il_sensitivity_data *data = NULL;
133 const struct il_sensitivity_ranges *ranges = priv->hw_params.sens; 133 const struct il_sensitivity_ranges *ranges = il->hw_params.sens;
134 134
135 data = &(priv->sensitivity_data); 135 data = &(il->sensitivity_data);
136 136
137 data->nrg_auto_corr_silence_diff = 0; 137 data->nrg_auto_corr_silence_diff = 0;
138 138
@@ -160,7 +160,7 @@ static int il4965_sens_energy_cck(struct il_priv *priv,
160 val = data->nrg_silence_rssi[i]; 160 val = data->nrg_silence_rssi[i];
161 silence_ref = max(silence_ref, val); 161 silence_ref = max(silence_ref, val);
162 } 162 }
163 IL_DEBUG_CALIB(priv, "silence a %u, b %u, c %u, 20-bcn max %u\n", 163 IL_DEBUG_CALIB(il, "silence a %u, b %u, c %u, 20-bcn max %u\n",
164 silence_rssi_a, silence_rssi_b, silence_rssi_c, 164 silence_rssi_a, silence_rssi_b, silence_rssi_c,
165 silence_ref); 165 silence_ref);
166 166
@@ -184,7 +184,7 @@ static int il4965_sens_energy_cck(struct il_priv *priv,
184 max_nrg_cck = (u32) max(max_nrg_cck, (data->nrg_value[i])); 184 max_nrg_cck = (u32) max(max_nrg_cck, (data->nrg_value[i]));
185 max_nrg_cck += 6; 185 max_nrg_cck += 6;
186 186
187 IL_DEBUG_CALIB(priv, "rx energy a %u, b %u, c %u, 10-bcn max/min %u\n", 187 IL_DEBUG_CALIB(il, "rx energy a %u, b %u, c %u, 10-bcn max/min %u\n",
188 rx_info->beacon_energy_a, rx_info->beacon_energy_b, 188 rx_info->beacon_energy_a, rx_info->beacon_energy_b,
189 rx_info->beacon_energy_c, max_nrg_cck - 6); 189 rx_info->beacon_energy_c, max_nrg_cck - 6);
190 190
@@ -194,15 +194,15 @@ static int il4965_sens_energy_cck(struct il_priv *priv,
194 data->num_in_cck_no_fa++; 194 data->num_in_cck_no_fa++;
195 else 195 else
196 data->num_in_cck_no_fa = 0; 196 data->num_in_cck_no_fa = 0;
197 IL_DEBUG_CALIB(priv, "consecutive bcns with few false alarms = %u\n", 197 IL_DEBUG_CALIB(il, "consecutive bcns with few false alarms = %u\n",
198 data->num_in_cck_no_fa); 198 data->num_in_cck_no_fa);
199 199
200 /* If we got too many false alarms this time, reduce sensitivity */ 200 /* If we got too many false alarms this time, reduce sensitivity */
201 if ((false_alarms > max_false_alarms) && 201 if ((false_alarms > max_false_alarms) &&
202 (data->auto_corr_cck > AUTO_CORR_MAX_TH_CCK)) { 202 (data->auto_corr_cck > AUTO_CORR_MAX_TH_CCK)) {
203 IL_DEBUG_CALIB(priv, "norm FA %u > max FA %u\n", 203 IL_DEBUG_CALIB(il, "norm FA %u > max FA %u\n",
204 false_alarms, max_false_alarms); 204 false_alarms, max_false_alarms);
205 IL_DEBUG_CALIB(priv, "... reducing sensitivity\n"); 205 IL_DEBUG_CALIB(il, "... reducing sensitivity\n");
206 data->nrg_curr_state = IL_FA_TOO_MANY; 206 data->nrg_curr_state = IL_FA_TOO_MANY;
207 /* Store for "fewer than desired" on later beacon */ 207 /* Store for "fewer than desired" on later beacon */
208 data->nrg_silence_ref = silence_ref; 208 data->nrg_silence_ref = silence_ref;
@@ -219,7 +219,7 @@ static int il4965_sens_energy_cck(struct il_priv *priv,
219 data->nrg_auto_corr_silence_diff = (s32)data->nrg_silence_ref - 219 data->nrg_auto_corr_silence_diff = (s32)data->nrg_silence_ref -
220 (s32)silence_ref; 220 (s32)silence_ref;
221 221
222 IL_DEBUG_CALIB(priv, 222 IL_DEBUG_CALIB(il,
223 "norm FA %u < min FA %u, silence diff %d\n", 223 "norm FA %u < min FA %u, silence diff %d\n",
224 false_alarms, min_false_alarms, 224 false_alarms, min_false_alarms,
225 data->nrg_auto_corr_silence_diff); 225 data->nrg_auto_corr_silence_diff);
@@ -234,18 +234,18 @@ static int il4965_sens_energy_cck(struct il_priv *priv,
234 ((data->nrg_auto_corr_silence_diff > NRG_DIFF) || 234 ((data->nrg_auto_corr_silence_diff > NRG_DIFF) ||
235 (data->num_in_cck_no_fa > MAX_NUMBER_CCK_NO_FA))) { 235 (data->num_in_cck_no_fa > MAX_NUMBER_CCK_NO_FA))) {
236 236
237 IL_DEBUG_CALIB(priv, "... increasing sensitivity\n"); 237 IL_DEBUG_CALIB(il, "... increasing sensitivity\n");
238 /* Increase nrg value to increase sensitivity */ 238 /* Increase nrg value to increase sensitivity */
239 val = data->nrg_th_cck + NRG_STEP_CCK; 239 val = data->nrg_th_cck + NRG_STEP_CCK;
240 data->nrg_th_cck = min((u32)ranges->min_nrg_cck, val); 240 data->nrg_th_cck = min((u32)ranges->min_nrg_cck, val);
241 } else { 241 } else {
242 IL_DEBUG_CALIB(priv, 242 IL_DEBUG_CALIB(il,
243 "... but not changing sensitivity\n"); 243 "... but not changing sensitivity\n");
244 } 244 }
245 245
246 /* Else we got a healthy number of false alarms, keep status quo */ 246 /* Else we got a healthy number of false alarms, keep status quo */
247 } else { 247 } else {
248 IL_DEBUG_CALIB(priv, " FA in safe zone\n"); 248 IL_DEBUG_CALIB(il, " FA in safe zone\n");
249 data->nrg_curr_state = IL_FA_GOOD_RANGE; 249 data->nrg_curr_state = IL_FA_GOOD_RANGE;
250 250
251 /* Store for use in "fewer than desired" with later beacon */ 251 /* Store for use in "fewer than desired" with later beacon */
@@ -255,7 +255,7 @@ static int il4965_sens_energy_cck(struct il_priv *priv,
255 * give it some extra margin by reducing sensitivity again 255 * give it some extra margin by reducing sensitivity again
256 * (but don't go below measured energy of desired Rx) */ 256 * (but don't go below measured energy of desired Rx) */
257 if (IL_FA_TOO_MANY == data->nrg_prev_state) { 257 if (IL_FA_TOO_MANY == data->nrg_prev_state) {
258 IL_DEBUG_CALIB(priv, "... increasing margin\n"); 258 IL_DEBUG_CALIB(il, "... increasing margin\n");
259 if (data->nrg_th_cck > (max_nrg_cck + NRG_MARGIN)) 259 if (data->nrg_th_cck > (max_nrg_cck + NRG_MARGIN))
260 data->nrg_th_cck -= NRG_MARGIN; 260 data->nrg_th_cck -= NRG_MARGIN;
261 else 261 else
@@ -269,7 +269,7 @@ static int il4965_sens_energy_cck(struct il_priv *priv,
269 * Lower value is higher energy, so we use max()! 269 * Lower value is higher energy, so we use max()!
270 */ 270 */
271 data->nrg_th_cck = max(max_nrg_cck, data->nrg_th_cck); 271 data->nrg_th_cck = max(max_nrg_cck, data->nrg_th_cck);
272 IL_DEBUG_CALIB(priv, "new nrg_th_cck %u\n", data->nrg_th_cck); 272 IL_DEBUG_CALIB(il, "new nrg_th_cck %u\n", data->nrg_th_cck);
273 273
274 data->nrg_prev_state = data->nrg_curr_state; 274 data->nrg_prev_state = data->nrg_curr_state;
275 275
@@ -306,7 +306,7 @@ static int il4965_sens_energy_cck(struct il_priv *priv,
306} 306}
307 307
308 308
309static int il4965_sens_auto_corr_ofdm(struct il_priv *priv, 309static int il4965_sens_auto_corr_ofdm(struct il_priv *il,
310 u32 norm_fa, 310 u32 norm_fa,
311 u32 rx_enable_time) 311 u32 rx_enable_time)
312{ 312{
@@ -315,14 +315,14 @@ static int il4965_sens_auto_corr_ofdm(struct il_priv *priv,
315 u32 max_false_alarms = MAX_FA_OFDM * rx_enable_time; 315 u32 max_false_alarms = MAX_FA_OFDM * rx_enable_time;
316 u32 min_false_alarms = MIN_FA_OFDM * rx_enable_time; 316 u32 min_false_alarms = MIN_FA_OFDM * rx_enable_time;
317 struct il_sensitivity_data *data = NULL; 317 struct il_sensitivity_data *data = NULL;
318 const struct il_sensitivity_ranges *ranges = priv->hw_params.sens; 318 const struct il_sensitivity_ranges *ranges = il->hw_params.sens;
319 319
320 data = &(priv->sensitivity_data); 320 data = &(il->sensitivity_data);
321 321
322 /* If we got too many false alarms this time, reduce sensitivity */ 322 /* If we got too many false alarms this time, reduce sensitivity */
323 if (false_alarms > max_false_alarms) { 323 if (false_alarms > max_false_alarms) {
324 324
325 IL_DEBUG_CALIB(priv, "norm FA %u > max FA %u)\n", 325 IL_DEBUG_CALIB(il, "norm FA %u > max FA %u)\n",
326 false_alarms, max_false_alarms); 326 false_alarms, max_false_alarms);
327 327
328 val = data->auto_corr_ofdm + AUTO_CORR_STEP_OFDM; 328 val = data->auto_corr_ofdm + AUTO_CORR_STEP_OFDM;
@@ -345,7 +345,7 @@ static int il4965_sens_auto_corr_ofdm(struct il_priv *priv,
345 /* Else if we got fewer than desired, increase sensitivity */ 345 /* Else if we got fewer than desired, increase sensitivity */
346 else if (false_alarms < min_false_alarms) { 346 else if (false_alarms < min_false_alarms) {
347 347
348 IL_DEBUG_CALIB(priv, "norm FA %u < min FA %u\n", 348 IL_DEBUG_CALIB(il, "norm FA %u < min FA %u\n",
349 false_alarms, min_false_alarms); 349 false_alarms, min_false_alarms);
350 350
351 val = data->auto_corr_ofdm - AUTO_CORR_STEP_OFDM; 351 val = data->auto_corr_ofdm - AUTO_CORR_STEP_OFDM;
@@ -364,13 +364,13 @@ static int il4965_sens_auto_corr_ofdm(struct il_priv *priv,
364 data->auto_corr_ofdm_mrc_x1 = 364 data->auto_corr_ofdm_mrc_x1 =
365 max((u32)ranges->auto_corr_min_ofdm_mrc_x1, val); 365 max((u32)ranges->auto_corr_min_ofdm_mrc_x1, val);
366 } else { 366 } else {
367 IL_DEBUG_CALIB(priv, "min FA %u < norm FA %u < max FA %u OK\n", 367 IL_DEBUG_CALIB(il, "min FA %u < norm FA %u < max FA %u OK\n",
368 min_false_alarms, false_alarms, max_false_alarms); 368 min_false_alarms, false_alarms, max_false_alarms);
369 } 369 }
370 return 0; 370 return 0;
371} 371}
372 372
373static void il4965_prepare_legacy_sensitivity_tbl(struct il_priv *priv, 373static void il4965_prepare_legacy_sensitivity_tbl(struct il_priv *il,
374 struct il_sensitivity_data *data, 374 struct il_sensitivity_data *data,
375 __le16 *tbl) 375 __le16 *tbl)
376{ 376{
@@ -400,18 +400,18 @@ static void il4965_prepare_legacy_sensitivity_tbl(struct il_priv *priv,
400 tbl[HD_OFDM_ENERGY_TH_IN_INDEX] = 400 tbl[HD_OFDM_ENERGY_TH_IN_INDEX] =
401 cpu_to_le16(data->nrg_th_cca); 401 cpu_to_le16(data->nrg_th_cca);
402 402
403 IL_DEBUG_CALIB(priv, "ofdm: ac %u mrc %u x1 %u mrc_x1 %u thresh %u\n", 403 IL_DEBUG_CALIB(il, "ofdm: ac %u mrc %u x1 %u mrc_x1 %u thresh %u\n",
404 data->auto_corr_ofdm, data->auto_corr_ofdm_mrc, 404 data->auto_corr_ofdm, data->auto_corr_ofdm_mrc,
405 data->auto_corr_ofdm_x1, data->auto_corr_ofdm_mrc_x1, 405 data->auto_corr_ofdm_x1, data->auto_corr_ofdm_mrc_x1,
406 data->nrg_th_ofdm); 406 data->nrg_th_ofdm);
407 407
408 IL_DEBUG_CALIB(priv, "cck: ac %u mrc %u thresh %u\n", 408 IL_DEBUG_CALIB(il, "cck: ac %u mrc %u thresh %u\n",
409 data->auto_corr_cck, data->auto_corr_cck_mrc, 409 data->auto_corr_cck, data->auto_corr_cck_mrc,
410 data->nrg_th_cck); 410 data->nrg_th_cck);
411} 411}
412 412
413/* Prepare a SENSITIVITY_CMD, send to uCode if values have changed */ 413/* Prepare a SENSITIVITY_CMD, send to uCode if values have changed */
414static int il4965_sensitivity_write(struct il_priv *priv) 414static int il4965_sensitivity_write(struct il_priv *il)
415{ 415{
416 struct il_sensitivity_cmd cmd; 416 struct il_sensitivity_cmd cmd;
417 struct il_sensitivity_data *data = NULL; 417 struct il_sensitivity_data *data = NULL;
@@ -422,43 +422,43 @@ static int il4965_sensitivity_write(struct il_priv *priv)
422 .data = &cmd, 422 .data = &cmd,
423 }; 423 };
424 424
425 data = &(priv->sensitivity_data); 425 data = &(il->sensitivity_data);
426 426
427 memset(&cmd, 0, sizeof(cmd)); 427 memset(&cmd, 0, sizeof(cmd));
428 428
429 il4965_prepare_legacy_sensitivity_tbl(priv, data, &cmd.table[0]); 429 il4965_prepare_legacy_sensitivity_tbl(il, data, &cmd.table[0]);
430 430
431 /* Update uCode's "work" table, and copy it to DSP */ 431 /* Update uCode's "work" table, and copy it to DSP */
432 cmd.control = SENSITIVITY_CMD_CONTROL_WORK_TABLE; 432 cmd.control = SENSITIVITY_CMD_CONTROL_WORK_TABLE;
433 433
434 /* Don't send command to uCode if nothing has changed */ 434 /* Don't send command to uCode if nothing has changed */
435 if (!memcmp(&cmd.table[0], &(priv->sensitivity_tbl[0]), 435 if (!memcmp(&cmd.table[0], &(il->sensitivity_tbl[0]),
436 sizeof(u16)*HD_TABLE_SIZE)) { 436 sizeof(u16)*HD_TABLE_SIZE)) {
437 IL_DEBUG_CALIB(priv, "No change in SENSITIVITY_CMD\n"); 437 IL_DEBUG_CALIB(il, "No change in SENSITIVITY_CMD\n");
438 return 0; 438 return 0;
439 } 439 }
440 440
441 /* Copy table for comparison next time */ 441 /* Copy table for comparison next time */
442 memcpy(&(priv->sensitivity_tbl[0]), &(cmd.table[0]), 442 memcpy(&(il->sensitivity_tbl[0]), &(cmd.table[0]),
443 sizeof(u16)*HD_TABLE_SIZE); 443 sizeof(u16)*HD_TABLE_SIZE);
444 444
445 return il_send_cmd(priv, &cmd_out); 445 return il_send_cmd(il, &cmd_out);
446} 446}
447 447
448void il4965_init_sensitivity(struct il_priv *priv) 448void il4965_init_sensitivity(struct il_priv *il)
449{ 449{
450 int ret = 0; 450 int ret = 0;
451 int i; 451 int i;
452 struct il_sensitivity_data *data = NULL; 452 struct il_sensitivity_data *data = NULL;
453 const struct il_sensitivity_ranges *ranges = priv->hw_params.sens; 453 const struct il_sensitivity_ranges *ranges = il->hw_params.sens;
454 454
455 if (priv->disable_sens_cal) 455 if (il->disable_sens_cal)
456 return; 456 return;
457 457
458 IL_DEBUG_CALIB(priv, "Start il4965_init_sensitivity\n"); 458 IL_DEBUG_CALIB(il, "Start il4965_init_sensitivity\n");
459 459
460 /* Clear driver's sensitivity algo data */ 460 /* Clear driver's sensitivity algo data */
461 data = &(priv->sensitivity_data); 461 data = &(il->sensitivity_data);
462 462
463 if (ranges == NULL) 463 if (ranges == NULL)
464 return; 464 return;
@@ -495,11 +495,11 @@ void il4965_init_sensitivity(struct il_priv *priv)
495 data->last_bad_plcp_cnt_cck = 0; 495 data->last_bad_plcp_cnt_cck = 0;
496 data->last_fa_cnt_cck = 0; 496 data->last_fa_cnt_cck = 0;
497 497
498 ret |= il4965_sensitivity_write(priv); 498 ret |= il4965_sensitivity_write(il);
499 IL_DEBUG_CALIB(priv, "<<return 0x%X\n", ret); 499 IL_DEBUG_CALIB(il, "<<return 0x%X\n", ret);
500} 500}
501 501
502void il4965_sensitivity_calibration(struct il_priv *priv, void *resp) 502void il4965_sensitivity_calibration(struct il_priv *il, void *resp)
503{ 503{
504 u32 rx_enable_time; 504 u32 rx_enable_time;
505 u32 fa_cck; 505 u32 fa_cck;
@@ -514,25 +514,25 @@ void il4965_sensitivity_calibration(struct il_priv *priv, void *resp)
514 unsigned long flags; 514 unsigned long flags;
515 struct statistics_general_data statis; 515 struct statistics_general_data statis;
516 516
517 if (priv->disable_sens_cal) 517 if (il->disable_sens_cal)
518 return; 518 return;
519 519
520 data = &(priv->sensitivity_data); 520 data = &(il->sensitivity_data);
521 521
522 if (!il_is_any_associated(priv)) { 522 if (!il_is_any_associated(il)) {
523 IL_DEBUG_CALIB(priv, "<< - not associated\n"); 523 IL_DEBUG_CALIB(il, "<< - not associated\n");
524 return; 524 return;
525 } 525 }
526 526
527 spin_lock_irqsave(&priv->lock, flags); 527 spin_lock_irqsave(&il->lock, flags);
528 528
529 rx_info = &(((struct il_notif_statistics *)resp)->rx.general); 529 rx_info = &(((struct il_notif_statistics *)resp)->rx.general);
530 ofdm = &(((struct il_notif_statistics *)resp)->rx.ofdm); 530 ofdm = &(((struct il_notif_statistics *)resp)->rx.ofdm);
531 cck = &(((struct il_notif_statistics *)resp)->rx.cck); 531 cck = &(((struct il_notif_statistics *)resp)->rx.cck);
532 532
533 if (rx_info->interference_data_flag != INTERFERENCE_DATA_AVAILABLE) { 533 if (rx_info->interference_data_flag != INTERFERENCE_DATA_AVAILABLE) {
534 IL_DEBUG_CALIB(priv, "<< invalid data.\n"); 534 IL_DEBUG_CALIB(il, "<< invalid data.\n");
535 spin_unlock_irqrestore(&priv->lock, flags); 535 spin_unlock_irqrestore(&il->lock, flags);
536 return; 536 return;
537 } 537 }
538 538
@@ -556,12 +556,12 @@ void il4965_sensitivity_calibration(struct il_priv *priv, void *resp)
556 statis.beacon_energy_c = 556 statis.beacon_energy_c =
557 le32_to_cpu(rx_info->beacon_energy_c); 557 le32_to_cpu(rx_info->beacon_energy_c);
558 558
559 spin_unlock_irqrestore(&priv->lock, flags); 559 spin_unlock_irqrestore(&il->lock, flags);
560 560
561 IL_DEBUG_CALIB(priv, "rx_enable_time = %u usecs\n", rx_enable_time); 561 IL_DEBUG_CALIB(il, "rx_enable_time = %u usecs\n", rx_enable_time);
562 562
563 if (!rx_enable_time) { 563 if (!rx_enable_time) {
564 IL_DEBUG_CALIB(priv, "<< RX Enable Time == 0!\n"); 564 IL_DEBUG_CALIB(il, "<< RX Enable Time == 0!\n");
565 return; 565 return;
566 } 566 }
567 567
@@ -600,14 +600,14 @@ void il4965_sensitivity_calibration(struct il_priv *priv, void *resp)
600 norm_fa_ofdm = fa_ofdm + bad_plcp_ofdm; 600 norm_fa_ofdm = fa_ofdm + bad_plcp_ofdm;
601 norm_fa_cck = fa_cck + bad_plcp_cck; 601 norm_fa_cck = fa_cck + bad_plcp_cck;
602 602
603 IL_DEBUG_CALIB(priv, 603 IL_DEBUG_CALIB(il,
604 "cck: fa %u badp %u ofdm: fa %u badp %u\n", fa_cck, 604 "cck: fa %u badp %u ofdm: fa %u badp %u\n", fa_cck,
605 bad_plcp_cck, fa_ofdm, bad_plcp_ofdm); 605 bad_plcp_cck, fa_ofdm, bad_plcp_ofdm);
606 606
607 il4965_sens_auto_corr_ofdm(priv, norm_fa_ofdm, rx_enable_time); 607 il4965_sens_auto_corr_ofdm(il, norm_fa_ofdm, rx_enable_time);
608 il4965_sens_energy_cck(priv, norm_fa_cck, rx_enable_time, &statis); 608 il4965_sens_energy_cck(il, norm_fa_cck, rx_enable_time, &statis);
609 609
610 il4965_sensitivity_write(priv); 610 il4965_sensitivity_write(il);
611} 611}
612 612
613static inline u8 il4965_find_first_chain(u8 mask) 613static inline u8 il4965_find_first_chain(u8 mask)
@@ -624,7 +624,7 @@ static inline u8 il4965_find_first_chain(u8 mask)
624 * disconnected. 624 * disconnected.
625 */ 625 */
626static void 626static void
627il4965_find_disconn_antenna(struct il_priv *priv, u32* average_sig, 627il4965_find_disconn_antenna(struct il_priv *il, u32* average_sig,
628 struct il_chain_noise_data *data) 628 struct il_chain_noise_data *data)
629{ 629{
630 u32 active_chains = 0; 630 u32 active_chains = 0;
@@ -635,11 +635,11 @@ il4965_find_disconn_antenna(struct il_priv *priv, u32* average_sig,
635 u16 i = 0; 635 u16 i = 0;
636 636
637 average_sig[0] = data->chain_signal_a / 637 average_sig[0] = data->chain_signal_a /
638 priv->cfg->base_params->chain_noise_num_beacons; 638 il->cfg->base_params->chain_noise_num_beacons;
639 average_sig[1] = data->chain_signal_b / 639 average_sig[1] = data->chain_signal_b /
640 priv->cfg->base_params->chain_noise_num_beacons; 640 il->cfg->base_params->chain_noise_num_beacons;
641 average_sig[2] = data->chain_signal_c / 641 average_sig[2] = data->chain_signal_c /
642 priv->cfg->base_params->chain_noise_num_beacons; 642 il->cfg->base_params->chain_noise_num_beacons;
643 643
644 if (average_sig[0] >= average_sig[1]) { 644 if (average_sig[0] >= average_sig[1]) {
645 max_average_sig = average_sig[0]; 645 max_average_sig = average_sig[0];
@@ -657,9 +657,9 @@ il4965_find_disconn_antenna(struct il_priv *priv, u32* average_sig,
657 active_chains = (1 << max_average_sig_antenna_i); 657 active_chains = (1 << max_average_sig_antenna_i);
658 } 658 }
659 659
660 IL_DEBUG_CALIB(priv, "average_sig: a %d b %d c %d\n", 660 IL_DEBUG_CALIB(il, "average_sig: a %d b %d c %d\n",
661 average_sig[0], average_sig[1], average_sig[2]); 661 average_sig[0], average_sig[1], average_sig[2]);
662 IL_DEBUG_CALIB(priv, "max_average_sig = %d, antenna %d\n", 662 IL_DEBUG_CALIB(il, "max_average_sig = %d, antenna %d\n",
663 max_average_sig, max_average_sig_antenna_i); 663 max_average_sig, max_average_sig_antenna_i);
664 664
665 /* Compare signal strengths for all 3 receivers. */ 665 /* Compare signal strengths for all 3 receivers. */
@@ -673,7 +673,7 @@ il4965_find_disconn_antenna(struct il_priv *priv, u32* average_sig,
673 data->disconn_array[i] = 1; 673 data->disconn_array[i] = 1;
674 else 674 else
675 active_chains |= (1 << i); 675 active_chains |= (1 << i);
676 IL_DEBUG_CALIB(priv, "i = %d rssiDelta = %d " 676 IL_DEBUG_CALIB(il, "i = %d rssiDelta = %d "
677 "disconn_array[i] = %d\n", 677 "disconn_array[i] = %d\n",
678 i, rssi_delta, data->disconn_array[i]); 678 i, rssi_delta, data->disconn_array[i]);
679 } 679 }
@@ -689,58 +689,58 @@ il4965_find_disconn_antenna(struct il_priv *priv, u32* average_sig,
689 * To be safe, simply mask out any chains that we know 689 * To be safe, simply mask out any chains that we know
690 * are not on the device. 690 * are not on the device.
691 */ 691 */
692 active_chains &= priv->hw_params.valid_rx_ant; 692 active_chains &= il->hw_params.valid_rx_ant;
693 693
694 num_tx_chains = 0; 694 num_tx_chains = 0;
695 for (i = 0; i < NUM_RX_CHAINS; i++) { 695 for (i = 0; i < NUM_RX_CHAINS; i++) {
696 /* loops on all the bits of 696 /* loops on all the bits of
697 * priv->hw_setting.valid_tx_ant */ 697 * il->hw_setting.valid_tx_ant */
698 u8 ant_msk = (1 << i); 698 u8 ant_msk = (1 << i);
699 if (!(priv->hw_params.valid_tx_ant & ant_msk)) 699 if (!(il->hw_params.valid_tx_ant & ant_msk))
700 continue; 700 continue;
701 701
702 num_tx_chains++; 702 num_tx_chains++;
703 if (data->disconn_array[i] == 0) 703 if (data->disconn_array[i] == 0)
704 /* there is a Tx antenna connected */ 704 /* there is a Tx antenna connected */
705 break; 705 break;
706 if (num_tx_chains == priv->hw_params.tx_chains_num && 706 if (num_tx_chains == il->hw_params.tx_chains_num &&
707 data->disconn_array[i]) { 707 data->disconn_array[i]) {
708 /* 708 /*
709 * If all chains are disconnected 709 * If all chains are disconnected
710 * connect the first valid tx chain 710 * connect the first valid tx chain
711 */ 711 */
712 first_chain = 712 first_chain =
713 il4965_find_first_chain(priv->cfg->valid_tx_ant); 713 il4965_find_first_chain(il->cfg->valid_tx_ant);
714 data->disconn_array[first_chain] = 0; 714 data->disconn_array[first_chain] = 0;
715 active_chains |= BIT(first_chain); 715 active_chains |= BIT(first_chain);
716 IL_DEBUG_CALIB(priv, 716 IL_DEBUG_CALIB(il,
717 "All Tx chains are disconnected W/A - declare %d as connected\n", 717 "All Tx chains are disconnected W/A - declare %d as connected\n",
718 first_chain); 718 first_chain);
719 break; 719 break;
720 } 720 }
721 } 721 }
722 722
723 if (active_chains != priv->hw_params.valid_rx_ant && 723 if (active_chains != il->hw_params.valid_rx_ant &&
724 active_chains != priv->chain_noise_data.active_chains) 724 active_chains != il->chain_noise_data.active_chains)
725 IL_DEBUG_CALIB(priv, 725 IL_DEBUG_CALIB(il,
726 "Detected that not all antennas are connected! " 726 "Detected that not all antennas are connected! "
727 "Connected: %#x, valid: %#x.\n", 727 "Connected: %#x, valid: %#x.\n",
728 active_chains, priv->hw_params.valid_rx_ant); 728 active_chains, il->hw_params.valid_rx_ant);
729 729
730 /* Save for use within RXON, TX, SCAN commands, etc. */ 730 /* Save for use within RXON, TX, SCAN commands, etc. */
731 data->active_chains = active_chains; 731 data->active_chains = active_chains;
732 IL_DEBUG_CALIB(priv, "active_chains (bitwise) = 0x%x\n", 732 IL_DEBUG_CALIB(il, "active_chains (bitwise) = 0x%x\n",
733 active_chains); 733 active_chains);
734} 734}
735 735
736static void il4965_gain_computation(struct il_priv *priv, 736static void il4965_gain_computation(struct il_priv *il,
737 u32 *average_noise, 737 u32 *average_noise,
738 u16 min_average_noise_antenna_i, 738 u16 min_average_noise_antenna_i,
739 u32 min_average_noise, 739 u32 min_average_noise,
740 u8 default_chain) 740 u8 default_chain)
741{ 741{
742 int i, ret; 742 int i, ret;
743 struct il_chain_noise_data *data = &priv->chain_noise_data; 743 struct il_chain_noise_data *data = &il->chain_noise_data;
744 744
745 data->delta_gain_code[min_average_noise_antenna_i] = 0; 745 data->delta_gain_code[min_average_noise_antenna_i] = 0;
746 746
@@ -762,7 +762,7 @@ static void il4965_gain_computation(struct il_priv *priv,
762 data->delta_gain_code[i] = 0; 762 data->delta_gain_code[i] = 0;
763 } 763 }
764 } 764 }
765 IL_DEBUG_CALIB(priv, "delta_gain_codes: a %d b %d c %d\n", 765 IL_DEBUG_CALIB(il, "delta_gain_codes: a %d b %d c %d\n",
766 data->delta_gain_code[0], 766 data->delta_gain_code[0],
767 data->delta_gain_code[1], 767 data->delta_gain_code[1],
768 data->delta_gain_code[2]); 768 data->delta_gain_code[2]);
@@ -777,10 +777,10 @@ static void il4965_gain_computation(struct il_priv *priv,
777 cmd.diff_gain_a = data->delta_gain_code[0]; 777 cmd.diff_gain_a = data->delta_gain_code[0];
778 cmd.diff_gain_b = data->delta_gain_code[1]; 778 cmd.diff_gain_b = data->delta_gain_code[1];
779 cmd.diff_gain_c = data->delta_gain_code[2]; 779 cmd.diff_gain_c = data->delta_gain_code[2];
780 ret = il_send_cmd_pdu(priv, REPLY_PHY_CALIBRATION_CMD, 780 ret = il_send_cmd_pdu(il, REPLY_PHY_CALIBRATION_CMD,
781 sizeof(cmd), &cmd); 781 sizeof(cmd), &cmd);
782 if (ret) 782 if (ret)
783 IL_DEBUG_CALIB(priv, "fail sending cmd " 783 IL_DEBUG_CALIB(il, "fail sending cmd "
784 "REPLY_PHY_CALIBRATION_CMD\n"); 784 "REPLY_PHY_CALIBRATION_CMD\n");
785 785
786 /* TODO we might want recalculate 786 /* TODO we might want recalculate
@@ -799,7 +799,7 @@ static void il4965_gain_computation(struct il_priv *priv,
799 * 1) Which antennas are connected. 799 * 1) Which antennas are connected.
800 * 2) Differential rx gain settings to balance the 3 receivers. 800 * 2) Differential rx gain settings to balance the 3 receivers.
801 */ 801 */
802void il4965_chain_noise_calibration(struct il_priv *priv, void *stat_resp) 802void il4965_chain_noise_calibration(struct il_priv *il, void *stat_resp)
803{ 803{
804 struct il_chain_noise_data *data = NULL; 804 struct il_chain_noise_data *data = NULL;
805 805
@@ -821,12 +821,12 @@ void il4965_chain_noise_calibration(struct il_priv *priv, void *stat_resp)
821 unsigned long flags; 821 unsigned long flags;
822 struct statistics_rx_non_phy *rx_info; 822 struct statistics_rx_non_phy *rx_info;
823 823
824 struct il_rxon_context *ctx = &priv->contexts[IL_RXON_CTX_BSS]; 824 struct il_rxon_context *ctx = &il->contexts[IL_RXON_CTX_BSS];
825 825
826 if (priv->disable_chain_noise_cal) 826 if (il->disable_chain_noise_cal)
827 return; 827 return;
828 828
829 data = &(priv->chain_noise_data); 829 data = &(il->chain_noise_data);
830 830
831 /* 831 /*
832 * Accumulate just the first "chain_noise_num_beacons" after 832 * Accumulate just the first "chain_noise_num_beacons" after
@@ -834,18 +834,18 @@ void il4965_chain_noise_calibration(struct il_priv *priv, void *stat_resp)
834 */ 834 */
835 if (data->state != IL_CHAIN_NOISE_ACCUMULATE) { 835 if (data->state != IL_CHAIN_NOISE_ACCUMULATE) {
836 if (data->state == IL_CHAIN_NOISE_ALIVE) 836 if (data->state == IL_CHAIN_NOISE_ALIVE)
837 IL_DEBUG_CALIB(priv, "Wait for noise calib reset\n"); 837 IL_DEBUG_CALIB(il, "Wait for noise calib reset\n");
838 return; 838 return;
839 } 839 }
840 840
841 spin_lock_irqsave(&priv->lock, flags); 841 spin_lock_irqsave(&il->lock, flags);
842 842
843 rx_info = &(((struct il_notif_statistics *)stat_resp)-> 843 rx_info = &(((struct il_notif_statistics *)stat_resp)->
844 rx.general); 844 rx.general);
845 845
846 if (rx_info->interference_data_flag != INTERFERENCE_DATA_AVAILABLE) { 846 if (rx_info->interference_data_flag != INTERFERENCE_DATA_AVAILABLE) {
847 IL_DEBUG_CALIB(priv, " << Interference data unavailable\n"); 847 IL_DEBUG_CALIB(il, " << Interference data unavailable\n");
848 spin_unlock_irqrestore(&priv->lock, flags); 848 spin_unlock_irqrestore(&il->lock, flags);
849 return; 849 return;
850 } 850 }
851 851
@@ -861,9 +861,9 @@ void il4965_chain_noise_calibration(struct il_priv *priv, void *stat_resp)
861 /* Make sure we accumulate data for just the associated channel 861 /* Make sure we accumulate data for just the associated channel
862 * (even if scanning). */ 862 * (even if scanning). */
863 if ((rxon_chnum != stat_chnum) || (rxon_band24 != stat_band24)) { 863 if ((rxon_chnum != stat_chnum) || (rxon_band24 != stat_band24)) {
864 IL_DEBUG_CALIB(priv, "Stats not from chan=%d, band24=%d\n", 864 IL_DEBUG_CALIB(il, "Stats not from chan=%d, band24=%d\n",
865 rxon_chnum, rxon_band24); 865 rxon_chnum, rxon_band24);
866 spin_unlock_irqrestore(&priv->lock, flags); 866 spin_unlock_irqrestore(&il->lock, flags);
867 return; 867 return;
868 } 868 }
869 869
@@ -882,7 +882,7 @@ void il4965_chain_noise_calibration(struct il_priv *priv, void *stat_resp)
882 chain_sig_b = le32_to_cpu(rx_info->beacon_rssi_b) & IN_BAND_FILTER; 882 chain_sig_b = le32_to_cpu(rx_info->beacon_rssi_b) & IN_BAND_FILTER;
883 chain_sig_c = le32_to_cpu(rx_info->beacon_rssi_c) & IN_BAND_FILTER; 883 chain_sig_c = le32_to_cpu(rx_info->beacon_rssi_c) & IN_BAND_FILTER;
884 884
885 spin_unlock_irqrestore(&priv->lock, flags); 885 spin_unlock_irqrestore(&il->lock, flags);
886 886
887 data->beacon_count++; 887 data->beacon_count++;
888 888
@@ -894,30 +894,30 @@ void il4965_chain_noise_calibration(struct il_priv *priv, void *stat_resp)
894 data->chain_signal_b = (chain_sig_b + data->chain_signal_b); 894 data->chain_signal_b = (chain_sig_b + data->chain_signal_b);
895 data->chain_signal_c = (chain_sig_c + data->chain_signal_c); 895 data->chain_signal_c = (chain_sig_c + data->chain_signal_c);
896 896
897 IL_DEBUG_CALIB(priv, "chan=%d, band24=%d, beacon=%d\n", 897 IL_DEBUG_CALIB(il, "chan=%d, band24=%d, beacon=%d\n",
898 rxon_chnum, rxon_band24, data->beacon_count); 898 rxon_chnum, rxon_band24, data->beacon_count);
899 IL_DEBUG_CALIB(priv, "chain_sig: a %d b %d c %d\n", 899 IL_DEBUG_CALIB(il, "chain_sig: a %d b %d c %d\n",
900 chain_sig_a, chain_sig_b, chain_sig_c); 900 chain_sig_a, chain_sig_b, chain_sig_c);
901 IL_DEBUG_CALIB(priv, "chain_noise: a %d b %d c %d\n", 901 IL_DEBUG_CALIB(il, "chain_noise: a %d b %d c %d\n",
902 chain_noise_a, chain_noise_b, chain_noise_c); 902 chain_noise_a, chain_noise_b, chain_noise_c);
903 903
904 /* If this is the "chain_noise_num_beacons", determine: 904 /* If this is the "chain_noise_num_beacons", determine:
905 * 1) Disconnected antennas (using signal strengths) 905 * 1) Disconnected antennas (using signal strengths)
906 * 2) Differential gain (using silence noise) to balance receivers */ 906 * 2) Differential gain (using silence noise) to balance receivers */
907 if (data->beacon_count != 907 if (data->beacon_count !=
908 priv->cfg->base_params->chain_noise_num_beacons) 908 il->cfg->base_params->chain_noise_num_beacons)
909 return; 909 return;
910 910
911 /* Analyze signal for disconnected antenna */ 911 /* Analyze signal for disconnected antenna */
912 il4965_find_disconn_antenna(priv, average_sig, data); 912 il4965_find_disconn_antenna(il, average_sig, data);
913 913
914 /* Analyze noise for rx balance */ 914 /* Analyze noise for rx balance */
915 average_noise[0] = data->chain_noise_a / 915 average_noise[0] = data->chain_noise_a /
916 priv->cfg->base_params->chain_noise_num_beacons; 916 il->cfg->base_params->chain_noise_num_beacons;
917 average_noise[1] = data->chain_noise_b / 917 average_noise[1] = data->chain_noise_b /
918 priv->cfg->base_params->chain_noise_num_beacons; 918 il->cfg->base_params->chain_noise_num_beacons;
919 average_noise[2] = data->chain_noise_c / 919 average_noise[2] = data->chain_noise_c /
920 priv->cfg->base_params->chain_noise_num_beacons; 920 il->cfg->base_params->chain_noise_num_beacons;
921 921
922 for (i = 0; i < NUM_RX_CHAINS; i++) { 922 for (i = 0; i < NUM_RX_CHAINS; i++) {
923 if (!(data->disconn_array[i]) && 923 if (!(data->disconn_array[i]) &&
@@ -929,39 +929,39 @@ void il4965_chain_noise_calibration(struct il_priv *priv, void *stat_resp)
929 } 929 }
930 } 930 }
931 931
932 IL_DEBUG_CALIB(priv, "average_noise: a %d b %d c %d\n", 932 IL_DEBUG_CALIB(il, "average_noise: a %d b %d c %d\n",
933 average_noise[0], average_noise[1], 933 average_noise[0], average_noise[1],
934 average_noise[2]); 934 average_noise[2]);
935 935
936 IL_DEBUG_CALIB(priv, "min_average_noise = %d, antenna %d\n", 936 IL_DEBUG_CALIB(il, "min_average_noise = %d, antenna %d\n",
937 min_average_noise, min_average_noise_antenna_i); 937 min_average_noise, min_average_noise_antenna_i);
938 938
939 il4965_gain_computation(priv, average_noise, 939 il4965_gain_computation(il, average_noise,
940 min_average_noise_antenna_i, min_average_noise, 940 min_average_noise_antenna_i, min_average_noise,
941 il4965_find_first_chain(priv->cfg->valid_rx_ant)); 941 il4965_find_first_chain(il->cfg->valid_rx_ant));
942 942
943 /* Some power changes may have been made during the calibration. 943 /* Some power changes may have been made during the calibration.
944 * Update and commit the RXON 944 * Update and commit the RXON
945 */ 945 */
946 if (priv->cfg->ops->lib->update_chain_flags) 946 if (il->cfg->ops->lib->update_chain_flags)
947 priv->cfg->ops->lib->update_chain_flags(priv); 947 il->cfg->ops->lib->update_chain_flags(il);
948 948
949 data->state = IL_CHAIN_NOISE_DONE; 949 data->state = IL_CHAIN_NOISE_DONE;
950 il_power_update_mode(priv, false); 950 il_power_update_mode(il, false);
951} 951}
952 952
953void il4965_reset_run_time_calib(struct il_priv *priv) 953void il4965_reset_run_time_calib(struct il_priv *il)
954{ 954{
955 int i; 955 int i;
956 memset(&(priv->sensitivity_data), 0, 956 memset(&(il->sensitivity_data), 0,
957 sizeof(struct il_sensitivity_data)); 957 sizeof(struct il_sensitivity_data));
958 memset(&(priv->chain_noise_data), 0, 958 memset(&(il->chain_noise_data), 0,
959 sizeof(struct il_chain_noise_data)); 959 sizeof(struct il_chain_noise_data));
960 for (i = 0; i < NUM_RX_CHAINS; i++) 960 for (i = 0; i < NUM_RX_CHAINS; i++)
961 priv->chain_noise_data.delta_gain_code[i] = 961 il->chain_noise_data.delta_gain_code[i] =
962 CHAIN_NOISE_DELTA_GAIN_INIT_VAL; 962 CHAIN_NOISE_DELTA_GAIN_INIT_VAL;
963 963
964 /* Ask for statistics now, the uCode will send notification 964 /* Ask for statistics now, the uCode will send notification
965 * periodically after association */ 965 * periodically after association */
966 il_send_statistics_request(priv, CMD_ASYNC, true); 966 il_send_statistics_request(il, CMD_ASYNC, true);
967} 967}
diff --git a/drivers/net/wireless/iwlegacy/iwl-4965-calib.h b/drivers/net/wireless/iwlegacy/iwl-4965-calib.h
index a23081f1d03e..0e30ea7ff12e 100644
--- a/drivers/net/wireless/iwlegacy/iwl-4965-calib.h
+++ b/drivers/net/wireless/iwlegacy/iwl-4965-calib.h
@@ -66,10 +66,10 @@
66#include "iwl-core.h" 66#include "iwl-core.h"
67#include "iwl-commands.h" 67#include "iwl-commands.h"
68 68
69void il4965_chain_noise_calibration(struct il_priv *priv, void *stat_resp); 69void il4965_chain_noise_calibration(struct il_priv *il, void *stat_resp);
70void il4965_sensitivity_calibration(struct il_priv *priv, void *resp); 70void il4965_sensitivity_calibration(struct il_priv *il, void *resp);
71void il4965_init_sensitivity(struct il_priv *priv); 71void il4965_init_sensitivity(struct il_priv *il);
72void il4965_reset_run_time_calib(struct il_priv *priv); 72void il4965_reset_run_time_calib(struct il_priv *il);
73void il4965_calib_free_results(struct il_priv *priv); 73void il4965_calib_free_results(struct il_priv *il);
74 74
75#endif /* __il_4965_calib_h__ */ 75#endif /* __il_4965_calib_h__ */
diff --git a/drivers/net/wireless/iwlegacy/iwl-4965-debugfs.c b/drivers/net/wireless/iwlegacy/iwl-4965-debugfs.c
index 3c2876ffadc5..8ea0ac205f7f 100644
--- a/drivers/net/wireless/iwlegacy/iwl-4965-debugfs.c
+++ b/drivers/net/wireless/iwlegacy/iwl-4965-debugfs.c
@@ -33,12 +33,12 @@ static const char *fmt_table = " %-30s %10u %10u %10u %10u\n";
33static const char *fmt_header = 33static const char *fmt_header =
34 "%-32s current cumulative delta max\n"; 34 "%-32s current cumulative delta max\n";
35 35
36static int il4965_statistics_flag(struct il_priv *priv, char *buf, int bufsz) 36static int il4965_statistics_flag(struct il_priv *il, char *buf, int bufsz)
37{ 37{
38 int p = 0; 38 int p = 0;
39 u32 flag; 39 u32 flag;
40 40
41 flag = le32_to_cpu(priv->_4965.statistics.flag); 41 flag = le32_to_cpu(il->_4965.statistics.flag);
42 42
43 p += scnprintf(buf + p, bufsz - p, "Statistics Flag(0x%X):\n", flag); 43 p += scnprintf(buf + p, bufsz - p, "Statistics Flag(0x%X):\n", flag);
44 if (flag & UCODE_STATISTICS_CLEAR_MSK) 44 if (flag & UCODE_STATISTICS_CLEAR_MSK)
@@ -57,7 +57,7 @@ static int il4965_statistics_flag(struct il_priv *priv, char *buf, int bufsz)
57ssize_t il4965_ucode_rx_stats_read(struct file *file, char __user *user_buf, 57ssize_t il4965_ucode_rx_stats_read(struct file *file, char __user *user_buf,
58 size_t count, loff_t *ppos) 58 size_t count, loff_t *ppos)
59{ 59{
60 struct il_priv *priv = file->private_data; 60 struct il_priv *il = file->private_data;
61 int pos = 0; 61 int pos = 0;
62 char *buf; 62 char *buf;
63 int bufsz = sizeof(struct statistics_rx_phy) * 40 + 63 int bufsz = sizeof(struct statistics_rx_phy) * 40 +
@@ -70,12 +70,12 @@ ssize_t il4965_ucode_rx_stats_read(struct file *file, char __user *user_buf,
70 struct statistics_rx_non_phy *delta_general, *max_general; 70 struct statistics_rx_non_phy *delta_general, *max_general;
71 struct statistics_rx_ht_phy *ht, *accum_ht, *delta_ht, *max_ht; 71 struct statistics_rx_ht_phy *ht, *accum_ht, *delta_ht, *max_ht;
72 72
73 if (!il_is_alive(priv)) 73 if (!il_is_alive(il))
74 return -EAGAIN; 74 return -EAGAIN;
75 75
76 buf = kzalloc(bufsz, GFP_KERNEL); 76 buf = kzalloc(bufsz, GFP_KERNEL);
77 if (!buf) { 77 if (!buf) {
78 IL_ERR(priv, "Can not allocate Buffer\n"); 78 IL_ERR(il, "Can not allocate Buffer\n");
79 return -ENOMEM; 79 return -ENOMEM;
80 } 80 }
81 81
@@ -84,24 +84,24 @@ ssize_t il4965_ucode_rx_stats_read(struct file *file, char __user *user_buf,
84 * the last statistics notification from uCode 84 * the last statistics notification from uCode
85 * might not reflect the current uCode activity 85 * might not reflect the current uCode activity
86 */ 86 */
87 ofdm = &priv->_4965.statistics.rx.ofdm; 87 ofdm = &il->_4965.statistics.rx.ofdm;
88 cck = &priv->_4965.statistics.rx.cck; 88 cck = &il->_4965.statistics.rx.cck;
89 general = &priv->_4965.statistics.rx.general; 89 general = &il->_4965.statistics.rx.general;
90 ht = &priv->_4965.statistics.rx.ofdm_ht; 90 ht = &il->_4965.statistics.rx.ofdm_ht;
91 accum_ofdm = &priv->_4965.accum_statistics.rx.ofdm; 91 accum_ofdm = &il->_4965.accum_statistics.rx.ofdm;
92 accum_cck = &priv->_4965.accum_statistics.rx.cck; 92 accum_cck = &il->_4965.accum_statistics.rx.cck;
93 accum_general = &priv->_4965.accum_statistics.rx.general; 93 accum_general = &il->_4965.accum_statistics.rx.general;
94 accum_ht = &priv->_4965.accum_statistics.rx.ofdm_ht; 94 accum_ht = &il->_4965.accum_statistics.rx.ofdm_ht;
95 delta_ofdm = &priv->_4965.delta_statistics.rx.ofdm; 95 delta_ofdm = &il->_4965.delta_statistics.rx.ofdm;
96 delta_cck = &priv->_4965.delta_statistics.rx.cck; 96 delta_cck = &il->_4965.delta_statistics.rx.cck;
97 delta_general = &priv->_4965.delta_statistics.rx.general; 97 delta_general = &il->_4965.delta_statistics.rx.general;
98 delta_ht = &priv->_4965.delta_statistics.rx.ofdm_ht; 98 delta_ht = &il->_4965.delta_statistics.rx.ofdm_ht;
99 max_ofdm = &priv->_4965.max_delta.rx.ofdm; 99 max_ofdm = &il->_4965.max_delta.rx.ofdm;
100 max_cck = &priv->_4965.max_delta.rx.cck; 100 max_cck = &il->_4965.max_delta.rx.cck;
101 max_general = &priv->_4965.max_delta.rx.general; 101 max_general = &il->_4965.max_delta.rx.general;
102 max_ht = &priv->_4965.max_delta.rx.ofdm_ht; 102 max_ht = &il->_4965.max_delta.rx.ofdm_ht;
103 103
104 pos += il4965_statistics_flag(priv, buf, bufsz); 104 pos += il4965_statistics_flag(il, buf, bufsz);
105 pos += scnprintf(buf + pos, bufsz - pos, 105 pos += scnprintf(buf + pos, bufsz - pos,
106 fmt_header, "Statistics_Rx - OFDM:"); 106 fmt_header, "Statistics_Rx - OFDM:");
107 pos += scnprintf(buf + pos, bufsz - pos, 107 pos += scnprintf(buf + pos, bufsz - pos,
@@ -489,19 +489,19 @@ ssize_t il4965_ucode_tx_stats_read(struct file *file,
489 char __user *user_buf, 489 char __user *user_buf,
490 size_t count, loff_t *ppos) 490 size_t count, loff_t *ppos)
491{ 491{
492 struct il_priv *priv = file->private_data; 492 struct il_priv *il = file->private_data;
493 int pos = 0; 493 int pos = 0;
494 char *buf; 494 char *buf;
495 int bufsz = (sizeof(struct statistics_tx) * 48) + 250; 495 int bufsz = (sizeof(struct statistics_tx) * 48) + 250;
496 ssize_t ret; 496 ssize_t ret;
497 struct statistics_tx *tx, *accum_tx, *delta_tx, *max_tx; 497 struct statistics_tx *tx, *accum_tx, *delta_tx, *max_tx;
498 498
499 if (!il_is_alive(priv)) 499 if (!il_is_alive(il))
500 return -EAGAIN; 500 return -EAGAIN;
501 501
502 buf = kzalloc(bufsz, GFP_KERNEL); 502 buf = kzalloc(bufsz, GFP_KERNEL);
503 if (!buf) { 503 if (!buf) {
504 IL_ERR(priv, "Can not allocate Buffer\n"); 504 IL_ERR(il, "Can not allocate Buffer\n");
505 return -ENOMEM; 505 return -ENOMEM;
506 } 506 }
507 507
@@ -509,12 +509,12 @@ ssize_t il4965_ucode_tx_stats_read(struct file *file,
509 * the last statistics notification from uCode 509 * the last statistics notification from uCode
510 * might not reflect the current uCode activity 510 * might not reflect the current uCode activity
511 */ 511 */
512 tx = &priv->_4965.statistics.tx; 512 tx = &il->_4965.statistics.tx;
513 accum_tx = &priv->_4965.accum_statistics.tx; 513 accum_tx = &il->_4965.accum_statistics.tx;
514 delta_tx = &priv->_4965.delta_statistics.tx; 514 delta_tx = &il->_4965.delta_statistics.tx;
515 max_tx = &priv->_4965.max_delta.tx; 515 max_tx = &il->_4965.max_delta.tx;
516 516
517 pos += il4965_statistics_flag(priv, buf, bufsz); 517 pos += il4965_statistics_flag(il, buf, bufsz);
518 pos += scnprintf(buf + pos, bufsz - pos, 518 pos += scnprintf(buf + pos, bufsz - pos,
519 fmt_header, "Statistics_Tx:"); 519 fmt_header, "Statistics_Tx:");
520 pos += scnprintf(buf + pos, bufsz - pos, 520 pos += scnprintf(buf + pos, bufsz - pos,
@@ -664,7 +664,7 @@ ssize_t
664il4965_ucode_general_stats_read(struct file *file, char __user *user_buf, 664il4965_ucode_general_stats_read(struct file *file, char __user *user_buf,
665 size_t count, loff_t *ppos) 665 size_t count, loff_t *ppos)
666{ 666{
667 struct il_priv *priv = file->private_data; 667 struct il_priv *il = file->private_data;
668 int pos = 0; 668 int pos = 0;
669 char *buf; 669 char *buf;
670 int bufsz = sizeof(struct statistics_general) * 10 + 300; 670 int bufsz = sizeof(struct statistics_general) * 10 + 300;
@@ -674,12 +674,12 @@ il4965_ucode_general_stats_read(struct file *file, char __user *user_buf,
674 struct statistics_dbg *dbg, *accum_dbg, *delta_dbg, *max_dbg; 674 struct statistics_dbg *dbg, *accum_dbg, *delta_dbg, *max_dbg;
675 struct statistics_div *div, *accum_div, *delta_div, *max_div; 675 struct statistics_div *div, *accum_div, *delta_div, *max_div;
676 676
677 if (!il_is_alive(priv)) 677 if (!il_is_alive(il))
678 return -EAGAIN; 678 return -EAGAIN;
679 679
680 buf = kzalloc(bufsz, GFP_KERNEL); 680 buf = kzalloc(bufsz, GFP_KERNEL);
681 if (!buf) { 681 if (!buf) {
682 IL_ERR(priv, "Can not allocate Buffer\n"); 682 IL_ERR(il, "Can not allocate Buffer\n");
683 return -ENOMEM; 683 return -ENOMEM;
684 } 684 }
685 685
@@ -687,20 +687,20 @@ il4965_ucode_general_stats_read(struct file *file, char __user *user_buf,
687 * the last statistics notification from uCode 687 * the last statistics notification from uCode
688 * might not reflect the current uCode activity 688 * might not reflect the current uCode activity
689 */ 689 */
690 general = &priv->_4965.statistics.general.common; 690 general = &il->_4965.statistics.general.common;
691 dbg = &priv->_4965.statistics.general.common.dbg; 691 dbg = &il->_4965.statistics.general.common.dbg;
692 div = &priv->_4965.statistics.general.common.div; 692 div = &il->_4965.statistics.general.common.div;
693 accum_general = &priv->_4965.accum_statistics.general.common; 693 accum_general = &il->_4965.accum_statistics.general.common;
694 accum_dbg = &priv->_4965.accum_statistics.general.common.dbg; 694 accum_dbg = &il->_4965.accum_statistics.general.common.dbg;
695 accum_div = &priv->_4965.accum_statistics.general.common.div; 695 accum_div = &il->_4965.accum_statistics.general.common.div;
696 delta_general = &priv->_4965.delta_statistics.general.common; 696 delta_general = &il->_4965.delta_statistics.general.common;
697 max_general = &priv->_4965.max_delta.general.common; 697 max_general = &il->_4965.max_delta.general.common;
698 delta_dbg = &priv->_4965.delta_statistics.general.common.dbg; 698 delta_dbg = &il->_4965.delta_statistics.general.common.dbg;
699 max_dbg = &priv->_4965.max_delta.general.common.dbg; 699 max_dbg = &il->_4965.max_delta.general.common.dbg;
700 delta_div = &priv->_4965.delta_statistics.general.common.div; 700 delta_div = &il->_4965.delta_statistics.general.common.div;
701 max_div = &priv->_4965.max_delta.general.common.div; 701 max_div = &il->_4965.max_delta.general.common.div;
702 702
703 pos += il4965_statistics_flag(priv, buf, bufsz); 703 pos += il4965_statistics_flag(il, buf, bufsz);
704 pos += scnprintf(buf + pos, bufsz - pos, 704 pos += scnprintf(buf + pos, bufsz - pos,
705 fmt_header, "Statistics_General:"); 705 fmt_header, "Statistics_General:");
706 pos += scnprintf(buf + pos, bufsz - pos, 706 pos += scnprintf(buf + pos, bufsz - pos,
diff --git a/drivers/net/wireless/iwlegacy/iwl-4965-eeprom.c b/drivers/net/wireless/iwlegacy/iwl-4965-eeprom.c
index e657b444cf48..947475ea3cef 100644
--- a/drivers/net/wireless/iwlegacy/iwl-4965-eeprom.c
+++ b/drivers/net/wireless/iwlegacy/iwl-4965-eeprom.c
@@ -87,23 +87,23 @@
87 * EEPROM chip, not a single event, so even reads could conflict if they 87 * EEPROM chip, not a single event, so even reads could conflict if they
88 * weren't arbitrated by the semaphore. 88 * weren't arbitrated by the semaphore.
89 */ 89 */
90int il4965_eeprom_acquire_semaphore(struct il_priv *priv) 90int il4965_eeprom_acquire_semaphore(struct il_priv *il)
91{ 91{
92 u16 count; 92 u16 count;
93 int ret; 93 int ret;
94 94
95 for (count = 0; count < EEPROM_SEM_RETRY_LIMIT; count++) { 95 for (count = 0; count < EEPROM_SEM_RETRY_LIMIT; count++) {
96 /* Request semaphore */ 96 /* Request semaphore */
97 il_set_bit(priv, CSR_HW_IF_CONFIG_REG, 97 il_set_bit(il, CSR_HW_IF_CONFIG_REG,
98 CSR_HW_IF_CONFIG_REG_BIT_EEPROM_OWN_SEM); 98 CSR_HW_IF_CONFIG_REG_BIT_EEPROM_OWN_SEM);
99 99
100 /* See if we got it */ 100 /* See if we got it */
101 ret = il_poll_bit(priv, CSR_HW_IF_CONFIG_REG, 101 ret = il_poll_bit(il, CSR_HW_IF_CONFIG_REG,
102 CSR_HW_IF_CONFIG_REG_BIT_EEPROM_OWN_SEM, 102 CSR_HW_IF_CONFIG_REG_BIT_EEPROM_OWN_SEM,
103 CSR_HW_IF_CONFIG_REG_BIT_EEPROM_OWN_SEM, 103 CSR_HW_IF_CONFIG_REG_BIT_EEPROM_OWN_SEM,
104 EEPROM_SEM_TIMEOUT); 104 EEPROM_SEM_TIMEOUT);
105 if (ret >= 0) { 105 if (ret >= 0) {
106 IL_DEBUG_IO(priv, 106 IL_DEBUG_IO(il,
107 "Acquired semaphore after %d tries.\n", 107 "Acquired semaphore after %d tries.\n",
108 count+1); 108 count+1);
109 return ret; 109 return ret;
@@ -113,42 +113,42 @@ int il4965_eeprom_acquire_semaphore(struct il_priv *priv)
113 return ret; 113 return ret;
114} 114}
115 115
116void il4965_eeprom_release_semaphore(struct il_priv *priv) 116void il4965_eeprom_release_semaphore(struct il_priv *il)
117{ 117{
118 il_clear_bit(priv, CSR_HW_IF_CONFIG_REG, 118 il_clear_bit(il, CSR_HW_IF_CONFIG_REG,
119 CSR_HW_IF_CONFIG_REG_BIT_EEPROM_OWN_SEM); 119 CSR_HW_IF_CONFIG_REG_BIT_EEPROM_OWN_SEM);
120 120
121} 121}
122 122
123int il4965_eeprom_check_version(struct il_priv *priv) 123int il4965_eeprom_check_version(struct il_priv *il)
124{ 124{
125 u16 eeprom_ver; 125 u16 eeprom_ver;
126 u16 calib_ver; 126 u16 calib_ver;
127 127
128 eeprom_ver = il_eeprom_query16(priv, EEPROM_VERSION); 128 eeprom_ver = il_eeprom_query16(il, EEPROM_VERSION);
129 calib_ver = il_eeprom_query16(priv, 129 calib_ver = il_eeprom_query16(il,
130 EEPROM_4965_CALIB_VERSION_OFFSET); 130 EEPROM_4965_CALIB_VERSION_OFFSET);
131 131
132 if (eeprom_ver < priv->cfg->eeprom_ver || 132 if (eeprom_ver < il->cfg->eeprom_ver ||
133 calib_ver < priv->cfg->eeprom_calib_ver) 133 calib_ver < il->cfg->eeprom_calib_ver)
134 goto err; 134 goto err;
135 135
136 IL_INFO(priv, "device EEPROM VER=0x%x, CALIB=0x%x\n", 136 IL_INFO(il, "device EEPROM VER=0x%x, CALIB=0x%x\n",
137 eeprom_ver, calib_ver); 137 eeprom_ver, calib_ver);
138 138
139 return 0; 139 return 0;
140err: 140err:
141 IL_ERR(priv, "Unsupported (too old) EEPROM VER=0x%x < 0x%x " 141 IL_ERR(il, "Unsupported (too old) EEPROM VER=0x%x < 0x%x "
142 "CALIB=0x%x < 0x%x\n", 142 "CALIB=0x%x < 0x%x\n",
143 eeprom_ver, priv->cfg->eeprom_ver, 143 eeprom_ver, il->cfg->eeprom_ver,
144 calib_ver, priv->cfg->eeprom_calib_ver); 144 calib_ver, il->cfg->eeprom_calib_ver);
145 return -EINVAL; 145 return -EINVAL;
146 146
147} 147}
148 148
149void il4965_eeprom_get_mac(const struct il_priv *priv, u8 *mac) 149void il4965_eeprom_get_mac(const struct il_priv *il, u8 *mac)
150{ 150{
151 const u8 *addr = il_eeprom_query_addr(priv, 151 const u8 *addr = il_eeprom_query_addr(il,
152 EEPROM_MAC_ADDRESS); 152 EEPROM_MAC_ADDRESS);
153 memcpy(mac, addr, ETH_ALEN); 153 memcpy(mac, addr, ETH_ALEN);
154} 154}
diff --git a/drivers/net/wireless/iwlegacy/iwl-4965-led.c b/drivers/net/wireless/iwlegacy/iwl-4965-led.c
index d2c8eacd6835..1436a1b7ebf6 100644
--- a/drivers/net/wireless/iwlegacy/iwl-4965-led.c
+++ b/drivers/net/wireless/iwlegacy/iwl-4965-led.c
@@ -44,7 +44,7 @@
44 44
45/* Send led command */ 45/* Send led command */
46static int 46static int
47il4965_send_led_cmd(struct il_priv *priv, struct il_led_cmd *led_cmd) 47il4965_send_led_cmd(struct il_priv *il, struct il_led_cmd *led_cmd)
48{ 48{
49 struct il_host_cmd cmd = { 49 struct il_host_cmd cmd = {
50 .id = REPLY_LEDS_CMD, 50 .id = REPLY_LEDS_CMD,
@@ -55,17 +55,17 @@ il4965_send_led_cmd(struct il_priv *priv, struct il_led_cmd *led_cmd)
55 }; 55 };
56 u32 reg; 56 u32 reg;
57 57
58 reg = il_read32(priv, CSR_LED_REG); 58 reg = il_read32(il, CSR_LED_REG);
59 if (reg != (reg & CSR_LED_BSM_CTRL_MSK)) 59 if (reg != (reg & CSR_LED_BSM_CTRL_MSK))
60 il_write32(priv, CSR_LED_REG, reg & CSR_LED_BSM_CTRL_MSK); 60 il_write32(il, CSR_LED_REG, reg & CSR_LED_BSM_CTRL_MSK);
61 61
62 return il_send_cmd(priv, &cmd); 62 return il_send_cmd(il, &cmd);
63} 63}
64 64
65/* Set led register off */ 65/* Set led register off */
66void il4965_led_enable(struct il_priv *priv) 66void il4965_led_enable(struct il_priv *il)
67{ 67{
68 il_write32(priv, CSR_LED_REG, CSR_LED_REG_TRUN_ON); 68 il_write32(il, CSR_LED_REG, CSR_LED_REG_TRUN_ON);
69} 69}
70 70
71const struct il_led_ops il4965_led_ops = { 71const struct il_led_ops il4965_led_ops = {
diff --git a/drivers/net/wireless/iwlegacy/iwl-4965-led.h b/drivers/net/wireless/iwlegacy/iwl-4965-led.h
index ab03dff812fd..e804fe16caef 100644
--- a/drivers/net/wireless/iwlegacy/iwl-4965-led.h
+++ b/drivers/net/wireless/iwlegacy/iwl-4965-led.h
@@ -28,6 +28,6 @@
28#define __il_4965_led_h__ 28#define __il_4965_led_h__
29 29
30extern const struct il_led_ops il4965_led_ops; 30extern const struct il_led_ops il4965_led_ops;
31void il4965_led_enable(struct il_priv *priv); 31void il4965_led_enable(struct il_priv *il);
32 32
33#endif /* __il_4965_led_h__ */ 33#endif /* __il_4965_led_h__ */
diff --git a/drivers/net/wireless/iwlegacy/iwl-4965-lib.c b/drivers/net/wireless/iwlegacy/iwl-4965-lib.c
index 25f1d4768e7b..4d25590b0339 100644
--- a/drivers/net/wireless/iwlegacy/iwl-4965-lib.c
+++ b/drivers/net/wireless/iwlegacy/iwl-4965-lib.c
@@ -40,13 +40,13 @@
40#include "iwl-4965.h" 40#include "iwl-4965.h"
41#include "iwl-sta.h" 41#include "iwl-sta.h"
42 42
43void il4965_check_abort_status(struct il_priv *priv, 43void il4965_check_abort_status(struct il_priv *il,
44 u8 frame_count, u32 status) 44 u8 frame_count, u32 status)
45{ 45{
46 if (frame_count == 1 && status == TX_STATUS_FAIL_RFKILL_FLUSH) { 46 if (frame_count == 1 && status == TX_STATUS_FAIL_RFKILL_FLUSH) {
47 IL_ERR(priv, "Tx flush command to flush out all frames\n"); 47 IL_ERR(il, "Tx flush command to flush out all frames\n");
48 if (!test_bit(STATUS_EXIT_PENDING, &priv->status)) 48 if (!test_bit(STATUS_EXIT_PENDING, &il->status))
49 queue_work(priv->workqueue, &priv->tx_flush); 49 queue_work(il->workqueue, &il->tx_flush);
50 } 50 }
51} 51}
52 52
@@ -59,7 +59,7 @@ struct il_mod_params il4965_mod_params = {
59 /* the rest are 0 by default */ 59 /* the rest are 0 by default */
60}; 60};
61 61
62void il4965_rx_queue_reset(struct il_priv *priv, struct il_rx_queue *rxq) 62void il4965_rx_queue_reset(struct il_priv *il, struct il_rx_queue *rxq)
63{ 63{
64 unsigned long flags; 64 unsigned long flags;
65 int i; 65 int i;
@@ -71,10 +71,10 @@ void il4965_rx_queue_reset(struct il_priv *priv, struct il_rx_queue *rxq)
71 /* In the reset function, these buffers may have been allocated 71 /* In the reset function, these buffers may have been allocated
72 * to an SKB, so we need to unmap and free potential storage */ 72 * to an SKB, so we need to unmap and free potential storage */
73 if (rxq->pool[i].page != NULL) { 73 if (rxq->pool[i].page != NULL) {
74 pci_unmap_page(priv->pci_dev, rxq->pool[i].page_dma, 74 pci_unmap_page(il->pci_dev, rxq->pool[i].page_dma,
75 PAGE_SIZE << priv->hw_params.rx_page_order, 75 PAGE_SIZE << il->hw_params.rx_page_order,
76 PCI_DMA_FROMDEVICE); 76 PCI_DMA_FROMDEVICE);
77 __il_free_pages(priv, rxq->pool[i].page); 77 __il_free_pages(il, rxq->pool[i].page);
78 rxq->pool[i].page = NULL; 78 rxq->pool[i].page = NULL;
79 } 79 }
80 list_add_tail(&rxq->pool[i].list, &rxq->rx_used); 80 list_add_tail(&rxq->pool[i].list, &rxq->rx_used);
@@ -91,29 +91,29 @@ void il4965_rx_queue_reset(struct il_priv *priv, struct il_rx_queue *rxq)
91 spin_unlock_irqrestore(&rxq->lock, flags); 91 spin_unlock_irqrestore(&rxq->lock, flags);
92} 92}
93 93
94int il4965_rx_init(struct il_priv *priv, struct il_rx_queue *rxq) 94int il4965_rx_init(struct il_priv *il, struct il_rx_queue *rxq)
95{ 95{
96 u32 rb_size; 96 u32 rb_size;
97 const u32 rfdnlog = RX_QUEUE_SIZE_LOG; /* 256 RBDs */ 97 const u32 rfdnlog = RX_QUEUE_SIZE_LOG; /* 256 RBDs */
98 u32 rb_timeout = 0; 98 u32 rb_timeout = 0;
99 99
100 if (priv->cfg->mod_params->amsdu_size_8K) 100 if (il->cfg->mod_params->amsdu_size_8K)
101 rb_size = FH_RCSR_RX_CONFIG_REG_VAL_RB_SIZE_8K; 101 rb_size = FH_RCSR_RX_CONFIG_REG_VAL_RB_SIZE_8K;
102 else 102 else
103 rb_size = FH_RCSR_RX_CONFIG_REG_VAL_RB_SIZE_4K; 103 rb_size = FH_RCSR_RX_CONFIG_REG_VAL_RB_SIZE_4K;
104 104
105 /* Stop Rx DMA */ 105 /* Stop Rx DMA */
106 il_write_direct32(priv, FH_MEM_RCSR_CHNL0_CONFIG_REG, 0); 106 il_write_direct32(il, FH_MEM_RCSR_CHNL0_CONFIG_REG, 0);
107 107
108 /* Reset driver's Rx queue write index */ 108 /* Reset driver's Rx queue write index */
109 il_write_direct32(priv, FH_RSCSR_CHNL0_RBDCB_WPTR_REG, 0); 109 il_write_direct32(il, FH_RSCSR_CHNL0_RBDCB_WPTR_REG, 0);
110 110
111 /* Tell device where to find RBD circular buffer in DRAM */ 111 /* Tell device where to find RBD circular buffer in DRAM */
112 il_write_direct32(priv, FH_RSCSR_CHNL0_RBDCB_BASE_REG, 112 il_write_direct32(il, FH_RSCSR_CHNL0_RBDCB_BASE_REG,
113 (u32)(rxq->bd_dma >> 8)); 113 (u32)(rxq->bd_dma >> 8));
114 114
115 /* Tell device where in DRAM to update its Rx status */ 115 /* Tell device where in DRAM to update its Rx status */
116 il_write_direct32(priv, FH_RSCSR_CHNL0_STTS_WPTR_REG, 116 il_write_direct32(il, FH_RSCSR_CHNL0_STTS_WPTR_REG,
117 rxq->rb_stts_dma >> 4); 117 rxq->rb_stts_dma >> 4);
118 118
119 /* Enable Rx DMA 119 /* Enable Rx DMA
@@ -122,7 +122,7 @@ int il4965_rx_init(struct il_priv *priv, struct il_rx_queue *rxq)
122 * RB timeout 0x10 122 * RB timeout 0x10
123 * 256 RBDs 123 * 256 RBDs
124 */ 124 */
125 il_write_direct32(priv, FH_MEM_RCSR_CHNL0_CONFIG_REG, 125 il_write_direct32(il, FH_MEM_RCSR_CHNL0_CONFIG_REG,
126 FH_RCSR_RX_CONFIG_CHNL_EN_ENABLE_VAL | 126 FH_RCSR_RX_CONFIG_CHNL_EN_ENABLE_VAL |
127 FH_RCSR_CHNL0_RX_CONFIG_IRQ_DEST_INT_HOST_VAL | 127 FH_RCSR_CHNL0_RX_CONFIG_IRQ_DEST_INT_HOST_VAL |
128 FH_RCSR_CHNL0_RX_CONFIG_SINGLE_FRAME_MSK | 128 FH_RCSR_CHNL0_RX_CONFIG_SINGLE_FRAME_MSK |
@@ -131,77 +131,77 @@ int il4965_rx_init(struct il_priv *priv, struct il_rx_queue *rxq)
131 (rfdnlog << FH_RCSR_RX_CONFIG_RBDCB_SIZE_POS)); 131 (rfdnlog << FH_RCSR_RX_CONFIG_RBDCB_SIZE_POS));
132 132
133 /* Set interrupt coalescing timer to default (2048 usecs) */ 133 /* Set interrupt coalescing timer to default (2048 usecs) */
134 il_write8(priv, CSR_INT_COALESCING, IL_HOST_INT_TIMEOUT_DEF); 134 il_write8(il, CSR_INT_COALESCING, IL_HOST_INT_TIMEOUT_DEF);
135 135
136 return 0; 136 return 0;
137} 137}
138 138
139static void il4965_set_pwr_vmain(struct il_priv *priv) 139static void il4965_set_pwr_vmain(struct il_priv *il)
140{ 140{
141/* 141/*
142 * (for documentation purposes) 142 * (for documentation purposes)
143 * to set power to V_AUX, do: 143 * to set power to V_AUX, do:
144 144
145 if (pci_pme_capable(priv->pci_dev, PCI_D3cold)) 145 if (pci_pme_capable(il->pci_dev, PCI_D3cold))
146 il_set_bits_mask_prph(priv, APMG_PS_CTRL_REG, 146 il_set_bits_mask_prph(il, APMG_PS_CTRL_REG,
147 APMG_PS_CTRL_VAL_PWR_SRC_VAUX, 147 APMG_PS_CTRL_VAL_PWR_SRC_VAUX,
148 ~APMG_PS_CTRL_MSK_PWR_SRC); 148 ~APMG_PS_CTRL_MSK_PWR_SRC);
149 */ 149 */
150 150
151 il_set_bits_mask_prph(priv, APMG_PS_CTRL_REG, 151 il_set_bits_mask_prph(il, APMG_PS_CTRL_REG,
152 APMG_PS_CTRL_VAL_PWR_SRC_VMAIN, 152 APMG_PS_CTRL_VAL_PWR_SRC_VMAIN,
153 ~APMG_PS_CTRL_MSK_PWR_SRC); 153 ~APMG_PS_CTRL_MSK_PWR_SRC);
154} 154}
155 155
156int il4965_hw_nic_init(struct il_priv *priv) 156int il4965_hw_nic_init(struct il_priv *il)
157{ 157{
158 unsigned long flags; 158 unsigned long flags;
159 struct il_rx_queue *rxq = &priv->rxq; 159 struct il_rx_queue *rxq = &il->rxq;
160 int ret; 160 int ret;
161 161
162 /* nic_init */ 162 /* nic_init */
163 spin_lock_irqsave(&priv->lock, flags); 163 spin_lock_irqsave(&il->lock, flags);
164 priv->cfg->ops->lib->apm_ops.init(priv); 164 il->cfg->ops->lib->apm_ops.init(il);
165 165
166 /* Set interrupt coalescing calibration timer to default (512 usecs) */ 166 /* Set interrupt coalescing calibration timer to default (512 usecs) */
167 il_write8(priv, CSR_INT_COALESCING, IL_HOST_INT_CALIB_TIMEOUT_DEF); 167 il_write8(il, CSR_INT_COALESCING, IL_HOST_INT_CALIB_TIMEOUT_DEF);
168 168
169 spin_unlock_irqrestore(&priv->lock, flags); 169 spin_unlock_irqrestore(&il->lock, flags);
170 170
171 il4965_set_pwr_vmain(priv); 171 il4965_set_pwr_vmain(il);
172 172
173 priv->cfg->ops->lib->apm_ops.config(priv); 173 il->cfg->ops->lib->apm_ops.config(il);
174 174
175 /* Allocate the RX queue, or reset if it is already allocated */ 175 /* Allocate the RX queue, or reset if it is already allocated */
176 if (!rxq->bd) { 176 if (!rxq->bd) {
177 ret = il_rx_queue_alloc(priv); 177 ret = il_rx_queue_alloc(il);
178 if (ret) { 178 if (ret) {
179 IL_ERR(priv, "Unable to initialize Rx queue\n"); 179 IL_ERR(il, "Unable to initialize Rx queue\n");
180 return -ENOMEM; 180 return -ENOMEM;
181 } 181 }
182 } else 182 } else
183 il4965_rx_queue_reset(priv, rxq); 183 il4965_rx_queue_reset(il, rxq);
184 184
185 il4965_rx_replenish(priv); 185 il4965_rx_replenish(il);
186 186
187 il4965_rx_init(priv, rxq); 187 il4965_rx_init(il, rxq);
188 188
189 spin_lock_irqsave(&priv->lock, flags); 189 spin_lock_irqsave(&il->lock, flags);
190 190
191 rxq->need_update = 1; 191 rxq->need_update = 1;
192 il_rx_queue_update_write_ptr(priv, rxq); 192 il_rx_queue_update_write_ptr(il, rxq);
193 193
194 spin_unlock_irqrestore(&priv->lock, flags); 194 spin_unlock_irqrestore(&il->lock, flags);
195 195
196 /* Allocate or reset and init all Tx and Command queues */ 196 /* Allocate or reset and init all Tx and Command queues */
197 if (!priv->txq) { 197 if (!il->txq) {
198 ret = il4965_txq_ctx_alloc(priv); 198 ret = il4965_txq_ctx_alloc(il);
199 if (ret) 199 if (ret)
200 return ret; 200 return ret;
201 } else 201 } else
202 il4965_txq_ctx_reset(priv); 202 il4965_txq_ctx_reset(il);
203 203
204 set_bit(STATUS_INIT, &priv->status); 204 set_bit(STATUS_INIT, &il->status);
205 205
206 return 0; 206 return 0;
207} 207}
@@ -209,7 +209,7 @@ int il4965_hw_nic_init(struct il_priv *priv)
209/** 209/**
210 * il4965_dma_addr2rbd_ptr - convert a DMA address to a uCode read buffer ptr 210 * il4965_dma_addr2rbd_ptr - convert a DMA address to a uCode read buffer ptr
211 */ 211 */
212static inline __le32 il4965_dma_addr2rbd_ptr(struct il_priv *priv, 212static inline __le32 il4965_dma_addr2rbd_ptr(struct il_priv *il,
213 dma_addr_t dma_addr) 213 dma_addr_t dma_addr)
214{ 214{
215 return cpu_to_le32((u32)(dma_addr >> 8)); 215 return cpu_to_le32((u32)(dma_addr >> 8));
@@ -226,9 +226,9 @@ static inline __le32 il4965_dma_addr2rbd_ptr(struct il_priv *priv,
226 * also updates the memory address in the firmware to reference the new 226 * also updates the memory address in the firmware to reference the new
227 * target buffer. 227 * target buffer.
228 */ 228 */
229void il4965_rx_queue_restock(struct il_priv *priv) 229void il4965_rx_queue_restock(struct il_priv *il)
230{ 230{
231 struct il_rx_queue *rxq = &priv->rxq; 231 struct il_rx_queue *rxq = &il->rxq;
232 struct list_head *element; 232 struct list_head *element;
233 struct il_rx_mem_buffer *rxb; 233 struct il_rx_mem_buffer *rxb;
234 unsigned long flags; 234 unsigned long flags;
@@ -245,7 +245,7 @@ void il4965_rx_queue_restock(struct il_priv *priv)
245 list_del(element); 245 list_del(element);
246 246
247 /* Point to Rx buffer via next RBD in circular buffer */ 247 /* Point to Rx buffer via next RBD in circular buffer */
248 rxq->bd[rxq->write] = il4965_dma_addr2rbd_ptr(priv, 248 rxq->bd[rxq->write] = il4965_dma_addr2rbd_ptr(il,
249 rxb->page_dma); 249 rxb->page_dma);
250 rxq->queue[rxq->write] = rxb; 250 rxq->queue[rxq->write] = rxb;
251 rxq->write = (rxq->write + 1) & RX_QUEUE_MASK; 251 rxq->write = (rxq->write + 1) & RX_QUEUE_MASK;
@@ -255,7 +255,7 @@ void il4965_rx_queue_restock(struct il_priv *priv)
255 /* If the pre-allocated buffer pool is dropping low, schedule to 255 /* If the pre-allocated buffer pool is dropping low, schedule to
256 * refill it */ 256 * refill it */
257 if (rxq->free_count <= RX_LOW_WATERMARK) 257 if (rxq->free_count <= RX_LOW_WATERMARK)
258 queue_work(priv->workqueue, &priv->rx_replenish); 258 queue_work(il->workqueue, &il->rx_replenish);
259 259
260 260
261 /* If we've added more space for the firmware to place data, tell it. 261 /* If we've added more space for the firmware to place data, tell it.
@@ -264,7 +264,7 @@ void il4965_rx_queue_restock(struct il_priv *priv)
264 spin_lock_irqsave(&rxq->lock, flags); 264 spin_lock_irqsave(&rxq->lock, flags);
265 rxq->need_update = 1; 265 rxq->need_update = 1;
266 spin_unlock_irqrestore(&rxq->lock, flags); 266 spin_unlock_irqrestore(&rxq->lock, flags);
267 il_rx_queue_update_write_ptr(priv, rxq); 267 il_rx_queue_update_write_ptr(il, rxq);
268 } 268 }
269} 269}
270 270
@@ -276,9 +276,9 @@ void il4965_rx_queue_restock(struct il_priv *priv)
276 * Also restock the Rx queue via il_rx_queue_restock. 276 * Also restock the Rx queue via il_rx_queue_restock.
277 * This is called as a scheduled work item (except for during initialization) 277 * This is called as a scheduled work item (except for during initialization)
278 */ 278 */
279static void il4965_rx_allocate(struct il_priv *priv, gfp_t priority) 279static void il4965_rx_allocate(struct il_priv *il, gfp_t priority)
280{ 280{
281 struct il_rx_queue *rxq = &priv->rxq; 281 struct il_rx_queue *rxq = &il->rxq;
282 struct list_head *element; 282 struct list_head *element;
283 struct il_rx_mem_buffer *rxb; 283 struct il_rx_mem_buffer *rxb;
284 struct page *page; 284 struct page *page;
@@ -296,20 +296,20 @@ static void il4965_rx_allocate(struct il_priv *priv, gfp_t priority)
296 if (rxq->free_count > RX_LOW_WATERMARK) 296 if (rxq->free_count > RX_LOW_WATERMARK)
297 gfp_mask |= __GFP_NOWARN; 297 gfp_mask |= __GFP_NOWARN;
298 298
299 if (priv->hw_params.rx_page_order > 0) 299 if (il->hw_params.rx_page_order > 0)
300 gfp_mask |= __GFP_COMP; 300 gfp_mask |= __GFP_COMP;
301 301
302 /* Alloc a new receive buffer */ 302 /* Alloc a new receive buffer */
303 page = alloc_pages(gfp_mask, priv->hw_params.rx_page_order); 303 page = alloc_pages(gfp_mask, il->hw_params.rx_page_order);
304 if (!page) { 304 if (!page) {
305 if (net_ratelimit()) 305 if (net_ratelimit())
306 IL_DEBUG_INFO(priv, "alloc_pages failed, " 306 IL_DEBUG_INFO(il, "alloc_pages failed, "
307 "order: %d\n", 307 "order: %d\n",
308 priv->hw_params.rx_page_order); 308 il->hw_params.rx_page_order);
309 309
310 if ((rxq->free_count <= RX_LOW_WATERMARK) && 310 if ((rxq->free_count <= RX_LOW_WATERMARK) &&
311 net_ratelimit()) 311 net_ratelimit())
312 IL_CRIT(priv, 312 IL_CRIT(il,
313 "Failed to alloc_pages with %s. " 313 "Failed to alloc_pages with %s. "
314 "Only %u free buffers remaining.\n", 314 "Only %u free buffers remaining.\n",
315 priority == GFP_ATOMIC ? 315 priority == GFP_ATOMIC ?
@@ -325,7 +325,7 @@ static void il4965_rx_allocate(struct il_priv *priv, gfp_t priority)
325 325
326 if (list_empty(&rxq->rx_used)) { 326 if (list_empty(&rxq->rx_used)) {
327 spin_unlock_irqrestore(&rxq->lock, flags); 327 spin_unlock_irqrestore(&rxq->lock, flags);
328 __free_pages(page, priv->hw_params.rx_page_order); 328 __free_pages(page, il->hw_params.rx_page_order);
329 return; 329 return;
330 } 330 }
331 element = rxq->rx_used.next; 331 element = rxq->rx_used.next;
@@ -337,8 +337,8 @@ static void il4965_rx_allocate(struct il_priv *priv, gfp_t priority)
337 BUG_ON(rxb->page); 337 BUG_ON(rxb->page);
338 rxb->page = page; 338 rxb->page = page;
339 /* Get physical address of the RB */ 339 /* Get physical address of the RB */
340 rxb->page_dma = pci_map_page(priv->pci_dev, page, 0, 340 rxb->page_dma = pci_map_page(il->pci_dev, page, 0,
341 PAGE_SIZE << priv->hw_params.rx_page_order, 341 PAGE_SIZE << il->hw_params.rx_page_order,
342 PCI_DMA_FROMDEVICE); 342 PCI_DMA_FROMDEVICE);
343 /* dma address must be no more than 36 bits */ 343 /* dma address must be no more than 36 bits */
344 BUG_ON(rxb->page_dma & ~DMA_BIT_MASK(36)); 344 BUG_ON(rxb->page_dma & ~DMA_BIT_MASK(36));
@@ -349,28 +349,28 @@ static void il4965_rx_allocate(struct il_priv *priv, gfp_t priority)
349 349
350 list_add_tail(&rxb->list, &rxq->rx_free); 350 list_add_tail(&rxb->list, &rxq->rx_free);
351 rxq->free_count++; 351 rxq->free_count++;
352 priv->alloc_rxb_page++; 352 il->alloc_rxb_page++;
353 353
354 spin_unlock_irqrestore(&rxq->lock, flags); 354 spin_unlock_irqrestore(&rxq->lock, flags);
355 } 355 }
356} 356}
357 357
358void il4965_rx_replenish(struct il_priv *priv) 358void il4965_rx_replenish(struct il_priv *il)
359{ 359{
360 unsigned long flags; 360 unsigned long flags;
361 361
362 il4965_rx_allocate(priv, GFP_KERNEL); 362 il4965_rx_allocate(il, GFP_KERNEL);
363 363
364 spin_lock_irqsave(&priv->lock, flags); 364 spin_lock_irqsave(&il->lock, flags);
365 il4965_rx_queue_restock(priv); 365 il4965_rx_queue_restock(il);
366 spin_unlock_irqrestore(&priv->lock, flags); 366 spin_unlock_irqrestore(&il->lock, flags);
367} 367}
368 368
369void il4965_rx_replenish_now(struct il_priv *priv) 369void il4965_rx_replenish_now(struct il_priv *il)
370{ 370{
371 il4965_rx_allocate(priv, GFP_ATOMIC); 371 il4965_rx_allocate(il, GFP_ATOMIC);
372 372
373 il4965_rx_queue_restock(priv); 373 il4965_rx_queue_restock(il);
374} 374}
375 375
376/* Assumes that the skb field of the buffers in 'pool' is kept accurate. 376/* Assumes that the skb field of the buffers in 'pool' is kept accurate.
@@ -378,33 +378,33 @@ void il4965_rx_replenish_now(struct il_priv *priv)
378 * This free routine walks the list of POOL entries and if SKB is set to 378 * This free routine walks the list of POOL entries and if SKB is set to
379 * non NULL it is unmapped and freed 379 * non NULL it is unmapped and freed
380 */ 380 */
381void il4965_rx_queue_free(struct il_priv *priv, struct il_rx_queue *rxq) 381void il4965_rx_queue_free(struct il_priv *il, struct il_rx_queue *rxq)
382{ 382{
383 int i; 383 int i;
384 for (i = 0; i < RX_QUEUE_SIZE + RX_FREE_BUFFERS; i++) { 384 for (i = 0; i < RX_QUEUE_SIZE + RX_FREE_BUFFERS; i++) {
385 if (rxq->pool[i].page != NULL) { 385 if (rxq->pool[i].page != NULL) {
386 pci_unmap_page(priv->pci_dev, rxq->pool[i].page_dma, 386 pci_unmap_page(il->pci_dev, rxq->pool[i].page_dma,
387 PAGE_SIZE << priv->hw_params.rx_page_order, 387 PAGE_SIZE << il->hw_params.rx_page_order,
388 PCI_DMA_FROMDEVICE); 388 PCI_DMA_FROMDEVICE);
389 __il_free_pages(priv, rxq->pool[i].page); 389 __il_free_pages(il, rxq->pool[i].page);
390 rxq->pool[i].page = NULL; 390 rxq->pool[i].page = NULL;
391 } 391 }
392 } 392 }
393 393
394 dma_free_coherent(&priv->pci_dev->dev, 4 * RX_QUEUE_SIZE, rxq->bd, 394 dma_free_coherent(&il->pci_dev->dev, 4 * RX_QUEUE_SIZE, rxq->bd,
395 rxq->bd_dma); 395 rxq->bd_dma);
396 dma_free_coherent(&priv->pci_dev->dev, sizeof(struct il_rb_status), 396 dma_free_coherent(&il->pci_dev->dev, sizeof(struct il_rb_status),
397 rxq->rb_stts, rxq->rb_stts_dma); 397 rxq->rb_stts, rxq->rb_stts_dma);
398 rxq->bd = NULL; 398 rxq->bd = NULL;
399 rxq->rb_stts = NULL; 399 rxq->rb_stts = NULL;
400} 400}
401 401
402int il4965_rxq_stop(struct il_priv *priv) 402int il4965_rxq_stop(struct il_priv *il)
403{ 403{
404 404
405 /* stop Rx DMA */ 405 /* stop Rx DMA */
406 il_write_direct32(priv, FH_MEM_RCSR_CHNL0_CONFIG_REG, 0); 406 il_write_direct32(il, FH_MEM_RCSR_CHNL0_CONFIG_REG, 0);
407 il_poll_direct_bit(priv, FH_MEM_RSSR_RX_STATUS_REG, 407 il_poll_direct_bit(il, FH_MEM_RSSR_RX_STATUS_REG,
408 FH_RSSR_CHNL0_RX_STATUS_CHNL_IDLE, 1000); 408 FH_RSSR_CHNL0_RX_STATUS_CHNL_IDLE, 1000);
409 409
410 return 0; 410 return 0;
@@ -431,7 +431,7 @@ int il4965_hwrate_to_mac80211_idx(u32 rate_n_flags, enum ieee80211_band band)
431 return -1; 431 return -1;
432} 432}
433 433
434static int il4965_calc_rssi(struct il_priv *priv, 434static int il4965_calc_rssi(struct il_priv *il,
435 struct il_rx_phy_res *rx_resp) 435 struct il_rx_phy_res *rx_resp)
436{ 436{
437 /* data from PHY/DSP regarding signal strength, etc., 437 /* data from PHY/DSP regarding signal strength, etc.,
@@ -456,7 +456,7 @@ static int il4965_calc_rssi(struct il_priv *priv,
456 if (valid_antennae & (1 << i)) 456 if (valid_antennae & (1 << i))
457 max_rssi = max(ncphy->rssi_info[i << 1], max_rssi); 457 max_rssi = max(ncphy->rssi_info[i << 1], max_rssi);
458 458
459 IL_DEBUG_STATS(priv, "Rssi In A %d B %d C %d Max %d AGC dB %d\n", 459 IL_DEBUG_STATS(il, "Rssi In A %d B %d C %d Max %d AGC dB %d\n",
460 ncphy->rssi_info[0], ncphy->rssi_info[2], ncphy->rssi_info[4], 460 ncphy->rssi_info[0], ncphy->rssi_info[2], ncphy->rssi_info[4],
461 max_rssi, agc); 461 max_rssi, agc);
462 462
@@ -466,7 +466,7 @@ static int il4965_calc_rssi(struct il_priv *priv,
466} 466}
467 467
468 468
469static u32 il4965_translate_rx_status(struct il_priv *priv, u32 decrypt_in) 469static u32 il4965_translate_rx_status(struct il_priv *il, u32 decrypt_in)
470{ 470{
471 u32 decrypt_out = 0; 471 u32 decrypt_out = 0;
472 472
@@ -519,13 +519,13 @@ static u32 il4965_translate_rx_status(struct il_priv *priv, u32 decrypt_in)
519 break; 519 break;
520 } 520 }
521 521
522 IL_DEBUG_RX(priv, "decrypt_in:0x%x decrypt_out = 0x%x\n", 522 IL_DEBUG_RX(il, "decrypt_in:0x%x decrypt_out = 0x%x\n",
523 decrypt_in, decrypt_out); 523 decrypt_in, decrypt_out);
524 524
525 return decrypt_out; 525 return decrypt_out;
526} 526}
527 527
528static void il4965_pass_packet_to_mac80211(struct il_priv *priv, 528static void il4965_pass_packet_to_mac80211(struct il_priv *il,
529 struct ieee80211_hdr *hdr, 529 struct ieee80211_hdr *hdr,
530 u16 len, 530 u16 len,
531 u32 ampdu_status, 531 u32 ampdu_status,
@@ -536,36 +536,36 @@ static void il4965_pass_packet_to_mac80211(struct il_priv *priv,
536 __le16 fc = hdr->frame_control; 536 __le16 fc = hdr->frame_control;
537 537
538 /* We only process data packets if the interface is open */ 538 /* We only process data packets if the interface is open */
539 if (unlikely(!priv->is_open)) { 539 if (unlikely(!il->is_open)) {
540 IL_DEBUG_DROP_LIMIT(priv, 540 IL_DEBUG_DROP_LIMIT(il,
541 "Dropping packet while interface is not open.\n"); 541 "Dropping packet while interface is not open.\n");
542 return; 542 return;
543 } 543 }
544 544
545 /* In case of HW accelerated crypto and bad decryption, drop */ 545 /* In case of HW accelerated crypto and bad decryption, drop */
546 if (!priv->cfg->mod_params->sw_crypto && 546 if (!il->cfg->mod_params->sw_crypto &&
547 il_set_decrypted_flag(priv, hdr, ampdu_status, stats)) 547 il_set_decrypted_flag(il, hdr, ampdu_status, stats))
548 return; 548 return;
549 549
550 skb = dev_alloc_skb(128); 550 skb = dev_alloc_skb(128);
551 if (!skb) { 551 if (!skb) {
552 IL_ERR(priv, "dev_alloc_skb failed\n"); 552 IL_ERR(il, "dev_alloc_skb failed\n");
553 return; 553 return;
554 } 554 }
555 555
556 skb_add_rx_frag(skb, 0, rxb->page, (void *)hdr - rxb_addr(rxb), len); 556 skb_add_rx_frag(skb, 0, rxb->page, (void *)hdr - rxb_addr(rxb), len);
557 557
558 il_update_stats(priv, false, fc, len); 558 il_update_stats(il, false, fc, len);
559 memcpy(IEEE80211_SKB_RXCB(skb), stats, sizeof(*stats)); 559 memcpy(IEEE80211_SKB_RXCB(skb), stats, sizeof(*stats));
560 560
561 ieee80211_rx(priv->hw, skb); 561 ieee80211_rx(il->hw, skb);
562 priv->alloc_rxb_page--; 562 il->alloc_rxb_page--;
563 rxb->page = NULL; 563 rxb->page = NULL;
564} 564}
565 565
566/* Called for REPLY_RX (legacy ABG frames), or 566/* Called for REPLY_RX (legacy ABG frames), or
567 * REPLY_RX_MPDU_CMD (HT high-throughput N frames). */ 567 * REPLY_RX_MPDU_CMD (HT high-throughput N frames). */
568void il4965_rx_reply_rx(struct il_priv *priv, 568void il4965_rx_reply_rx(struct il_priv *il,
569 struct il_rx_mem_buffer *rxb) 569 struct il_rx_mem_buffer *rxb)
570{ 570{
571 struct ieee80211_hdr *header; 571 struct ieee80211_hdr *header;
@@ -582,7 +582,7 @@ void il4965_rx_reply_rx(struct il_priv *priv,
582 * REPLY_RX and REPLY_RX_MPDU_CMD are handled differently. 582 * REPLY_RX and REPLY_RX_MPDU_CMD are handled differently.
583 * REPLY_RX: physical layer info is in this buffer 583 * REPLY_RX: physical layer info is in this buffer
584 * REPLY_RX_MPDU_CMD: physical layer info was sent in separate 584 * REPLY_RX_MPDU_CMD: physical layer info was sent in separate
585 * command and cached in priv->last_phy_res 585 * command and cached in il->last_phy_res
586 * 586 *
587 * Here we set up local variables depending on which command is 587 * Here we set up local variables depending on which command is
588 * received. 588 * received.
@@ -597,28 +597,28 @@ void il4965_rx_reply_rx(struct il_priv *priv,
597 phy_res->cfg_phy_cnt + len); 597 phy_res->cfg_phy_cnt + len);
598 ampdu_status = le32_to_cpu(rx_pkt_status); 598 ampdu_status = le32_to_cpu(rx_pkt_status);
599 } else { 599 } else {
600 if (!priv->_4965.last_phy_res_valid) { 600 if (!il->_4965.last_phy_res_valid) {
601 IL_ERR(priv, "MPDU frame without cached PHY data\n"); 601 IL_ERR(il, "MPDU frame without cached PHY data\n");
602 return; 602 return;
603 } 603 }
604 phy_res = &priv->_4965.last_phy_res; 604 phy_res = &il->_4965.last_phy_res;
605 amsdu = (struct il_rx_mpdu_res_start *)pkt->u.raw; 605 amsdu = (struct il_rx_mpdu_res_start *)pkt->u.raw;
606 header = (struct ieee80211_hdr *)(pkt->u.raw + sizeof(*amsdu)); 606 header = (struct ieee80211_hdr *)(pkt->u.raw + sizeof(*amsdu));
607 len = le16_to_cpu(amsdu->byte_count); 607 len = le16_to_cpu(amsdu->byte_count);
608 rx_pkt_status = *(__le32 *)(pkt->u.raw + sizeof(*amsdu) + len); 608 rx_pkt_status = *(__le32 *)(pkt->u.raw + sizeof(*amsdu) + len);
609 ampdu_status = il4965_translate_rx_status(priv, 609 ampdu_status = il4965_translate_rx_status(il,
610 le32_to_cpu(rx_pkt_status)); 610 le32_to_cpu(rx_pkt_status));
611 } 611 }
612 612
613 if ((unlikely(phy_res->cfg_phy_cnt > 20))) { 613 if ((unlikely(phy_res->cfg_phy_cnt > 20))) {
614 IL_DEBUG_DROP(priv, "dsp size out of range [0,20]: %d/n", 614 IL_DEBUG_DROP(il, "dsp size out of range [0,20]: %d/n",
615 phy_res->cfg_phy_cnt); 615 phy_res->cfg_phy_cnt);
616 return; 616 return;
617 } 617 }
618 618
619 if (!(rx_pkt_status & RX_RES_STATUS_NO_CRC32_ERROR) || 619 if (!(rx_pkt_status & RX_RES_STATUS_NO_CRC32_ERROR) ||
620 !(rx_pkt_status & RX_RES_STATUS_NO_RXE_OVERFLOW)) { 620 !(rx_pkt_status & RX_RES_STATUS_NO_RXE_OVERFLOW)) {
621 IL_DEBUG_RX(priv, "Bad CRC or FIFO: 0x%08X.\n", 621 IL_DEBUG_RX(il, "Bad CRC or FIFO: 0x%08X.\n",
622 le32_to_cpu(rx_pkt_status)); 622 le32_to_cpu(rx_pkt_status));
623 return; 623 return;
624 } 624 }
@@ -641,13 +641,13 @@ void il4965_rx_reply_rx(struct il_priv *priv,
641 * this W/A doesn't propagate it to the mac80211 */ 641 * this W/A doesn't propagate it to the mac80211 */
642 /*rx_status.flag |= RX_FLAG_MACTIME_MPDU;*/ 642 /*rx_status.flag |= RX_FLAG_MACTIME_MPDU;*/
643 643
644 priv->ucode_beacon_time = le32_to_cpu(phy_res->beacon_time_stamp); 644 il->ucode_beacon_time = le32_to_cpu(phy_res->beacon_time_stamp);
645 645
646 /* Find max signal strength (dBm) among 3 antenna/receiver chains */ 646 /* Find max signal strength (dBm) among 3 antenna/receiver chains */
647 rx_status.signal = il4965_calc_rssi(priv, phy_res); 647 rx_status.signal = il4965_calc_rssi(il, phy_res);
648 648
649 il_dbg_log_rx_data_frame(priv, len, header); 649 il_dbg_log_rx_data_frame(il, len, header);
650 IL_DEBUG_STATS_LIMIT(priv, "Rssi %d, TSF %llu\n", 650 IL_DEBUG_STATS_LIMIT(il, "Rssi %d, TSF %llu\n",
651 rx_status.signal, (unsigned long long)rx_status.mactime); 651 rx_status.signal, (unsigned long long)rx_status.mactime);
652 652
653 /* 653 /*
@@ -679,22 +679,22 @@ void il4965_rx_reply_rx(struct il_priv *priv,
679 if (rate_n_flags & RATE_MCS_SGI_MSK) 679 if (rate_n_flags & RATE_MCS_SGI_MSK)
680 rx_status.flag |= RX_FLAG_SHORT_GI; 680 rx_status.flag |= RX_FLAG_SHORT_GI;
681 681
682 il4965_pass_packet_to_mac80211(priv, header, len, ampdu_status, 682 il4965_pass_packet_to_mac80211(il, header, len, ampdu_status,
683 rxb, &rx_status); 683 rxb, &rx_status);
684} 684}
685 685
686/* Cache phy data (Rx signal strength, etc) for HT frame (REPLY_RX_PHY_CMD). 686/* Cache phy data (Rx signal strength, etc) for HT frame (REPLY_RX_PHY_CMD).
687 * This will be used later in il_rx_reply_rx() for REPLY_RX_MPDU_CMD. */ 687 * This will be used later in il_rx_reply_rx() for REPLY_RX_MPDU_CMD. */
688void il4965_rx_reply_rx_phy(struct il_priv *priv, 688void il4965_rx_reply_rx_phy(struct il_priv *il,
689 struct il_rx_mem_buffer *rxb) 689 struct il_rx_mem_buffer *rxb)
690{ 690{
691 struct il_rx_packet *pkt = rxb_addr(rxb); 691 struct il_rx_packet *pkt = rxb_addr(rxb);
692 priv->_4965.last_phy_res_valid = true; 692 il->_4965.last_phy_res_valid = true;
693 memcpy(&priv->_4965.last_phy_res, pkt->u.raw, 693 memcpy(&il->_4965.last_phy_res, pkt->u.raw,
694 sizeof(struct il_rx_phy_res)); 694 sizeof(struct il_rx_phy_res));
695} 695}
696 696
697static int il4965_get_channels_for_scan(struct il_priv *priv, 697static int il4965_get_channels_for_scan(struct il_priv *il,
698 struct ieee80211_vif *vif, 698 struct ieee80211_vif *vif,
699 enum ieee80211_band band, 699 enum ieee80211_band band,
700 u8 is_active, u8 n_probes, 700 u8 is_active, u8 n_probes,
@@ -708,18 +708,18 @@ static int il4965_get_channels_for_scan(struct il_priv *priv,
708 int added, i; 708 int added, i;
709 u16 channel; 709 u16 channel;
710 710
711 sband = il_get_hw_mode(priv, band); 711 sband = il_get_hw_mode(il, band);
712 if (!sband) 712 if (!sband)
713 return 0; 713 return 0;
714 714
715 active_dwell = il_get_active_dwell_time(priv, band, n_probes); 715 active_dwell = il_get_active_dwell_time(il, band, n_probes);
716 passive_dwell = il_get_passive_dwell_time(priv, band, vif); 716 passive_dwell = il_get_passive_dwell_time(il, band, vif);
717 717
718 if (passive_dwell <= active_dwell) 718 if (passive_dwell <= active_dwell)
719 passive_dwell = active_dwell + 1; 719 passive_dwell = active_dwell + 1;
720 720
721 for (i = 0, added = 0; i < priv->scan_request->n_channels; i++) { 721 for (i = 0, added = 0; i < il->scan_request->n_channels; i++) {
722 chan = priv->scan_request->channels[i]; 722 chan = il->scan_request->channels[i];
723 723
724 if (chan->band != band) 724 if (chan->band != band)
725 continue; 725 continue;
@@ -727,9 +727,9 @@ static int il4965_get_channels_for_scan(struct il_priv *priv,
727 channel = chan->hw_value; 727 channel = chan->hw_value;
728 scan_ch->channel = cpu_to_le16(channel); 728 scan_ch->channel = cpu_to_le16(channel);
729 729
730 ch_info = il_get_channel_info(priv, band, channel); 730 ch_info = il_get_channel_info(il, band, channel);
731 if (!il_is_channel_valid(ch_info)) { 731 if (!il_is_channel_valid(ch_info)) {
732 IL_DEBUG_SCAN(priv, 732 IL_DEBUG_SCAN(il,
733 "Channel %d is INVALID for this band.\n", 733 "Channel %d is INVALID for this band.\n",
734 channel); 734 channel);
735 continue; 735 continue;
@@ -759,7 +759,7 @@ static int il4965_get_channels_for_scan(struct il_priv *priv,
759 else 759 else
760 scan_ch->tx_gain = ((1 << 5) | (5 << 3)); 760 scan_ch->tx_gain = ((1 << 5) | (5 << 3));
761 761
762 IL_DEBUG_SCAN(priv, "Scanning ch=%d prob=0x%X [%s %d]\n", 762 IL_DEBUG_SCAN(il, "Scanning ch=%d prob=0x%X [%s %d]\n",
763 channel, le32_to_cpu(scan_ch->type), 763 channel, le32_to_cpu(scan_ch->type),
764 (scan_ch->type & SCAN_CHANNEL_TYPE_ACTIVE) ? 764 (scan_ch->type & SCAN_CHANNEL_TYPE_ACTIVE) ?
765 "ACTIVE" : "PASSIVE", 765 "ACTIVE" : "PASSIVE",
@@ -770,11 +770,11 @@ static int il4965_get_channels_for_scan(struct il_priv *priv,
770 added++; 770 added++;
771 } 771 }
772 772
773 IL_DEBUG_SCAN(priv, "total channels to scan %d\n", added); 773 IL_DEBUG_SCAN(il, "total channels to scan %d\n", added);
774 return added; 774 return added;
775} 775}
776 776
777int il4965_request_scan(struct il_priv *priv, struct ieee80211_vif *vif) 777int il4965_request_scan(struct il_priv *il, struct ieee80211_vif *vif)
778{ 778{
779 struct il_host_cmd cmd = { 779 struct il_host_cmd cmd = {
780 .id = REPLY_SCAN_CMD, 780 .id = REPLY_SCAN_CMD,
@@ -782,47 +782,47 @@ int il4965_request_scan(struct il_priv *priv, struct ieee80211_vif *vif)
782 .flags = CMD_SIZE_HUGE, 782 .flags = CMD_SIZE_HUGE,
783 }; 783 };
784 struct il_scan_cmd *scan; 784 struct il_scan_cmd *scan;
785 struct il_rxon_context *ctx = &priv->contexts[IL_RXON_CTX_BSS]; 785 struct il_rxon_context *ctx = &il->contexts[IL_RXON_CTX_BSS];
786 u32 rate_flags = 0; 786 u32 rate_flags = 0;
787 u16 cmd_len; 787 u16 cmd_len;
788 u16 rx_chain = 0; 788 u16 rx_chain = 0;
789 enum ieee80211_band band; 789 enum ieee80211_band band;
790 u8 n_probes = 0; 790 u8 n_probes = 0;
791 u8 rx_ant = priv->hw_params.valid_rx_ant; 791 u8 rx_ant = il->hw_params.valid_rx_ant;
792 u8 rate; 792 u8 rate;
793 bool is_active = false; 793 bool is_active = false;
794 int chan_mod; 794 int chan_mod;
795 u8 active_chains; 795 u8 active_chains;
796 u8 scan_tx_antennas = priv->hw_params.valid_tx_ant; 796 u8 scan_tx_antennas = il->hw_params.valid_tx_ant;
797 int ret; 797 int ret;
798 798
799 lockdep_assert_held(&priv->mutex); 799 lockdep_assert_held(&il->mutex);
800 800
801 if (vif) 801 if (vif)
802 ctx = il_rxon_ctx_from_vif(vif); 802 ctx = il_rxon_ctx_from_vif(vif);
803 803
804 if (!priv->scan_cmd) { 804 if (!il->scan_cmd) {
805 priv->scan_cmd = kmalloc(sizeof(struct il_scan_cmd) + 805 il->scan_cmd = kmalloc(sizeof(struct il_scan_cmd) +
806 IL_MAX_SCAN_SIZE, GFP_KERNEL); 806 IL_MAX_SCAN_SIZE, GFP_KERNEL);
807 if (!priv->scan_cmd) { 807 if (!il->scan_cmd) {
808 IL_DEBUG_SCAN(priv, 808 IL_DEBUG_SCAN(il,
809 "fail to allocate memory for scan\n"); 809 "fail to allocate memory for scan\n");
810 return -ENOMEM; 810 return -ENOMEM;
811 } 811 }
812 } 812 }
813 scan = priv->scan_cmd; 813 scan = il->scan_cmd;
814 memset(scan, 0, sizeof(struct il_scan_cmd) + IL_MAX_SCAN_SIZE); 814 memset(scan, 0, sizeof(struct il_scan_cmd) + IL_MAX_SCAN_SIZE);
815 815
816 scan->quiet_plcp_th = IL_PLCP_QUIET_THRESH; 816 scan->quiet_plcp_th = IL_PLCP_QUIET_THRESH;
817 scan->quiet_time = IL_ACTIVE_QUIET_TIME; 817 scan->quiet_time = IL_ACTIVE_QUIET_TIME;
818 818
819 if (il_is_any_associated(priv)) { 819 if (il_is_any_associated(il)) {
820 u16 interval; 820 u16 interval;
821 u32 extra; 821 u32 extra;
822 u32 suspend_time = 100; 822 u32 suspend_time = 100;
823 u32 scan_suspend_time = 100; 823 u32 scan_suspend_time = 100;
824 824
825 IL_DEBUG_INFO(priv, "Scanning while associated...\n"); 825 IL_DEBUG_INFO(il, "Scanning while associated...\n");
826 interval = vif->bss_conf.beacon_int; 826 interval = vif->bss_conf.beacon_int;
827 827
828 scan->suspend_time = 0; 828 scan->suspend_time = 0;
@@ -834,39 +834,39 @@ int il4965_request_scan(struct il_priv *priv, struct ieee80211_vif *vif)
834 scan_suspend_time = (extra | 834 scan_suspend_time = (extra |
835 ((suspend_time % interval) * 1024)); 835 ((suspend_time % interval) * 1024));
836 scan->suspend_time = cpu_to_le32(scan_suspend_time); 836 scan->suspend_time = cpu_to_le32(scan_suspend_time);
837 IL_DEBUG_SCAN(priv, "suspend_time 0x%X beacon interval %d\n", 837 IL_DEBUG_SCAN(il, "suspend_time 0x%X beacon interval %d\n",
838 scan_suspend_time, interval); 838 scan_suspend_time, interval);
839 } 839 }
840 840
841 if (priv->scan_request->n_ssids) { 841 if (il->scan_request->n_ssids) {
842 int i, p = 0; 842 int i, p = 0;
843 IL_DEBUG_SCAN(priv, "Kicking off active scan\n"); 843 IL_DEBUG_SCAN(il, "Kicking off active scan\n");
844 for (i = 0; i < priv->scan_request->n_ssids; i++) { 844 for (i = 0; i < il->scan_request->n_ssids; i++) {
845 /* always does wildcard anyway */ 845 /* always does wildcard anyway */
846 if (!priv->scan_request->ssids[i].ssid_len) 846 if (!il->scan_request->ssids[i].ssid_len)
847 continue; 847 continue;
848 scan->direct_scan[p].id = WLAN_EID_SSID; 848 scan->direct_scan[p].id = WLAN_EID_SSID;
849 scan->direct_scan[p].len = 849 scan->direct_scan[p].len =
850 priv->scan_request->ssids[i].ssid_len; 850 il->scan_request->ssids[i].ssid_len;
851 memcpy(scan->direct_scan[p].ssid, 851 memcpy(scan->direct_scan[p].ssid,
852 priv->scan_request->ssids[i].ssid, 852 il->scan_request->ssids[i].ssid,
853 priv->scan_request->ssids[i].ssid_len); 853 il->scan_request->ssids[i].ssid_len);
854 n_probes++; 854 n_probes++;
855 p++; 855 p++;
856 } 856 }
857 is_active = true; 857 is_active = true;
858 } else 858 } else
859 IL_DEBUG_SCAN(priv, "Start passive scan.\n"); 859 IL_DEBUG_SCAN(il, "Start passive scan.\n");
860 860
861 scan->tx_cmd.tx_flags = TX_CMD_FLG_SEQ_CTL_MSK; 861 scan->tx_cmd.tx_flags = TX_CMD_FLG_SEQ_CTL_MSK;
862 scan->tx_cmd.sta_id = ctx->bcast_sta_id; 862 scan->tx_cmd.sta_id = ctx->bcast_sta_id;
863 scan->tx_cmd.stop_time.life_time = TX_CMD_LIFE_TIME_INFINITE; 863 scan->tx_cmd.stop_time.life_time = TX_CMD_LIFE_TIME_INFINITE;
864 864
865 switch (priv->scan_band) { 865 switch (il->scan_band) {
866 case IEEE80211_BAND_2GHZ: 866 case IEEE80211_BAND_2GHZ:
867 scan->flags = RXON_FLG_BAND_24G_MSK | RXON_FLG_AUTO_DETECT_MSK; 867 scan->flags = RXON_FLG_BAND_24G_MSK | RXON_FLG_AUTO_DETECT_MSK;
868 chan_mod = le32_to_cpu( 868 chan_mod = le32_to_cpu(
869 priv->contexts[IL_RXON_CTX_BSS].active.flags & 869 il->contexts[IL_RXON_CTX_BSS].active.flags &
870 RXON_FLG_CHANNEL_MODE_MSK) 870 RXON_FLG_CHANNEL_MODE_MSK)
871 >> RXON_FLG_CHANNEL_MODE_POS; 871 >> RXON_FLG_CHANNEL_MODE_POS;
872 if (chan_mod == CHANNEL_MODE_PURE_40) { 872 if (chan_mod == CHANNEL_MODE_PURE_40) {
@@ -880,7 +880,7 @@ int il4965_request_scan(struct il_priv *priv, struct ieee80211_vif *vif)
880 rate = IL_RATE_6M_PLCP; 880 rate = IL_RATE_6M_PLCP;
881 break; 881 break;
882 default: 882 default:
883 IL_WARN(priv, "Invalid scan band\n"); 883 IL_WARN(il, "Invalid scan band\n");
884 return -EIO; 884 return -EIO;
885 } 885 }
886 886
@@ -904,54 +904,54 @@ int il4965_request_scan(struct il_priv *priv, struct ieee80211_vif *vif)
904 scan->good_CRC_th = is_active ? IL_GOOD_CRC_TH_DEFAULT : 904 scan->good_CRC_th = is_active ? IL_GOOD_CRC_TH_DEFAULT :
905 IL_GOOD_CRC_TH_NEVER; 905 IL_GOOD_CRC_TH_NEVER;
906 906
907 band = priv->scan_band; 907 band = il->scan_band;
908 908
909 if (priv->cfg->scan_rx_antennas[band]) 909 if (il->cfg->scan_rx_antennas[band])
910 rx_ant = priv->cfg->scan_rx_antennas[band]; 910 rx_ant = il->cfg->scan_rx_antennas[band];
911 911
912 priv->scan_tx_ant[band] = il4965_toggle_tx_ant(priv, 912 il->scan_tx_ant[band] = il4965_toggle_tx_ant(il,
913 priv->scan_tx_ant[band], 913 il->scan_tx_ant[band],
914 scan_tx_antennas); 914 scan_tx_antennas);
915 rate_flags |= il4965_ant_idx_to_flags(priv->scan_tx_ant[band]); 915 rate_flags |= il4965_ant_idx_to_flags(il->scan_tx_ant[band]);
916 scan->tx_cmd.rate_n_flags = il4965_hw_set_rate_n_flags(rate, rate_flags); 916 scan->tx_cmd.rate_n_flags = il4965_hw_set_rate_n_flags(rate, rate_flags);
917 917
918 /* In power save mode use one chain, otherwise use all chains */ 918 /* In power save mode use one chain, otherwise use all chains */
919 if (test_bit(STATUS_POWER_PMI, &priv->status)) { 919 if (test_bit(STATUS_POWER_PMI, &il->status)) {
920 /* rx_ant has been set to all valid chains previously */ 920 /* rx_ant has been set to all valid chains previously */
921 active_chains = rx_ant & 921 active_chains = rx_ant &
922 ((u8)(priv->chain_noise_data.active_chains)); 922 ((u8)(il->chain_noise_data.active_chains));
923 if (!active_chains) 923 if (!active_chains)
924 active_chains = rx_ant; 924 active_chains = rx_ant;
925 925
926 IL_DEBUG_SCAN(priv, "chain_noise_data.active_chains: %u\n", 926 IL_DEBUG_SCAN(il, "chain_noise_data.active_chains: %u\n",
927 priv->chain_noise_data.active_chains); 927 il->chain_noise_data.active_chains);
928 928
929 rx_ant = il4965_first_antenna(active_chains); 929 rx_ant = il4965_first_antenna(active_chains);
930 } 930 }
931 931
932 /* MIMO is not used here, but value is required */ 932 /* MIMO is not used here, but value is required */
933 rx_chain |= priv->hw_params.valid_rx_ant << RXON_RX_CHAIN_VALID_POS; 933 rx_chain |= il->hw_params.valid_rx_ant << RXON_RX_CHAIN_VALID_POS;
934 rx_chain |= rx_ant << RXON_RX_CHAIN_FORCE_MIMO_SEL_POS; 934 rx_chain |= rx_ant << RXON_RX_CHAIN_FORCE_MIMO_SEL_POS;
935 rx_chain |= rx_ant << RXON_RX_CHAIN_FORCE_SEL_POS; 935 rx_chain |= rx_ant << RXON_RX_CHAIN_FORCE_SEL_POS;
936 rx_chain |= 0x1 << RXON_RX_CHAIN_DRIVER_FORCE_POS; 936 rx_chain |= 0x1 << RXON_RX_CHAIN_DRIVER_FORCE_POS;
937 scan->rx_chain = cpu_to_le16(rx_chain); 937 scan->rx_chain = cpu_to_le16(rx_chain);
938 938
939 cmd_len = il_fill_probe_req(priv, 939 cmd_len = il_fill_probe_req(il,
940 (struct ieee80211_mgmt *)scan->data, 940 (struct ieee80211_mgmt *)scan->data,
941 vif->addr, 941 vif->addr,
942 priv->scan_request->ie, 942 il->scan_request->ie,
943 priv->scan_request->ie_len, 943 il->scan_request->ie_len,
944 IL_MAX_SCAN_SIZE - sizeof(*scan)); 944 IL_MAX_SCAN_SIZE - sizeof(*scan));
945 scan->tx_cmd.len = cpu_to_le16(cmd_len); 945 scan->tx_cmd.len = cpu_to_le16(cmd_len);
946 946
947 scan->filter_flags |= (RXON_FILTER_ACCEPT_GRP_MSK | 947 scan->filter_flags |= (RXON_FILTER_ACCEPT_GRP_MSK |
948 RXON_FILTER_BCON_AWARE_MSK); 948 RXON_FILTER_BCON_AWARE_MSK);
949 949
950 scan->channel_count = il4965_get_channels_for_scan(priv, vif, band, 950 scan->channel_count = il4965_get_channels_for_scan(il, vif, band,
951 is_active, n_probes, 951 is_active, n_probes,
952 (void *)&scan->data[cmd_len]); 952 (void *)&scan->data[cmd_len]);
953 if (scan->channel_count == 0) { 953 if (scan->channel_count == 0) {
954 IL_DEBUG_SCAN(priv, "channel count %d\n", scan->channel_count); 954 IL_DEBUG_SCAN(il, "channel count %d\n", scan->channel_count);
955 return -EIO; 955 return -EIO;
956 } 956 }
957 957
@@ -960,49 +960,49 @@ int il4965_request_scan(struct il_priv *priv, struct ieee80211_vif *vif)
960 cmd.data = scan; 960 cmd.data = scan;
961 scan->len = cpu_to_le16(cmd.len); 961 scan->len = cpu_to_le16(cmd.len);
962 962
963 set_bit(STATUS_SCAN_HW, &priv->status); 963 set_bit(STATUS_SCAN_HW, &il->status);
964 964
965 ret = il_send_cmd_sync(priv, &cmd); 965 ret = il_send_cmd_sync(il, &cmd);
966 if (ret) 966 if (ret)
967 clear_bit(STATUS_SCAN_HW, &priv->status); 967 clear_bit(STATUS_SCAN_HW, &il->status);
968 968
969 return ret; 969 return ret;
970} 970}
971 971
972int il4965_manage_ibss_station(struct il_priv *priv, 972int il4965_manage_ibss_station(struct il_priv *il,
973 struct ieee80211_vif *vif, bool add) 973 struct ieee80211_vif *vif, bool add)
974{ 974{
975 struct il_vif_priv *vif_priv = (void *)vif->drv_priv; 975 struct il_vif_priv *vif_priv = (void *)vif->drv_priv;
976 976
977 if (add) 977 if (add)
978 return il4965_add_bssid_station(priv, vif_priv->ctx, 978 return il4965_add_bssid_station(il, vif_priv->ctx,
979 vif->bss_conf.bssid, 979 vif->bss_conf.bssid,
980 &vif_priv->ibss_bssid_sta_id); 980 &vif_priv->ibss_bssid_sta_id);
981 return il_remove_station(priv, vif_priv->ibss_bssid_sta_id, 981 return il_remove_station(il, vif_priv->ibss_bssid_sta_id,
982 vif->bss_conf.bssid); 982 vif->bss_conf.bssid);
983} 983}
984 984
985void il4965_free_tfds_in_queue(struct il_priv *priv, 985void il4965_free_tfds_in_queue(struct il_priv *il,
986 int sta_id, int tid, int freed) 986 int sta_id, int tid, int freed)
987{ 987{
988 lockdep_assert_held(&priv->sta_lock); 988 lockdep_assert_held(&il->sta_lock);
989 989
990 if (priv->stations[sta_id].tid[tid].tfds_in_queue >= freed) 990 if (il->stations[sta_id].tid[tid].tfds_in_queue >= freed)
991 priv->stations[sta_id].tid[tid].tfds_in_queue -= freed; 991 il->stations[sta_id].tid[tid].tfds_in_queue -= freed;
992 else { 992 else {
993 IL_DEBUG_TX(priv, "free more than tfds_in_queue (%u:%d)\n", 993 IL_DEBUG_TX(il, "free more than tfds_in_queue (%u:%d)\n",
994 priv->stations[sta_id].tid[tid].tfds_in_queue, 994 il->stations[sta_id].tid[tid].tfds_in_queue,
995 freed); 995 freed);
996 priv->stations[sta_id].tid[tid].tfds_in_queue = 0; 996 il->stations[sta_id].tid[tid].tfds_in_queue = 0;
997 } 997 }
998} 998}
999 999
1000#define IL_TX_QUEUE_MSK 0xfffff 1000#define IL_TX_QUEUE_MSK 0xfffff
1001 1001
1002static bool il4965_is_single_rx_stream(struct il_priv *priv) 1002static bool il4965_is_single_rx_stream(struct il_priv *il)
1003{ 1003{
1004 return priv->current_ht_config.smps == IEEE80211_SMPS_STATIC || 1004 return il->current_ht_config.smps == IEEE80211_SMPS_STATIC ||
1005 priv->current_ht_config.single_chain_sufficient; 1005 il->current_ht_config.single_chain_sufficient;
1006} 1006}
1007 1007
1008#define IL_NUM_RX_CHAINS_MULTIPLE 3 1008#define IL_NUM_RX_CHAINS_MULTIPLE 3
@@ -1020,10 +1020,10 @@ static bool il4965_is_single_rx_stream(struct il_priv *priv)
1020 * MIMO (dual stream) requires at least 2, but works better with 3. 1020 * MIMO (dual stream) requires at least 2, but works better with 3.
1021 * This does not determine *which* chains to use, just how many. 1021 * This does not determine *which* chains to use, just how many.
1022 */ 1022 */
1023static int il4965_get_active_rx_chain_count(struct il_priv *priv) 1023static int il4965_get_active_rx_chain_count(struct il_priv *il)
1024{ 1024{
1025 /* # of Rx chains to use when expecting MIMO. */ 1025 /* # of Rx chains to use when expecting MIMO. */
1026 if (il4965_is_single_rx_stream(priv)) 1026 if (il4965_is_single_rx_stream(il))
1027 return IL_NUM_RX_CHAINS_SINGLE; 1027 return IL_NUM_RX_CHAINS_SINGLE;
1028 else 1028 else
1029 return IL_NUM_RX_CHAINS_MULTIPLE; 1029 return IL_NUM_RX_CHAINS_MULTIPLE;
@@ -1034,10 +1034,10 @@ static int il4965_get_active_rx_chain_count(struct il_priv *priv)
1034 * multiplexing power save, use the active count for rx chain count. 1034 * multiplexing power save, use the active count for rx chain count.
1035 */ 1035 */
1036static int 1036static int
1037il4965_get_idle_rx_chain_count(struct il_priv *priv, int active_cnt) 1037il4965_get_idle_rx_chain_count(struct il_priv *il, int active_cnt)
1038{ 1038{
1039 /* # Rx chains when idling, depending on SMPS mode */ 1039 /* # Rx chains when idling, depending on SMPS mode */
1040 switch (priv->current_ht_config.smps) { 1040 switch (il->current_ht_config.smps) {
1041 case IEEE80211_SMPS_STATIC: 1041 case IEEE80211_SMPS_STATIC:
1042 case IEEE80211_SMPS_DYNAMIC: 1042 case IEEE80211_SMPS_DYNAMIC:
1043 return IL_NUM_IDLE_CHAINS_SINGLE; 1043 return IL_NUM_IDLE_CHAINS_SINGLE;
@@ -1045,7 +1045,7 @@ il4965_get_idle_rx_chain_count(struct il_priv *priv, int active_cnt)
1045 return active_cnt; 1045 return active_cnt;
1046 default: 1046 default:
1047 WARN(1, "invalid SMPS mode %d", 1047 WARN(1, "invalid SMPS mode %d",
1048 priv->current_ht_config.smps); 1048 il->current_ht_config.smps);
1049 return active_cnt; 1049 return active_cnt;
1050 } 1050 }
1051} 1051}
@@ -1067,10 +1067,10 @@ static u8 il4965_count_chain_bitmap(u32 chain_bitmap)
1067 * Selects how many and which Rx receivers/antennas/chains to use. 1067 * Selects how many and which Rx receivers/antennas/chains to use.
1068 * This should not be used for scan command ... it puts data in wrong place. 1068 * This should not be used for scan command ... it puts data in wrong place.
1069 */ 1069 */
1070void il4965_set_rxon_chain(struct il_priv *priv, struct il_rxon_context *ctx) 1070void il4965_set_rxon_chain(struct il_priv *il, struct il_rxon_context *ctx)
1071{ 1071{
1072 bool is_single = il4965_is_single_rx_stream(priv); 1072 bool is_single = il4965_is_single_rx_stream(il);
1073 bool is_cam = !test_bit(STATUS_POWER_PMI, &priv->status); 1073 bool is_cam = !test_bit(STATUS_POWER_PMI, &il->status);
1074 u8 idle_rx_cnt, active_rx_cnt, valid_rx_cnt; 1074 u8 idle_rx_cnt, active_rx_cnt, valid_rx_cnt;
1075 u32 active_chains; 1075 u32 active_chains;
1076 u16 rx_chain; 1076 u16 rx_chain;
@@ -1079,16 +1079,16 @@ void il4965_set_rxon_chain(struct il_priv *priv, struct il_rxon_context *ctx)
1079 * Before first association, we assume all antennas are connected. 1079 * Before first association, we assume all antennas are connected.
1080 * Just after first association, il4965_chain_noise_calibration() 1080 * Just after first association, il4965_chain_noise_calibration()
1081 * checks which antennas actually *are* connected. */ 1081 * checks which antennas actually *are* connected. */
1082 if (priv->chain_noise_data.active_chains) 1082 if (il->chain_noise_data.active_chains)
1083 active_chains = priv->chain_noise_data.active_chains; 1083 active_chains = il->chain_noise_data.active_chains;
1084 else 1084 else
1085 active_chains = priv->hw_params.valid_rx_ant; 1085 active_chains = il->hw_params.valid_rx_ant;
1086 1086
1087 rx_chain = active_chains << RXON_RX_CHAIN_VALID_POS; 1087 rx_chain = active_chains << RXON_RX_CHAIN_VALID_POS;
1088 1088
1089 /* How many receivers should we use? */ 1089 /* How many receivers should we use? */
1090 active_rx_cnt = il4965_get_active_rx_chain_count(priv); 1090 active_rx_cnt = il4965_get_active_rx_chain_count(il);
1091 idle_rx_cnt = il4965_get_idle_rx_chain_count(priv, active_rx_cnt); 1091 idle_rx_cnt = il4965_get_idle_rx_chain_count(il, active_rx_cnt);
1092 1092
1093 1093
1094 /* correct rx chain count according hw settings 1094 /* correct rx chain count according hw settings
@@ -1111,7 +1111,7 @@ void il4965_set_rxon_chain(struct il_priv *priv, struct il_rxon_context *ctx)
1111 else 1111 else
1112 ctx->staging.rx_chain &= ~RXON_RX_CHAIN_MIMO_FORCE_MSK; 1112 ctx->staging.rx_chain &= ~RXON_RX_CHAIN_MIMO_FORCE_MSK;
1113 1113
1114 IL_DEBUG_ASSOC(priv, "rx_chain=0x%X active=%d idle=%d\n", 1114 IL_DEBUG_ASSOC(il, "rx_chain=0x%X active=%d idle=%d\n",
1115 ctx->staging.rx_chain, 1115 ctx->staging.rx_chain,
1116 active_rx_cnt, idle_rx_cnt); 1116 active_rx_cnt, idle_rx_cnt);
1117 1117
@@ -1119,7 +1119,7 @@ void il4965_set_rxon_chain(struct il_priv *priv, struct il_rxon_context *ctx)
1119 active_rx_cnt < idle_rx_cnt); 1119 active_rx_cnt < idle_rx_cnt);
1120} 1120}
1121 1121
1122u8 il4965_toggle_tx_ant(struct il_priv *priv, u8 ant, u8 valid) 1122u8 il4965_toggle_tx_ant(struct il_priv *il, u8 ant, u8 valid)
1123{ 1123{
1124 int i; 1124 int i;
1125 u8 ind = ant; 1125 u8 ind = ant;
@@ -1149,7 +1149,7 @@ static const char *il4965_get_fh_string(int cmd)
1149 } 1149 }
1150} 1150}
1151 1151
1152int il4965_dump_fh(struct il_priv *priv, char **buf, bool display) 1152int il4965_dump_fh(struct il_priv *il, char **buf, bool display)
1153{ 1153{
1154 int i; 1154 int i;
1155#ifdef CONFIG_IWLWIFI_LEGACY_DEBUG 1155#ifdef CONFIG_IWLWIFI_LEGACY_DEBUG
@@ -1179,16 +1179,16 @@ int il4965_dump_fh(struct il_priv *priv, char **buf, bool display)
1179 pos += scnprintf(*buf + pos, bufsz - pos, 1179 pos += scnprintf(*buf + pos, bufsz - pos,
1180 " %34s: 0X%08x\n", 1180 " %34s: 0X%08x\n",
1181 il4965_get_fh_string(fh_tbl[i]), 1181 il4965_get_fh_string(fh_tbl[i]),
1182 il_read_direct32(priv, fh_tbl[i])); 1182 il_read_direct32(il, fh_tbl[i]));
1183 } 1183 }
1184 return pos; 1184 return pos;
1185 } 1185 }
1186#endif 1186#endif
1187 IL_ERR(priv, "FH register values:\n"); 1187 IL_ERR(il, "FH register values:\n");
1188 for (i = 0; i < ARRAY_SIZE(fh_tbl); i++) { 1188 for (i = 0; i < ARRAY_SIZE(fh_tbl); i++) {
1189 IL_ERR(priv, " %34s: 0X%08x\n", 1189 IL_ERR(il, " %34s: 0X%08x\n",
1190 il4965_get_fh_string(fh_tbl[i]), 1190 il4965_get_fh_string(fh_tbl[i]),
1191 il_read_direct32(priv, fh_tbl[i])); 1191 il_read_direct32(il, fh_tbl[i]));
1192 } 1192 }
1193 return 0; 1193 return 0;
1194} 1194}
diff --git a/drivers/net/wireless/iwlegacy/iwl-4965-rs.c b/drivers/net/wireless/iwlegacy/iwl-4965-rs.c
index a7298f5997a2..e53ed1a5d5db 100644
--- a/drivers/net/wireless/iwlegacy/iwl-4965-rs.c
+++ b/drivers/net/wireless/iwlegacy/iwl-4965-rs.c
@@ -140,11 +140,11 @@ static int il4965_hwrate_to_plcp_idx(u32 rate_n_flags)
140 return -1; 140 return -1;
141} 141}
142 142
143static void il4965_rs_rate_scale_perform(struct il_priv *priv, 143static void il4965_rs_rate_scale_perform(struct il_priv *il,
144 struct sk_buff *skb, 144 struct sk_buff *skb,
145 struct ieee80211_sta *sta, 145 struct ieee80211_sta *sta,
146 struct il_lq_sta *lq_sta); 146 struct il_lq_sta *lq_sta);
147static void il4965_rs_fill_link_cmd(struct il_priv *priv, 147static void il4965_rs_fill_link_cmd(struct il_priv *il,
148 struct il_lq_sta *lq_sta, u32 rate_n_flags); 148 struct il_lq_sta *lq_sta, u32 rate_n_flags);
149static void il4965_rs_stay_in_table(struct il_lq_sta *lq_sta, 149static void il4965_rs_stay_in_table(struct il_lq_sta *lq_sta,
150 bool force_search); 150 bool force_search);
@@ -348,7 +348,7 @@ static u32 il4965_rs_tl_get_load(struct il_lq_sta *lq_data, u8 tid)
348 return tl->total; 348 return tl->total;
349} 349}
350 350
351static int il4965_rs_tl_turn_on_agg_for_tid(struct il_priv *priv, 351static int il4965_rs_tl_turn_on_agg_for_tid(struct il_priv *il,
352 struct il_lq_sta *lq_data, u8 tid, 352 struct il_lq_sta *lq_data, u8 tid,
353 struct ieee80211_sta *sta) 353 struct ieee80211_sta *sta)
354{ 354{
@@ -358,7 +358,7 @@ static int il4965_rs_tl_turn_on_agg_for_tid(struct il_priv *priv,
358 load = il4965_rs_tl_get_load(lq_data, tid); 358 load = il4965_rs_tl_get_load(lq_data, tid);
359 359
360 if (load > IL_AGG_LOAD_THRESHOLD) { 360 if (load > IL_AGG_LOAD_THRESHOLD) {
361 IL_DEBUG_HT(priv, "Starting Tx agg: STA: %pM tid: %d\n", 361 IL_DEBUG_HT(il, "Starting Tx agg: STA: %pM tid: %d\n",
362 sta->addr, tid); 362 sta->addr, tid);
363 ret = ieee80211_start_tx_ba_session(sta, tid, 5000); 363 ret = ieee80211_start_tx_ba_session(sta, tid, 5000);
364 if (ret == -EAGAIN) { 364 if (ret == -EAGAIN) {
@@ -367,25 +367,25 @@ static int il4965_rs_tl_turn_on_agg_for_tid(struct il_priv *priv,
367 * this might be cause by reloading firmware 367 * this might be cause by reloading firmware
368 * stop the tx ba session here 368 * stop the tx ba session here
369 */ 369 */
370 IL_ERR(priv, "Fail start Tx agg on tid: %d\n", 370 IL_ERR(il, "Fail start Tx agg on tid: %d\n",
371 tid); 371 tid);
372 ieee80211_stop_tx_ba_session(sta, tid); 372 ieee80211_stop_tx_ba_session(sta, tid);
373 } 373 }
374 } else { 374 } else {
375 IL_ERR(priv, "Aggregation not enabled for tid %d " 375 IL_ERR(il, "Aggregation not enabled for tid %d "
376 "because load = %u\n", tid, load); 376 "because load = %u\n", tid, load);
377 } 377 }
378 return ret; 378 return ret;
379} 379}
380 380
381static void il4965_rs_tl_turn_on_agg(struct il_priv *priv, u8 tid, 381static void il4965_rs_tl_turn_on_agg(struct il_priv *il, u8 tid,
382 struct il_lq_sta *lq_data, 382 struct il_lq_sta *lq_data,
383 struct ieee80211_sta *sta) 383 struct ieee80211_sta *sta)
384{ 384{
385 if (tid < TID_MAX_LOAD_COUNT) 385 if (tid < TID_MAX_LOAD_COUNT)
386 il4965_rs_tl_turn_on_agg_for_tid(priv, lq_data, tid, sta); 386 il4965_rs_tl_turn_on_agg_for_tid(il, lq_data, tid, sta);
387 else 387 else
388 IL_ERR(priv, "tid exceeds max load count: %d/%d\n", 388 IL_ERR(il, "tid exceeds max load count: %d/%d\n",
389 tid, TID_MAX_LOAD_COUNT); 389 tid, TID_MAX_LOAD_COUNT);
390} 390}
391 391
@@ -492,7 +492,7 @@ static int il4965_rs_collect_tx_data(struct il_scale_tbl_info *tbl,
492/* 492/*
493 * Fill uCode API rate_n_flags field, based on "search" or "active" table. 493 * Fill uCode API rate_n_flags field, based on "search" or "active" table.
494 */ 494 */
495static u32 il4965_rate_n_flags_from_tbl(struct il_priv *priv, 495static u32 il4965_rate_n_flags_from_tbl(struct il_priv *il,
496 struct il_scale_tbl_info *tbl, 496 struct il_scale_tbl_info *tbl,
497 int index, u8 use_green) 497 int index, u8 use_green)
498{ 498{
@@ -505,7 +505,7 @@ static u32 il4965_rate_n_flags_from_tbl(struct il_priv *priv,
505 505
506 } else if (is_Ht(tbl->lq_type)) { 506 } else if (is_Ht(tbl->lq_type)) {
507 if (index > IL_LAST_OFDM_RATE) { 507 if (index > IL_LAST_OFDM_RATE) {
508 IL_ERR(priv, "Invalid HT rate index %d\n", index); 508 IL_ERR(il, "Invalid HT rate index %d\n", index);
509 index = IL_LAST_OFDM_RATE; 509 index = IL_LAST_OFDM_RATE;
510 } 510 }
511 rate_n_flags = RATE_MCS_HT_MSK; 511 rate_n_flags = RATE_MCS_HT_MSK;
@@ -515,7 +515,7 @@ static u32 il4965_rate_n_flags_from_tbl(struct il_priv *priv,
515 else 515 else
516 rate_n_flags |= iwlegacy_rates[index].plcp_mimo2; 516 rate_n_flags |= iwlegacy_rates[index].plcp_mimo2;
517 } else { 517 } else {
518 IL_ERR(priv, "Invalid tbl->lq_type %d\n", tbl->lq_type); 518 IL_ERR(il, "Invalid tbl->lq_type %d\n", tbl->lq_type);
519 } 519 }
520 520
521 rate_n_flags |= ((tbl->ant_type << RATE_MCS_ANT_POS) & 521 rate_n_flags |= ((tbl->ant_type << RATE_MCS_ANT_POS) &
@@ -535,7 +535,7 @@ static u32 il4965_rate_n_flags_from_tbl(struct il_priv *priv,
535 rate_n_flags |= RATE_MCS_GF_MSK; 535 rate_n_flags |= RATE_MCS_GF_MSK;
536 if (is_siso(tbl->lq_type) && tbl->is_SGI) { 536 if (is_siso(tbl->lq_type) && tbl->is_SGI) {
537 rate_n_flags &= ~RATE_MCS_SGI_MSK; 537 rate_n_flags &= ~RATE_MCS_SGI_MSK;
538 IL_ERR(priv, "GF was set with SGI:SISO\n"); 538 IL_ERR(il, "GF was set with SGI:SISO\n");
539 } 539 }
540 } 540 }
541 } 541 }
@@ -667,7 +667,7 @@ static u16 il4965_rs_get_supported_rates(struct il_lq_sta *lq_sta,
667} 667}
668 668
669static u16 669static u16
670il4965_rs_get_adjacent_rate(struct il_priv *priv, u8 index, u16 rate_mask, 670il4965_rs_get_adjacent_rate(struct il_priv *il, u8 index, u16 rate_mask,
671 int rate_type) 671 int rate_type)
672{ 672{
673 u8 high = IL_RATE_INVALID; 673 u8 high = IL_RATE_INVALID;
@@ -707,7 +707,7 @@ il4965_rs_get_adjacent_rate(struct il_priv *priv, u8 index, u16 rate_mask,
707 break; 707 break;
708 if (rate_mask & (1 << low)) 708 if (rate_mask & (1 << low))
709 break; 709 break;
710 IL_DEBUG_RATE(priv, "Skipping masked lower rate: %d\n", low); 710 IL_DEBUG_RATE(il, "Skipping masked lower rate: %d\n", low);
711 } 711 }
712 712
713 high = index; 713 high = index;
@@ -717,7 +717,7 @@ il4965_rs_get_adjacent_rate(struct il_priv *priv, u8 index, u16 rate_mask,
717 break; 717 break;
718 if (rate_mask & (1 << high)) 718 if (rate_mask & (1 << high))
719 break; 719 break;
720 IL_DEBUG_RATE(priv, "Skipping masked higher rate: %d\n", high); 720 IL_DEBUG_RATE(il, "Skipping masked higher rate: %d\n", high);
721 } 721 }
722 722
723 return (high << 8) | low; 723 return (high << 8) | low;
@@ -732,7 +732,7 @@ static u32 il4965_rs_get_lower_rate(struct il_lq_sta *lq_sta,
732 u16 high_low; 732 u16 high_low;
733 u8 switch_to_legacy = 0; 733 u8 switch_to_legacy = 0;
734 u8 is_green = lq_sta->is_green; 734 u8 is_green = lq_sta->is_green;
735 struct il_priv *priv = lq_sta->drv; 735 struct il_priv *il = lq_sta->drv;
736 736
737 /* check if we need to switch from HT to legacy rates. 737 /* check if we need to switch from HT to legacy rates.
738 * assumption is that mandatory rates (1Mbps or 6Mbps) 738 * assumption is that mandatory rates (1Mbps or 6Mbps)
@@ -747,7 +747,7 @@ static u32 il4965_rs_get_lower_rate(struct il_lq_sta *lq_sta,
747 747
748 if (il4965_num_of_ant(tbl->ant_type) > 1) 748 if (il4965_num_of_ant(tbl->ant_type) > 1)
749 tbl->ant_type = 749 tbl->ant_type =
750 il4965_first_antenna(priv->hw_params.valid_tx_ant); 750 il4965_first_antenna(il->hw_params.valid_tx_ant);
751 751
752 tbl->is_ht40 = 0; 752 tbl->is_ht40 = 0;
753 tbl->is_SGI = 0; 753 tbl->is_SGI = 0;
@@ -798,17 +798,17 @@ static bool il4965_table_type_matches(struct il_scale_tbl_info *a,
798 * mac80211 sends us Tx status 798 * mac80211 sends us Tx status
799 */ 799 */
800static void 800static void
801il4965_rs_tx_status(void *priv_r, struct ieee80211_supported_band *sband, 801il4965_rs_tx_status(void *il_r, struct ieee80211_supported_band *sband,
802 struct ieee80211_sta *sta, void *priv_sta, 802 struct ieee80211_sta *sta, void *il_sta,
803 struct sk_buff *skb) 803 struct sk_buff *skb)
804{ 804{
805 int legacy_success; 805 int legacy_success;
806 int retries; 806 int retries;
807 int rs_index, mac_index, i; 807 int rs_index, mac_index, i;
808 struct il_lq_sta *lq_sta = priv_sta; 808 struct il_lq_sta *lq_sta = il_sta;
809 struct il_link_quality_cmd *table; 809 struct il_link_quality_cmd *table;
810 struct ieee80211_hdr *hdr = (struct ieee80211_hdr *)skb->data; 810 struct ieee80211_hdr *hdr = (struct ieee80211_hdr *)skb->data;
811 struct il_priv *priv = (struct il_priv *)priv_r; 811 struct il_priv *il = (struct il_priv *)il_r;
812 struct ieee80211_tx_info *info = IEEE80211_SKB_CB(skb); 812 struct ieee80211_tx_info *info = IEEE80211_SKB_CB(skb);
813 enum mac80211_rate_control_flags mac_flags; 813 enum mac80211_rate_control_flags mac_flags;
814 u32 tx_rate; 814 u32 tx_rate;
@@ -817,15 +817,15 @@ il4965_rs_tx_status(void *priv_r, struct ieee80211_supported_band *sband,
817 struct il_station_priv *sta_priv = (void *)sta->drv_priv; 817 struct il_station_priv *sta_priv = (void *)sta->drv_priv;
818 struct il_rxon_context *ctx = sta_priv->common.ctx; 818 struct il_rxon_context *ctx = sta_priv->common.ctx;
819 819
820 IL_DEBUG_RATE_LIMIT(priv, 820 IL_DEBUG_RATE_LIMIT(il,
821 "get frame ack response, update rate scale window\n"); 821 "get frame ack response, update rate scale window\n");
822 822
823 /* Treat uninitialized rate scaling data same as non-existing. */ 823 /* Treat uninitialized rate scaling data same as non-existing. */
824 if (!lq_sta) { 824 if (!lq_sta) {
825 IL_DEBUG_RATE(priv, "Station rate scaling not created yet.\n"); 825 IL_DEBUG_RATE(il, "Station rate scaling not created yet.\n");
826 return; 826 return;
827 } else if (!lq_sta->drv) { 827 } else if (!lq_sta->drv) {
828 IL_DEBUG_RATE(priv, "Rate scaling not initialized yet.\n"); 828 IL_DEBUG_RATE(il, "Rate scaling not initialized yet.\n");
829 return; 829 return;
830 } 830 }
831 831
@@ -849,8 +849,8 @@ il4965_rs_tx_status(void *priv_r, struct ieee80211_supported_band *sband,
849 table = &lq_sta->lq; 849 table = &lq_sta->lq;
850 tx_rate = le32_to_cpu(table->rs_table[0].rate_n_flags); 850 tx_rate = le32_to_cpu(table->rs_table[0].rate_n_flags);
851 il4965_rs_get_tbl_info_from_mcs(tx_rate, 851 il4965_rs_get_tbl_info_from_mcs(tx_rate,
852 priv->band, &tbl_type, &rs_index); 852 il->band, &tbl_type, &rs_index);
853 if (priv->band == IEEE80211_BAND_5GHZ) 853 if (il->band == IEEE80211_BAND_5GHZ)
854 rs_index -= IL_FIRST_OFDM_RATE; 854 rs_index -= IL_FIRST_OFDM_RATE;
855 mac_flags = info->status.rates[0].flags; 855 mac_flags = info->status.rates[0].flags;
856 mac_index = info->status.rates[0].idx; 856 mac_index = info->status.rates[0].idx;
@@ -863,7 +863,7 @@ il4965_rs_tx_status(void *priv_r, struct ieee80211_supported_band *sband,
863 * mac80211 HT index is always zero-indexed; we need to move 863 * mac80211 HT index is always zero-indexed; we need to move
864 * HT OFDM rates after CCK rates in 2.4 GHz band 864 * HT OFDM rates after CCK rates in 2.4 GHz band
865 */ 865 */
866 if (priv->band == IEEE80211_BAND_2GHZ) 866 if (il->band == IEEE80211_BAND_2GHZ)
867 mac_index += IL_FIRST_OFDM_RATE; 867 mac_index += IL_FIRST_OFDM_RATE;
868 } 868 }
869 /* Here we actually compare this rate to the latest LQ command */ 869 /* Here we actually compare this rate to the latest LQ command */
@@ -880,7 +880,7 @@ il4965_rs_tx_status(void *priv_r, struct ieee80211_supported_band *sband,
880 (!!(tx_rate & RATE_MCS_GF_MSK) != 880 (!!(tx_rate & RATE_MCS_GF_MSK) !=
881 !!(mac_flags & IEEE80211_TX_RC_GREEN_FIELD)) || 881 !!(mac_flags & IEEE80211_TX_RC_GREEN_FIELD)) ||
882 (rs_index != mac_index)) { 882 (rs_index != mac_index)) {
883 IL_DEBUG_RATE(priv, 883 IL_DEBUG_RATE(il,
884 "initial rate %d does not match %d (0x%x)\n", 884 "initial rate %d does not match %d (0x%x)\n",
885 mac_index, rs_index, tx_rate); 885 mac_index, rs_index, tx_rate);
886 /* 886 /*
@@ -891,7 +891,7 @@ il4965_rs_tx_status(void *priv_r, struct ieee80211_supported_band *sband,
891 lq_sta->missed_rate_counter++; 891 lq_sta->missed_rate_counter++;
892 if (lq_sta->missed_rate_counter > IL_MISSED_RATE_MAX) { 892 if (lq_sta->missed_rate_counter > IL_MISSED_RATE_MAX) {
893 lq_sta->missed_rate_counter = 0; 893 lq_sta->missed_rate_counter = 0;
894 il_send_lq_cmd(priv, ctx, &lq_sta->lq, 894 il_send_lq_cmd(il, ctx, &lq_sta->lq,
895 CMD_ASYNC, false); 895 CMD_ASYNC, false);
896 } 896 }
897 /* Regardless, ignore this status info for outdated rate */ 897 /* Regardless, ignore this status info for outdated rate */
@@ -910,15 +910,15 @@ il4965_rs_tx_status(void *priv_r, struct ieee80211_supported_band *sband,
910 curr_tbl = &(lq_sta->lq_info[1 - lq_sta->active_tbl]); 910 curr_tbl = &(lq_sta->lq_info[1 - lq_sta->active_tbl]);
911 other_tbl = &(lq_sta->lq_info[lq_sta->active_tbl]); 911 other_tbl = &(lq_sta->lq_info[lq_sta->active_tbl]);
912 } else { 912 } else {
913 IL_DEBUG_RATE(priv, 913 IL_DEBUG_RATE(il,
914 "Neither active nor search matches tx rate\n"); 914 "Neither active nor search matches tx rate\n");
915 tmp_tbl = &(lq_sta->lq_info[lq_sta->active_tbl]); 915 tmp_tbl = &(lq_sta->lq_info[lq_sta->active_tbl]);
916 IL_DEBUG_RATE(priv, "active- lq:%x, ant:%x, SGI:%d\n", 916 IL_DEBUG_RATE(il, "active- lq:%x, ant:%x, SGI:%d\n",
917 tmp_tbl->lq_type, tmp_tbl->ant_type, tmp_tbl->is_SGI); 917 tmp_tbl->lq_type, tmp_tbl->ant_type, tmp_tbl->is_SGI);
918 tmp_tbl = &(lq_sta->lq_info[1 - lq_sta->active_tbl]); 918 tmp_tbl = &(lq_sta->lq_info[1 - lq_sta->active_tbl]);
919 IL_DEBUG_RATE(priv, "search- lq:%x, ant:%x, SGI:%d\n", 919 IL_DEBUG_RATE(il, "search- lq:%x, ant:%x, SGI:%d\n",
920 tmp_tbl->lq_type, tmp_tbl->ant_type, tmp_tbl->is_SGI); 920 tmp_tbl->lq_type, tmp_tbl->ant_type, tmp_tbl->is_SGI);
921 IL_DEBUG_RATE(priv, "actual- lq:%x, ant:%x, SGI:%d\n", 921 IL_DEBUG_RATE(il, "actual- lq:%x, ant:%x, SGI:%d\n",
922 tbl_type.lq_type, tbl_type.ant_type, tbl_type.is_SGI); 922 tbl_type.lq_type, tbl_type.ant_type, tbl_type.is_SGI);
923 /* 923 /*
924 * no matching table found, let's by-pass the data collection 924 * no matching table found, let's by-pass the data collection
@@ -937,7 +937,7 @@ il4965_rs_tx_status(void *priv_r, struct ieee80211_supported_band *sband,
937 */ 937 */
938 if (info->flags & IEEE80211_TX_STAT_AMPDU) { 938 if (info->flags & IEEE80211_TX_STAT_AMPDU) {
939 tx_rate = le32_to_cpu(table->rs_table[0].rate_n_flags); 939 tx_rate = le32_to_cpu(table->rs_table[0].rate_n_flags);
940 il4965_rs_get_tbl_info_from_mcs(tx_rate, priv->band, &tbl_type, 940 il4965_rs_get_tbl_info_from_mcs(tx_rate, il->band, &tbl_type,
941 &rs_index); 941 &rs_index);
942 il4965_rs_collect_tx_data(curr_tbl, rs_index, 942 il4965_rs_collect_tx_data(curr_tbl, rs_index,
943 info->status.ampdu_len, 943 info->status.ampdu_len,
@@ -962,7 +962,7 @@ il4965_rs_tx_status(void *priv_r, struct ieee80211_supported_band *sband,
962 /* Collect data for each rate used during failed TX attempts */ 962 /* Collect data for each rate used during failed TX attempts */
963 for (i = 0; i <= retries; ++i) { 963 for (i = 0; i <= retries; ++i) {
964 tx_rate = le32_to_cpu(table->rs_table[i].rate_n_flags); 964 tx_rate = le32_to_cpu(table->rs_table[i].rate_n_flags);
965 il4965_rs_get_tbl_info_from_mcs(tx_rate, priv->band, 965 il4965_rs_get_tbl_info_from_mcs(tx_rate, il->band,
966 &tbl_type, &rs_index); 966 &tbl_type, &rs_index);
967 /* 967 /*
968 * Only collect stats if retried rate is in the same RS 968 * Only collect stats if retried rate is in the same RS
@@ -990,7 +990,7 @@ il4965_rs_tx_status(void *priv_r, struct ieee80211_supported_band *sband,
990done: 990done:
991 /* See if there's a better rate or modulation mode to try. */ 991 /* See if there's a better rate or modulation mode to try. */
992 if (sta && sta->supp_rates[sband->band]) 992 if (sta && sta->supp_rates[sband->band])
993 il4965_rs_rate_scale_perform(priv, skb, sta, lq_sta); 993 il4965_rs_rate_scale_perform(il, skb, sta, lq_sta);
994} 994}
995 995
996/* 996/*
@@ -1001,10 +1001,10 @@ done:
1001 * These control how long we stay using same modulation mode before 1001 * These control how long we stay using same modulation mode before
1002 * searching for a new mode. 1002 * searching for a new mode.
1003 */ 1003 */
1004static void il4965_rs_set_stay_in_table(struct il_priv *priv, u8 is_legacy, 1004static void il4965_rs_set_stay_in_table(struct il_priv *il, u8 is_legacy,
1005 struct il_lq_sta *lq_sta) 1005 struct il_lq_sta *lq_sta)
1006{ 1006{
1007 IL_DEBUG_RATE(priv, "we are staying in the same table\n"); 1007 IL_DEBUG_RATE(il, "we are staying in the same table\n");
1008 lq_sta->stay_in_tbl = 1; /* only place this gets set */ 1008 lq_sta->stay_in_tbl = 1; /* only place this gets set */
1009 if (is_legacy) { 1009 if (is_legacy) {
1010 lq_sta->table_count_limit = IL_LEGACY_TABLE_COUNT; 1010 lq_sta->table_count_limit = IL_LEGACY_TABLE_COUNT;
@@ -1077,7 +1077,7 @@ static void il4965_rs_set_expected_tpt_table(struct il_lq_sta *lq_sta,
1077 * to decrease to match "active" throughput. When moving from MIMO to SISO, 1077 * to decrease to match "active" throughput. When moving from MIMO to SISO,
1078 * bit rate will typically need to increase, but not if performance was bad. 1078 * bit rate will typically need to increase, but not if performance was bad.
1079 */ 1079 */
1080static s32 il4965_rs_get_best_rate(struct il_priv *priv, 1080static s32 il4965_rs_get_best_rate(struct il_priv *il,
1081 struct il_lq_sta *lq_sta, 1081 struct il_lq_sta *lq_sta,
1082 struct il_scale_tbl_info *tbl, /* "search" */ 1082 struct il_scale_tbl_info *tbl, /* "search" */
1083 u16 rate_mask, s8 index) 1083 u16 rate_mask, s8 index)
@@ -1098,7 +1098,7 @@ static s32 il4965_rs_get_best_rate(struct il_priv *priv,
1098 new_rate = high = low = start_hi = IL_RATE_INVALID; 1098 new_rate = high = low = start_hi = IL_RATE_INVALID;
1099 1099
1100 for (; ;) { 1100 for (; ;) {
1101 high_low = il4965_rs_get_adjacent_rate(priv, rate, rate_mask, 1101 high_low = il4965_rs_get_adjacent_rate(il, rate, rate_mask,
1102 tbl->lq_type); 1102 tbl->lq_type);
1103 1103
1104 low = high_low & 0xff; 1104 low = high_low & 0xff;
@@ -1171,7 +1171,7 @@ static s32 il4965_rs_get_best_rate(struct il_priv *priv,
1171/* 1171/*
1172 * Set up search table for MIMO2 1172 * Set up search table for MIMO2
1173 */ 1173 */
1174static int il4965_rs_switch_to_mimo2(struct il_priv *priv, 1174static int il4965_rs_switch_to_mimo2(struct il_priv *il,
1175 struct il_lq_sta *lq_sta, 1175 struct il_lq_sta *lq_sta,
1176 struct ieee80211_conf *conf, 1176 struct ieee80211_conf *conf,
1177 struct ieee80211_sta *sta, 1177 struct ieee80211_sta *sta,
@@ -1191,10 +1191,10 @@ static int il4965_rs_switch_to_mimo2(struct il_priv *priv,
1191 return -1; 1191 return -1;
1192 1192
1193 /* Need both Tx chains/antennas to support MIMO */ 1193 /* Need both Tx chains/antennas to support MIMO */
1194 if (priv->hw_params.tx_chains_num < 2) 1194 if (il->hw_params.tx_chains_num < 2)
1195 return -1; 1195 return -1;
1196 1196
1197 IL_DEBUG_RATE(priv, "LQ: try to switch to MIMO2\n"); 1197 IL_DEBUG_RATE(il, "LQ: try to switch to MIMO2\n");
1198 1198
1199 tbl->lq_type = LQ_MIMO2; 1199 tbl->lq_type = LQ_MIMO2;
1200 tbl->is_dup = lq_sta->is_dup; 1200 tbl->is_dup = lq_sta->is_dup;
@@ -1202,27 +1202,27 @@ static int il4965_rs_switch_to_mimo2(struct il_priv *priv,
1202 tbl->max_search = IL_MAX_SEARCH; 1202 tbl->max_search = IL_MAX_SEARCH;
1203 rate_mask = lq_sta->active_mimo2_rate; 1203 rate_mask = lq_sta->active_mimo2_rate;
1204 1204
1205 if (il_is_ht40_tx_allowed(priv, ctx, &sta->ht_cap)) 1205 if (il_is_ht40_tx_allowed(il, ctx, &sta->ht_cap))
1206 tbl->is_ht40 = 1; 1206 tbl->is_ht40 = 1;
1207 else 1207 else
1208 tbl->is_ht40 = 0; 1208 tbl->is_ht40 = 0;
1209 1209
1210 il4965_rs_set_expected_tpt_table(lq_sta, tbl); 1210 il4965_rs_set_expected_tpt_table(lq_sta, tbl);
1211 1211
1212 rate = il4965_rs_get_best_rate(priv, lq_sta, tbl, rate_mask, index); 1212 rate = il4965_rs_get_best_rate(il, lq_sta, tbl, rate_mask, index);
1213 1213
1214 IL_DEBUG_RATE(priv, "LQ: MIMO2 best rate %d mask %X\n", 1214 IL_DEBUG_RATE(il, "LQ: MIMO2 best rate %d mask %X\n",
1215 rate, rate_mask); 1215 rate, rate_mask);
1216 if ((rate == IL_RATE_INVALID) || !((1 << rate) & rate_mask)) { 1216 if ((rate == IL_RATE_INVALID) || !((1 << rate) & rate_mask)) {
1217 IL_DEBUG_RATE(priv, 1217 IL_DEBUG_RATE(il,
1218 "Can't switch with index %d rate mask %x\n", 1218 "Can't switch with index %d rate mask %x\n",
1219 rate, rate_mask); 1219 rate, rate_mask);
1220 return -1; 1220 return -1;
1221 } 1221 }
1222 tbl->current_rate = il4965_rate_n_flags_from_tbl(priv, 1222 tbl->current_rate = il4965_rate_n_flags_from_tbl(il,
1223 tbl, rate, is_green); 1223 tbl, rate, is_green);
1224 1224
1225 IL_DEBUG_RATE(priv, "LQ: Switch to new mcs %X index is green %X\n", 1225 IL_DEBUG_RATE(il, "LQ: Switch to new mcs %X index is green %X\n",
1226 tbl->current_rate, is_green); 1226 tbl->current_rate, is_green);
1227 return 0; 1227 return 0;
1228} 1228}
@@ -1230,7 +1230,7 @@ static int il4965_rs_switch_to_mimo2(struct il_priv *priv,
1230/* 1230/*
1231 * Set up search table for SISO 1231 * Set up search table for SISO
1232 */ 1232 */
1233static int il4965_rs_switch_to_siso(struct il_priv *priv, 1233static int il4965_rs_switch_to_siso(struct il_priv *il,
1234 struct il_lq_sta *lq_sta, 1234 struct il_lq_sta *lq_sta,
1235 struct ieee80211_conf *conf, 1235 struct ieee80211_conf *conf,
1236 struct ieee80211_sta *sta, 1236 struct ieee80211_sta *sta,
@@ -1245,7 +1245,7 @@ static int il4965_rs_switch_to_siso(struct il_priv *priv,
1245 if (!conf_is_ht(conf) || !sta->ht_cap.ht_supported) 1245 if (!conf_is_ht(conf) || !sta->ht_cap.ht_supported)
1246 return -1; 1246 return -1;
1247 1247
1248 IL_DEBUG_RATE(priv, "LQ: try to switch to SISO\n"); 1248 IL_DEBUG_RATE(il, "LQ: try to switch to SISO\n");
1249 1249
1250 tbl->is_dup = lq_sta->is_dup; 1250 tbl->is_dup = lq_sta->is_dup;
1251 tbl->lq_type = LQ_SISO; 1251 tbl->lq_type = LQ_SISO;
@@ -1253,7 +1253,7 @@ static int il4965_rs_switch_to_siso(struct il_priv *priv,
1253 tbl->max_search = IL_MAX_SEARCH; 1253 tbl->max_search = IL_MAX_SEARCH;
1254 rate_mask = lq_sta->active_siso_rate; 1254 rate_mask = lq_sta->active_siso_rate;
1255 1255
1256 if (il_is_ht40_tx_allowed(priv, ctx, &sta->ht_cap)) 1256 if (il_is_ht40_tx_allowed(il, ctx, &sta->ht_cap))
1257 tbl->is_ht40 = 1; 1257 tbl->is_ht40 = 1;
1258 else 1258 else
1259 tbl->is_ht40 = 0; 1259 tbl->is_ht40 = 0;
@@ -1262,18 +1262,18 @@ static int il4965_rs_switch_to_siso(struct il_priv *priv,
1262 tbl->is_SGI = 0; /*11n spec: no SGI in SISO+Greenfield*/ 1262 tbl->is_SGI = 0; /*11n spec: no SGI in SISO+Greenfield*/
1263 1263
1264 il4965_rs_set_expected_tpt_table(lq_sta, tbl); 1264 il4965_rs_set_expected_tpt_table(lq_sta, tbl);
1265 rate = il4965_rs_get_best_rate(priv, lq_sta, tbl, rate_mask, index); 1265 rate = il4965_rs_get_best_rate(il, lq_sta, tbl, rate_mask, index);
1266 1266
1267 IL_DEBUG_RATE(priv, "LQ: get best rate %d mask %X\n", rate, rate_mask); 1267 IL_DEBUG_RATE(il, "LQ: get best rate %d mask %X\n", rate, rate_mask);
1268 if ((rate == IL_RATE_INVALID) || !((1 << rate) & rate_mask)) { 1268 if ((rate == IL_RATE_INVALID) || !((1 << rate) & rate_mask)) {
1269 IL_DEBUG_RATE(priv, 1269 IL_DEBUG_RATE(il,
1270 "can not switch with index %d rate mask %x\n", 1270 "can not switch with index %d rate mask %x\n",
1271 rate, rate_mask); 1271 rate, rate_mask);
1272 return -1; 1272 return -1;
1273 } 1273 }
1274 tbl->current_rate = il4965_rate_n_flags_from_tbl(priv, 1274 tbl->current_rate = il4965_rate_n_flags_from_tbl(il,
1275 tbl, rate, is_green); 1275 tbl, rate, is_green);
1276 IL_DEBUG_RATE(priv, "LQ: Switch to new mcs %X index is green %X\n", 1276 IL_DEBUG_RATE(il, "LQ: Switch to new mcs %X index is green %X\n",
1277 tbl->current_rate, is_green); 1277 tbl->current_rate, is_green);
1278 return 0; 1278 return 0;
1279} 1279}
@@ -1281,7 +1281,7 @@ static int il4965_rs_switch_to_siso(struct il_priv *priv,
1281/* 1281/*
1282 * Try to switch to new modulation mode from legacy 1282 * Try to switch to new modulation mode from legacy
1283 */ 1283 */
1284static int il4965_rs_move_legacy_other(struct il_priv *priv, 1284static int il4965_rs_move_legacy_other(struct il_priv *il,
1285 struct il_lq_sta *lq_sta, 1285 struct il_lq_sta *lq_sta,
1286 struct ieee80211_conf *conf, 1286 struct ieee80211_conf *conf,
1287 struct ieee80211_sta *sta, 1287 struct ieee80211_sta *sta,
@@ -1294,8 +1294,8 @@ static int il4965_rs_move_legacy_other(struct il_priv *priv,
1294 u32 sz = (sizeof(struct il_scale_tbl_info) - 1294 u32 sz = (sizeof(struct il_scale_tbl_info) -
1295 (sizeof(struct il_rate_scale_data) * IL_RATE_COUNT)); 1295 (sizeof(struct il_rate_scale_data) * IL_RATE_COUNT));
1296 u8 start_action; 1296 u8 start_action;
1297 u8 valid_tx_ant = priv->hw_params.valid_tx_ant; 1297 u8 valid_tx_ant = il->hw_params.valid_tx_ant;
1298 u8 tx_chains_num = priv->hw_params.tx_chains_num; 1298 u8 tx_chains_num = il->hw_params.tx_chains_num;
1299 int ret = 0; 1299 int ret = 0;
1300 u8 update_search_tbl_counter = 0; 1300 u8 update_search_tbl_counter = 0;
1301 1301
@@ -1307,7 +1307,7 @@ static int il4965_rs_move_legacy_other(struct il_priv *priv,
1307 switch (tbl->action) { 1307 switch (tbl->action) {
1308 case IL_LEGACY_SWITCH_ANTENNA1: 1308 case IL_LEGACY_SWITCH_ANTENNA1:
1309 case IL_LEGACY_SWITCH_ANTENNA2: 1309 case IL_LEGACY_SWITCH_ANTENNA2:
1310 IL_DEBUG_RATE(priv, "LQ: Legacy toggle Antenna\n"); 1310 IL_DEBUG_RATE(il, "LQ: Legacy toggle Antenna\n");
1311 1311
1312 if ((tbl->action == IL_LEGACY_SWITCH_ANTENNA1 && 1312 if ((tbl->action == IL_LEGACY_SWITCH_ANTENNA1 &&
1313 tx_chains_num <= 1) || 1313 tx_chains_num <= 1) ||
@@ -1331,12 +1331,12 @@ static int il4965_rs_move_legacy_other(struct il_priv *priv,
1331 } 1331 }
1332 break; 1332 break;
1333 case IL_LEGACY_SWITCH_SISO: 1333 case IL_LEGACY_SWITCH_SISO:
1334 IL_DEBUG_RATE(priv, "LQ: Legacy switch to SISO\n"); 1334 IL_DEBUG_RATE(il, "LQ: Legacy switch to SISO\n");
1335 1335
1336 /* Set up search table to try SISO */ 1336 /* Set up search table to try SISO */
1337 memcpy(search_tbl, tbl, sz); 1337 memcpy(search_tbl, tbl, sz);
1338 search_tbl->is_SGI = 0; 1338 search_tbl->is_SGI = 0;
1339 ret = il4965_rs_switch_to_siso(priv, lq_sta, conf, sta, 1339 ret = il4965_rs_switch_to_siso(il, lq_sta, conf, sta,
1340 search_tbl, index); 1340 search_tbl, index);
1341 if (!ret) { 1341 if (!ret) {
1342 lq_sta->action_counter = 0; 1342 lq_sta->action_counter = 0;
@@ -1347,7 +1347,7 @@ static int il4965_rs_move_legacy_other(struct il_priv *priv,
1347 case IL_LEGACY_SWITCH_MIMO2_AB: 1347 case IL_LEGACY_SWITCH_MIMO2_AB:
1348 case IL_LEGACY_SWITCH_MIMO2_AC: 1348 case IL_LEGACY_SWITCH_MIMO2_AC:
1349 case IL_LEGACY_SWITCH_MIMO2_BC: 1349 case IL_LEGACY_SWITCH_MIMO2_BC:
1350 IL_DEBUG_RATE(priv, "LQ: Legacy switch to MIMO2\n"); 1350 IL_DEBUG_RATE(il, "LQ: Legacy switch to MIMO2\n");
1351 1351
1352 /* Set up search table to try MIMO */ 1352 /* Set up search table to try MIMO */
1353 memcpy(search_tbl, tbl, sz); 1353 memcpy(search_tbl, tbl, sz);
@@ -1364,7 +1364,7 @@ static int il4965_rs_move_legacy_other(struct il_priv *priv,
1364 search_tbl->ant_type)) 1364 search_tbl->ant_type))
1365 break; 1365 break;
1366 1366
1367 ret = il4965_rs_switch_to_mimo2(priv, lq_sta, 1367 ret = il4965_rs_switch_to_mimo2(il, lq_sta,
1368 conf, sta, 1368 conf, sta,
1369 search_tbl, index); 1369 search_tbl, index);
1370 if (!ret) { 1370 if (!ret) {
@@ -1398,7 +1398,7 @@ out:
1398/* 1398/*
1399 * Try to switch to new modulation mode from SISO 1399 * Try to switch to new modulation mode from SISO
1400 */ 1400 */
1401static int il4965_rs_move_siso_to_other(struct il_priv *priv, 1401static int il4965_rs_move_siso_to_other(struct il_priv *il,
1402 struct il_lq_sta *lq_sta, 1402 struct il_lq_sta *lq_sta,
1403 struct ieee80211_conf *conf, 1403 struct ieee80211_conf *conf,
1404 struct ieee80211_sta *sta, int index) 1404 struct ieee80211_sta *sta, int index)
@@ -1412,8 +1412,8 @@ static int il4965_rs_move_siso_to_other(struct il_priv *priv,
1412 u32 sz = (sizeof(struct il_scale_tbl_info) - 1412 u32 sz = (sizeof(struct il_scale_tbl_info) -
1413 (sizeof(struct il_rate_scale_data) * IL_RATE_COUNT)); 1413 (sizeof(struct il_rate_scale_data) * IL_RATE_COUNT));
1414 u8 start_action; 1414 u8 start_action;
1415 u8 valid_tx_ant = priv->hw_params.valid_tx_ant; 1415 u8 valid_tx_ant = il->hw_params.valid_tx_ant;
1416 u8 tx_chains_num = priv->hw_params.tx_chains_num; 1416 u8 tx_chains_num = il->hw_params.tx_chains_num;
1417 u8 update_search_tbl_counter = 0; 1417 u8 update_search_tbl_counter = 0;
1418 int ret; 1418 int ret;
1419 1419
@@ -1424,7 +1424,7 @@ static int il4965_rs_move_siso_to_other(struct il_priv *priv,
1424 switch (tbl->action) { 1424 switch (tbl->action) {
1425 case IL_SISO_SWITCH_ANTENNA1: 1425 case IL_SISO_SWITCH_ANTENNA1:
1426 case IL_SISO_SWITCH_ANTENNA2: 1426 case IL_SISO_SWITCH_ANTENNA2:
1427 IL_DEBUG_RATE(priv, "LQ: SISO toggle Antenna\n"); 1427 IL_DEBUG_RATE(il, "LQ: SISO toggle Antenna\n");
1428 if ((tbl->action == IL_SISO_SWITCH_ANTENNA1 && 1428 if ((tbl->action == IL_SISO_SWITCH_ANTENNA1 &&
1429 tx_chains_num <= 1) || 1429 tx_chains_num <= 1) ||
1430 (tbl->action == IL_SISO_SWITCH_ANTENNA2 && 1430 (tbl->action == IL_SISO_SWITCH_ANTENNA2 &&
@@ -1444,7 +1444,7 @@ static int il4965_rs_move_siso_to_other(struct il_priv *priv,
1444 case IL_SISO_SWITCH_MIMO2_AB: 1444 case IL_SISO_SWITCH_MIMO2_AB:
1445 case IL_SISO_SWITCH_MIMO2_AC: 1445 case IL_SISO_SWITCH_MIMO2_AC:
1446 case IL_SISO_SWITCH_MIMO2_BC: 1446 case IL_SISO_SWITCH_MIMO2_BC:
1447 IL_DEBUG_RATE(priv, "LQ: SISO switch to MIMO2\n"); 1447 IL_DEBUG_RATE(il, "LQ: SISO switch to MIMO2\n");
1448 memcpy(search_tbl, tbl, sz); 1448 memcpy(search_tbl, tbl, sz);
1449 search_tbl->is_SGI = 0; 1449 search_tbl->is_SGI = 0;
1450 1450
@@ -1459,7 +1459,7 @@ static int il4965_rs_move_siso_to_other(struct il_priv *priv,
1459 search_tbl->ant_type)) 1459 search_tbl->ant_type))
1460 break; 1460 break;
1461 1461
1462 ret = il4965_rs_switch_to_mimo2(priv, lq_sta, 1462 ret = il4965_rs_switch_to_mimo2(il, lq_sta,
1463 conf, sta, 1463 conf, sta,
1464 search_tbl, index); 1464 search_tbl, index);
1465 if (!ret) 1465 if (!ret)
@@ -1473,14 +1473,14 @@ static int il4965_rs_move_siso_to_other(struct il_priv *priv,
1473 IEEE80211_HT_CAP_SGI_40)) 1473 IEEE80211_HT_CAP_SGI_40))
1474 break; 1474 break;
1475 1475
1476 IL_DEBUG_RATE(priv, "LQ: SISO toggle SGI/NGI\n"); 1476 IL_DEBUG_RATE(il, "LQ: SISO toggle SGI/NGI\n");
1477 1477
1478 memcpy(search_tbl, tbl, sz); 1478 memcpy(search_tbl, tbl, sz);
1479 if (is_green) { 1479 if (is_green) {
1480 if (!tbl->is_SGI) 1480 if (!tbl->is_SGI)
1481 break; 1481 break;
1482 else 1482 else
1483 IL_ERR(priv, 1483 IL_ERR(il,
1484 "SGI was set in GF+SISO\n"); 1484 "SGI was set in GF+SISO\n");
1485 } 1485 }
1486 search_tbl->is_SGI = !tbl->is_SGI; 1486 search_tbl->is_SGI = !tbl->is_SGI;
@@ -1491,7 +1491,7 @@ static int il4965_rs_move_siso_to_other(struct il_priv *priv,
1491 break; 1491 break;
1492 } 1492 }
1493 search_tbl->current_rate = 1493 search_tbl->current_rate =
1494 il4965_rate_n_flags_from_tbl(priv, search_tbl, 1494 il4965_rate_n_flags_from_tbl(il, search_tbl,
1495 index, is_green); 1495 index, is_green);
1496 update_search_tbl_counter = 1; 1496 update_search_tbl_counter = 1;
1497 goto out; 1497 goto out;
@@ -1520,7 +1520,7 @@ static int il4965_rs_move_siso_to_other(struct il_priv *priv,
1520/* 1520/*
1521 * Try to switch to new modulation mode from MIMO2 1521 * Try to switch to new modulation mode from MIMO2
1522 */ 1522 */
1523static int il4965_rs_move_mimo2_to_other(struct il_priv *priv, 1523static int il4965_rs_move_mimo2_to_other(struct il_priv *il,
1524 struct il_lq_sta *lq_sta, 1524 struct il_lq_sta *lq_sta,
1525 struct ieee80211_conf *conf, 1525 struct ieee80211_conf *conf,
1526 struct ieee80211_sta *sta, int index) 1526 struct ieee80211_sta *sta, int index)
@@ -1534,8 +1534,8 @@ static int il4965_rs_move_mimo2_to_other(struct il_priv *priv,
1534 u32 sz = (sizeof(struct il_scale_tbl_info) - 1534 u32 sz = (sizeof(struct il_scale_tbl_info) -
1535 (sizeof(struct il_rate_scale_data) * IL_RATE_COUNT)); 1535 (sizeof(struct il_rate_scale_data) * IL_RATE_COUNT));
1536 u8 start_action; 1536 u8 start_action;
1537 u8 valid_tx_ant = priv->hw_params.valid_tx_ant; 1537 u8 valid_tx_ant = il->hw_params.valid_tx_ant;
1538 u8 tx_chains_num = priv->hw_params.tx_chains_num; 1538 u8 tx_chains_num = il->hw_params.tx_chains_num;
1539 u8 update_search_tbl_counter = 0; 1539 u8 update_search_tbl_counter = 0;
1540 int ret; 1540 int ret;
1541 1541
@@ -1545,7 +1545,7 @@ static int il4965_rs_move_mimo2_to_other(struct il_priv *priv,
1545 switch (tbl->action) { 1545 switch (tbl->action) {
1546 case IL_MIMO2_SWITCH_ANTENNA1: 1546 case IL_MIMO2_SWITCH_ANTENNA1:
1547 case IL_MIMO2_SWITCH_ANTENNA2: 1547 case IL_MIMO2_SWITCH_ANTENNA2:
1548 IL_DEBUG_RATE(priv, "LQ: MIMO2 toggle Antennas\n"); 1548 IL_DEBUG_RATE(il, "LQ: MIMO2 toggle Antennas\n");
1549 1549
1550 if (tx_chains_num <= 2) 1550 if (tx_chains_num <= 2)
1551 break; 1551 break;
@@ -1563,7 +1563,7 @@ static int il4965_rs_move_mimo2_to_other(struct il_priv *priv,
1563 case IL_MIMO2_SWITCH_SISO_A: 1563 case IL_MIMO2_SWITCH_SISO_A:
1564 case IL_MIMO2_SWITCH_SISO_B: 1564 case IL_MIMO2_SWITCH_SISO_B:
1565 case IL_MIMO2_SWITCH_SISO_C: 1565 case IL_MIMO2_SWITCH_SISO_C:
1566 IL_DEBUG_RATE(priv, "LQ: MIMO2 switch to SISO\n"); 1566 IL_DEBUG_RATE(il, "LQ: MIMO2 switch to SISO\n");
1567 1567
1568 /* Set up new search table for SISO */ 1568 /* Set up new search table for SISO */
1569 memcpy(search_tbl, tbl, sz); 1569 memcpy(search_tbl, tbl, sz);
@@ -1579,7 +1579,7 @@ static int il4965_rs_move_mimo2_to_other(struct il_priv *priv,
1579 search_tbl->ant_type)) 1579 search_tbl->ant_type))
1580 break; 1580 break;
1581 1581
1582 ret = il4965_rs_switch_to_siso(priv, lq_sta, 1582 ret = il4965_rs_switch_to_siso(il, lq_sta,
1583 conf, sta, 1583 conf, sta,
1584 search_tbl, index); 1584 search_tbl, index);
1585 if (!ret) 1585 if (!ret)
@@ -1595,7 +1595,7 @@ static int il4965_rs_move_mimo2_to_other(struct il_priv *priv,
1595 IEEE80211_HT_CAP_SGI_40)) 1595 IEEE80211_HT_CAP_SGI_40))
1596 break; 1596 break;
1597 1597
1598 IL_DEBUG_RATE(priv, "LQ: MIMO2 toggle SGI/NGI\n"); 1598 IL_DEBUG_RATE(il, "LQ: MIMO2 toggle SGI/NGI\n");
1599 1599
1600 /* Set up new search table for MIMO2 */ 1600 /* Set up new search table for MIMO2 */
1601 memcpy(search_tbl, tbl, sz); 1601 memcpy(search_tbl, tbl, sz);
@@ -1613,7 +1613,7 @@ static int il4965_rs_move_mimo2_to_other(struct il_priv *priv,
1613 break; 1613 break;
1614 } 1614 }
1615 search_tbl->current_rate = 1615 search_tbl->current_rate =
1616 il4965_rate_n_flags_from_tbl(priv, search_tbl, 1616 il4965_rate_n_flags_from_tbl(il, search_tbl,
1617 index, is_green); 1617 index, is_green);
1618 update_search_tbl_counter = 1; 1618 update_search_tbl_counter = 1;
1619 goto out; 1619 goto out;
@@ -1654,9 +1654,9 @@ il4965_rs_stay_in_table(struct il_lq_sta *lq_sta, bool force_search)
1654 int i; 1654 int i;
1655 int active_tbl; 1655 int active_tbl;
1656 int flush_interval_passed = 0; 1656 int flush_interval_passed = 0;
1657 struct il_priv *priv; 1657 struct il_priv *il;
1658 1658
1659 priv = lq_sta->drv; 1659 il = lq_sta->drv;
1660 active_tbl = lq_sta->active_tbl; 1660 active_tbl = lq_sta->active_tbl;
1661 1661
1662 tbl = &(lq_sta->lq_info[active_tbl]); 1662 tbl = &(lq_sta->lq_info[active_tbl]);
@@ -1684,7 +1684,7 @@ il4965_rs_stay_in_table(struct il_lq_sta *lq_sta, bool force_search)
1684 (lq_sta->total_success > lq_sta->max_success_limit) || 1684 (lq_sta->total_success > lq_sta->max_success_limit) ||
1685 ((!lq_sta->search_better_tbl) && (lq_sta->flush_timer) 1685 ((!lq_sta->search_better_tbl) && (lq_sta->flush_timer)
1686 && (flush_interval_passed))) { 1686 && (flush_interval_passed))) {
1687 IL_DEBUG_RATE(priv, "LQ: stay is expired %d %d %d\n:", 1687 IL_DEBUG_RATE(il, "LQ: stay is expired %d %d %d\n:",
1688 lq_sta->total_failed, 1688 lq_sta->total_failed,
1689 lq_sta->total_success, 1689 lq_sta->total_success,
1690 flush_interval_passed); 1690 flush_interval_passed);
@@ -1707,7 +1707,7 @@ il4965_rs_stay_in_table(struct il_lq_sta *lq_sta, bool force_search)
1707 lq_sta->table_count_limit) { 1707 lq_sta->table_count_limit) {
1708 lq_sta->table_count = 0; 1708 lq_sta->table_count = 0;
1709 1709
1710 IL_DEBUG_RATE(priv, 1710 IL_DEBUG_RATE(il,
1711 "LQ: stay in table clear win\n"); 1711 "LQ: stay in table clear win\n");
1712 for (i = 0; i < IL_RATE_COUNT; i++) 1712 for (i = 0; i < IL_RATE_COUNT; i++)
1713 il4965_rs_rate_scale_clear_window( 1713 il4965_rs_rate_scale_clear_window(
@@ -1730,7 +1730,7 @@ il4965_rs_stay_in_table(struct il_lq_sta *lq_sta, bool force_search)
1730 * setup rate table in uCode 1730 * setup rate table in uCode
1731 * return rate_n_flags as used in the table 1731 * return rate_n_flags as used in the table
1732 */ 1732 */
1733static u32 il4965_rs_update_rate_tbl(struct il_priv *priv, 1733static u32 il4965_rs_update_rate_tbl(struct il_priv *il,
1734 struct il_rxon_context *ctx, 1734 struct il_rxon_context *ctx,
1735 struct il_lq_sta *lq_sta, 1735 struct il_lq_sta *lq_sta,
1736 struct il_scale_tbl_info *tbl, 1736 struct il_scale_tbl_info *tbl,
@@ -1739,9 +1739,9 @@ static u32 il4965_rs_update_rate_tbl(struct il_priv *priv,
1739 u32 rate; 1739 u32 rate;
1740 1740
1741 /* Update uCode's rate table. */ 1741 /* Update uCode's rate table. */
1742 rate = il4965_rate_n_flags_from_tbl(priv, tbl, index, is_green); 1742 rate = il4965_rate_n_flags_from_tbl(il, tbl, index, is_green);
1743 il4965_rs_fill_link_cmd(priv, lq_sta, rate); 1743 il4965_rs_fill_link_cmd(il, lq_sta, rate);
1744 il_send_lq_cmd(priv, ctx, &lq_sta->lq, CMD_ASYNC, false); 1744 il_send_lq_cmd(il, ctx, &lq_sta->lq, CMD_ASYNC, false);
1745 1745
1746 return rate; 1746 return rate;
1747} 1747}
@@ -1749,12 +1749,12 @@ static u32 il4965_rs_update_rate_tbl(struct il_priv *priv,
1749/* 1749/*
1750 * Do rate scaling and search for new modulation mode. 1750 * Do rate scaling and search for new modulation mode.
1751 */ 1751 */
1752static void il4965_rs_rate_scale_perform(struct il_priv *priv, 1752static void il4965_rs_rate_scale_perform(struct il_priv *il,
1753 struct sk_buff *skb, 1753 struct sk_buff *skb,
1754 struct ieee80211_sta *sta, 1754 struct ieee80211_sta *sta,
1755 struct il_lq_sta *lq_sta) 1755 struct il_lq_sta *lq_sta)
1756{ 1756{
1757 struct ieee80211_hw *hw = priv->hw; 1757 struct ieee80211_hw *hw = il->hw;
1758 struct ieee80211_conf *conf = &hw->conf; 1758 struct ieee80211_conf *conf = &hw->conf;
1759 struct ieee80211_tx_info *info = IEEE80211_SKB_CB(skb); 1759 struct ieee80211_tx_info *info = IEEE80211_SKB_CB(skb);
1760 struct ieee80211_hdr *hdr = (struct ieee80211_hdr *)skb->data; 1760 struct ieee80211_hdr *hdr = (struct ieee80211_hdr *)skb->data;
@@ -1783,7 +1783,7 @@ static void il4965_rs_rate_scale_perform(struct il_priv *priv,
1783 struct il_station_priv *sta_priv = (void *)sta->drv_priv; 1783 struct il_station_priv *sta_priv = (void *)sta->drv_priv;
1784 struct il_rxon_context *ctx = sta_priv->common.ctx; 1784 struct il_rxon_context *ctx = sta_priv->common.ctx;
1785 1785
1786 IL_DEBUG_RATE(priv, "rate scale calculate new rate for skb\n"); 1786 IL_DEBUG_RATE(il, "rate scale calculate new rate for skb\n");
1787 1787
1788 /* Send management frames and NO_ACK data using lowest rate. */ 1788 /* Send management frames and NO_ACK data using lowest rate. */
1789 /* TODO: this could probably be improved.. */ 1789 /* TODO: this could probably be improved.. */
@@ -1798,7 +1798,7 @@ static void il4965_rs_rate_scale_perform(struct il_priv *priv,
1798 1798
1799 tid = il4965_rs_tl_add_packet(lq_sta, hdr); 1799 tid = il4965_rs_tl_add_packet(lq_sta, hdr);
1800 if ((tid != MAX_TID_COUNT) && (lq_sta->tx_agg_tid_en & (1 << tid))) { 1800 if ((tid != MAX_TID_COUNT) && (lq_sta->tx_agg_tid_en & (1 << tid))) {
1801 tid_data = &priv->stations[lq_sta->lq.sta_id].tid[tid]; 1801 tid_data = &il->stations[lq_sta->lq.sta_id].tid[tid];
1802 if (tid_data->agg.state == IL_AGG_OFF) 1802 if (tid_data->agg.state == IL_AGG_OFF)
1803 lq_sta->is_agg = 0; 1803 lq_sta->is_agg = 0;
1804 else 1804 else
@@ -1826,13 +1826,13 @@ static void il4965_rs_rate_scale_perform(struct il_priv *priv,
1826 /* current tx rate */ 1826 /* current tx rate */
1827 index = lq_sta->last_txrate_idx; 1827 index = lq_sta->last_txrate_idx;
1828 1828
1829 IL_DEBUG_RATE(priv, "Rate scale index %d for type %d\n", index, 1829 IL_DEBUG_RATE(il, "Rate scale index %d for type %d\n", index,
1830 tbl->lq_type); 1830 tbl->lq_type);
1831 1831
1832 /* rates available for this association, and for modulation mode */ 1832 /* rates available for this association, and for modulation mode */
1833 rate_mask = il4965_rs_get_supported_rates(lq_sta, hdr, tbl->lq_type); 1833 rate_mask = il4965_rs_get_supported_rates(lq_sta, hdr, tbl->lq_type);
1834 1834
1835 IL_DEBUG_RATE(priv, "mask 0x%04X\n", rate_mask); 1835 IL_DEBUG_RATE(il, "mask 0x%04X\n", rate_mask);
1836 1836
1837 /* mask with station rate restriction */ 1837 /* mask with station rate restriction */
1838 if (is_legacy(tbl->lq_type)) { 1838 if (is_legacy(tbl->lq_type)) {
@@ -1851,7 +1851,7 @@ static void il4965_rs_rate_scale_perform(struct il_priv *priv,
1851 rate_scale_index_msk = rate_mask; 1851 rate_scale_index_msk = rate_mask;
1852 1852
1853 if (!((1 << index) & rate_scale_index_msk)) { 1853 if (!((1 << index) & rate_scale_index_msk)) {
1854 IL_ERR(priv, "Current Rate is not valid\n"); 1854 IL_ERR(il, "Current Rate is not valid\n");
1855 if (lq_sta->search_better_tbl) { 1855 if (lq_sta->search_better_tbl) {
1856 /* revert to active table if search table is not valid*/ 1856 /* revert to active table if search table is not valid*/
1857 tbl->lq_type = LQ_NONE; 1857 tbl->lq_type = LQ_NONE;
@@ -1859,7 +1859,7 @@ static void il4965_rs_rate_scale_perform(struct il_priv *priv,
1859 tbl = &(lq_sta->lq_info[lq_sta->active_tbl]); 1859 tbl = &(lq_sta->lq_info[lq_sta->active_tbl]);
1860 /* get "active" rate info */ 1860 /* get "active" rate info */
1861 index = il4965_hwrate_to_plcp_idx(tbl->current_rate); 1861 index = il4965_hwrate_to_plcp_idx(tbl->current_rate);
1862 rate = il4965_rs_update_rate_tbl(priv, ctx, lq_sta, 1862 rate = il4965_rs_update_rate_tbl(il, ctx, lq_sta,
1863 tbl, index, is_green); 1863 tbl, index, is_green);
1864 } 1864 }
1865 return; 1865 return;
@@ -1867,7 +1867,7 @@ static void il4965_rs_rate_scale_perform(struct il_priv *priv,
1867 1867
1868 /* Get expected throughput table and history window for current rate */ 1868 /* Get expected throughput table and history window for current rate */
1869 if (!tbl->expected_tpt) { 1869 if (!tbl->expected_tpt) {
1870 IL_ERR(priv, "tbl->expected_tpt is NULL\n"); 1870 IL_ERR(il, "tbl->expected_tpt is NULL\n");
1871 return; 1871 return;
1872 } 1872 }
1873 1873
@@ -1892,7 +1892,7 @@ static void il4965_rs_rate_scale_perform(struct il_priv *priv,
1892 fail_count = window->counter - window->success_counter; 1892 fail_count = window->counter - window->success_counter;
1893 if ((fail_count < IL_RATE_MIN_FAILURE_TH) && 1893 if ((fail_count < IL_RATE_MIN_FAILURE_TH) &&
1894 (window->success_counter < IL_RATE_MIN_SUCCESS_TH)) { 1894 (window->success_counter < IL_RATE_MIN_SUCCESS_TH)) {
1895 IL_DEBUG_RATE(priv, "LQ: still below TH. succ=%d total=%d " 1895 IL_DEBUG_RATE(il, "LQ: still below TH. succ=%d total=%d "
1896 "for index %d\n", 1896 "for index %d\n",
1897 window->success_counter, window->counter, index); 1897 window->success_counter, window->counter, index);
1898 1898
@@ -1909,7 +1909,7 @@ static void il4965_rs_rate_scale_perform(struct il_priv *priv,
1909 * actual average throughput */ 1909 * actual average throughput */
1910 if (window->average_tpt != ((window->success_ratio * 1910 if (window->average_tpt != ((window->success_ratio *
1911 tbl->expected_tpt[index] + 64) / 128)) { 1911 tbl->expected_tpt[index] + 64) / 128)) {
1912 IL_ERR(priv, 1912 IL_ERR(il,
1913 "expected_tpt should have been calculated by now\n"); 1913 "expected_tpt should have been calculated by now\n");
1914 window->average_tpt = ((window->success_ratio * 1914 window->average_tpt = ((window->success_ratio *
1915 tbl->expected_tpt[index] + 64) / 128); 1915 tbl->expected_tpt[index] + 64) / 128);
@@ -1922,7 +1922,7 @@ static void il4965_rs_rate_scale_perform(struct il_priv *priv,
1922 * continuing to use the setup that we've been trying. */ 1922 * continuing to use the setup that we've been trying. */
1923 if (window->average_tpt > lq_sta->last_tpt) { 1923 if (window->average_tpt > lq_sta->last_tpt) {
1924 1924
1925 IL_DEBUG_RATE(priv, "LQ: SWITCHING TO NEW TABLE " 1925 IL_DEBUG_RATE(il, "LQ: SWITCHING TO NEW TABLE "
1926 "suc=%d cur-tpt=%d old-tpt=%d\n", 1926 "suc=%d cur-tpt=%d old-tpt=%d\n",
1927 window->success_ratio, 1927 window->success_ratio,
1928 window->average_tpt, 1928 window->average_tpt,
@@ -1938,7 +1938,7 @@ static void il4965_rs_rate_scale_perform(struct il_priv *priv,
1938 /* Else poor success; go back to mode in "active" table */ 1938 /* Else poor success; go back to mode in "active" table */
1939 } else { 1939 } else {
1940 1940
1941 IL_DEBUG_RATE(priv, "LQ: GOING BACK TO THE OLD TABLE " 1941 IL_DEBUG_RATE(il, "LQ: GOING BACK TO THE OLD TABLE "
1942 "suc=%d cur-tpt=%d old-tpt=%d\n", 1942 "suc=%d cur-tpt=%d old-tpt=%d\n",
1943 window->success_ratio, 1943 window->success_ratio,
1944 window->average_tpt, 1944 window->average_tpt,
@@ -1968,7 +1968,7 @@ static void il4965_rs_rate_scale_perform(struct il_priv *priv,
1968 1968
1969 /* (Else) not in search of better modulation mode, try for better 1969 /* (Else) not in search of better modulation mode, try for better
1970 * starting rate, while staying in this mode. */ 1970 * starting rate, while staying in this mode. */
1971 high_low = il4965_rs_get_adjacent_rate(priv, index, 1971 high_low = il4965_rs_get_adjacent_rate(il, index,
1972 rate_scale_index_msk, 1972 rate_scale_index_msk,
1973 tbl->lq_type); 1973 tbl->lq_type);
1974 low = high_low & 0xff; 1974 low = high_low & 0xff;
@@ -1992,7 +1992,7 @@ static void il4965_rs_rate_scale_perform(struct il_priv *priv,
1992 1992
1993 /* Too many failures, decrease rate */ 1993 /* Too many failures, decrease rate */
1994 if ((sr <= IL_RATE_DECREASE_TH) || (current_tpt == 0)) { 1994 if ((sr <= IL_RATE_DECREASE_TH) || (current_tpt == 0)) {
1995 IL_DEBUG_RATE(priv, 1995 IL_DEBUG_RATE(il,
1996 "decrease rate because of low success_ratio\n"); 1996 "decrease rate because of low success_ratio\n");
1997 scale_action = -1; 1997 scale_action = -1;
1998 1998
@@ -2031,7 +2031,7 @@ static void il4965_rs_rate_scale_perform(struct il_priv *priv,
2031 } else if (low_tpt != IL_INVALID_VALUE) { 2031 } else if (low_tpt != IL_INVALID_VALUE) {
2032 /* Lower rate has better throughput */ 2032 /* Lower rate has better throughput */
2033 if (low_tpt > current_tpt) { 2033 if (low_tpt > current_tpt) {
2034 IL_DEBUG_RATE(priv, 2034 IL_DEBUG_RATE(il,
2035 "decrease rate because of low tpt\n"); 2035 "decrease rate because of low tpt\n");
2036 scale_action = -1; 2036 scale_action = -1;
2037 } else if (sr >= IL_RATE_INCREASE_TH) { 2037 } else if (sr >= IL_RATE_INCREASE_TH) {
@@ -2070,14 +2070,14 @@ static void il4965_rs_rate_scale_perform(struct il_priv *priv,
2070 break; 2070 break;
2071 } 2071 }
2072 2072
2073 IL_DEBUG_RATE(priv, "choose rate scale index %d action %d low %d " 2073 IL_DEBUG_RATE(il, "choose rate scale index %d action %d low %d "
2074 "high %d type %d\n", 2074 "high %d type %d\n",
2075 index, scale_action, low, high, tbl->lq_type); 2075 index, scale_action, low, high, tbl->lq_type);
2076 2076
2077lq_update: 2077lq_update:
2078 /* Replace uCode's rate table for the destination station. */ 2078 /* Replace uCode's rate table for the destination station. */
2079 if (update_lq) 2079 if (update_lq)
2080 rate = il4965_rs_update_rate_tbl(priv, ctx, lq_sta, 2080 rate = il4965_rs_update_rate_tbl(il, ctx, lq_sta,
2081 tbl, index, is_green); 2081 tbl, index, is_green);
2082 2082
2083 /* Should we stay with this modulation mode, 2083 /* Should we stay with this modulation mode,
@@ -2098,13 +2098,13 @@ lq_update:
2098 /* Select a new "search" modulation mode to try. 2098 /* Select a new "search" modulation mode to try.
2099 * If one is found, set up the new "search" table. */ 2099 * If one is found, set up the new "search" table. */
2100 if (is_legacy(tbl->lq_type)) 2100 if (is_legacy(tbl->lq_type))
2101 il4965_rs_move_legacy_other(priv, lq_sta, 2101 il4965_rs_move_legacy_other(il, lq_sta,
2102 conf, sta, index); 2102 conf, sta, index);
2103 else if (is_siso(tbl->lq_type)) 2103 else if (is_siso(tbl->lq_type))
2104 il4965_rs_move_siso_to_other(priv, lq_sta, 2104 il4965_rs_move_siso_to_other(il, lq_sta,
2105 conf, sta, index); 2105 conf, sta, index);
2106 else /* (is_mimo2(tbl->lq_type)) */ 2106 else /* (is_mimo2(tbl->lq_type)) */
2107 il4965_rs_move_mimo2_to_other(priv, lq_sta, 2107 il4965_rs_move_mimo2_to_other(il, lq_sta,
2108 conf, sta, index); 2108 conf, sta, index);
2109 2109
2110 /* If new "search" mode was selected, set up in uCode table */ 2110 /* If new "search" mode was selected, set up in uCode table */
@@ -2118,12 +2118,12 @@ lq_update:
2118 /* Use new "search" start rate */ 2118 /* Use new "search" start rate */
2119 index = il4965_hwrate_to_plcp_idx(tbl->current_rate); 2119 index = il4965_hwrate_to_plcp_idx(tbl->current_rate);
2120 2120
2121 IL_DEBUG_RATE(priv, 2121 IL_DEBUG_RATE(il,
2122 "Switch current mcs: %X index: %d\n", 2122 "Switch current mcs: %X index: %d\n",
2123 tbl->current_rate, index); 2123 tbl->current_rate, index);
2124 il4965_rs_fill_link_cmd(priv, lq_sta, 2124 il4965_rs_fill_link_cmd(il, lq_sta,
2125 tbl->current_rate); 2125 tbl->current_rate);
2126 il_send_lq_cmd(priv, ctx, 2126 il_send_lq_cmd(il, ctx,
2127 &lq_sta->lq, CMD_ASYNC, false); 2127 &lq_sta->lq, CMD_ASYNC, false);
2128 } else 2128 } else
2129 done_search = 1; 2129 done_search = 1;
@@ -2138,8 +2138,8 @@ lq_update:
2138 tbl1 = &(lq_sta->lq_info[lq_sta->active_tbl]); 2138 tbl1 = &(lq_sta->lq_info[lq_sta->active_tbl]);
2139 if (is_legacy(tbl1->lq_type) && !conf_is_ht(conf) && 2139 if (is_legacy(tbl1->lq_type) && !conf_is_ht(conf) &&
2140 lq_sta->action_counter > tbl1->max_search) { 2140 lq_sta->action_counter > tbl1->max_search) {
2141 IL_DEBUG_RATE(priv, "LQ: STAY in legacy table\n"); 2141 IL_DEBUG_RATE(il, "LQ: STAY in legacy table\n");
2142 il4965_rs_set_stay_in_table(priv, 1, lq_sta); 2142 il4965_rs_set_stay_in_table(il, 1, lq_sta);
2143 } 2143 }
2144 2144
2145 /* If we're in an HT mode, and all 3 mode switch actions 2145 /* If we're in an HT mode, and all 3 mode switch actions
@@ -2151,21 +2151,21 @@ lq_update:
2151 (lq_sta->tx_agg_tid_en & (1 << tid)) && 2151 (lq_sta->tx_agg_tid_en & (1 << tid)) &&
2152 (tid != MAX_TID_COUNT)) { 2152 (tid != MAX_TID_COUNT)) {
2153 tid_data = 2153 tid_data =
2154 &priv->stations[lq_sta->lq.sta_id].tid[tid]; 2154 &il->stations[lq_sta->lq.sta_id].tid[tid];
2155 if (tid_data->agg.state == IL_AGG_OFF) { 2155 if (tid_data->agg.state == IL_AGG_OFF) {
2156 IL_DEBUG_RATE(priv, 2156 IL_DEBUG_RATE(il,
2157 "try to aggregate tid %d\n", 2157 "try to aggregate tid %d\n",
2158 tid); 2158 tid);
2159 il4965_rs_tl_turn_on_agg(priv, tid, 2159 il4965_rs_tl_turn_on_agg(il, tid,
2160 lq_sta, sta); 2160 lq_sta, sta);
2161 } 2161 }
2162 } 2162 }
2163 il4965_rs_set_stay_in_table(priv, 0, lq_sta); 2163 il4965_rs_set_stay_in_table(il, 0, lq_sta);
2164 } 2164 }
2165 } 2165 }
2166 2166
2167out: 2167out:
2168 tbl->current_rate = il4965_rate_n_flags_from_tbl(priv, tbl, 2168 tbl->current_rate = il4965_rate_n_flags_from_tbl(il, tbl,
2169 index, is_green); 2169 index, is_green);
2170 i = index; 2170 i = index;
2171 lq_sta->last_txrate_idx = i; 2171 lq_sta->last_txrate_idx = i;
@@ -2185,7 +2185,7 @@ out:
2185 * calling this function (which runs REPLY_TX_LINK_QUALITY_CMD, 2185 * calling this function (which runs REPLY_TX_LINK_QUALITY_CMD,
2186 * which requires station table entry to exist). 2186 * which requires station table entry to exist).
2187 */ 2187 */
2188static void il4965_rs_initialize_lq(struct il_priv *priv, 2188static void il4965_rs_initialize_lq(struct il_priv *il,
2189 struct ieee80211_conf *conf, 2189 struct ieee80211_conf *conf,
2190 struct ieee80211_sta *sta, 2190 struct ieee80211_sta *sta,
2191 struct il_lq_sta *lq_sta) 2191 struct il_lq_sta *lq_sta)
@@ -2208,7 +2208,7 @@ static void il4965_rs_initialize_lq(struct il_priv *priv,
2208 2208
2209 i = lq_sta->last_txrate_idx; 2209 i = lq_sta->last_txrate_idx;
2210 2210
2211 valid_tx_ant = priv->hw_params.valid_tx_ant; 2211 valid_tx_ant = il->hw_params.valid_tx_ant;
2212 2212
2213 if (!lq_sta->search_better_tbl) 2213 if (!lq_sta->search_better_tbl)
2214 active_tbl = lq_sta->active_tbl; 2214 active_tbl = lq_sta->active_tbl;
@@ -2227,31 +2227,31 @@ static void il4965_rs_initialize_lq(struct il_priv *priv,
2227 if (i >= IL_FIRST_CCK_RATE && i <= IL_LAST_CCK_RATE) 2227 if (i >= IL_FIRST_CCK_RATE && i <= IL_LAST_CCK_RATE)
2228 rate |= RATE_MCS_CCK_MSK; 2228 rate |= RATE_MCS_CCK_MSK;
2229 2229
2230 il4965_rs_get_tbl_info_from_mcs(rate, priv->band, tbl, &rate_idx); 2230 il4965_rs_get_tbl_info_from_mcs(rate, il->band, tbl, &rate_idx);
2231 if (!il4965_rs_is_valid_ant(valid_tx_ant, tbl->ant_type)) 2231 if (!il4965_rs_is_valid_ant(valid_tx_ant, tbl->ant_type))
2232 il4965_rs_toggle_antenna(valid_tx_ant, &rate, tbl); 2232 il4965_rs_toggle_antenna(valid_tx_ant, &rate, tbl);
2233 2233
2234 rate = il4965_rate_n_flags_from_tbl(priv, tbl, rate_idx, use_green); 2234 rate = il4965_rate_n_flags_from_tbl(il, tbl, rate_idx, use_green);
2235 tbl->current_rate = rate; 2235 tbl->current_rate = rate;
2236 il4965_rs_set_expected_tpt_table(lq_sta, tbl); 2236 il4965_rs_set_expected_tpt_table(lq_sta, tbl);
2237 il4965_rs_fill_link_cmd(NULL, lq_sta, rate); 2237 il4965_rs_fill_link_cmd(NULL, lq_sta, rate);
2238 priv->stations[lq_sta->lq.sta_id].lq = &lq_sta->lq; 2238 il->stations[lq_sta->lq.sta_id].lq = &lq_sta->lq;
2239 il_send_lq_cmd(priv, ctx, &lq_sta->lq, CMD_SYNC, true); 2239 il_send_lq_cmd(il, ctx, &lq_sta->lq, CMD_SYNC, true);
2240} 2240}
2241 2241
2242static void 2242static void
2243il4965_rs_get_rate(void *priv_r, struct ieee80211_sta *sta, void *priv_sta, 2243il4965_rs_get_rate(void *il_r, struct ieee80211_sta *sta, void *il_sta,
2244 struct ieee80211_tx_rate_control *txrc) 2244 struct ieee80211_tx_rate_control *txrc)
2245{ 2245{
2246 2246
2247 struct sk_buff *skb = txrc->skb; 2247 struct sk_buff *skb = txrc->skb;
2248 struct ieee80211_supported_band *sband = txrc->sband; 2248 struct ieee80211_supported_band *sband = txrc->sband;
2249 struct il_priv *priv __maybe_unused = (struct il_priv *)priv_r; 2249 struct il_priv *il __maybe_unused = (struct il_priv *)il_r;
2250 struct ieee80211_tx_info *info = IEEE80211_SKB_CB(skb); 2250 struct ieee80211_tx_info *info = IEEE80211_SKB_CB(skb);
2251 struct il_lq_sta *lq_sta = priv_sta; 2251 struct il_lq_sta *lq_sta = il_sta;
2252 int rate_idx; 2252 int rate_idx;
2253 2253
2254 IL_DEBUG_RATE_LIMIT(priv, "rate scale calculate new rate for skb\n"); 2254 IL_DEBUG_RATE_LIMIT(il, "rate scale calculate new rate for skb\n");
2255 2255
2256 /* Get max rate if user set max rate */ 2256 /* Get max rate if user set max rate */
2257 if (lq_sta) { 2257 if (lq_sta) {
@@ -2266,12 +2266,12 @@ il4965_rs_get_rate(void *priv_r, struct ieee80211_sta *sta, void *priv_sta,
2266 2266
2267 /* Treat uninitialized rate scaling data same as non-existing. */ 2267 /* Treat uninitialized rate scaling data same as non-existing. */
2268 if (lq_sta && !lq_sta->drv) { 2268 if (lq_sta && !lq_sta->drv) {
2269 IL_DEBUG_RATE(priv, "Rate scaling not initialized yet.\n"); 2269 IL_DEBUG_RATE(il, "Rate scaling not initialized yet.\n");
2270 priv_sta = NULL; 2270 il_sta = NULL;
2271 } 2271 }
2272 2272
2273 /* Send management frames and NO_ACK data using lowest rate. */ 2273 /* Send management frames and NO_ACK data using lowest rate. */
2274 if (rate_control_send_low(sta, priv_sta, txrc)) 2274 if (rate_control_send_low(sta, il_sta, txrc))
2275 return; 2275 return;
2276 2276
2277 if (!lq_sta) 2277 if (!lq_sta)
@@ -2314,16 +2314,16 @@ il4965_rs_get_rate(void *priv_r, struct ieee80211_sta *sta, void *priv_sta,
2314 2314
2315} 2315}
2316 2316
2317static void *il4965_rs_alloc_sta(void *priv_rate, struct ieee80211_sta *sta, 2317static void *il4965_rs_alloc_sta(void *il_rate, struct ieee80211_sta *sta,
2318 gfp_t gfp) 2318 gfp_t gfp)
2319{ 2319{
2320 struct il_lq_sta *lq_sta; 2320 struct il_lq_sta *lq_sta;
2321 struct il_station_priv *sta_priv = 2321 struct il_station_priv *sta_priv =
2322 (struct il_station_priv *) sta->drv_priv; 2322 (struct il_station_priv *) sta->drv_priv;
2323 struct il_priv *priv; 2323 struct il_priv *il;
2324 2324
2325 priv = (struct il_priv *)priv_rate; 2325 il = (struct il_priv *)il_rate;
2326 IL_DEBUG_RATE(priv, "create station rate scale window\n"); 2326 IL_DEBUG_RATE(il, "create station rate scale window\n");
2327 2327
2328 lq_sta = &sta_priv->lq_sta; 2328 lq_sta = &sta_priv->lq_sta;
2329 2329
@@ -2334,13 +2334,13 @@ static void *il4965_rs_alloc_sta(void *priv_rate, struct ieee80211_sta *sta,
2334 * Called after adding a new station to initialize rate scaling 2334 * Called after adding a new station to initialize rate scaling
2335 */ 2335 */
2336void 2336void
2337il4965_rs_rate_init(struct il_priv *priv, 2337il4965_rs_rate_init(struct il_priv *il,
2338 struct ieee80211_sta *sta, 2338 struct ieee80211_sta *sta,
2339 u8 sta_id) 2339 u8 sta_id)
2340{ 2340{
2341 int i, j; 2341 int i, j;
2342 struct ieee80211_hw *hw = priv->hw; 2342 struct ieee80211_hw *hw = il->hw;
2343 struct ieee80211_conf *conf = &priv->hw->conf; 2343 struct ieee80211_conf *conf = &il->hw->conf;
2344 struct ieee80211_sta_ht_cap *ht_cap = &sta->ht_cap; 2344 struct ieee80211_sta_ht_cap *ht_cap = &sta->ht_cap;
2345 struct il_station_priv *sta_priv; 2345 struct il_station_priv *sta_priv;
2346 struct il_lq_sta *lq_sta; 2346 struct il_lq_sta *lq_sta;
@@ -2365,7 +2365,7 @@ il4965_rs_rate_init(struct il_priv *priv,
2365 il4965_rs_rate_scale_clear_window( 2365 il4965_rs_rate_scale_clear_window(
2366 &lq_sta->lq_info[j].win[i]); 2366 &lq_sta->lq_info[j].win[i]);
2367 2367
2368 IL_DEBUG_RATE(priv, "LQ:" 2368 IL_DEBUG_RATE(il, "LQ:"
2369 "*** rate scale station global init for station %d ***\n", 2369 "*** rate scale station global init for station %d ***\n",
2370 sta_id); 2370 sta_id);
2371 /* TODO: what is a good starting rate for STA? About middle? Maybe not 2371 /* TODO: what is a good starting rate for STA? About middle? Maybe not
@@ -2377,8 +2377,8 @@ il4965_rs_rate_init(struct il_priv *priv,
2377 lq_sta->max_rate_idx = -1; 2377 lq_sta->max_rate_idx = -1;
2378 lq_sta->missed_rate_counter = IL_MISSED_RATE_MAX; 2378 lq_sta->missed_rate_counter = IL_MISSED_RATE_MAX;
2379 lq_sta->is_green = il4965_rs_use_green(sta); 2379 lq_sta->is_green = il4965_rs_use_green(sta);
2380 lq_sta->active_legacy_rate = priv->active_rate & ~(0x1000); 2380 lq_sta->active_legacy_rate = il->active_rate & ~(0x1000);
2381 lq_sta->band = priv->band; 2381 lq_sta->band = il->band;
2382 /* 2382 /*
2383 * active_siso_rate mask includes 9 MBits (bit 5), and CCK (bits 0-3), 2383 * active_siso_rate mask includes 9 MBits (bit 5), and CCK (bits 0-3),
2384 * supp_rates[] does not; shift to convert format, force 9 MBits off. 2384 * supp_rates[] does not; shift to convert format, force 9 MBits off.
@@ -2396,20 +2396,20 @@ il4965_rs_rate_init(struct il_priv *priv,
2396 2396
2397 /* These values will be overridden later */ 2397 /* These values will be overridden later */
2398 lq_sta->lq.general_params.single_stream_ant_msk = 2398 lq_sta->lq.general_params.single_stream_ant_msk =
2399 il4965_first_antenna(priv->hw_params.valid_tx_ant); 2399 il4965_first_antenna(il->hw_params.valid_tx_ant);
2400 lq_sta->lq.general_params.dual_stream_ant_msk = 2400 lq_sta->lq.general_params.dual_stream_ant_msk =
2401 priv->hw_params.valid_tx_ant & 2401 il->hw_params.valid_tx_ant &
2402 ~il4965_first_antenna(priv->hw_params.valid_tx_ant); 2402 ~il4965_first_antenna(il->hw_params.valid_tx_ant);
2403 if (!lq_sta->lq.general_params.dual_stream_ant_msk) { 2403 if (!lq_sta->lq.general_params.dual_stream_ant_msk) {
2404 lq_sta->lq.general_params.dual_stream_ant_msk = ANT_AB; 2404 lq_sta->lq.general_params.dual_stream_ant_msk = ANT_AB;
2405 } else if (il4965_num_of_ant(priv->hw_params.valid_tx_ant) == 2) { 2405 } else if (il4965_num_of_ant(il->hw_params.valid_tx_ant) == 2) {
2406 lq_sta->lq.general_params.dual_stream_ant_msk = 2406 lq_sta->lq.general_params.dual_stream_ant_msk =
2407 priv->hw_params.valid_tx_ant; 2407 il->hw_params.valid_tx_ant;
2408 } 2408 }
2409 2409
2410 /* as default allow aggregation for all tids */ 2410 /* as default allow aggregation for all tids */
2411 lq_sta->tx_agg_tid_en = IL_AGG_ALL_TID; 2411 lq_sta->tx_agg_tid_en = IL_AGG_ALL_TID;
2412 lq_sta->drv = priv; 2412 lq_sta->drv = il;
2413 2413
2414 /* Set last_txrate_idx to lowest rate */ 2414 /* Set last_txrate_idx to lowest rate */
2415 lq_sta->last_txrate_idx = rate_lowest_index(sband, sta); 2415 lq_sta->last_txrate_idx = rate_lowest_index(sband, sta);
@@ -2421,10 +2421,10 @@ il4965_rs_rate_init(struct il_priv *priv,
2421 lq_sta->dbg_fixed_rate = 0; 2421 lq_sta->dbg_fixed_rate = 0;
2422#endif 2422#endif
2423 2423
2424 il4965_rs_initialize_lq(priv, conf, sta, lq_sta); 2424 il4965_rs_initialize_lq(il, conf, sta, lq_sta);
2425} 2425}
2426 2426
2427static void il4965_rs_fill_link_cmd(struct il_priv *priv, 2427static void il4965_rs_fill_link_cmd(struct il_priv *il,
2428 struct il_lq_sta *lq_sta, u32 new_rate) 2428 struct il_lq_sta *lq_sta, u32 new_rate)
2429{ 2429{
2430 struct il_scale_tbl_info tbl_type; 2430 struct il_scale_tbl_info tbl_type;
@@ -2467,8 +2467,8 @@ static void il4965_rs_fill_link_cmd(struct il_priv *priv,
2467 2467
2468 index++; 2468 index++;
2469 repeat_rate--; 2469 repeat_rate--;
2470 if (priv) 2470 if (il)
2471 valid_tx_ant = priv->hw_params.valid_tx_ant; 2471 valid_tx_ant = il->hw_params.valid_tx_ant;
2472 2472
2473 /* Fill rest of rate table */ 2473 /* Fill rest of rate table */
2474 while (index < LINK_QUAL_MAX_RETRY_NUM) { 2474 while (index < LINK_QUAL_MAX_RETRY_NUM) {
@@ -2479,7 +2479,7 @@ static void il4965_rs_fill_link_cmd(struct il_priv *priv,
2479 if (is_legacy(tbl_type.lq_type)) { 2479 if (is_legacy(tbl_type.lq_type)) {
2480 if (ant_toggle_cnt < NUM_TRY_BEFORE_ANT_TOGGLE) 2480 if (ant_toggle_cnt < NUM_TRY_BEFORE_ANT_TOGGLE)
2481 ant_toggle_cnt++; 2481 ant_toggle_cnt++;
2482 else if (priv && 2482 else if (il &&
2483 il4965_rs_toggle_antenna(valid_tx_ant, 2483 il4965_rs_toggle_antenna(valid_tx_ant,
2484 &new_rate, &tbl_type)) 2484 &new_rate, &tbl_type))
2485 ant_toggle_cnt = 1; 2485 ant_toggle_cnt = 1;
@@ -2514,7 +2514,7 @@ static void il4965_rs_fill_link_cmd(struct il_priv *priv,
2514 if (is_legacy(tbl_type.lq_type)) { 2514 if (is_legacy(tbl_type.lq_type)) {
2515 if (ant_toggle_cnt < NUM_TRY_BEFORE_ANT_TOGGLE) 2515 if (ant_toggle_cnt < NUM_TRY_BEFORE_ANT_TOGGLE)
2516 ant_toggle_cnt++; 2516 ant_toggle_cnt++;
2517 else if (priv && 2517 else if (il &&
2518 il4965_rs_toggle_antenna(valid_tx_ant, 2518 il4965_rs_toggle_antenna(valid_tx_ant,
2519 &new_rate, &tbl_type)) 2519 &new_rate, &tbl_type))
2520 ant_toggle_cnt = 1; 2520 ant_toggle_cnt = 1;
@@ -2551,18 +2551,18 @@ static void
2551 return hw->priv; 2551 return hw->priv;
2552} 2552}
2553/* rate scale requires free function to be implemented */ 2553/* rate scale requires free function to be implemented */
2554static void il4965_rs_free(void *priv_rate) 2554static void il4965_rs_free(void *il_rate)
2555{ 2555{
2556 return; 2556 return;
2557} 2557}
2558 2558
2559static void il4965_rs_free_sta(void *priv_r, struct ieee80211_sta *sta, 2559static void il4965_rs_free_sta(void *il_r, struct ieee80211_sta *sta,
2560 void *priv_sta) 2560 void *il_sta)
2561{ 2561{
2562 struct il_priv *priv __maybe_unused = priv_r; 2562 struct il_priv *il __maybe_unused = il_r;
2563 2563
2564 IL_DEBUG_RATE(priv, "enter\n"); 2564 IL_DEBUG_RATE(il, "enter\n");
2565 IL_DEBUG_RATE(priv, "leave\n"); 2565 IL_DEBUG_RATE(il, "leave\n");
2566} 2566}
2567 2567
2568 2568
@@ -2575,28 +2575,28 @@ static int il4965_open_file_generic(struct inode *inode, struct file *file)
2575static void il4965_rs_dbgfs_set_mcs(struct il_lq_sta *lq_sta, 2575static void il4965_rs_dbgfs_set_mcs(struct il_lq_sta *lq_sta,
2576 u32 *rate_n_flags, int index) 2576 u32 *rate_n_flags, int index)
2577{ 2577{
2578 struct il_priv *priv; 2578 struct il_priv *il;
2579 u8 valid_tx_ant; 2579 u8 valid_tx_ant;
2580 u8 ant_sel_tx; 2580 u8 ant_sel_tx;
2581 2581
2582 priv = lq_sta->drv; 2582 il = lq_sta->drv;
2583 valid_tx_ant = priv->hw_params.valid_tx_ant; 2583 valid_tx_ant = il->hw_params.valid_tx_ant;
2584 if (lq_sta->dbg_fixed_rate) { 2584 if (lq_sta->dbg_fixed_rate) {
2585 ant_sel_tx = 2585 ant_sel_tx =
2586 ((lq_sta->dbg_fixed_rate & RATE_MCS_ANT_ABC_MSK) 2586 ((lq_sta->dbg_fixed_rate & RATE_MCS_ANT_ABC_MSK)
2587 >> RATE_MCS_ANT_POS); 2587 >> RATE_MCS_ANT_POS);
2588 if ((valid_tx_ant & ant_sel_tx) == ant_sel_tx) { 2588 if ((valid_tx_ant & ant_sel_tx) == ant_sel_tx) {
2589 *rate_n_flags = lq_sta->dbg_fixed_rate; 2589 *rate_n_flags = lq_sta->dbg_fixed_rate;
2590 IL_DEBUG_RATE(priv, "Fixed rate ON\n"); 2590 IL_DEBUG_RATE(il, "Fixed rate ON\n");
2591 } else { 2591 } else {
2592 lq_sta->dbg_fixed_rate = 0; 2592 lq_sta->dbg_fixed_rate = 0;
2593 IL_ERR(priv, 2593 IL_ERR(il,
2594 "Invalid antenna selection 0x%X, Valid is 0x%X\n", 2594 "Invalid antenna selection 0x%X, Valid is 0x%X\n",
2595 ant_sel_tx, valid_tx_ant); 2595 ant_sel_tx, valid_tx_ant);
2596 IL_DEBUG_RATE(priv, "Fixed rate OFF\n"); 2596 IL_DEBUG_RATE(il, "Fixed rate OFF\n");
2597 } 2597 }
2598 } else { 2598 } else {
2599 IL_DEBUG_RATE(priv, "Fixed rate OFF\n"); 2599 IL_DEBUG_RATE(il, "Fixed rate OFF\n");
2600 } 2600 }
2601} 2601}
2602 2602
@@ -2604,7 +2604,7 @@ static ssize_t il4965_rs_sta_dbgfs_scale_table_write(struct file *file,
2604 const char __user *user_buf, size_t count, loff_t *ppos) 2604 const char __user *user_buf, size_t count, loff_t *ppos)
2605{ 2605{
2606 struct il_lq_sta *lq_sta = file->private_data; 2606 struct il_lq_sta *lq_sta = file->private_data;
2607 struct il_priv *priv; 2607 struct il_priv *il;
2608 char buf[64]; 2608 char buf[64];
2609 size_t buf_size; 2609 size_t buf_size;
2610 u32 parsed_rate; 2610 u32 parsed_rate;
@@ -2612,7 +2612,7 @@ static ssize_t il4965_rs_sta_dbgfs_scale_table_write(struct file *file,
2612 container_of(lq_sta, struct il_station_priv, lq_sta); 2612 container_of(lq_sta, struct il_station_priv, lq_sta);
2613 struct il_rxon_context *ctx = sta_priv->common.ctx; 2613 struct il_rxon_context *ctx = sta_priv->common.ctx;
2614 2614
2615 priv = lq_sta->drv; 2615 il = lq_sta->drv;
2616 memset(buf, 0, sizeof(buf)); 2616 memset(buf, 0, sizeof(buf));
2617 buf_size = min(count, sizeof(buf) - 1); 2617 buf_size = min(count, sizeof(buf) - 1);
2618 if (copy_from_user(buf, user_buf, buf_size)) 2618 if (copy_from_user(buf, user_buf, buf_size))
@@ -2627,7 +2627,7 @@ static ssize_t il4965_rs_sta_dbgfs_scale_table_write(struct file *file,
2627 lq_sta->active_siso_rate = 0x1FD0; /* 6 - 60 MBits, no 9, no CCK */ 2627 lq_sta->active_siso_rate = 0x1FD0; /* 6 - 60 MBits, no 9, no CCK */
2628 lq_sta->active_mimo2_rate = 0x1FD0; /* 6 - 60 MBits, no 9, no CCK */ 2628 lq_sta->active_mimo2_rate = 0x1FD0; /* 6 - 60 MBits, no 9, no CCK */
2629 2629
2630 IL_DEBUG_RATE(priv, "sta_id %d rate 0x%X\n", 2630 IL_DEBUG_RATE(il, "sta_id %d rate 0x%X\n",
2631 lq_sta->lq.sta_id, lq_sta->dbg_fixed_rate); 2631 lq_sta->lq.sta_id, lq_sta->dbg_fixed_rate);
2632 2632
2633 if (lq_sta->dbg_fixed_rate) { 2633 if (lq_sta->dbg_fixed_rate) {
@@ -2649,10 +2649,10 @@ static ssize_t il4965_rs_sta_dbgfs_scale_table_read(struct file *file,
2649 ssize_t ret; 2649 ssize_t ret;
2650 2650
2651 struct il_lq_sta *lq_sta = file->private_data; 2651 struct il_lq_sta *lq_sta = file->private_data;
2652 struct il_priv *priv; 2652 struct il_priv *il;
2653 struct il_scale_tbl_info *tbl = &(lq_sta->lq_info[lq_sta->active_tbl]); 2653 struct il_scale_tbl_info *tbl = &(lq_sta->lq_info[lq_sta->active_tbl]);
2654 2654
2655 priv = lq_sta->drv; 2655 il = lq_sta->drv;
2656 buff = kmalloc(1024, GFP_KERNEL); 2656 buff = kmalloc(1024, GFP_KERNEL);
2657 if (!buff) 2657 if (!buff)
2658 return -ENOMEM; 2658 return -ENOMEM;
@@ -2664,9 +2664,9 @@ static ssize_t il4965_rs_sta_dbgfs_scale_table_read(struct file *file,
2664 desc += sprintf(buff+desc, "fixed rate 0x%X\n", 2664 desc += sprintf(buff+desc, "fixed rate 0x%X\n",
2665 lq_sta->dbg_fixed_rate); 2665 lq_sta->dbg_fixed_rate);
2666 desc += sprintf(buff+desc, "valid_tx_ant %s%s%s\n", 2666 desc += sprintf(buff+desc, "valid_tx_ant %s%s%s\n",
2667 (priv->hw_params.valid_tx_ant & ANT_A) ? "ANT_A," : "", 2667 (il->hw_params.valid_tx_ant & ANT_A) ? "ANT_A," : "",
2668 (priv->hw_params.valid_tx_ant & ANT_B) ? "ANT_B," : "", 2668 (il->hw_params.valid_tx_ant & ANT_B) ? "ANT_B," : "",
2669 (priv->hw_params.valid_tx_ant & ANT_C) ? "ANT_C" : ""); 2669 (il->hw_params.valid_tx_ant & ANT_C) ? "ANT_C" : "");
2670 desc += sprintf(buff+desc, "lq type %s\n", 2670 desc += sprintf(buff+desc, "lq type %s\n",
2671 (is_legacy(tbl->lq_type)) ? "legacy" : "HT"); 2671 (is_legacy(tbl->lq_type)) ? "legacy" : "HT");
2672 if (is_Ht(tbl->lq_type)) { 2672 if (is_Ht(tbl->lq_type)) {
@@ -2781,10 +2781,10 @@ static ssize_t il4965_rs_sta_dbgfs_rate_scale_data_read(struct file *file,
2781 ssize_t ret; 2781 ssize_t ret;
2782 2782
2783 struct il_lq_sta *lq_sta = file->private_data; 2783 struct il_lq_sta *lq_sta = file->private_data;
2784 struct il_priv *priv; 2784 struct il_priv *il;
2785 struct il_scale_tbl_info *tbl = &lq_sta->lq_info[lq_sta->active_tbl]; 2785 struct il_scale_tbl_info *tbl = &lq_sta->lq_info[lq_sta->active_tbl];
2786 2786
2787 priv = lq_sta->drv; 2787 il = lq_sta->drv;
2788 2788
2789 if (is_Ht(tbl->lq_type)) 2789 if (is_Ht(tbl->lq_type))
2790 desc += sprintf(buff+desc, 2790 desc += sprintf(buff+desc,
@@ -2805,10 +2805,10 @@ static const struct file_operations rs_sta_dbgfs_rate_scale_data_ops = {
2805 .llseek = default_llseek, 2805 .llseek = default_llseek,
2806}; 2806};
2807 2807
2808static void il4965_rs_add_debugfs(void *priv, void *priv_sta, 2808static void il4965_rs_add_debugfs(void *il, void *il_sta,
2809 struct dentry *dir) 2809 struct dentry *dir)
2810{ 2810{
2811 struct il_lq_sta *lq_sta = priv_sta; 2811 struct il_lq_sta *lq_sta = il_sta;
2812 lq_sta->rs_sta_dbgfs_scale_table_file = 2812 lq_sta->rs_sta_dbgfs_scale_table_file =
2813 debugfs_create_file("rate_scale_table", S_IRUSR | S_IWUSR, dir, 2813 debugfs_create_file("rate_scale_table", S_IRUSR | S_IWUSR, dir,
2814 lq_sta, &rs_sta_dbgfs_scale_table_ops); 2814 lq_sta, &rs_sta_dbgfs_scale_table_ops);
@@ -2824,9 +2824,9 @@ static void il4965_rs_add_debugfs(void *priv, void *priv_sta,
2824 2824
2825} 2825}
2826 2826
2827static void il4965_rs_remove_debugfs(void *priv, void *priv_sta) 2827static void il4965_rs_remove_debugfs(void *il, void *il_sta)
2828{ 2828{
2829 struct il_lq_sta *lq_sta = priv_sta; 2829 struct il_lq_sta *lq_sta = il_sta;
2830 debugfs_remove(lq_sta->rs_sta_dbgfs_scale_table_file); 2830 debugfs_remove(lq_sta->rs_sta_dbgfs_scale_table_file);
2831 debugfs_remove(lq_sta->rs_sta_dbgfs_stats_table_file); 2831 debugfs_remove(lq_sta->rs_sta_dbgfs_stats_table_file);
2832 debugfs_remove(lq_sta->rs_sta_dbgfs_rate_scale_data_file); 2832 debugfs_remove(lq_sta->rs_sta_dbgfs_rate_scale_data_file);
@@ -2840,8 +2840,8 @@ static void il4965_rs_remove_debugfs(void *priv, void *priv_sta)
2840 * station is added we ignore it. 2840 * station is added we ignore it.
2841 */ 2841 */
2842static void 2842static void
2843il4965_rs_rate_init_stub(void *priv_r, struct ieee80211_supported_band *sband, 2843il4965_rs_rate_init_stub(void *il_r, struct ieee80211_supported_band *sband,
2844 struct ieee80211_sta *sta, void *priv_sta) 2844 struct ieee80211_sta *sta, void *il_sta)
2845{ 2845{
2846} 2846}
2847static struct rate_control_ops rs_4965_ops = { 2847static struct rate_control_ops rs_4965_ops = {
diff --git a/drivers/net/wireless/iwlegacy/iwl-4965-rx.c b/drivers/net/wireless/iwlegacy/iwl-4965-rx.c
index 47cbe565a530..c987c80a37cf 100644
--- a/drivers/net/wireless/iwlegacy/iwl-4965-rx.c
+++ b/drivers/net/wireless/iwlegacy/iwl-4965-rx.c
@@ -41,7 +41,7 @@
41#include "iwl-4965-hw.h" 41#include "iwl-4965-hw.h"
42#include "iwl-4965.h" 42#include "iwl-4965.h"
43 43
44void il4965_rx_missed_beacon_notif(struct il_priv *priv, 44void il4965_rx_missed_beacon_notif(struct il_priv *il,
45 struct il_rx_mem_buffer *rxb) 45 struct il_rx_mem_buffer *rxb)
46 46
47{ 47{
@@ -50,22 +50,22 @@ void il4965_rx_missed_beacon_notif(struct il_priv *priv,
50 50
51 missed_beacon = &pkt->u.missed_beacon; 51 missed_beacon = &pkt->u.missed_beacon;
52 if (le32_to_cpu(missed_beacon->consecutive_missed_beacons) > 52 if (le32_to_cpu(missed_beacon->consecutive_missed_beacons) >
53 priv->missed_beacon_threshold) { 53 il->missed_beacon_threshold) {
54 IL_DEBUG_CALIB(priv, 54 IL_DEBUG_CALIB(il,
55 "missed bcn cnsq %d totl %d rcd %d expctd %d\n", 55 "missed bcn cnsq %d totl %d rcd %d expctd %d\n",
56 le32_to_cpu(missed_beacon->consecutive_missed_beacons), 56 le32_to_cpu(missed_beacon->consecutive_missed_beacons),
57 le32_to_cpu(missed_beacon->total_missed_becons), 57 le32_to_cpu(missed_beacon->total_missed_becons),
58 le32_to_cpu(missed_beacon->num_recvd_beacons), 58 le32_to_cpu(missed_beacon->num_recvd_beacons),
59 le32_to_cpu(missed_beacon->num_expected_beacons)); 59 le32_to_cpu(missed_beacon->num_expected_beacons));
60 if (!test_bit(STATUS_SCANNING, &priv->status)) 60 if (!test_bit(STATUS_SCANNING, &il->status))
61 il4965_init_sensitivity(priv); 61 il4965_init_sensitivity(il);
62 } 62 }
63} 63}
64 64
65/* Calculate noise level, based on measurements during network silence just 65/* Calculate noise level, based on measurements during network silence just
66 * before arriving beacon. This measurement can be done only if we know 66 * before arriving beacon. This measurement can be done only if we know
67 * exactly when to expect beacons, therefore only when we're associated. */ 67 * exactly when to expect beacons, therefore only when we're associated. */
68static void il4965_rx_calc_noise(struct il_priv *priv) 68static void il4965_rx_calc_noise(struct il_priv *il)
69{ 69{
70 struct statistics_rx_non_phy *rx_info; 70 struct statistics_rx_non_phy *rx_info;
71 int num_active_rx = 0; 71 int num_active_rx = 0;
@@ -73,7 +73,7 @@ static void il4965_rx_calc_noise(struct il_priv *priv)
73 int bcn_silence_a, bcn_silence_b, bcn_silence_c; 73 int bcn_silence_a, bcn_silence_b, bcn_silence_c;
74 int last_rx_noise; 74 int last_rx_noise;
75 75
76 rx_info = &(priv->_4965.statistics.rx.general); 76 rx_info = &(il->_4965.statistics.rx.general);
77 bcn_silence_a = 77 bcn_silence_a =
78 le32_to_cpu(rx_info->beacon_silence_rssi_a) & IN_BAND_FILTER; 78 le32_to_cpu(rx_info->beacon_silence_rssi_a) & IN_BAND_FILTER;
79 bcn_silence_b = 79 bcn_silence_b =
@@ -100,7 +100,7 @@ static void il4965_rx_calc_noise(struct il_priv *priv)
100 else 100 else
101 last_rx_noise = IL_NOISE_MEAS_NOT_AVAILABLE; 101 last_rx_noise = IL_NOISE_MEAS_NOT_AVAILABLE;
102 102
103 IL_DEBUG_CALIB(priv, "inband silence a %u, b %u, c %u, dBm %d\n", 103 IL_DEBUG_CALIB(il, "inband silence a %u, b %u, c %u, dBm %d\n",
104 bcn_silence_a, bcn_silence_b, bcn_silence_c, 104 bcn_silence_a, bcn_silence_b, bcn_silence_c,
105 last_rx_noise); 105 last_rx_noise);
106} 106}
@@ -111,7 +111,7 @@ static void il4965_rx_calc_noise(struct il_priv *priv)
111 * FIXME: This function is for debugging, do not deal with 111 * FIXME: This function is for debugging, do not deal with
112 * the case of counters roll-over. 112 * the case of counters roll-over.
113 */ 113 */
114static void il4965_accumulative_statistics(struct il_priv *priv, 114static void il4965_accumulative_statistics(struct il_priv *il,
115 __le32 *stats) 115 __le32 *stats)
116{ 116{
117 int i, size; 117 int i, size;
@@ -121,15 +121,15 @@ static void il4965_accumulative_statistics(struct il_priv *priv,
121 struct statistics_general_common *general, *accum_general; 121 struct statistics_general_common *general, *accum_general;
122 struct statistics_tx *tx, *accum_tx; 122 struct statistics_tx *tx, *accum_tx;
123 123
124 prev_stats = (__le32 *)&priv->_4965.statistics; 124 prev_stats = (__le32 *)&il->_4965.statistics;
125 accum_stats = (u32 *)&priv->_4965.accum_statistics; 125 accum_stats = (u32 *)&il->_4965.accum_statistics;
126 size = sizeof(struct il_notif_statistics); 126 size = sizeof(struct il_notif_statistics);
127 general = &priv->_4965.statistics.general.common; 127 general = &il->_4965.statistics.general.common;
128 accum_general = &priv->_4965.accum_statistics.general.common; 128 accum_general = &il->_4965.accum_statistics.general.common;
129 tx = &priv->_4965.statistics.tx; 129 tx = &il->_4965.statistics.tx;
130 accum_tx = &priv->_4965.accum_statistics.tx; 130 accum_tx = &il->_4965.accum_statistics.tx;
131 delta = (u32 *)&priv->_4965.delta_statistics; 131 delta = (u32 *)&il->_4965.delta_statistics;
132 max_delta = (u32 *)&priv->_4965.max_delta; 132 max_delta = (u32 *)&il->_4965.max_delta;
133 133
134 for (i = sizeof(__le32); i < size; 134 for (i = sizeof(__le32); i < size;
135 i += sizeof(__le32), stats++, prev_stats++, delta++, 135 i += sizeof(__le32), stats++, prev_stats++, delta++,
@@ -151,65 +151,65 @@ static void il4965_accumulative_statistics(struct il_priv *priv,
151 151
152#define REG_RECALIB_PERIOD (60) 152#define REG_RECALIB_PERIOD (60)
153 153
154void il4965_rx_statistics(struct il_priv *priv, 154void il4965_rx_statistics(struct il_priv *il,
155 struct il_rx_mem_buffer *rxb) 155 struct il_rx_mem_buffer *rxb)
156{ 156{
157 int change; 157 int change;
158 struct il_rx_packet *pkt = rxb_addr(rxb); 158 struct il_rx_packet *pkt = rxb_addr(rxb);
159 159
160 IL_DEBUG_RX(priv, 160 IL_DEBUG_RX(il,
161 "Statistics notification received (%d vs %d).\n", 161 "Statistics notification received (%d vs %d).\n",
162 (int)sizeof(struct il_notif_statistics), 162 (int)sizeof(struct il_notif_statistics),
163 le32_to_cpu(pkt->len_n_flags) & 163 le32_to_cpu(pkt->len_n_flags) &
164 FH_RSCSR_FRAME_SIZE_MSK); 164 FH_RSCSR_FRAME_SIZE_MSK);
165 165
166 change = ((priv->_4965.statistics.general.common.temperature != 166 change = ((il->_4965.statistics.general.common.temperature !=
167 pkt->u.stats.general.common.temperature) || 167 pkt->u.stats.general.common.temperature) ||
168 ((priv->_4965.statistics.flag & 168 ((il->_4965.statistics.flag &
169 STATISTICS_REPLY_FLG_HT40_MODE_MSK) != 169 STATISTICS_REPLY_FLG_HT40_MODE_MSK) !=
170 (pkt->u.stats.flag & 170 (pkt->u.stats.flag &
171 STATISTICS_REPLY_FLG_HT40_MODE_MSK))); 171 STATISTICS_REPLY_FLG_HT40_MODE_MSK)));
172#ifdef CONFIG_IWLWIFI_LEGACY_DEBUGFS 172#ifdef CONFIG_IWLWIFI_LEGACY_DEBUGFS
173 il4965_accumulative_statistics(priv, (__le32 *)&pkt->u.stats); 173 il4965_accumulative_statistics(il, (__le32 *)&pkt->u.stats);
174#endif 174#endif
175 175
176 /* TODO: reading some of statistics is unneeded */ 176 /* TODO: reading some of statistics is unneeded */
177 memcpy(&priv->_4965.statistics, &pkt->u.stats, 177 memcpy(&il->_4965.statistics, &pkt->u.stats,
178 sizeof(priv->_4965.statistics)); 178 sizeof(il->_4965.statistics));
179 179
180 set_bit(STATUS_STATISTICS, &priv->status); 180 set_bit(STATUS_STATISTICS, &il->status);
181 181
182 /* Reschedule the statistics timer to occur in 182 /* Reschedule the statistics timer to occur in
183 * REG_RECALIB_PERIOD seconds to ensure we get a 183 * REG_RECALIB_PERIOD seconds to ensure we get a
184 * thermal update even if the uCode doesn't give 184 * thermal update even if the uCode doesn't give
185 * us one */ 185 * us one */
186 mod_timer(&priv->statistics_periodic, jiffies + 186 mod_timer(&il->statistics_periodic, jiffies +
187 msecs_to_jiffies(REG_RECALIB_PERIOD * 1000)); 187 msecs_to_jiffies(REG_RECALIB_PERIOD * 1000));
188 188
189 if (unlikely(!test_bit(STATUS_SCANNING, &priv->status)) && 189 if (unlikely(!test_bit(STATUS_SCANNING, &il->status)) &&
190 (pkt->hdr.cmd == STATISTICS_NOTIFICATION)) { 190 (pkt->hdr.cmd == STATISTICS_NOTIFICATION)) {
191 il4965_rx_calc_noise(priv); 191 il4965_rx_calc_noise(il);
192 queue_work(priv->workqueue, &priv->run_time_calib_work); 192 queue_work(il->workqueue, &il->run_time_calib_work);
193 } 193 }
194 if (priv->cfg->ops->lib->temp_ops.temperature && change) 194 if (il->cfg->ops->lib->temp_ops.temperature && change)
195 priv->cfg->ops->lib->temp_ops.temperature(priv); 195 il->cfg->ops->lib->temp_ops.temperature(il);
196} 196}
197 197
198void il4965_reply_statistics(struct il_priv *priv, 198void il4965_reply_statistics(struct il_priv *il,
199 struct il_rx_mem_buffer *rxb) 199 struct il_rx_mem_buffer *rxb)
200{ 200{
201 struct il_rx_packet *pkt = rxb_addr(rxb); 201 struct il_rx_packet *pkt = rxb_addr(rxb);
202 202
203 if (le32_to_cpu(pkt->u.stats.flag) & UCODE_STATISTICS_CLEAR_MSK) { 203 if (le32_to_cpu(pkt->u.stats.flag) & UCODE_STATISTICS_CLEAR_MSK) {
204#ifdef CONFIG_IWLWIFI_LEGACY_DEBUGFS 204#ifdef CONFIG_IWLWIFI_LEGACY_DEBUGFS
205 memset(&priv->_4965.accum_statistics, 0, 205 memset(&il->_4965.accum_statistics, 0,
206 sizeof(struct il_notif_statistics)); 206 sizeof(struct il_notif_statistics));
207 memset(&priv->_4965.delta_statistics, 0, 207 memset(&il->_4965.delta_statistics, 0,
208 sizeof(struct il_notif_statistics)); 208 sizeof(struct il_notif_statistics));
209 memset(&priv->_4965.max_delta, 0, 209 memset(&il->_4965.max_delta, 0,
210 sizeof(struct il_notif_statistics)); 210 sizeof(struct il_notif_statistics));
211#endif 211#endif
212 IL_DEBUG_RX(priv, "Statistics have been cleared\n"); 212 IL_DEBUG_RX(il, "Statistics have been cleared\n");
213 } 213 }
214 il4965_rx_statistics(priv, rxb); 214 il4965_rx_statistics(il, rxb);
215} 215}
diff --git a/drivers/net/wireless/iwlegacy/iwl-4965-sta.c b/drivers/net/wireless/iwlegacy/iwl-4965-sta.c
index 3ac9aef439a6..20290d24fd62 100644
--- a/drivers/net/wireless/iwlegacy/iwl-4965-sta.c
+++ b/drivers/net/wireless/iwlegacy/iwl-4965-sta.c
@@ -35,7 +35,7 @@
35#include "iwl-4965.h" 35#include "iwl-4965.h"
36 36
37static struct il_link_quality_cmd * 37static struct il_link_quality_cmd *
38il4965_sta_alloc_lq(struct il_priv *priv, u8 sta_id) 38il4965_sta_alloc_lq(struct il_priv *il, u8 sta_id)
39{ 39{
40 int i, r; 40 int i, r;
41 struct il_link_quality_cmd *link_cmd; 41 struct il_link_quality_cmd *link_cmd;
@@ -44,12 +44,12 @@ il4965_sta_alloc_lq(struct il_priv *priv, u8 sta_id)
44 44
45 link_cmd = kzalloc(sizeof(struct il_link_quality_cmd), GFP_KERNEL); 45 link_cmd = kzalloc(sizeof(struct il_link_quality_cmd), GFP_KERNEL);
46 if (!link_cmd) { 46 if (!link_cmd) {
47 IL_ERR(priv, "Unable to allocate memory for LQ cmd.\n"); 47 IL_ERR(il, "Unable to allocate memory for LQ cmd.\n");
48 return NULL; 48 return NULL;
49 } 49 }
50 /* Set up the rate scaling to start at selected rate, fall back 50 /* Set up the rate scaling to start at selected rate, fall back
51 * all the way down to 1M in IEEE order, and then spin on 1M */ 51 * all the way down to 1M in IEEE order, and then spin on 1M */
52 if (priv->band == IEEE80211_BAND_5GHZ) 52 if (il->band == IEEE80211_BAND_5GHZ)
53 r = IL_RATE_6M_INDEX; 53 r = IL_RATE_6M_INDEX;
54 else 54 else
55 r = IL_RATE_1M_INDEX; 55 r = IL_RATE_1M_INDEX;
@@ -57,7 +57,7 @@ il4965_sta_alloc_lq(struct il_priv *priv, u8 sta_id)
57 if (r >= IL_FIRST_CCK_RATE && r <= IL_LAST_CCK_RATE) 57 if (r >= IL_FIRST_CCK_RATE && r <= IL_LAST_CCK_RATE)
58 rate_flags |= RATE_MCS_CCK_MSK; 58 rate_flags |= RATE_MCS_CCK_MSK;
59 59
60 rate_flags |= il4965_first_antenna(priv->hw_params.valid_tx_ant) << 60 rate_flags |= il4965_first_antenna(il->hw_params.valid_tx_ant) <<
61 RATE_MCS_ANT_POS; 61 RATE_MCS_ANT_POS;
62 rate_n_flags = il4965_hw_set_rate_n_flags(iwlegacy_rates[r].plcp, 62 rate_n_flags = il4965_hw_set_rate_n_flags(iwlegacy_rates[r].plcp,
63 rate_flags); 63 rate_flags);
@@ -65,16 +65,16 @@ il4965_sta_alloc_lq(struct il_priv *priv, u8 sta_id)
65 link_cmd->rs_table[i].rate_n_flags = rate_n_flags; 65 link_cmd->rs_table[i].rate_n_flags = rate_n_flags;
66 66
67 link_cmd->general_params.single_stream_ant_msk = 67 link_cmd->general_params.single_stream_ant_msk =
68 il4965_first_antenna(priv->hw_params.valid_tx_ant); 68 il4965_first_antenna(il->hw_params.valid_tx_ant);
69 69
70 link_cmd->general_params.dual_stream_ant_msk = 70 link_cmd->general_params.dual_stream_ant_msk =
71 priv->hw_params.valid_tx_ant & 71 il->hw_params.valid_tx_ant &
72 ~il4965_first_antenna(priv->hw_params.valid_tx_ant); 72 ~il4965_first_antenna(il->hw_params.valid_tx_ant);
73 if (!link_cmd->general_params.dual_stream_ant_msk) { 73 if (!link_cmd->general_params.dual_stream_ant_msk) {
74 link_cmd->general_params.dual_stream_ant_msk = ANT_AB; 74 link_cmd->general_params.dual_stream_ant_msk = ANT_AB;
75 } else if (il4965_num_of_ant(priv->hw_params.valid_tx_ant) == 2) { 75 } else if (il4965_num_of_ant(il->hw_params.valid_tx_ant) == 2) {
76 link_cmd->general_params.dual_stream_ant_msk = 76 link_cmd->general_params.dual_stream_ant_msk =
77 priv->hw_params.valid_tx_ant; 77 il->hw_params.valid_tx_ant;
78 } 78 }
79 79
80 link_cmd->agg_params.agg_dis_start_th = LINK_QUAL_AGG_DISABLE_START_DEF; 80 link_cmd->agg_params.agg_dis_start_th = LINK_QUAL_AGG_DISABLE_START_DEF;
@@ -92,7 +92,7 @@ il4965_sta_alloc_lq(struct il_priv *priv, u8 sta_id)
92 * Function sleeps. 92 * Function sleeps.
93 */ 93 */
94int 94int
95il4965_add_bssid_station(struct il_priv *priv, struct il_rxon_context *ctx, 95il4965_add_bssid_station(struct il_priv *il, struct il_rxon_context *ctx,
96 const u8 *addr, u8 *sta_id_r) 96 const u8 *addr, u8 *sta_id_r)
97{ 97{
98 int ret; 98 int ret;
@@ -103,40 +103,40 @@ il4965_add_bssid_station(struct il_priv *priv, struct il_rxon_context *ctx,
103 if (sta_id_r) 103 if (sta_id_r)
104 *sta_id_r = IL_INVALID_STATION; 104 *sta_id_r = IL_INVALID_STATION;
105 105
106 ret = il_add_station_common(priv, ctx, addr, 0, NULL, &sta_id); 106 ret = il_add_station_common(il, ctx, addr, 0, NULL, &sta_id);
107 if (ret) { 107 if (ret) {
108 IL_ERR(priv, "Unable to add station %pM\n", addr); 108 IL_ERR(il, "Unable to add station %pM\n", addr);
109 return ret; 109 return ret;
110 } 110 }
111 111
112 if (sta_id_r) 112 if (sta_id_r)
113 *sta_id_r = sta_id; 113 *sta_id_r = sta_id;
114 114
115 spin_lock_irqsave(&priv->sta_lock, flags); 115 spin_lock_irqsave(&il->sta_lock, flags);
116 priv->stations[sta_id].used |= IL_STA_LOCAL; 116 il->stations[sta_id].used |= IL_STA_LOCAL;
117 spin_unlock_irqrestore(&priv->sta_lock, flags); 117 spin_unlock_irqrestore(&il->sta_lock, flags);
118 118
119 /* Set up default rate scaling table in device's station table */ 119 /* Set up default rate scaling table in device's station table */
120 link_cmd = il4965_sta_alloc_lq(priv, sta_id); 120 link_cmd = il4965_sta_alloc_lq(il, sta_id);
121 if (!link_cmd) { 121 if (!link_cmd) {
122 IL_ERR(priv, 122 IL_ERR(il,
123 "Unable to initialize rate scaling for station %pM.\n", 123 "Unable to initialize rate scaling for station %pM.\n",
124 addr); 124 addr);
125 return -ENOMEM; 125 return -ENOMEM;
126 } 126 }
127 127
128 ret = il_send_lq_cmd(priv, ctx, link_cmd, CMD_SYNC, true); 128 ret = il_send_lq_cmd(il, ctx, link_cmd, CMD_SYNC, true);
129 if (ret) 129 if (ret)
130 IL_ERR(priv, "Link quality command failed (%d)\n", ret); 130 IL_ERR(il, "Link quality command failed (%d)\n", ret);
131 131
132 spin_lock_irqsave(&priv->sta_lock, flags); 132 spin_lock_irqsave(&il->sta_lock, flags);
133 priv->stations[sta_id].lq = link_cmd; 133 il->stations[sta_id].lq = link_cmd;
134 spin_unlock_irqrestore(&priv->sta_lock, flags); 134 spin_unlock_irqrestore(&il->sta_lock, flags);
135 135
136 return 0; 136 return 0;
137} 137}
138 138
139static int il4965_static_wepkey_cmd(struct il_priv *priv, 139static int il4965_static_wepkey_cmd(struct il_priv *il,
140 struct il_rxon_context *ctx, 140 struct il_rxon_context *ctx,
141 bool send_if_empty) 141 bool send_if_empty)
142{ 142{
@@ -178,74 +178,74 @@ static int il4965_static_wepkey_cmd(struct il_priv *priv,
178 cmd.len = cmd_size; 178 cmd.len = cmd_size;
179 179
180 if (not_empty || send_if_empty) 180 if (not_empty || send_if_empty)
181 return il_send_cmd(priv, &cmd); 181 return il_send_cmd(il, &cmd);
182 else 182 else
183 return 0; 183 return 0;
184} 184}
185 185
186int il4965_restore_default_wep_keys(struct il_priv *priv, 186int il4965_restore_default_wep_keys(struct il_priv *il,
187 struct il_rxon_context *ctx) 187 struct il_rxon_context *ctx)
188{ 188{
189 lockdep_assert_held(&priv->mutex); 189 lockdep_assert_held(&il->mutex);
190 190
191 return il4965_static_wepkey_cmd(priv, ctx, false); 191 return il4965_static_wepkey_cmd(il, ctx, false);
192} 192}
193 193
194int il4965_remove_default_wep_key(struct il_priv *priv, 194int il4965_remove_default_wep_key(struct il_priv *il,
195 struct il_rxon_context *ctx, 195 struct il_rxon_context *ctx,
196 struct ieee80211_key_conf *keyconf) 196 struct ieee80211_key_conf *keyconf)
197{ 197{
198 int ret; 198 int ret;
199 199
200 lockdep_assert_held(&priv->mutex); 200 lockdep_assert_held(&il->mutex);
201 201
202 IL_DEBUG_WEP(priv, "Removing default WEP key: idx=%d\n", 202 IL_DEBUG_WEP(il, "Removing default WEP key: idx=%d\n",
203 keyconf->keyidx); 203 keyconf->keyidx);
204 204
205 memset(&ctx->wep_keys[keyconf->keyidx], 0, sizeof(ctx->wep_keys[0])); 205 memset(&ctx->wep_keys[keyconf->keyidx], 0, sizeof(ctx->wep_keys[0]));
206 if (il_is_rfkill(priv)) { 206 if (il_is_rfkill(il)) {
207 IL_DEBUG_WEP(priv, 207 IL_DEBUG_WEP(il,
208 "Not sending REPLY_WEPKEY command due to RFKILL.\n"); 208 "Not sending REPLY_WEPKEY command due to RFKILL.\n");
209 /* but keys in device are clear anyway so return success */ 209 /* but keys in device are clear anyway so return success */
210 return 0; 210 return 0;
211 } 211 }
212 ret = il4965_static_wepkey_cmd(priv, ctx, 1); 212 ret = il4965_static_wepkey_cmd(il, ctx, 1);
213 IL_DEBUG_WEP(priv, "Remove default WEP key: idx=%d ret=%d\n", 213 IL_DEBUG_WEP(il, "Remove default WEP key: idx=%d ret=%d\n",
214 keyconf->keyidx, ret); 214 keyconf->keyidx, ret);
215 215
216 return ret; 216 return ret;
217} 217}
218 218
219int il4965_set_default_wep_key(struct il_priv *priv, 219int il4965_set_default_wep_key(struct il_priv *il,
220 struct il_rxon_context *ctx, 220 struct il_rxon_context *ctx,
221 struct ieee80211_key_conf *keyconf) 221 struct ieee80211_key_conf *keyconf)
222{ 222{
223 int ret; 223 int ret;
224 224
225 lockdep_assert_held(&priv->mutex); 225 lockdep_assert_held(&il->mutex);
226 226
227 if (keyconf->keylen != WEP_KEY_LEN_128 && 227 if (keyconf->keylen != WEP_KEY_LEN_128 &&
228 keyconf->keylen != WEP_KEY_LEN_64) { 228 keyconf->keylen != WEP_KEY_LEN_64) {
229 IL_DEBUG_WEP(priv, "Bad WEP key length %d\n", keyconf->keylen); 229 IL_DEBUG_WEP(il, "Bad WEP key length %d\n", keyconf->keylen);
230 return -EINVAL; 230 return -EINVAL;
231 } 231 }
232 232
233 keyconf->flags &= ~IEEE80211_KEY_FLAG_GENERATE_IV; 233 keyconf->flags &= ~IEEE80211_KEY_FLAG_GENERATE_IV;
234 keyconf->hw_key_idx = HW_KEY_DEFAULT; 234 keyconf->hw_key_idx = HW_KEY_DEFAULT;
235 priv->stations[ctx->ap_sta_id].keyinfo.cipher = keyconf->cipher; 235 il->stations[ctx->ap_sta_id].keyinfo.cipher = keyconf->cipher;
236 236
237 ctx->wep_keys[keyconf->keyidx].key_size = keyconf->keylen; 237 ctx->wep_keys[keyconf->keyidx].key_size = keyconf->keylen;
238 memcpy(&ctx->wep_keys[keyconf->keyidx].key, &keyconf->key, 238 memcpy(&ctx->wep_keys[keyconf->keyidx].key, &keyconf->key,
239 keyconf->keylen); 239 keyconf->keylen);
240 240
241 ret = il4965_static_wepkey_cmd(priv, ctx, false); 241 ret = il4965_static_wepkey_cmd(il, ctx, false);
242 IL_DEBUG_WEP(priv, "Set default WEP key: len=%d idx=%d ret=%d\n", 242 IL_DEBUG_WEP(il, "Set default WEP key: len=%d idx=%d ret=%d\n",
243 keyconf->keylen, keyconf->keyidx, ret); 243 keyconf->keylen, keyconf->keyidx, ret);
244 244
245 return ret; 245 return ret;
246} 246}
247 247
248static int il4965_set_wep_dynamic_key_info(struct il_priv *priv, 248static int il4965_set_wep_dynamic_key_info(struct il_priv *il,
249 struct il_rxon_context *ctx, 249 struct il_rxon_context *ctx,
250 struct ieee80211_key_conf *keyconf, 250 struct ieee80211_key_conf *keyconf,
251 u8 sta_id) 251 u8 sta_id)
@@ -254,7 +254,7 @@ static int il4965_set_wep_dynamic_key_info(struct il_priv *priv,
254 __le16 key_flags = 0; 254 __le16 key_flags = 0;
255 struct il_addsta_cmd sta_cmd; 255 struct il_addsta_cmd sta_cmd;
256 256
257 lockdep_assert_held(&priv->mutex); 257 lockdep_assert_held(&il->mutex);
258 258
259 keyconf->flags &= ~IEEE80211_KEY_FLAG_GENERATE_IV; 259 keyconf->flags &= ~IEEE80211_KEY_FLAG_GENERATE_IV;
260 260
@@ -268,40 +268,40 @@ static int il4965_set_wep_dynamic_key_info(struct il_priv *priv,
268 if (sta_id == ctx->bcast_sta_id) 268 if (sta_id == ctx->bcast_sta_id)
269 key_flags |= STA_KEY_MULTICAST_MSK; 269 key_flags |= STA_KEY_MULTICAST_MSK;
270 270
271 spin_lock_irqsave(&priv->sta_lock, flags); 271 spin_lock_irqsave(&il->sta_lock, flags);
272 272
273 priv->stations[sta_id].keyinfo.cipher = keyconf->cipher; 273 il->stations[sta_id].keyinfo.cipher = keyconf->cipher;
274 priv->stations[sta_id].keyinfo.keylen = keyconf->keylen; 274 il->stations[sta_id].keyinfo.keylen = keyconf->keylen;
275 priv->stations[sta_id].keyinfo.keyidx = keyconf->keyidx; 275 il->stations[sta_id].keyinfo.keyidx = keyconf->keyidx;
276 276
277 memcpy(priv->stations[sta_id].keyinfo.key, 277 memcpy(il->stations[sta_id].keyinfo.key,
278 keyconf->key, keyconf->keylen); 278 keyconf->key, keyconf->keylen);
279 279
280 memcpy(&priv->stations[sta_id].sta.key.key[3], 280 memcpy(&il->stations[sta_id].sta.key.key[3],
281 keyconf->key, keyconf->keylen); 281 keyconf->key, keyconf->keylen);
282 282
283 if ((priv->stations[sta_id].sta.key.key_flags & STA_KEY_FLG_ENCRYPT_MSK) 283 if ((il->stations[sta_id].sta.key.key_flags & STA_KEY_FLG_ENCRYPT_MSK)
284 == STA_KEY_FLG_NO_ENC) 284 == STA_KEY_FLG_NO_ENC)
285 priv->stations[sta_id].sta.key.key_offset = 285 il->stations[sta_id].sta.key.key_offset =
286 il_get_free_ucode_key_index(priv); 286 il_get_free_ucode_key_index(il);
287 /* else, we are overriding an existing key => no need to allocated room 287 /* else, we are overriding an existing key => no need to allocated room
288 * in uCode. */ 288 * in uCode. */
289 289
290 WARN(priv->stations[sta_id].sta.key.key_offset == WEP_INVALID_OFFSET, 290 WARN(il->stations[sta_id].sta.key.key_offset == WEP_INVALID_OFFSET,
291 "no space for a new key"); 291 "no space for a new key");
292 292
293 priv->stations[sta_id].sta.key.key_flags = key_flags; 293 il->stations[sta_id].sta.key.key_flags = key_flags;
294 priv->stations[sta_id].sta.sta.modify_mask = STA_MODIFY_KEY_MASK; 294 il->stations[sta_id].sta.sta.modify_mask = STA_MODIFY_KEY_MASK;
295 priv->stations[sta_id].sta.mode = STA_CONTROL_MODIFY_MSK; 295 il->stations[sta_id].sta.mode = STA_CONTROL_MODIFY_MSK;
296 296
297 memcpy(&sta_cmd, &priv->stations[sta_id].sta, 297 memcpy(&sta_cmd, &il->stations[sta_id].sta,
298 sizeof(struct il_addsta_cmd)); 298 sizeof(struct il_addsta_cmd));
299 spin_unlock_irqrestore(&priv->sta_lock, flags); 299 spin_unlock_irqrestore(&il->sta_lock, flags);
300 300
301 return il_send_add_sta(priv, &sta_cmd, CMD_SYNC); 301 return il_send_add_sta(il, &sta_cmd, CMD_SYNC);
302} 302}
303 303
304static int il4965_set_ccmp_dynamic_key_info(struct il_priv *priv, 304static int il4965_set_ccmp_dynamic_key_info(struct il_priv *il,
305 struct il_rxon_context *ctx, 305 struct il_rxon_context *ctx,
306 struct ieee80211_key_conf *keyconf, 306 struct ieee80211_key_conf *keyconf,
307 u8 sta_id) 307 u8 sta_id)
@@ -310,7 +310,7 @@ static int il4965_set_ccmp_dynamic_key_info(struct il_priv *priv,
310 __le16 key_flags = 0; 310 __le16 key_flags = 0;
311 struct il_addsta_cmd sta_cmd; 311 struct il_addsta_cmd sta_cmd;
312 312
313 lockdep_assert_held(&priv->mutex); 313 lockdep_assert_held(&il->mutex);
314 314
315 key_flags |= (STA_KEY_FLG_CCMP | STA_KEY_FLG_MAP_KEY_MSK); 315 key_flags |= (STA_KEY_FLG_CCMP | STA_KEY_FLG_MAP_KEY_MSK);
316 key_flags |= cpu_to_le16(keyconf->keyidx << STA_KEY_FLG_KEYID_POS); 316 key_flags |= cpu_to_le16(keyconf->keyidx << STA_KEY_FLG_KEYID_POS);
@@ -321,38 +321,38 @@ static int il4965_set_ccmp_dynamic_key_info(struct il_priv *priv,
321 321
322 keyconf->flags |= IEEE80211_KEY_FLAG_GENERATE_IV; 322 keyconf->flags |= IEEE80211_KEY_FLAG_GENERATE_IV;
323 323
324 spin_lock_irqsave(&priv->sta_lock, flags); 324 spin_lock_irqsave(&il->sta_lock, flags);
325 priv->stations[sta_id].keyinfo.cipher = keyconf->cipher; 325 il->stations[sta_id].keyinfo.cipher = keyconf->cipher;
326 priv->stations[sta_id].keyinfo.keylen = keyconf->keylen; 326 il->stations[sta_id].keyinfo.keylen = keyconf->keylen;
327 327
328 memcpy(priv->stations[sta_id].keyinfo.key, keyconf->key, 328 memcpy(il->stations[sta_id].keyinfo.key, keyconf->key,
329 keyconf->keylen); 329 keyconf->keylen);
330 330
331 memcpy(priv->stations[sta_id].sta.key.key, keyconf->key, 331 memcpy(il->stations[sta_id].sta.key.key, keyconf->key,
332 keyconf->keylen); 332 keyconf->keylen);
333 333
334 if ((priv->stations[sta_id].sta.key.key_flags & STA_KEY_FLG_ENCRYPT_MSK) 334 if ((il->stations[sta_id].sta.key.key_flags & STA_KEY_FLG_ENCRYPT_MSK)
335 == STA_KEY_FLG_NO_ENC) 335 == STA_KEY_FLG_NO_ENC)
336 priv->stations[sta_id].sta.key.key_offset = 336 il->stations[sta_id].sta.key.key_offset =
337 il_get_free_ucode_key_index(priv); 337 il_get_free_ucode_key_index(il);
338 /* else, we are overriding an existing key => no need to allocated room 338 /* else, we are overriding an existing key => no need to allocated room
339 * in uCode. */ 339 * in uCode. */
340 340
341 WARN(priv->stations[sta_id].sta.key.key_offset == WEP_INVALID_OFFSET, 341 WARN(il->stations[sta_id].sta.key.key_offset == WEP_INVALID_OFFSET,
342 "no space for a new key"); 342 "no space for a new key");
343 343
344 priv->stations[sta_id].sta.key.key_flags = key_flags; 344 il->stations[sta_id].sta.key.key_flags = key_flags;
345 priv->stations[sta_id].sta.sta.modify_mask = STA_MODIFY_KEY_MASK; 345 il->stations[sta_id].sta.sta.modify_mask = STA_MODIFY_KEY_MASK;
346 priv->stations[sta_id].sta.mode = STA_CONTROL_MODIFY_MSK; 346 il->stations[sta_id].sta.mode = STA_CONTROL_MODIFY_MSK;
347 347
348 memcpy(&sta_cmd, &priv->stations[sta_id].sta, 348 memcpy(&sta_cmd, &il->stations[sta_id].sta,
349 sizeof(struct il_addsta_cmd)); 349 sizeof(struct il_addsta_cmd));
350 spin_unlock_irqrestore(&priv->sta_lock, flags); 350 spin_unlock_irqrestore(&il->sta_lock, flags);
351 351
352 return il_send_add_sta(priv, &sta_cmd, CMD_SYNC); 352 return il_send_add_sta(il, &sta_cmd, CMD_SYNC);
353} 353}
354 354
355static int il4965_set_tkip_dynamic_key_info(struct il_priv *priv, 355static int il4965_set_tkip_dynamic_key_info(struct il_priv *il,
356 struct il_rxon_context *ctx, 356 struct il_rxon_context *ctx,
357 struct ieee80211_key_conf *keyconf, 357 struct ieee80211_key_conf *keyconf,
358 u8 sta_id) 358 u8 sta_id)
@@ -371,35 +371,35 @@ static int il4965_set_tkip_dynamic_key_info(struct il_priv *priv,
371 keyconf->flags |= IEEE80211_KEY_FLAG_GENERATE_IV; 371 keyconf->flags |= IEEE80211_KEY_FLAG_GENERATE_IV;
372 keyconf->flags |= IEEE80211_KEY_FLAG_GENERATE_MMIC; 372 keyconf->flags |= IEEE80211_KEY_FLAG_GENERATE_MMIC;
373 373
374 spin_lock_irqsave(&priv->sta_lock, flags); 374 spin_lock_irqsave(&il->sta_lock, flags);
375 375
376 priv->stations[sta_id].keyinfo.cipher = keyconf->cipher; 376 il->stations[sta_id].keyinfo.cipher = keyconf->cipher;
377 priv->stations[sta_id].keyinfo.keylen = 16; 377 il->stations[sta_id].keyinfo.keylen = 16;
378 378
379 if ((priv->stations[sta_id].sta.key.key_flags & STA_KEY_FLG_ENCRYPT_MSK) 379 if ((il->stations[sta_id].sta.key.key_flags & STA_KEY_FLG_ENCRYPT_MSK)
380 == STA_KEY_FLG_NO_ENC) 380 == STA_KEY_FLG_NO_ENC)
381 priv->stations[sta_id].sta.key.key_offset = 381 il->stations[sta_id].sta.key.key_offset =
382 il_get_free_ucode_key_index(priv); 382 il_get_free_ucode_key_index(il);
383 /* else, we are overriding an existing key => no need to allocated room 383 /* else, we are overriding an existing key => no need to allocated room
384 * in uCode. */ 384 * in uCode. */
385 385
386 WARN(priv->stations[sta_id].sta.key.key_offset == WEP_INVALID_OFFSET, 386 WARN(il->stations[sta_id].sta.key.key_offset == WEP_INVALID_OFFSET,
387 "no space for a new key"); 387 "no space for a new key");
388 388
389 priv->stations[sta_id].sta.key.key_flags = key_flags; 389 il->stations[sta_id].sta.key.key_flags = key_flags;
390 390
391 391
392 /* This copy is acutally not needed: we get the key with each TX */ 392 /* This copy is acutally not needed: we get the key with each TX */
393 memcpy(priv->stations[sta_id].keyinfo.key, keyconf->key, 16); 393 memcpy(il->stations[sta_id].keyinfo.key, keyconf->key, 16);
394 394
395 memcpy(priv->stations[sta_id].sta.key.key, keyconf->key, 16); 395 memcpy(il->stations[sta_id].sta.key.key, keyconf->key, 16);
396 396
397 spin_unlock_irqrestore(&priv->sta_lock, flags); 397 spin_unlock_irqrestore(&il->sta_lock, flags);
398 398
399 return ret; 399 return ret;
400} 400}
401 401
402void il4965_update_tkip_key(struct il_priv *priv, 402void il4965_update_tkip_key(struct il_priv *il,
403 struct il_rxon_context *ctx, 403 struct il_rxon_context *ctx,
404 struct ieee80211_key_conf *keyconf, 404 struct ieee80211_key_conf *keyconf,
405 struct ieee80211_sta *sta, u32 iv32, u16 *phase1key) 405 struct ieee80211_sta *sta, u32 iv32, u16 *phase1key)
@@ -408,34 +408,34 @@ void il4965_update_tkip_key(struct il_priv *priv,
408 unsigned long flags; 408 unsigned long flags;
409 int i; 409 int i;
410 410
411 if (il_scan_cancel(priv)) { 411 if (il_scan_cancel(il)) {
412 /* cancel scan failed, just live w/ bad key and rely 412 /* cancel scan failed, just live w/ bad key and rely
413 briefly on SW decryption */ 413 briefly on SW decryption */
414 return; 414 return;
415 } 415 }
416 416
417 sta_id = il_sta_id_or_broadcast(priv, ctx, sta); 417 sta_id = il_sta_id_or_broadcast(il, ctx, sta);
418 if (sta_id == IL_INVALID_STATION) 418 if (sta_id == IL_INVALID_STATION)
419 return; 419 return;
420 420
421 spin_lock_irqsave(&priv->sta_lock, flags); 421 spin_lock_irqsave(&il->sta_lock, flags);
422 422
423 priv->stations[sta_id].sta.key.tkip_rx_tsc_byte2 = (u8) iv32; 423 il->stations[sta_id].sta.key.tkip_rx_tsc_byte2 = (u8) iv32;
424 424
425 for (i = 0; i < 5; i++) 425 for (i = 0; i < 5; i++)
426 priv->stations[sta_id].sta.key.tkip_rx_ttak[i] = 426 il->stations[sta_id].sta.key.tkip_rx_ttak[i] =
427 cpu_to_le16(phase1key[i]); 427 cpu_to_le16(phase1key[i]);
428 428
429 priv->stations[sta_id].sta.sta.modify_mask = STA_MODIFY_KEY_MASK; 429 il->stations[sta_id].sta.sta.modify_mask = STA_MODIFY_KEY_MASK;
430 priv->stations[sta_id].sta.mode = STA_CONTROL_MODIFY_MSK; 430 il->stations[sta_id].sta.mode = STA_CONTROL_MODIFY_MSK;
431 431
432 il_send_add_sta(priv, &priv->stations[sta_id].sta, CMD_ASYNC); 432 il_send_add_sta(il, &il->stations[sta_id].sta, CMD_ASYNC);
433 433
434 spin_unlock_irqrestore(&priv->sta_lock, flags); 434 spin_unlock_irqrestore(&il->sta_lock, flags);
435 435
436} 436}
437 437
438int il4965_remove_dynamic_key(struct il_priv *priv, 438int il4965_remove_dynamic_key(struct il_priv *il,
439 struct il_rxon_context *ctx, 439 struct il_rxon_context *ctx,
440 struct ieee80211_key_conf *keyconf, 440 struct ieee80211_key_conf *keyconf,
441 u8 sta_id) 441 u8 sta_id)
@@ -445,15 +445,15 @@ int il4965_remove_dynamic_key(struct il_priv *priv,
445 u8 keyidx; 445 u8 keyidx;
446 struct il_addsta_cmd sta_cmd; 446 struct il_addsta_cmd sta_cmd;
447 447
448 lockdep_assert_held(&priv->mutex); 448 lockdep_assert_held(&il->mutex);
449 449
450 ctx->key_mapping_keys--; 450 ctx->key_mapping_keys--;
451 451
452 spin_lock_irqsave(&priv->sta_lock, flags); 452 spin_lock_irqsave(&il->sta_lock, flags);
453 key_flags = le16_to_cpu(priv->stations[sta_id].sta.key.key_flags); 453 key_flags = le16_to_cpu(il->stations[sta_id].sta.key.key_flags);
454 keyidx = (key_flags >> STA_KEY_FLG_KEYID_POS) & 0x3; 454 keyidx = (key_flags >> STA_KEY_FLG_KEYID_POS) & 0x3;
455 455
456 IL_DEBUG_WEP(priv, "Remove dynamic key: idx=%d sta=%d\n", 456 IL_DEBUG_WEP(il, "Remove dynamic key: idx=%d sta=%d\n",
457 keyconf->keyidx, sta_id); 457 keyconf->keyidx, sta_id);
458 458
459 if (keyconf->keyidx != keyidx) { 459 if (keyconf->keyidx != keyidx) {
@@ -462,76 +462,76 @@ int il4965_remove_dynamic_key(struct il_priv *priv,
462 * been replaced by another one with different index. 462 * been replaced by another one with different index.
463 * Don't do anything and return ok 463 * Don't do anything and return ok
464 */ 464 */
465 spin_unlock_irqrestore(&priv->sta_lock, flags); 465 spin_unlock_irqrestore(&il->sta_lock, flags);
466 return 0; 466 return 0;
467 } 467 }
468 468
469 if (priv->stations[sta_id].sta.key.key_offset == WEP_INVALID_OFFSET) { 469 if (il->stations[sta_id].sta.key.key_offset == WEP_INVALID_OFFSET) {
470 IL_WARN(priv, "Removing wrong key %d 0x%x\n", 470 IL_WARN(il, "Removing wrong key %d 0x%x\n",
471 keyconf->keyidx, key_flags); 471 keyconf->keyidx, key_flags);
472 spin_unlock_irqrestore(&priv->sta_lock, flags); 472 spin_unlock_irqrestore(&il->sta_lock, flags);
473 return 0; 473 return 0;
474 } 474 }
475 475
476 if (!test_and_clear_bit(priv->stations[sta_id].sta.key.key_offset, 476 if (!test_and_clear_bit(il->stations[sta_id].sta.key.key_offset,
477 &priv->ucode_key_table)) 477 &il->ucode_key_table))
478 IL_ERR(priv, "index %d not used in uCode key table.\n", 478 IL_ERR(il, "index %d not used in uCode key table.\n",
479 priv->stations[sta_id].sta.key.key_offset); 479 il->stations[sta_id].sta.key.key_offset);
480 memset(&priv->stations[sta_id].keyinfo, 0, 480 memset(&il->stations[sta_id].keyinfo, 0,
481 sizeof(struct il_hw_key)); 481 sizeof(struct il_hw_key));
482 memset(&priv->stations[sta_id].sta.key, 0, 482 memset(&il->stations[sta_id].sta.key, 0,
483 sizeof(struct il4965_keyinfo)); 483 sizeof(struct il4965_keyinfo));
484 priv->stations[sta_id].sta.key.key_flags = 484 il->stations[sta_id].sta.key.key_flags =
485 STA_KEY_FLG_NO_ENC | STA_KEY_FLG_INVALID; 485 STA_KEY_FLG_NO_ENC | STA_KEY_FLG_INVALID;
486 priv->stations[sta_id].sta.key.key_offset = WEP_INVALID_OFFSET; 486 il->stations[sta_id].sta.key.key_offset = WEP_INVALID_OFFSET;
487 priv->stations[sta_id].sta.sta.modify_mask = STA_MODIFY_KEY_MASK; 487 il->stations[sta_id].sta.sta.modify_mask = STA_MODIFY_KEY_MASK;
488 priv->stations[sta_id].sta.mode = STA_CONTROL_MODIFY_MSK; 488 il->stations[sta_id].sta.mode = STA_CONTROL_MODIFY_MSK;
489 489
490 if (il_is_rfkill(priv)) { 490 if (il_is_rfkill(il)) {
491 IL_DEBUG_WEP(priv, 491 IL_DEBUG_WEP(il,
492 "Not sending REPLY_ADD_STA command because RFKILL enabled.\n"); 492 "Not sending REPLY_ADD_STA command because RFKILL enabled.\n");
493 spin_unlock_irqrestore(&priv->sta_lock, flags); 493 spin_unlock_irqrestore(&il->sta_lock, flags);
494 return 0; 494 return 0;
495 } 495 }
496 memcpy(&sta_cmd, &priv->stations[sta_id].sta, 496 memcpy(&sta_cmd, &il->stations[sta_id].sta,
497 sizeof(struct il_addsta_cmd)); 497 sizeof(struct il_addsta_cmd));
498 spin_unlock_irqrestore(&priv->sta_lock, flags); 498 spin_unlock_irqrestore(&il->sta_lock, flags);
499 499
500 return il_send_add_sta(priv, &sta_cmd, CMD_SYNC); 500 return il_send_add_sta(il, &sta_cmd, CMD_SYNC);
501} 501}
502 502
503int il4965_set_dynamic_key(struct il_priv *priv, struct il_rxon_context *ctx, 503int il4965_set_dynamic_key(struct il_priv *il, struct il_rxon_context *ctx,
504 struct ieee80211_key_conf *keyconf, u8 sta_id) 504 struct ieee80211_key_conf *keyconf, u8 sta_id)
505{ 505{
506 int ret; 506 int ret;
507 507
508 lockdep_assert_held(&priv->mutex); 508 lockdep_assert_held(&il->mutex);
509 509
510 ctx->key_mapping_keys++; 510 ctx->key_mapping_keys++;
511 keyconf->hw_key_idx = HW_KEY_DYNAMIC; 511 keyconf->hw_key_idx = HW_KEY_DYNAMIC;
512 512
513 switch (keyconf->cipher) { 513 switch (keyconf->cipher) {
514 case WLAN_CIPHER_SUITE_CCMP: 514 case WLAN_CIPHER_SUITE_CCMP:
515 ret = il4965_set_ccmp_dynamic_key_info(priv, ctx, 515 ret = il4965_set_ccmp_dynamic_key_info(il, ctx,
516 keyconf, sta_id); 516 keyconf, sta_id);
517 break; 517 break;
518 case WLAN_CIPHER_SUITE_TKIP: 518 case WLAN_CIPHER_SUITE_TKIP:
519 ret = il4965_set_tkip_dynamic_key_info(priv, ctx, 519 ret = il4965_set_tkip_dynamic_key_info(il, ctx,
520 keyconf, sta_id); 520 keyconf, sta_id);
521 break; 521 break;
522 case WLAN_CIPHER_SUITE_WEP40: 522 case WLAN_CIPHER_SUITE_WEP40:
523 case WLAN_CIPHER_SUITE_WEP104: 523 case WLAN_CIPHER_SUITE_WEP104:
524 ret = il4965_set_wep_dynamic_key_info(priv, ctx, 524 ret = il4965_set_wep_dynamic_key_info(il, ctx,
525 keyconf, sta_id); 525 keyconf, sta_id);
526 break; 526 break;
527 default: 527 default:
528 IL_ERR(priv, 528 IL_ERR(il,
529 "Unknown alg: %s cipher = %x\n", __func__, 529 "Unknown alg: %s cipher = %x\n", __func__,
530 keyconf->cipher); 530 keyconf->cipher);
531 ret = -EINVAL; 531 ret = -EINVAL;
532 } 532 }
533 533
534 IL_DEBUG_WEP(priv, 534 IL_DEBUG_WEP(il,
535 "Set dynamic key: cipher=%x len=%d idx=%d sta=%d ret=%d\n", 535 "Set dynamic key: cipher=%x len=%d idx=%d sta=%d ret=%d\n",
536 keyconf->cipher, keyconf->keylen, keyconf->keyidx, 536 keyconf->cipher, keyconf->keylen, keyconf->keyidx,
537 sta_id, ret); 537 sta_id, ret);
@@ -546,37 +546,37 @@ int il4965_set_dynamic_key(struct il_priv *priv, struct il_rxon_context *ctx,
546 * and marks it driver active, so that it will be restored to the 546 * and marks it driver active, so that it will be restored to the
547 * device at the next best time. 547 * device at the next best time.
548 */ 548 */
549int il4965_alloc_bcast_station(struct il_priv *priv, 549int il4965_alloc_bcast_station(struct il_priv *il,
550 struct il_rxon_context *ctx) 550 struct il_rxon_context *ctx)
551{ 551{
552 struct il_link_quality_cmd *link_cmd; 552 struct il_link_quality_cmd *link_cmd;
553 unsigned long flags; 553 unsigned long flags;
554 u8 sta_id; 554 u8 sta_id;
555 555
556 spin_lock_irqsave(&priv->sta_lock, flags); 556 spin_lock_irqsave(&il->sta_lock, flags);
557 sta_id = il_prep_station(priv, ctx, iwlegacy_bcast_addr, 557 sta_id = il_prep_station(il, ctx, iwlegacy_bcast_addr,
558 false, NULL); 558 false, NULL);
559 if (sta_id == IL_INVALID_STATION) { 559 if (sta_id == IL_INVALID_STATION) {
560 IL_ERR(priv, "Unable to prepare broadcast station\n"); 560 IL_ERR(il, "Unable to prepare broadcast station\n");
561 spin_unlock_irqrestore(&priv->sta_lock, flags); 561 spin_unlock_irqrestore(&il->sta_lock, flags);
562 562
563 return -EINVAL; 563 return -EINVAL;
564 } 564 }
565 565
566 priv->stations[sta_id].used |= IL_STA_DRIVER_ACTIVE; 566 il->stations[sta_id].used |= IL_STA_DRIVER_ACTIVE;
567 priv->stations[sta_id].used |= IL_STA_BCAST; 567 il->stations[sta_id].used |= IL_STA_BCAST;
568 spin_unlock_irqrestore(&priv->sta_lock, flags); 568 spin_unlock_irqrestore(&il->sta_lock, flags);
569 569
570 link_cmd = il4965_sta_alloc_lq(priv, sta_id); 570 link_cmd = il4965_sta_alloc_lq(il, sta_id);
571 if (!link_cmd) { 571 if (!link_cmd) {
572 IL_ERR(priv, 572 IL_ERR(il,
573 "Unable to initialize rate scaling for bcast station.\n"); 573 "Unable to initialize rate scaling for bcast station.\n");
574 return -ENOMEM; 574 return -ENOMEM;
575 } 575 }
576 576
577 spin_lock_irqsave(&priv->sta_lock, flags); 577 spin_lock_irqsave(&il->sta_lock, flags);
578 priv->stations[sta_id].lq = link_cmd; 578 il->stations[sta_id].lq = link_cmd;
579 spin_unlock_irqrestore(&priv->sta_lock, flags); 579 spin_unlock_irqrestore(&il->sta_lock, flags);
580 580
581 return 0; 581 return 0;
582} 582}
@@ -587,39 +587,39 @@ int il4965_alloc_bcast_station(struct il_priv *priv,
587 * Only used by iwl4965. Placed here to have all bcast station management 587 * Only used by iwl4965. Placed here to have all bcast station management
588 * code together. 588 * code together.
589 */ 589 */
590static int il4965_update_bcast_station(struct il_priv *priv, 590static int il4965_update_bcast_station(struct il_priv *il,
591 struct il_rxon_context *ctx) 591 struct il_rxon_context *ctx)
592{ 592{
593 unsigned long flags; 593 unsigned long flags;
594 struct il_link_quality_cmd *link_cmd; 594 struct il_link_quality_cmd *link_cmd;
595 u8 sta_id = ctx->bcast_sta_id; 595 u8 sta_id = ctx->bcast_sta_id;
596 596
597 link_cmd = il4965_sta_alloc_lq(priv, sta_id); 597 link_cmd = il4965_sta_alloc_lq(il, sta_id);
598 if (!link_cmd) { 598 if (!link_cmd) {
599 IL_ERR(priv, 599 IL_ERR(il,
600 "Unable to initialize rate scaling for bcast station.\n"); 600 "Unable to initialize rate scaling for bcast station.\n");
601 return -ENOMEM; 601 return -ENOMEM;
602 } 602 }
603 603
604 spin_lock_irqsave(&priv->sta_lock, flags); 604 spin_lock_irqsave(&il->sta_lock, flags);
605 if (priv->stations[sta_id].lq) 605 if (il->stations[sta_id].lq)
606 kfree(priv->stations[sta_id].lq); 606 kfree(il->stations[sta_id].lq);
607 else 607 else
608 IL_DEBUG_INFO(priv, 608 IL_DEBUG_INFO(il,
609 "Bcast station rate scaling has not been initialized yet.\n"); 609 "Bcast station rate scaling has not been initialized yet.\n");
610 priv->stations[sta_id].lq = link_cmd; 610 il->stations[sta_id].lq = link_cmd;
611 spin_unlock_irqrestore(&priv->sta_lock, flags); 611 spin_unlock_irqrestore(&il->sta_lock, flags);
612 612
613 return 0; 613 return 0;
614} 614}
615 615
616int il4965_update_bcast_stations(struct il_priv *priv) 616int il4965_update_bcast_stations(struct il_priv *il)
617{ 617{
618 struct il_rxon_context *ctx; 618 struct il_rxon_context *ctx;
619 int ret = 0; 619 int ret = 0;
620 620
621 for_each_context(priv, ctx) { 621 for_each_context(il, ctx) {
622 ret = il4965_update_bcast_station(priv, ctx); 622 ret = il4965_update_bcast_station(il, ctx);
623 if (ret) 623 if (ret)
624 break; 624 break;
625 } 625 }
@@ -630,92 +630,92 @@ int il4965_update_bcast_stations(struct il_priv *priv)
630/** 630/**
631 * il4965_sta_tx_modify_enable_tid - Enable Tx for this TID in station table 631 * il4965_sta_tx_modify_enable_tid - Enable Tx for this TID in station table
632 */ 632 */
633int il4965_sta_tx_modify_enable_tid(struct il_priv *priv, int sta_id, int tid) 633int il4965_sta_tx_modify_enable_tid(struct il_priv *il, int sta_id, int tid)
634{ 634{
635 unsigned long flags; 635 unsigned long flags;
636 struct il_addsta_cmd sta_cmd; 636 struct il_addsta_cmd sta_cmd;
637 637
638 lockdep_assert_held(&priv->mutex); 638 lockdep_assert_held(&il->mutex);
639 639
640 /* Remove "disable" flag, to enable Tx for this TID */ 640 /* Remove "disable" flag, to enable Tx for this TID */
641 spin_lock_irqsave(&priv->sta_lock, flags); 641 spin_lock_irqsave(&il->sta_lock, flags);
642 priv->stations[sta_id].sta.sta.modify_mask = STA_MODIFY_TID_DISABLE_TX; 642 il->stations[sta_id].sta.sta.modify_mask = STA_MODIFY_TID_DISABLE_TX;
643 priv->stations[sta_id].sta.tid_disable_tx &= cpu_to_le16(~(1 << tid)); 643 il->stations[sta_id].sta.tid_disable_tx &= cpu_to_le16(~(1 << tid));
644 priv->stations[sta_id].sta.mode = STA_CONTROL_MODIFY_MSK; 644 il->stations[sta_id].sta.mode = STA_CONTROL_MODIFY_MSK;
645 memcpy(&sta_cmd, &priv->stations[sta_id].sta, 645 memcpy(&sta_cmd, &il->stations[sta_id].sta,
646 sizeof(struct il_addsta_cmd)); 646 sizeof(struct il_addsta_cmd));
647 spin_unlock_irqrestore(&priv->sta_lock, flags); 647 spin_unlock_irqrestore(&il->sta_lock, flags);
648 648
649 return il_send_add_sta(priv, &sta_cmd, CMD_SYNC); 649 return il_send_add_sta(il, &sta_cmd, CMD_SYNC);
650} 650}
651 651
652int il4965_sta_rx_agg_start(struct il_priv *priv, struct ieee80211_sta *sta, 652int il4965_sta_rx_agg_start(struct il_priv *il, struct ieee80211_sta *sta,
653 int tid, u16 ssn) 653 int tid, u16 ssn)
654{ 654{
655 unsigned long flags; 655 unsigned long flags;
656 int sta_id; 656 int sta_id;
657 struct il_addsta_cmd sta_cmd; 657 struct il_addsta_cmd sta_cmd;
658 658
659 lockdep_assert_held(&priv->mutex); 659 lockdep_assert_held(&il->mutex);
660 660
661 sta_id = il_sta_id(sta); 661 sta_id = il_sta_id(sta);
662 if (sta_id == IL_INVALID_STATION) 662 if (sta_id == IL_INVALID_STATION)
663 return -ENXIO; 663 return -ENXIO;
664 664
665 spin_lock_irqsave(&priv->sta_lock, flags); 665 spin_lock_irqsave(&il->sta_lock, flags);
666 priv->stations[sta_id].sta.station_flags_msk = 0; 666 il->stations[sta_id].sta.station_flags_msk = 0;
667 priv->stations[sta_id].sta.sta.modify_mask = STA_MODIFY_ADDBA_TID_MSK; 667 il->stations[sta_id].sta.sta.modify_mask = STA_MODIFY_ADDBA_TID_MSK;
668 priv->stations[sta_id].sta.add_immediate_ba_tid = (u8)tid; 668 il->stations[sta_id].sta.add_immediate_ba_tid = (u8)tid;
669 priv->stations[sta_id].sta.add_immediate_ba_ssn = cpu_to_le16(ssn); 669 il->stations[sta_id].sta.add_immediate_ba_ssn = cpu_to_le16(ssn);
670 priv->stations[sta_id].sta.mode = STA_CONTROL_MODIFY_MSK; 670 il->stations[sta_id].sta.mode = STA_CONTROL_MODIFY_MSK;
671 memcpy(&sta_cmd, &priv->stations[sta_id].sta, 671 memcpy(&sta_cmd, &il->stations[sta_id].sta,
672 sizeof(struct il_addsta_cmd)); 672 sizeof(struct il_addsta_cmd));
673 spin_unlock_irqrestore(&priv->sta_lock, flags); 673 spin_unlock_irqrestore(&il->sta_lock, flags);
674 674
675 return il_send_add_sta(priv, &sta_cmd, CMD_SYNC); 675 return il_send_add_sta(il, &sta_cmd, CMD_SYNC);
676} 676}
677 677
678int il4965_sta_rx_agg_stop(struct il_priv *priv, struct ieee80211_sta *sta, 678int il4965_sta_rx_agg_stop(struct il_priv *il, struct ieee80211_sta *sta,
679 int tid) 679 int tid)
680{ 680{
681 unsigned long flags; 681 unsigned long flags;
682 int sta_id; 682 int sta_id;
683 struct il_addsta_cmd sta_cmd; 683 struct il_addsta_cmd sta_cmd;
684 684
685 lockdep_assert_held(&priv->mutex); 685 lockdep_assert_held(&il->mutex);
686 686
687 sta_id = il_sta_id(sta); 687 sta_id = il_sta_id(sta);
688 if (sta_id == IL_INVALID_STATION) { 688 if (sta_id == IL_INVALID_STATION) {
689 IL_ERR(priv, "Invalid station for AGG tid %d\n", tid); 689 IL_ERR(il, "Invalid station for AGG tid %d\n", tid);
690 return -ENXIO; 690 return -ENXIO;
691 } 691 }
692 692
693 spin_lock_irqsave(&priv->sta_lock, flags); 693 spin_lock_irqsave(&il->sta_lock, flags);
694 priv->stations[sta_id].sta.station_flags_msk = 0; 694 il->stations[sta_id].sta.station_flags_msk = 0;
695 priv->stations[sta_id].sta.sta.modify_mask = STA_MODIFY_DELBA_TID_MSK; 695 il->stations[sta_id].sta.sta.modify_mask = STA_MODIFY_DELBA_TID_MSK;
696 priv->stations[sta_id].sta.remove_immediate_ba_tid = (u8)tid; 696 il->stations[sta_id].sta.remove_immediate_ba_tid = (u8)tid;
697 priv->stations[sta_id].sta.mode = STA_CONTROL_MODIFY_MSK; 697 il->stations[sta_id].sta.mode = STA_CONTROL_MODIFY_MSK;
698 memcpy(&sta_cmd, &priv->stations[sta_id].sta, 698 memcpy(&sta_cmd, &il->stations[sta_id].sta,
699 sizeof(struct il_addsta_cmd)); 699 sizeof(struct il_addsta_cmd));
700 spin_unlock_irqrestore(&priv->sta_lock, flags); 700 spin_unlock_irqrestore(&il->sta_lock, flags);
701 701
702 return il_send_add_sta(priv, &sta_cmd, CMD_SYNC); 702 return il_send_add_sta(il, &sta_cmd, CMD_SYNC);
703} 703}
704 704
705void 705void
706il4965_sta_modify_sleep_tx_count(struct il_priv *priv, int sta_id, int cnt) 706il4965_sta_modify_sleep_tx_count(struct il_priv *il, int sta_id, int cnt)
707{ 707{
708 unsigned long flags; 708 unsigned long flags;
709 709
710 spin_lock_irqsave(&priv->sta_lock, flags); 710 spin_lock_irqsave(&il->sta_lock, flags);
711 priv->stations[sta_id].sta.station_flags |= STA_FLG_PWR_SAVE_MSK; 711 il->stations[sta_id].sta.station_flags |= STA_FLG_PWR_SAVE_MSK;
712 priv->stations[sta_id].sta.station_flags_msk = STA_FLG_PWR_SAVE_MSK; 712 il->stations[sta_id].sta.station_flags_msk = STA_FLG_PWR_SAVE_MSK;
713 priv->stations[sta_id].sta.sta.modify_mask = 713 il->stations[sta_id].sta.sta.modify_mask =
714 STA_MODIFY_SLEEP_TX_COUNT_MSK; 714 STA_MODIFY_SLEEP_TX_COUNT_MSK;
715 priv->stations[sta_id].sta.sleep_tx_count = cpu_to_le16(cnt); 715 il->stations[sta_id].sta.sleep_tx_count = cpu_to_le16(cnt);
716 priv->stations[sta_id].sta.mode = STA_CONTROL_MODIFY_MSK; 716 il->stations[sta_id].sta.mode = STA_CONTROL_MODIFY_MSK;
717 il_send_add_sta(priv, 717 il_send_add_sta(il,
718 &priv->stations[sta_id].sta, CMD_ASYNC); 718 &il->stations[sta_id].sta, CMD_ASYNC);
719 spin_unlock_irqrestore(&priv->sta_lock, flags); 719 spin_unlock_irqrestore(&il->sta_lock, flags);
720 720
721} 721}
diff --git a/drivers/net/wireless/iwlegacy/iwl-4965-tx.c b/drivers/net/wireless/iwlegacy/iwl-4965-tx.c
index 3fdb9d9201dd..59d737496b5c 100644
--- a/drivers/net/wireless/iwlegacy/iwl-4965-tx.c
+++ b/drivers/net/wireless/iwlegacy/iwl-4965-tx.c
@@ -99,7 +99,7 @@ il4965_get_fifo_from_tid(struct il_rxon_context *ctx, u16 tid)
99/* 99/*
100 * handle build REPLY_TX command notification. 100 * handle build REPLY_TX command notification.
101 */ 101 */
102static void il4965_tx_cmd_build_basic(struct il_priv *priv, 102static void il4965_tx_cmd_build_basic(struct il_priv *il,
103 struct sk_buff *skb, 103 struct sk_buff *skb,
104 struct il_tx_cmd *tx_cmd, 104 struct il_tx_cmd *tx_cmd,
105 struct ieee80211_tx_info *info, 105 struct ieee80211_tx_info *info,
@@ -137,7 +137,7 @@ static void il4965_tx_cmd_build_basic(struct il_priv *priv,
137 tx_flags |= TX_CMD_FLG_SEQ_CTL_MSK; 137 tx_flags |= TX_CMD_FLG_SEQ_CTL_MSK;
138 } 138 }
139 139
140 il_tx_cmd_protection(priv, info, fc, &tx_flags); 140 il_tx_cmd_protection(il, info, fc, &tx_flags);
141 141
142 tx_flags &= ~(TX_CMD_FLG_ANT_SEL_MSK); 142 tx_flags &= ~(TX_CMD_FLG_ANT_SEL_MSK);
143 if (ieee80211_is_mgmt(fc)) { 143 if (ieee80211_is_mgmt(fc)) {
@@ -156,7 +156,7 @@ static void il4965_tx_cmd_build_basic(struct il_priv *priv,
156 156
157#define RTS_DFAULT_RETRY_LIMIT 60 157#define RTS_DFAULT_RETRY_LIMIT 60
158 158
159static void il4965_tx_cmd_build_rate(struct il_priv *priv, 159static void il4965_tx_cmd_build_rate(struct il_priv *il,
160 struct il_tx_cmd *tx_cmd, 160 struct il_tx_cmd *tx_cmd,
161 struct ieee80211_tx_info *info, 161 struct ieee80211_tx_info *info,
162 __le16 fc) 162 __le16 fc)
@@ -197,7 +197,7 @@ static void il4965_tx_cmd_build_rate(struct il_priv *priv,
197 rate_idx = info->control.rates[0].idx; 197 rate_idx = info->control.rates[0].idx;
198 if (info->control.rates[0].flags & IEEE80211_TX_RC_MCS || 198 if (info->control.rates[0].flags & IEEE80211_TX_RC_MCS ||
199 (rate_idx < 0) || (rate_idx > IL_RATE_COUNT_LEGACY)) 199 (rate_idx < 0) || (rate_idx > IL_RATE_COUNT_LEGACY))
200 rate_idx = rate_lowest_index(&priv->bands[info->band], 200 rate_idx = rate_lowest_index(&il->bands[info->band],
201 info->control.sta); 201 info->control.sta);
202 /* For 5 GHZ band, remap mac80211 rate indices into driver indices */ 202 /* For 5 GHZ band, remap mac80211 rate indices into driver indices */
203 if (info->band == IEEE80211_BAND_5GHZ) 203 if (info->band == IEEE80211_BAND_5GHZ)
@@ -212,16 +212,16 @@ static void il4965_tx_cmd_build_rate(struct il_priv *priv,
212 rate_flags |= RATE_MCS_CCK_MSK; 212 rate_flags |= RATE_MCS_CCK_MSK;
213 213
214 /* Set up antennas */ 214 /* Set up antennas */
215 priv->mgmt_tx_ant = il4965_toggle_tx_ant(priv, priv->mgmt_tx_ant, 215 il->mgmt_tx_ant = il4965_toggle_tx_ant(il, il->mgmt_tx_ant,
216 priv->hw_params.valid_tx_ant); 216 il->hw_params.valid_tx_ant);
217 217
218 rate_flags |= il4965_ant_idx_to_flags(priv->mgmt_tx_ant); 218 rate_flags |= il4965_ant_idx_to_flags(il->mgmt_tx_ant);
219 219
220 /* Set the rate in the TX cmd */ 220 /* Set the rate in the TX cmd */
221 tx_cmd->rate_n_flags = il4965_hw_set_rate_n_flags(rate_plcp, rate_flags); 221 tx_cmd->rate_n_flags = il4965_hw_set_rate_n_flags(rate_plcp, rate_flags);
222} 222}
223 223
224static void il4965_tx_cmd_build_hwcrypto(struct il_priv *priv, 224static void il4965_tx_cmd_build_hwcrypto(struct il_priv *il,
225 struct ieee80211_tx_info *info, 225 struct ieee80211_tx_info *info,
226 struct il_tx_cmd *tx_cmd, 226 struct il_tx_cmd *tx_cmd,
227 struct sk_buff *skb_frag, 227 struct sk_buff *skb_frag,
@@ -235,13 +235,13 @@ static void il4965_tx_cmd_build_hwcrypto(struct il_priv *priv,
235 memcpy(tx_cmd->key, keyconf->key, keyconf->keylen); 235 memcpy(tx_cmd->key, keyconf->key, keyconf->keylen);
236 if (info->flags & IEEE80211_TX_CTL_AMPDU) 236 if (info->flags & IEEE80211_TX_CTL_AMPDU)
237 tx_cmd->tx_flags |= TX_CMD_FLG_AGG_CCMP_MSK; 237 tx_cmd->tx_flags |= TX_CMD_FLG_AGG_CCMP_MSK;
238 IL_DEBUG_TX(priv, "tx_cmd with AES hwcrypto\n"); 238 IL_DEBUG_TX(il, "tx_cmd with AES hwcrypto\n");
239 break; 239 break;
240 240
241 case WLAN_CIPHER_SUITE_TKIP: 241 case WLAN_CIPHER_SUITE_TKIP:
242 tx_cmd->sec_ctl = TX_CMD_SEC_TKIP; 242 tx_cmd->sec_ctl = TX_CMD_SEC_TKIP;
243 ieee80211_get_tkip_p2k(keyconf, skb_frag, tx_cmd->key); 243 ieee80211_get_tkip_p2k(keyconf, skb_frag, tx_cmd->key);
244 IL_DEBUG_TX(priv, "tx_cmd with tkip hwcrypto\n"); 244 IL_DEBUG_TX(il, "tx_cmd with tkip hwcrypto\n");
245 break; 245 break;
246 246
247 case WLAN_CIPHER_SUITE_WEP104: 247 case WLAN_CIPHER_SUITE_WEP104:
@@ -253,12 +253,12 @@ static void il4965_tx_cmd_build_hwcrypto(struct il_priv *priv,
253 253
254 memcpy(&tx_cmd->key[3], keyconf->key, keyconf->keylen); 254 memcpy(&tx_cmd->key[3], keyconf->key, keyconf->keylen);
255 255
256 IL_DEBUG_TX(priv, "Configuring packet for WEP encryption " 256 IL_DEBUG_TX(il, "Configuring packet for WEP encryption "
257 "with key %d\n", keyconf->keyidx); 257 "with key %d\n", keyconf->keyidx);
258 break; 258 break;
259 259
260 default: 260 default:
261 IL_ERR(priv, "Unknown encode cipher %x\n", keyconf->cipher); 261 IL_ERR(il, "Unknown encode cipher %x\n", keyconf->cipher);
262 break; 262 break;
263 } 263 }
264} 264}
@@ -266,7 +266,7 @@ static void il4965_tx_cmd_build_hwcrypto(struct il_priv *priv,
266/* 266/*
267 * start REPLY_TX command process 267 * start REPLY_TX command process
268 */ 268 */
269int il4965_tx_skb(struct il_priv *priv, struct sk_buff *skb) 269int il4965_tx_skb(struct il_priv *il, struct sk_buff *skb)
270{ 270{
271 struct ieee80211_hdr *hdr = (struct ieee80211_hdr *)skb->data; 271 struct ieee80211_hdr *hdr = (struct ieee80211_hdr *)skb->data;
272 struct ieee80211_tx_info *info = IEEE80211_SKB_CB(skb); 272 struct ieee80211_tx_info *info = IEEE80211_SKB_CB(skb);
@@ -277,7 +277,7 @@ int il4965_tx_skb(struct il_priv *priv, struct sk_buff *skb)
277 struct il_device_cmd *out_cmd; 277 struct il_device_cmd *out_cmd;
278 struct il_cmd_meta *out_meta; 278 struct il_cmd_meta *out_meta;
279 struct il_tx_cmd *tx_cmd; 279 struct il_tx_cmd *tx_cmd;
280 struct il_rxon_context *ctx = &priv->contexts[IL_RXON_CTX_BSS]; 280 struct il_rxon_context *ctx = &il->contexts[IL_RXON_CTX_BSS];
281 int txq_id; 281 int txq_id;
282 dma_addr_t phys_addr; 282 dma_addr_t phys_addr;
283 dma_addr_t txcmd_phys; 283 dma_addr_t txcmd_phys;
@@ -296,9 +296,9 @@ int il4965_tx_skb(struct il_priv *priv, struct sk_buff *skb)
296 if (info->control.vif) 296 if (info->control.vif)
297 ctx = il_rxon_ctx_from_vif(info->control.vif); 297 ctx = il_rxon_ctx_from_vif(info->control.vif);
298 298
299 spin_lock_irqsave(&priv->lock, flags); 299 spin_lock_irqsave(&il->lock, flags);
300 if (il_is_rfkill(priv)) { 300 if (il_is_rfkill(il)) {
301 IL_DEBUG_DROP(priv, "Dropping - RF KILL\n"); 301 IL_DEBUG_DROP(il, "Dropping - RF KILL\n");
302 goto drop_unlock; 302 goto drop_unlock;
303 } 303 }
304 304
@@ -306,11 +306,11 @@ int il4965_tx_skb(struct il_priv *priv, struct sk_buff *skb)
306 306
307#ifdef CONFIG_IWLWIFI_LEGACY_DEBUG 307#ifdef CONFIG_IWLWIFI_LEGACY_DEBUG
308 if (ieee80211_is_auth(fc)) 308 if (ieee80211_is_auth(fc))
309 IL_DEBUG_TX(priv, "Sending AUTH frame\n"); 309 IL_DEBUG_TX(il, "Sending AUTH frame\n");
310 else if (ieee80211_is_assoc_req(fc)) 310 else if (ieee80211_is_assoc_req(fc))
311 IL_DEBUG_TX(priv, "Sending ASSOC frame\n"); 311 IL_DEBUG_TX(il, "Sending ASSOC frame\n");
312 else if (ieee80211_is_reassoc_req(fc)) 312 else if (ieee80211_is_reassoc_req(fc))
313 IL_DEBUG_TX(priv, "Sending REASSOC frame\n"); 313 IL_DEBUG_TX(il, "Sending REASSOC frame\n");
314#endif 314#endif
315 315
316 hdr_len = ieee80211_hdrlen(fc); 316 hdr_len = ieee80211_hdrlen(fc);
@@ -320,16 +320,16 @@ int il4965_tx_skb(struct il_priv *priv, struct sk_buff *skb)
320 sta_id = ctx->bcast_sta_id; 320 sta_id = ctx->bcast_sta_id;
321 else { 321 else {
322 /* Find index into station table for destination station */ 322 /* Find index into station table for destination station */
323 sta_id = il_sta_id_or_broadcast(priv, ctx, info->control.sta); 323 sta_id = il_sta_id_or_broadcast(il, ctx, info->control.sta);
324 324
325 if (sta_id == IL_INVALID_STATION) { 325 if (sta_id == IL_INVALID_STATION) {
326 IL_DEBUG_DROP(priv, "Dropping - INVALID STATION: %pM\n", 326 IL_DEBUG_DROP(il, "Dropping - INVALID STATION: %pM\n",
327 hdr->addr1); 327 hdr->addr1);
328 goto drop_unlock; 328 goto drop_unlock;
329 } 329 }
330 } 330 }
331 331
332 IL_DEBUG_TX(priv, "station Id %d\n", sta_id); 332 IL_DEBUG_TX(il, "station Id %d\n", sta_id);
333 333
334 if (sta) 334 if (sta)
335 sta_priv = (void *)sta->drv_priv; 335 sta_priv = (void *)sta->drv_priv;
@@ -345,7 +345,7 @@ int il4965_tx_skb(struct il_priv *priv, struct sk_buff *skb)
345 * For now set the counter to just 1 since we do not 345 * For now set the counter to just 1 since we do not
346 * support uAPSD yet. 346 * support uAPSD yet.
347 */ 347 */
348 il4965_sta_modify_sleep_tx_count(priv, sta_id, 1); 348 il4965_sta_modify_sleep_tx_count(il, sta_id, 1);
349 } 349 }
350 350
351 /* 351 /*
@@ -363,17 +363,17 @@ int il4965_tx_skb(struct il_priv *priv, struct sk_buff *skb)
363 } else 363 } else
364 txq_id = ctx->ac_to_queue[skb_get_queue_mapping(skb)]; 364 txq_id = ctx->ac_to_queue[skb_get_queue_mapping(skb)];
365 365
366 /* irqs already disabled/saved above when locking priv->lock */ 366 /* irqs already disabled/saved above when locking il->lock */
367 spin_lock(&priv->sta_lock); 367 spin_lock(&il->sta_lock);
368 368
369 if (ieee80211_is_data_qos(fc)) { 369 if (ieee80211_is_data_qos(fc)) {
370 qc = ieee80211_get_qos_ctl(hdr); 370 qc = ieee80211_get_qos_ctl(hdr);
371 tid = qc[0] & IEEE80211_QOS_CTL_TID_MASK; 371 tid = qc[0] & IEEE80211_QOS_CTL_TID_MASK;
372 if (WARN_ON_ONCE(tid >= MAX_TID_COUNT)) { 372 if (WARN_ON_ONCE(tid >= MAX_TID_COUNT)) {
373 spin_unlock(&priv->sta_lock); 373 spin_unlock(&il->sta_lock);
374 goto drop_unlock; 374 goto drop_unlock;
375 } 375 }
376 seq_number = priv->stations[sta_id].tid[tid].seq_number; 376 seq_number = il->stations[sta_id].tid[tid].seq_number;
377 seq_number &= IEEE80211_SCTL_SEQ; 377 seq_number &= IEEE80211_SCTL_SEQ;
378 hdr->seq_ctrl = hdr->seq_ctrl & 378 hdr->seq_ctrl = hdr->seq_ctrl &
379 cpu_to_le16(IEEE80211_SCTL_FRAG); 379 cpu_to_le16(IEEE80211_SCTL_FRAG);
@@ -381,27 +381,27 @@ int il4965_tx_skb(struct il_priv *priv, struct sk_buff *skb)
381 seq_number += 0x10; 381 seq_number += 0x10;
382 /* aggregation is on for this <sta,tid> */ 382 /* aggregation is on for this <sta,tid> */
383 if (info->flags & IEEE80211_TX_CTL_AMPDU && 383 if (info->flags & IEEE80211_TX_CTL_AMPDU &&
384 priv->stations[sta_id].tid[tid].agg.state == IL_AGG_ON) { 384 il->stations[sta_id].tid[tid].agg.state == IL_AGG_ON) {
385 txq_id = priv->stations[sta_id].tid[tid].agg.txq_id; 385 txq_id = il->stations[sta_id].tid[tid].agg.txq_id;
386 is_agg = true; 386 is_agg = true;
387 } 387 }
388 } 388 }
389 389
390 txq = &priv->txq[txq_id]; 390 txq = &il->txq[txq_id];
391 q = &txq->q; 391 q = &txq->q;
392 392
393 if (unlikely(il_queue_space(q) < q->high_mark)) { 393 if (unlikely(il_queue_space(q) < q->high_mark)) {
394 spin_unlock(&priv->sta_lock); 394 spin_unlock(&il->sta_lock);
395 goto drop_unlock; 395 goto drop_unlock;
396 } 396 }
397 397
398 if (ieee80211_is_data_qos(fc)) { 398 if (ieee80211_is_data_qos(fc)) {
399 priv->stations[sta_id].tid[tid].tfds_in_queue++; 399 il->stations[sta_id].tid[tid].tfds_in_queue++;
400 if (!ieee80211_has_morefrags(fc)) 400 if (!ieee80211_has_morefrags(fc))
401 priv->stations[sta_id].tid[tid].seq_number = seq_number; 401 il->stations[sta_id].tid[tid].seq_number = seq_number;
402 } 402 }
403 403
404 spin_unlock(&priv->sta_lock); 404 spin_unlock(&il->sta_lock);
405 405
406 /* Set up driver data for this TFD */ 406 /* Set up driver data for this TFD */
407 memset(&(txq->txb[q->write_ptr]), 0, sizeof(struct il_tx_info)); 407 memset(&(txq->txb[q->write_ptr]), 0, sizeof(struct il_tx_info));
@@ -434,15 +434,15 @@ int il4965_tx_skb(struct il_priv *priv, struct sk_buff *skb)
434 tx_cmd->len = cpu_to_le16(len); 434 tx_cmd->len = cpu_to_le16(len);
435 435
436 if (info->control.hw_key) 436 if (info->control.hw_key)
437 il4965_tx_cmd_build_hwcrypto(priv, info, tx_cmd, skb, sta_id); 437 il4965_tx_cmd_build_hwcrypto(il, info, tx_cmd, skb, sta_id);
438 438
439 /* TODO need this for burst mode later on */ 439 /* TODO need this for burst mode later on */
440 il4965_tx_cmd_build_basic(priv, skb, tx_cmd, info, hdr, sta_id); 440 il4965_tx_cmd_build_basic(il, skb, tx_cmd, info, hdr, sta_id);
441 il_dbg_log_tx_data_frame(priv, len, hdr); 441 il_dbg_log_tx_data_frame(il, len, hdr);
442 442
443 il4965_tx_cmd_build_rate(priv, tx_cmd, info, fc); 443 il4965_tx_cmd_build_rate(il, tx_cmd, info, fc);
444 444
445 il_update_stats(priv, true, fc, len); 445 il_update_stats(il, true, fc, len);
446 /* 446 /*
447 * Use the first empty entry in this queue's command buffer array 447 * Use the first empty entry in this queue's command buffer array
448 * to contain the Tx command and MAC header concatenated together 448 * to contain the Tx command and MAC header concatenated together
@@ -462,14 +462,14 @@ int il4965_tx_skb(struct il_priv *priv, struct sk_buff *skb)
462 462
463 /* Physical address of this Tx command's header (not MAC header!), 463 /* Physical address of this Tx command's header (not MAC header!),
464 * within command buffer array. */ 464 * within command buffer array. */
465 txcmd_phys = pci_map_single(priv->pci_dev, 465 txcmd_phys = pci_map_single(il->pci_dev,
466 &out_cmd->hdr, firstlen, 466 &out_cmd->hdr, firstlen,
467 PCI_DMA_BIDIRECTIONAL); 467 PCI_DMA_BIDIRECTIONAL);
468 dma_unmap_addr_set(out_meta, mapping, txcmd_phys); 468 dma_unmap_addr_set(out_meta, mapping, txcmd_phys);
469 dma_unmap_len_set(out_meta, len, firstlen); 469 dma_unmap_len_set(out_meta, len, firstlen);
470 /* Add buffer containing Tx command and MAC(!) header to TFD's 470 /* Add buffer containing Tx command and MAC(!) header to TFD's
471 * first entry */ 471 * first entry */
472 priv->cfg->ops->lib->txq_attach_buf_to_tfd(priv, txq, 472 il->cfg->ops->lib->txq_attach_buf_to_tfd(il, txq,
473 txcmd_phys, firstlen, 1, 0); 473 txcmd_phys, firstlen, 1, 0);
474 474
475 if (!ieee80211_has_morefrags(hdr->frame_control)) { 475 if (!ieee80211_has_morefrags(hdr->frame_control)) {
@@ -483,9 +483,9 @@ int il4965_tx_skb(struct il_priv *priv, struct sk_buff *skb)
483 * if any (802.11 null frames have no payload). */ 483 * if any (802.11 null frames have no payload). */
484 secondlen = skb->len - hdr_len; 484 secondlen = skb->len - hdr_len;
485 if (secondlen > 0) { 485 if (secondlen > 0) {
486 phys_addr = pci_map_single(priv->pci_dev, skb->data + hdr_len, 486 phys_addr = pci_map_single(il->pci_dev, skb->data + hdr_len,
487 secondlen, PCI_DMA_TODEVICE); 487 secondlen, PCI_DMA_TODEVICE);
488 priv->cfg->ops->lib->txq_attach_buf_to_tfd(priv, txq, 488 il->cfg->ops->lib->txq_attach_buf_to_tfd(il, txq,
489 phys_addr, secondlen, 489 phys_addr, secondlen,
490 0, 0); 490 0, 0);
491 } 491 }
@@ -494,29 +494,29 @@ int il4965_tx_skb(struct il_priv *priv, struct sk_buff *skb)
494 offsetof(struct il_tx_cmd, scratch); 494 offsetof(struct il_tx_cmd, scratch);
495 495
496 /* take back ownership of DMA buffer to enable update */ 496 /* take back ownership of DMA buffer to enable update */
497 pci_dma_sync_single_for_cpu(priv->pci_dev, txcmd_phys, 497 pci_dma_sync_single_for_cpu(il->pci_dev, txcmd_phys,
498 firstlen, PCI_DMA_BIDIRECTIONAL); 498 firstlen, PCI_DMA_BIDIRECTIONAL);
499 tx_cmd->dram_lsb_ptr = cpu_to_le32(scratch_phys); 499 tx_cmd->dram_lsb_ptr = cpu_to_le32(scratch_phys);
500 tx_cmd->dram_msb_ptr = il_get_dma_hi_addr(scratch_phys); 500 tx_cmd->dram_msb_ptr = il_get_dma_hi_addr(scratch_phys);
501 501
502 IL_DEBUG_TX(priv, "sequence nr = 0X%x\n", 502 IL_DEBUG_TX(il, "sequence nr = 0X%x\n",
503 le16_to_cpu(out_cmd->hdr.sequence)); 503 le16_to_cpu(out_cmd->hdr.sequence));
504 IL_DEBUG_TX(priv, "tx_flags = 0X%x\n", le32_to_cpu(tx_cmd->tx_flags)); 504 IL_DEBUG_TX(il, "tx_flags = 0X%x\n", le32_to_cpu(tx_cmd->tx_flags));
505 il_print_hex_dump(priv, IL_DL_TX, (u8 *)tx_cmd, sizeof(*tx_cmd)); 505 il_print_hex_dump(il, IL_DL_TX, (u8 *)tx_cmd, sizeof(*tx_cmd));
506 il_print_hex_dump(priv, IL_DL_TX, (u8 *)tx_cmd->hdr, hdr_len); 506 il_print_hex_dump(il, IL_DL_TX, (u8 *)tx_cmd->hdr, hdr_len);
507 507
508 /* Set up entry for this TFD in Tx byte-count array */ 508 /* Set up entry for this TFD in Tx byte-count array */
509 if (info->flags & IEEE80211_TX_CTL_AMPDU) 509 if (info->flags & IEEE80211_TX_CTL_AMPDU)
510 priv->cfg->ops->lib->txq_update_byte_cnt_tbl(priv, txq, 510 il->cfg->ops->lib->txq_update_byte_cnt_tbl(il, txq,
511 le16_to_cpu(tx_cmd->len)); 511 le16_to_cpu(tx_cmd->len));
512 512
513 pci_dma_sync_single_for_device(priv->pci_dev, txcmd_phys, 513 pci_dma_sync_single_for_device(il->pci_dev, txcmd_phys,
514 firstlen, PCI_DMA_BIDIRECTIONAL); 514 firstlen, PCI_DMA_BIDIRECTIONAL);
515 515
516 /* Tell device the write index *just past* this latest filled TFD */ 516 /* Tell device the write index *just past* this latest filled TFD */
517 q->write_ptr = il_queue_inc_wrap(q->write_ptr, q->n_bd); 517 q->write_ptr = il_queue_inc_wrap(q->write_ptr, q->n_bd);
518 il_txq_update_write_ptr(priv, txq); 518 il_txq_update_write_ptr(il, txq);
519 spin_unlock_irqrestore(&priv->lock, flags); 519 spin_unlock_irqrestore(&il->lock, flags);
520 520
521 /* 521 /*
522 * At this point the frame is "transmitted" successfully 522 * At this point the frame is "transmitted" successfully
@@ -536,28 +536,28 @@ int il4965_tx_skb(struct il_priv *priv, struct sk_buff *skb)
536 atomic_inc(&sta_priv->pending_frames); 536 atomic_inc(&sta_priv->pending_frames);
537 537
538 if ((il_queue_space(q) < q->high_mark) && 538 if ((il_queue_space(q) < q->high_mark) &&
539 priv->mac80211_registered) { 539 il->mac80211_registered) {
540 if (wait_write_ptr) { 540 if (wait_write_ptr) {
541 spin_lock_irqsave(&priv->lock, flags); 541 spin_lock_irqsave(&il->lock, flags);
542 txq->need_update = 1; 542 txq->need_update = 1;
543 il_txq_update_write_ptr(priv, txq); 543 il_txq_update_write_ptr(il, txq);
544 spin_unlock_irqrestore(&priv->lock, flags); 544 spin_unlock_irqrestore(&il->lock, flags);
545 } else { 545 } else {
546 il_stop_queue(priv, txq); 546 il_stop_queue(il, txq);
547 } 547 }
548 } 548 }
549 549
550 return 0; 550 return 0;
551 551
552drop_unlock: 552drop_unlock:
553 spin_unlock_irqrestore(&priv->lock, flags); 553 spin_unlock_irqrestore(&il->lock, flags);
554 return -1; 554 return -1;
555} 555}
556 556
557static inline int il4965_alloc_dma_ptr(struct il_priv *priv, 557static inline int il4965_alloc_dma_ptr(struct il_priv *il,
558 struct il_dma_ptr *ptr, size_t size) 558 struct il_dma_ptr *ptr, size_t size)
559{ 559{
560 ptr->addr = dma_alloc_coherent(&priv->pci_dev->dev, size, &ptr->dma, 560 ptr->addr = dma_alloc_coherent(&il->pci_dev->dev, size, &ptr->dma,
561 GFP_KERNEL); 561 GFP_KERNEL);
562 if (!ptr->addr) 562 if (!ptr->addr)
563 return -ENOMEM; 563 return -ENOMEM;
@@ -565,13 +565,13 @@ static inline int il4965_alloc_dma_ptr(struct il_priv *priv,
565 return 0; 565 return 0;
566} 566}
567 567
568static inline void il4965_free_dma_ptr(struct il_priv *priv, 568static inline void il4965_free_dma_ptr(struct il_priv *il,
569 struct il_dma_ptr *ptr) 569 struct il_dma_ptr *ptr)
570{ 570{
571 if (unlikely(!ptr->addr)) 571 if (unlikely(!ptr->addr))
572 return; 572 return;
573 573
574 dma_free_coherent(&priv->pci_dev->dev, ptr->size, ptr->addr, ptr->dma); 574 dma_free_coherent(&il->pci_dev->dev, ptr->size, ptr->addr, ptr->dma);
575 memset(ptr, 0, sizeof(*ptr)); 575 memset(ptr, 0, sizeof(*ptr));
576} 576}
577 577
@@ -580,79 +580,79 @@ static inline void il4965_free_dma_ptr(struct il_priv *priv,
580 * 580 *
581 * Destroy all TX DMA queues and structures 581 * Destroy all TX DMA queues and structures
582 */ 582 */
583void il4965_hw_txq_ctx_free(struct il_priv *priv) 583void il4965_hw_txq_ctx_free(struct il_priv *il)
584{ 584{
585 int txq_id; 585 int txq_id;
586 586
587 /* Tx queues */ 587 /* Tx queues */
588 if (priv->txq) { 588 if (il->txq) {
589 for (txq_id = 0; txq_id < priv->hw_params.max_txq_num; txq_id++) 589 for (txq_id = 0; txq_id < il->hw_params.max_txq_num; txq_id++)
590 if (txq_id == priv->cmd_queue) 590 if (txq_id == il->cmd_queue)
591 il_cmd_queue_free(priv); 591 il_cmd_queue_free(il);
592 else 592 else
593 il_tx_queue_free(priv, txq_id); 593 il_tx_queue_free(il, txq_id);
594 } 594 }
595 il4965_free_dma_ptr(priv, &priv->kw); 595 il4965_free_dma_ptr(il, &il->kw);
596 596
597 il4965_free_dma_ptr(priv, &priv->scd_bc_tbls); 597 il4965_free_dma_ptr(il, &il->scd_bc_tbls);
598 598
599 /* free tx queue structure */ 599 /* free tx queue structure */
600 il_txq_mem(priv); 600 il_txq_mem(il);
601} 601}
602 602
603/** 603/**
604 * il4965_txq_ctx_alloc - allocate TX queue context 604 * il4965_txq_ctx_alloc - allocate TX queue context
605 * Allocate all Tx DMA structures and initialize them 605 * Allocate all Tx DMA structures and initialize them
606 * 606 *
607 * @param priv 607 * @param il
608 * @return error code 608 * @return error code
609 */ 609 */
610int il4965_txq_ctx_alloc(struct il_priv *priv) 610int il4965_txq_ctx_alloc(struct il_priv *il)
611{ 611{
612 int ret; 612 int ret;
613 int txq_id, slots_num; 613 int txq_id, slots_num;
614 unsigned long flags; 614 unsigned long flags;
615 615
616 /* Free all tx/cmd queues and keep-warm buffer */ 616 /* Free all tx/cmd queues and keep-warm buffer */
617 il4965_hw_txq_ctx_free(priv); 617 il4965_hw_txq_ctx_free(il);
618 618
619 ret = il4965_alloc_dma_ptr(priv, &priv->scd_bc_tbls, 619 ret = il4965_alloc_dma_ptr(il, &il->scd_bc_tbls,
620 priv->hw_params.scd_bc_tbls_size); 620 il->hw_params.scd_bc_tbls_size);
621 if (ret) { 621 if (ret) {
622 IL_ERR(priv, "Scheduler BC Table allocation failed\n"); 622 IL_ERR(il, "Scheduler BC Table allocation failed\n");
623 goto error_bc_tbls; 623 goto error_bc_tbls;
624 } 624 }
625 /* Alloc keep-warm buffer */ 625 /* Alloc keep-warm buffer */
626 ret = il4965_alloc_dma_ptr(priv, &priv->kw, IL_KW_SIZE); 626 ret = il4965_alloc_dma_ptr(il, &il->kw, IL_KW_SIZE);
627 if (ret) { 627 if (ret) {
628 IL_ERR(priv, "Keep Warm allocation failed\n"); 628 IL_ERR(il, "Keep Warm allocation failed\n");
629 goto error_kw; 629 goto error_kw;
630 } 630 }
631 631
632 /* allocate tx queue structure */ 632 /* allocate tx queue structure */
633 ret = il_alloc_txq_mem(priv); 633 ret = il_alloc_txq_mem(il);
634 if (ret) 634 if (ret)
635 goto error; 635 goto error;
636 636
637 spin_lock_irqsave(&priv->lock, flags); 637 spin_lock_irqsave(&il->lock, flags);
638 638
639 /* Turn off all Tx DMA fifos */ 639 /* Turn off all Tx DMA fifos */
640 il4965_txq_set_sched(priv, 0); 640 il4965_txq_set_sched(il, 0);
641 641
642 /* Tell NIC where to find the "keep warm" buffer */ 642 /* Tell NIC where to find the "keep warm" buffer */
643 il_write_direct32(priv, FH_KW_MEM_ADDR_REG, priv->kw.dma >> 4); 643 il_write_direct32(il, FH_KW_MEM_ADDR_REG, il->kw.dma >> 4);
644 644
645 spin_unlock_irqrestore(&priv->lock, flags); 645 spin_unlock_irqrestore(&il->lock, flags);
646 646
647 /* Alloc and init all Tx queues, including the command queue (#4/#9) */ 647 /* Alloc and init all Tx queues, including the command queue (#4/#9) */
648 for (txq_id = 0; txq_id < priv->hw_params.max_txq_num; txq_id++) { 648 for (txq_id = 0; txq_id < il->hw_params.max_txq_num; txq_id++) {
649 slots_num = (txq_id == priv->cmd_queue) ? 649 slots_num = (txq_id == il->cmd_queue) ?
650 TFD_CMD_SLOTS : TFD_TX_CMD_SLOTS; 650 TFD_CMD_SLOTS : TFD_TX_CMD_SLOTS;
651 ret = il_tx_queue_init(priv, 651 ret = il_tx_queue_init(il,
652 &priv->txq[txq_id], slots_num, 652 &il->txq[txq_id], slots_num,
653 txq_id); 653 txq_id);
654 if (ret) { 654 if (ret) {
655 IL_ERR(priv, "Tx %d queue init failed\n", txq_id); 655 IL_ERR(il, "Tx %d queue init failed\n", txq_id);
656 goto error; 656 goto error;
657 } 657 }
658 } 658 }
@@ -660,34 +660,34 @@ int il4965_txq_ctx_alloc(struct il_priv *priv)
660 return ret; 660 return ret;
661 661
662 error: 662 error:
663 il4965_hw_txq_ctx_free(priv); 663 il4965_hw_txq_ctx_free(il);
664 il4965_free_dma_ptr(priv, &priv->kw); 664 il4965_free_dma_ptr(il, &il->kw);
665 error_kw: 665 error_kw:
666 il4965_free_dma_ptr(priv, &priv->scd_bc_tbls); 666 il4965_free_dma_ptr(il, &il->scd_bc_tbls);
667 error_bc_tbls: 667 error_bc_tbls:
668 return ret; 668 return ret;
669} 669}
670 670
671void il4965_txq_ctx_reset(struct il_priv *priv) 671void il4965_txq_ctx_reset(struct il_priv *il)
672{ 672{
673 int txq_id, slots_num; 673 int txq_id, slots_num;
674 unsigned long flags; 674 unsigned long flags;
675 675
676 spin_lock_irqsave(&priv->lock, flags); 676 spin_lock_irqsave(&il->lock, flags);
677 677
678 /* Turn off all Tx DMA fifos */ 678 /* Turn off all Tx DMA fifos */
679 il4965_txq_set_sched(priv, 0); 679 il4965_txq_set_sched(il, 0);
680 680
681 /* Tell NIC where to find the "keep warm" buffer */ 681 /* Tell NIC where to find the "keep warm" buffer */
682 il_write_direct32(priv, FH_KW_MEM_ADDR_REG, priv->kw.dma >> 4); 682 il_write_direct32(il, FH_KW_MEM_ADDR_REG, il->kw.dma >> 4);
683 683
684 spin_unlock_irqrestore(&priv->lock, flags); 684 spin_unlock_irqrestore(&il->lock, flags);
685 685
686 /* Alloc and init all Tx queues, including the command queue (#4) */ 686 /* Alloc and init all Tx queues, including the command queue (#4) */
687 for (txq_id = 0; txq_id < priv->hw_params.max_txq_num; txq_id++) { 687 for (txq_id = 0; txq_id < il->hw_params.max_txq_num; txq_id++) {
688 slots_num = txq_id == priv->cmd_queue ? 688 slots_num = txq_id == il->cmd_queue ?
689 TFD_CMD_SLOTS : TFD_TX_CMD_SLOTS; 689 TFD_CMD_SLOTS : TFD_TX_CMD_SLOTS;
690 il_tx_queue_reset(priv, &priv->txq[txq_id], 690 il_tx_queue_reset(il, &il->txq[txq_id],
691 slots_num, txq_id); 691 slots_num, txq_id);
692 } 692 }
693} 693}
@@ -695,39 +695,39 @@ void il4965_txq_ctx_reset(struct il_priv *priv)
695/** 695/**
696 * il4965_txq_ctx_stop - Stop all Tx DMA channels 696 * il4965_txq_ctx_stop - Stop all Tx DMA channels
697 */ 697 */
698void il4965_txq_ctx_stop(struct il_priv *priv) 698void il4965_txq_ctx_stop(struct il_priv *il)
699{ 699{
700 int ch, txq_id; 700 int ch, txq_id;
701 unsigned long flags; 701 unsigned long flags;
702 702
703 /* Turn off all Tx DMA fifos */ 703 /* Turn off all Tx DMA fifos */
704 spin_lock_irqsave(&priv->lock, flags); 704 spin_lock_irqsave(&il->lock, flags);
705 705
706 il4965_txq_set_sched(priv, 0); 706 il4965_txq_set_sched(il, 0);
707 707
708 /* Stop each Tx DMA channel, and wait for it to be idle */ 708 /* Stop each Tx DMA channel, and wait for it to be idle */
709 for (ch = 0; ch < priv->hw_params.dma_chnl_num; ch++) { 709 for (ch = 0; ch < il->hw_params.dma_chnl_num; ch++) {
710 il_write_direct32(priv, 710 il_write_direct32(il,
711 FH_TCSR_CHNL_TX_CONFIG_REG(ch), 0x0); 711 FH_TCSR_CHNL_TX_CONFIG_REG(ch), 0x0);
712 if (il_poll_direct_bit(priv, FH_TSSR_TX_STATUS_REG, 712 if (il_poll_direct_bit(il, FH_TSSR_TX_STATUS_REG,
713 FH_TSSR_TX_STATUS_REG_MSK_CHNL_IDLE(ch), 713 FH_TSSR_TX_STATUS_REG_MSK_CHNL_IDLE(ch),
714 1000)) 714 1000))
715 IL_ERR(priv, "Failing on timeout while stopping" 715 IL_ERR(il, "Failing on timeout while stopping"
716 " DMA channel %d [0x%08x]", ch, 716 " DMA channel %d [0x%08x]", ch,
717 il_read_direct32(priv, 717 il_read_direct32(il,
718 FH_TSSR_TX_STATUS_REG)); 718 FH_TSSR_TX_STATUS_REG));
719 } 719 }
720 spin_unlock_irqrestore(&priv->lock, flags); 720 spin_unlock_irqrestore(&il->lock, flags);
721 721
722 if (!priv->txq) 722 if (!il->txq)
723 return; 723 return;
724 724
725 /* Unmap DMA from host system and free skb's */ 725 /* Unmap DMA from host system and free skb's */
726 for (txq_id = 0; txq_id < priv->hw_params.max_txq_num; txq_id++) 726 for (txq_id = 0; txq_id < il->hw_params.max_txq_num; txq_id++)
727 if (txq_id == priv->cmd_queue) 727 if (txq_id == il->cmd_queue)
728 il_cmd_queue_unmap(priv); 728 il_cmd_queue_unmap(il);
729 else 729 else
730 il_tx_queue_unmap(priv, txq_id); 730 il_tx_queue_unmap(il, txq_id);
731} 731}
732 732
733/* 733/*
@@ -736,12 +736,12 @@ void il4965_txq_ctx_stop(struct il_priv *priv)
736 * Should never return anything < 7, because they should already 736 * Should never return anything < 7, because they should already
737 * be in use as EDCA AC (0-3), Command (4), reserved (5, 6) 737 * be in use as EDCA AC (0-3), Command (4), reserved (5, 6)
738 */ 738 */
739static int il4965_txq_ctx_activate_free(struct il_priv *priv) 739static int il4965_txq_ctx_activate_free(struct il_priv *il)
740{ 740{
741 int txq_id; 741 int txq_id;
742 742
743 for (txq_id = 0; txq_id < priv->hw_params.max_txq_num; txq_id++) 743 for (txq_id = 0; txq_id < il->hw_params.max_txq_num; txq_id++)
744 if (!test_and_set_bit(txq_id, &priv->txq_ctx_active_msk)) 744 if (!test_and_set_bit(txq_id, &il->txq_ctx_active_msk))
745 return txq_id; 745 return txq_id;
746 return -1; 746 return -1;
747} 747}
@@ -749,12 +749,12 @@ static int il4965_txq_ctx_activate_free(struct il_priv *priv)
749/** 749/**
750 * il4965_tx_queue_stop_scheduler - Stop queue, but keep configuration 750 * il4965_tx_queue_stop_scheduler - Stop queue, but keep configuration
751 */ 751 */
752static void il4965_tx_queue_stop_scheduler(struct il_priv *priv, 752static void il4965_tx_queue_stop_scheduler(struct il_priv *il,
753 u16 txq_id) 753 u16 txq_id)
754{ 754{
755 /* Simply stop the queue, but don't change any configuration; 755 /* Simply stop the queue, but don't change any configuration;
756 * the SCD_ACT_EN bit is the write-enable mask for the ACTIVE bit. */ 756 * the SCD_ACT_EN bit is the write-enable mask for the ACTIVE bit. */
757 il_write_prph(priv, 757 il_write_prph(il,
758 IWL49_SCD_QUEUE_STATUS_BITS(txq_id), 758 IWL49_SCD_QUEUE_STATUS_BITS(txq_id),
759 (0 << IWL49_SCD_QUEUE_STTS_REG_POS_ACTIVE)| 759 (0 << IWL49_SCD_QUEUE_STTS_REG_POS_ACTIVE)|
760 (1 << IWL49_SCD_QUEUE_STTS_REG_POS_SCD_ACT_EN)); 760 (1 << IWL49_SCD_QUEUE_STTS_REG_POS_SCD_ACT_EN));
@@ -763,7 +763,7 @@ static void il4965_tx_queue_stop_scheduler(struct il_priv *priv,
763/** 763/**
764 * il4965_tx_queue_set_q2ratid - Map unique receiver/tid combination to a queue 764 * il4965_tx_queue_set_q2ratid - Map unique receiver/tid combination to a queue
765 */ 765 */
766static int il4965_tx_queue_set_q2ratid(struct il_priv *priv, u16 ra_tid, 766static int il4965_tx_queue_set_q2ratid(struct il_priv *il, u16 ra_tid,
767 u16 txq_id) 767 u16 txq_id)
768{ 768{
769 u32 tbl_dw_addr; 769 u32 tbl_dw_addr;
@@ -772,17 +772,17 @@ static int il4965_tx_queue_set_q2ratid(struct il_priv *priv, u16 ra_tid,
772 772
773 scd_q2ratid = ra_tid & IL_SCD_QUEUE_RA_TID_MAP_RATID_MSK; 773 scd_q2ratid = ra_tid & IL_SCD_QUEUE_RA_TID_MAP_RATID_MSK;
774 774
775 tbl_dw_addr = priv->scd_base_addr + 775 tbl_dw_addr = il->scd_base_addr +
776 IWL49_SCD_TRANSLATE_TBL_OFFSET_QUEUE(txq_id); 776 IWL49_SCD_TRANSLATE_TBL_OFFSET_QUEUE(txq_id);
777 777
778 tbl_dw = il_read_targ_mem(priv, tbl_dw_addr); 778 tbl_dw = il_read_targ_mem(il, tbl_dw_addr);
779 779
780 if (txq_id & 0x1) 780 if (txq_id & 0x1)
781 tbl_dw = (scd_q2ratid << 16) | (tbl_dw & 0x0000FFFF); 781 tbl_dw = (scd_q2ratid << 16) | (tbl_dw & 0x0000FFFF);
782 else 782 else
783 tbl_dw = scd_q2ratid | (tbl_dw & 0xFFFF0000); 783 tbl_dw = scd_q2ratid | (tbl_dw & 0xFFFF0000);
784 784
785 il_write_targ_mem(priv, tbl_dw_addr, tbl_dw); 785 il_write_targ_mem(il, tbl_dw_addr, tbl_dw);
786 786
787 return 0; 787 return 0;
788} 788}
@@ -793,7 +793,7 @@ static int il4965_tx_queue_set_q2ratid(struct il_priv *priv, u16 ra_tid,
793 * NOTE: txq_id must be greater than IWL49_FIRST_AMPDU_QUEUE, 793 * NOTE: txq_id must be greater than IWL49_FIRST_AMPDU_QUEUE,
794 * i.e. it must be one of the higher queues used for aggregation 794 * i.e. it must be one of the higher queues used for aggregation
795 */ 795 */
796static int il4965_txq_agg_enable(struct il_priv *priv, int txq_id, 796static int il4965_txq_agg_enable(struct il_priv *il, int txq_id,
797 int tx_fifo, int sta_id, int tid, u16 ssn_idx) 797 int tx_fifo, int sta_id, int tid, u16 ssn_idx)
798{ 798{
799 unsigned long flags; 799 unsigned long flags;
@@ -802,62 +802,62 @@ static int il4965_txq_agg_enable(struct il_priv *priv, int txq_id,
802 802
803 if ((IWL49_FIRST_AMPDU_QUEUE > txq_id) || 803 if ((IWL49_FIRST_AMPDU_QUEUE > txq_id) ||
804 (IWL49_FIRST_AMPDU_QUEUE + 804 (IWL49_FIRST_AMPDU_QUEUE +
805 priv->cfg->base_params->num_of_ampdu_queues <= txq_id)) { 805 il->cfg->base_params->num_of_ampdu_queues <= txq_id)) {
806 IL_WARN(priv, 806 IL_WARN(il,
807 "queue number out of range: %d, must be %d to %d\n", 807 "queue number out of range: %d, must be %d to %d\n",
808 txq_id, IWL49_FIRST_AMPDU_QUEUE, 808 txq_id, IWL49_FIRST_AMPDU_QUEUE,
809 IWL49_FIRST_AMPDU_QUEUE + 809 IWL49_FIRST_AMPDU_QUEUE +
810 priv->cfg->base_params->num_of_ampdu_queues - 1); 810 il->cfg->base_params->num_of_ampdu_queues - 1);
811 return -EINVAL; 811 return -EINVAL;
812 } 812 }
813 813
814 ra_tid = BUILD_RAxTID(sta_id, tid); 814 ra_tid = BUILD_RAxTID(sta_id, tid);
815 815
816 /* Modify device's station table to Tx this TID */ 816 /* Modify device's station table to Tx this TID */
817 ret = il4965_sta_tx_modify_enable_tid(priv, sta_id, tid); 817 ret = il4965_sta_tx_modify_enable_tid(il, sta_id, tid);
818 if (ret) 818 if (ret)
819 return ret; 819 return ret;
820 820
821 spin_lock_irqsave(&priv->lock, flags); 821 spin_lock_irqsave(&il->lock, flags);
822 822
823 /* Stop this Tx queue before configuring it */ 823 /* Stop this Tx queue before configuring it */
824 il4965_tx_queue_stop_scheduler(priv, txq_id); 824 il4965_tx_queue_stop_scheduler(il, txq_id);
825 825
826 /* Map receiver-address / traffic-ID to this queue */ 826 /* Map receiver-address / traffic-ID to this queue */
827 il4965_tx_queue_set_q2ratid(priv, ra_tid, txq_id); 827 il4965_tx_queue_set_q2ratid(il, ra_tid, txq_id);
828 828
829 /* Set this queue as a chain-building queue */ 829 /* Set this queue as a chain-building queue */
830 il_set_bits_prph(priv, IWL49_SCD_QUEUECHAIN_SEL, (1 << txq_id)); 830 il_set_bits_prph(il, IWL49_SCD_QUEUECHAIN_SEL, (1 << txq_id));
831 831
832 /* Place first TFD at index corresponding to start sequence number. 832 /* Place first TFD at index corresponding to start sequence number.
833 * Assumes that ssn_idx is valid (!= 0xFFF) */ 833 * Assumes that ssn_idx is valid (!= 0xFFF) */
834 priv->txq[txq_id].q.read_ptr = (ssn_idx & 0xff); 834 il->txq[txq_id].q.read_ptr = (ssn_idx & 0xff);
835 priv->txq[txq_id].q.write_ptr = (ssn_idx & 0xff); 835 il->txq[txq_id].q.write_ptr = (ssn_idx & 0xff);
836 il4965_set_wr_ptrs(priv, txq_id, ssn_idx); 836 il4965_set_wr_ptrs(il, txq_id, ssn_idx);
837 837
838 /* Set up Tx window size and frame limit for this queue */ 838 /* Set up Tx window size and frame limit for this queue */
839 il_write_targ_mem(priv, 839 il_write_targ_mem(il,
840 priv->scd_base_addr + IWL49_SCD_CONTEXT_QUEUE_OFFSET(txq_id), 840 il->scd_base_addr + IWL49_SCD_CONTEXT_QUEUE_OFFSET(txq_id),
841 (SCD_WIN_SIZE << IWL49_SCD_QUEUE_CTX_REG1_WIN_SIZE_POS) & 841 (SCD_WIN_SIZE << IWL49_SCD_QUEUE_CTX_REG1_WIN_SIZE_POS) &
842 IWL49_SCD_QUEUE_CTX_REG1_WIN_SIZE_MSK); 842 IWL49_SCD_QUEUE_CTX_REG1_WIN_SIZE_MSK);
843 843
844 il_write_targ_mem(priv, priv->scd_base_addr + 844 il_write_targ_mem(il, il->scd_base_addr +
845 IWL49_SCD_CONTEXT_QUEUE_OFFSET(txq_id) + sizeof(u32), 845 IWL49_SCD_CONTEXT_QUEUE_OFFSET(txq_id) + sizeof(u32),
846 (SCD_FRAME_LIMIT << IWL49_SCD_QUEUE_CTX_REG2_FRAME_LIMIT_POS) 846 (SCD_FRAME_LIMIT << IWL49_SCD_QUEUE_CTX_REG2_FRAME_LIMIT_POS)
847 & IWL49_SCD_QUEUE_CTX_REG2_FRAME_LIMIT_MSK); 847 & IWL49_SCD_QUEUE_CTX_REG2_FRAME_LIMIT_MSK);
848 848
849 il_set_bits_prph(priv, IWL49_SCD_INTERRUPT_MASK, (1 << txq_id)); 849 il_set_bits_prph(il, IWL49_SCD_INTERRUPT_MASK, (1 << txq_id));
850 850
851 /* Set up Status area in SRAM, map to Tx DMA/FIFO, activate the queue */ 851 /* Set up Status area in SRAM, map to Tx DMA/FIFO, activate the queue */
852 il4965_tx_queue_set_status(priv, &priv->txq[txq_id], tx_fifo, 1); 852 il4965_tx_queue_set_status(il, &il->txq[txq_id], tx_fifo, 1);
853 853
854 spin_unlock_irqrestore(&priv->lock, flags); 854 spin_unlock_irqrestore(&il->lock, flags);
855 855
856 return 0; 856 return 0;
857} 857}
858 858
859 859
860int il4965_tx_agg_start(struct il_priv *priv, struct ieee80211_vif *vif, 860int il4965_tx_agg_start(struct il_priv *il, struct ieee80211_vif *vif,
861 struct ieee80211_sta *sta, u16 tid, u16 *ssn) 861 struct ieee80211_sta *sta, u16 tid, u16 *ssn)
862{ 862{
863 int sta_id; 863 int sta_id;
@@ -871,94 +871,94 @@ int il4965_tx_agg_start(struct il_priv *priv, struct ieee80211_vif *vif,
871 if (unlikely(tx_fifo < 0)) 871 if (unlikely(tx_fifo < 0))
872 return tx_fifo; 872 return tx_fifo;
873 873
874 IL_WARN(priv, "%s on ra = %pM tid = %d\n", 874 IL_WARN(il, "%s on ra = %pM tid = %d\n",
875 __func__, sta->addr, tid); 875 __func__, sta->addr, tid);
876 876
877 sta_id = il_sta_id(sta); 877 sta_id = il_sta_id(sta);
878 if (sta_id == IL_INVALID_STATION) { 878 if (sta_id == IL_INVALID_STATION) {
879 IL_ERR(priv, "Start AGG on invalid station\n"); 879 IL_ERR(il, "Start AGG on invalid station\n");
880 return -ENXIO; 880 return -ENXIO;
881 } 881 }
882 if (unlikely(tid >= MAX_TID_COUNT)) 882 if (unlikely(tid >= MAX_TID_COUNT))
883 return -EINVAL; 883 return -EINVAL;
884 884
885 if (priv->stations[sta_id].tid[tid].agg.state != IL_AGG_OFF) { 885 if (il->stations[sta_id].tid[tid].agg.state != IL_AGG_OFF) {
886 IL_ERR(priv, "Start AGG when state is not IL_AGG_OFF !\n"); 886 IL_ERR(il, "Start AGG when state is not IL_AGG_OFF !\n");
887 return -ENXIO; 887 return -ENXIO;
888 } 888 }
889 889
890 txq_id = il4965_txq_ctx_activate_free(priv); 890 txq_id = il4965_txq_ctx_activate_free(il);
891 if (txq_id == -1) { 891 if (txq_id == -1) {
892 IL_ERR(priv, "No free aggregation queue available\n"); 892 IL_ERR(il, "No free aggregation queue available\n");
893 return -ENXIO; 893 return -ENXIO;
894 } 894 }
895 895
896 spin_lock_irqsave(&priv->sta_lock, flags); 896 spin_lock_irqsave(&il->sta_lock, flags);
897 tid_data = &priv->stations[sta_id].tid[tid]; 897 tid_data = &il->stations[sta_id].tid[tid];
898 *ssn = SEQ_TO_SN(tid_data->seq_number); 898 *ssn = SEQ_TO_SN(tid_data->seq_number);
899 tid_data->agg.txq_id = txq_id; 899 tid_data->agg.txq_id = txq_id;
900 il_set_swq_id(&priv->txq[txq_id], 900 il_set_swq_id(&il->txq[txq_id],
901 il4965_get_ac_from_tid(tid), txq_id); 901 il4965_get_ac_from_tid(tid), txq_id);
902 spin_unlock_irqrestore(&priv->sta_lock, flags); 902 spin_unlock_irqrestore(&il->sta_lock, flags);
903 903
904 ret = il4965_txq_agg_enable(priv, txq_id, tx_fifo, 904 ret = il4965_txq_agg_enable(il, txq_id, tx_fifo,
905 sta_id, tid, *ssn); 905 sta_id, tid, *ssn);
906 if (ret) 906 if (ret)
907 return ret; 907 return ret;
908 908
909 spin_lock_irqsave(&priv->sta_lock, flags); 909 spin_lock_irqsave(&il->sta_lock, flags);
910 tid_data = &priv->stations[sta_id].tid[tid]; 910 tid_data = &il->stations[sta_id].tid[tid];
911 if (tid_data->tfds_in_queue == 0) { 911 if (tid_data->tfds_in_queue == 0) {
912 IL_DEBUG_HT(priv, "HW queue is empty\n"); 912 IL_DEBUG_HT(il, "HW queue is empty\n");
913 tid_data->agg.state = IL_AGG_ON; 913 tid_data->agg.state = IL_AGG_ON;
914 ieee80211_start_tx_ba_cb_irqsafe(vif, sta->addr, tid); 914 ieee80211_start_tx_ba_cb_irqsafe(vif, sta->addr, tid);
915 } else { 915 } else {
916 IL_DEBUG_HT(priv, 916 IL_DEBUG_HT(il,
917 "HW queue is NOT empty: %d packets in HW queue\n", 917 "HW queue is NOT empty: %d packets in HW queue\n",
918 tid_data->tfds_in_queue); 918 tid_data->tfds_in_queue);
919 tid_data->agg.state = IL_EMPTYING_HW_QUEUE_ADDBA; 919 tid_data->agg.state = IL_EMPTYING_HW_QUEUE_ADDBA;
920 } 920 }
921 spin_unlock_irqrestore(&priv->sta_lock, flags); 921 spin_unlock_irqrestore(&il->sta_lock, flags);
922 return ret; 922 return ret;
923} 923}
924 924
925/** 925/**
926 * txq_id must be greater than IWL49_FIRST_AMPDU_QUEUE 926 * txq_id must be greater than IWL49_FIRST_AMPDU_QUEUE
927 * priv->lock must be held by the caller 927 * il->lock must be held by the caller
928 */ 928 */
929static int il4965_txq_agg_disable(struct il_priv *priv, u16 txq_id, 929static int il4965_txq_agg_disable(struct il_priv *il, u16 txq_id,
930 u16 ssn_idx, u8 tx_fifo) 930 u16 ssn_idx, u8 tx_fifo)
931{ 931{
932 if ((IWL49_FIRST_AMPDU_QUEUE > txq_id) || 932 if ((IWL49_FIRST_AMPDU_QUEUE > txq_id) ||
933 (IWL49_FIRST_AMPDU_QUEUE + 933 (IWL49_FIRST_AMPDU_QUEUE +
934 priv->cfg->base_params->num_of_ampdu_queues <= txq_id)) { 934 il->cfg->base_params->num_of_ampdu_queues <= txq_id)) {
935 IL_WARN(priv, 935 IL_WARN(il,
936 "queue number out of range: %d, must be %d to %d\n", 936 "queue number out of range: %d, must be %d to %d\n",
937 txq_id, IWL49_FIRST_AMPDU_QUEUE, 937 txq_id, IWL49_FIRST_AMPDU_QUEUE,
938 IWL49_FIRST_AMPDU_QUEUE + 938 IWL49_FIRST_AMPDU_QUEUE +
939 priv->cfg->base_params->num_of_ampdu_queues - 1); 939 il->cfg->base_params->num_of_ampdu_queues - 1);
940 return -EINVAL; 940 return -EINVAL;
941 } 941 }
942 942
943 il4965_tx_queue_stop_scheduler(priv, txq_id); 943 il4965_tx_queue_stop_scheduler(il, txq_id);
944 944
945 il_clear_bits_prph(priv, 945 il_clear_bits_prph(il,
946 IWL49_SCD_QUEUECHAIN_SEL, (1 << txq_id)); 946 IWL49_SCD_QUEUECHAIN_SEL, (1 << txq_id));
947 947
948 priv->txq[txq_id].q.read_ptr = (ssn_idx & 0xff); 948 il->txq[txq_id].q.read_ptr = (ssn_idx & 0xff);
949 priv->txq[txq_id].q.write_ptr = (ssn_idx & 0xff); 949 il->txq[txq_id].q.write_ptr = (ssn_idx & 0xff);
950 /* supposes that ssn_idx is valid (!= 0xFFF) */ 950 /* supposes that ssn_idx is valid (!= 0xFFF) */
951 il4965_set_wr_ptrs(priv, txq_id, ssn_idx); 951 il4965_set_wr_ptrs(il, txq_id, ssn_idx);
952 952
953 il_clear_bits_prph(priv, 953 il_clear_bits_prph(il,
954 IWL49_SCD_INTERRUPT_MASK, (1 << txq_id)); 954 IWL49_SCD_INTERRUPT_MASK, (1 << txq_id));
955 il_txq_ctx_deactivate(priv, txq_id); 955 il_txq_ctx_deactivate(il, txq_id);
956 il4965_tx_queue_set_status(priv, &priv->txq[txq_id], tx_fifo, 0); 956 il4965_tx_queue_set_status(il, &il->txq[txq_id], tx_fifo, 0);
957 957
958 return 0; 958 return 0;
959} 959}
960 960
961int il4965_tx_agg_stop(struct il_priv *priv, struct ieee80211_vif *vif, 961int il4965_tx_agg_stop(struct il_priv *il, struct ieee80211_vif *vif,
962 struct ieee80211_sta *sta, u16 tid) 962 struct ieee80211_sta *sta, u16 tid)
963{ 963{
964 int tx_fifo_id, txq_id, sta_id, ssn; 964 int tx_fifo_id, txq_id, sta_id, ssn;
@@ -973,17 +973,17 @@ int il4965_tx_agg_stop(struct il_priv *priv, struct ieee80211_vif *vif,
973 sta_id = il_sta_id(sta); 973 sta_id = il_sta_id(sta);
974 974
975 if (sta_id == IL_INVALID_STATION) { 975 if (sta_id == IL_INVALID_STATION) {
976 IL_ERR(priv, "Invalid station for AGG tid %d\n", tid); 976 IL_ERR(il, "Invalid station for AGG tid %d\n", tid);
977 return -ENXIO; 977 return -ENXIO;
978 } 978 }
979 979
980 spin_lock_irqsave(&priv->sta_lock, flags); 980 spin_lock_irqsave(&il->sta_lock, flags);
981 981
982 tid_data = &priv->stations[sta_id].tid[tid]; 982 tid_data = &il->stations[sta_id].tid[tid];
983 ssn = (tid_data->seq_number & IEEE80211_SCTL_SEQ) >> 4; 983 ssn = (tid_data->seq_number & IEEE80211_SCTL_SEQ) >> 4;
984 txq_id = tid_data->agg.txq_id; 984 txq_id = tid_data->agg.txq_id;
985 985
986 switch (priv->stations[sta_id].tid[tid].agg.state) { 986 switch (il->stations[sta_id].tid[tid].agg.state) {
987 case IL_EMPTYING_HW_QUEUE_ADDBA: 987 case IL_EMPTYING_HW_QUEUE_ADDBA:
988 /* 988 /*
989 * This can happen if the peer stops aggregation 989 * This can happen if the peer stops aggregation
@@ -991,33 +991,33 @@ int il4965_tx_agg_stop(struct il_priv *priv, struct ieee80211_vif *vif,
991 * queue we selected previously, i.e. before the 991 * queue we selected previously, i.e. before the
992 * session was really started completely. 992 * session was really started completely.
993 */ 993 */
994 IL_DEBUG_HT(priv, "AGG stop before setup done\n"); 994 IL_DEBUG_HT(il, "AGG stop before setup done\n");
995 goto turn_off; 995 goto turn_off;
996 case IL_AGG_ON: 996 case IL_AGG_ON:
997 break; 997 break;
998 default: 998 default:
999 IL_WARN(priv, "Stopping AGG while state not ON or starting\n"); 999 IL_WARN(il, "Stopping AGG while state not ON or starting\n");
1000 } 1000 }
1001 1001
1002 write_ptr = priv->txq[txq_id].q.write_ptr; 1002 write_ptr = il->txq[txq_id].q.write_ptr;
1003 read_ptr = priv->txq[txq_id].q.read_ptr; 1003 read_ptr = il->txq[txq_id].q.read_ptr;
1004 1004
1005 /* The queue is not empty */ 1005 /* The queue is not empty */
1006 if (write_ptr != read_ptr) { 1006 if (write_ptr != read_ptr) {
1007 IL_DEBUG_HT(priv, "Stopping a non empty AGG HW QUEUE\n"); 1007 IL_DEBUG_HT(il, "Stopping a non empty AGG HW QUEUE\n");
1008 priv->stations[sta_id].tid[tid].agg.state = 1008 il->stations[sta_id].tid[tid].agg.state =
1009 IL_EMPTYING_HW_QUEUE_DELBA; 1009 IL_EMPTYING_HW_QUEUE_DELBA;
1010 spin_unlock_irqrestore(&priv->sta_lock, flags); 1010 spin_unlock_irqrestore(&il->sta_lock, flags);
1011 return 0; 1011 return 0;
1012 } 1012 }
1013 1013
1014 IL_DEBUG_HT(priv, "HW queue is empty\n"); 1014 IL_DEBUG_HT(il, "HW queue is empty\n");
1015 turn_off: 1015 turn_off:
1016 priv->stations[sta_id].tid[tid].agg.state = IL_AGG_OFF; 1016 il->stations[sta_id].tid[tid].agg.state = IL_AGG_OFF;
1017 1017
1018 /* do not restore/save irqs */ 1018 /* do not restore/save irqs */
1019 spin_unlock(&priv->sta_lock); 1019 spin_unlock(&il->sta_lock);
1020 spin_lock(&priv->lock); 1020 spin_lock(&il->lock);
1021 1021
1022 /* 1022 /*
1023 * the only reason this call can fail is queue number out of range, 1023 * the only reason this call can fail is queue number out of range,
@@ -1026,27 +1026,27 @@ int il4965_tx_agg_stop(struct il_priv *priv, struct ieee80211_vif *vif,
1026 * to deactivate the uCode queue, just return "success" to allow 1026 * to deactivate the uCode queue, just return "success" to allow
1027 * mac80211 to clean up it own data. 1027 * mac80211 to clean up it own data.
1028 */ 1028 */
1029 il4965_txq_agg_disable(priv, txq_id, ssn, tx_fifo_id); 1029 il4965_txq_agg_disable(il, txq_id, ssn, tx_fifo_id);
1030 spin_unlock_irqrestore(&priv->lock, flags); 1030 spin_unlock_irqrestore(&il->lock, flags);
1031 1031
1032 ieee80211_stop_tx_ba_cb_irqsafe(vif, sta->addr, tid); 1032 ieee80211_stop_tx_ba_cb_irqsafe(vif, sta->addr, tid);
1033 1033
1034 return 0; 1034 return 0;
1035} 1035}
1036 1036
1037int il4965_txq_check_empty(struct il_priv *priv, 1037int il4965_txq_check_empty(struct il_priv *il,
1038 int sta_id, u8 tid, int txq_id) 1038 int sta_id, u8 tid, int txq_id)
1039{ 1039{
1040 struct il_queue *q = &priv->txq[txq_id].q; 1040 struct il_queue *q = &il->txq[txq_id].q;
1041 u8 *addr = priv->stations[sta_id].sta.sta.addr; 1041 u8 *addr = il->stations[sta_id].sta.sta.addr;
1042 struct il_tid_data *tid_data = &priv->stations[sta_id].tid[tid]; 1042 struct il_tid_data *tid_data = &il->stations[sta_id].tid[tid];
1043 struct il_rxon_context *ctx; 1043 struct il_rxon_context *ctx;
1044 1044
1045 ctx = &priv->contexts[priv->stations[sta_id].ctxid]; 1045 ctx = &il->contexts[il->stations[sta_id].ctxid];
1046 1046
1047 lockdep_assert_held(&priv->sta_lock); 1047 lockdep_assert_held(&il->sta_lock);
1048 1048
1049 switch (priv->stations[sta_id].tid[tid].agg.state) { 1049 switch (il->stations[sta_id].tid[tid].agg.state) {
1050 case IL_EMPTYING_HW_QUEUE_DELBA: 1050 case IL_EMPTYING_HW_QUEUE_DELBA:
1051 /* We are reclaiming the last packet of the */ 1051 /* We are reclaiming the last packet of the */
1052 /* aggregated HW queue */ 1052 /* aggregated HW queue */
@@ -1054,9 +1054,9 @@ int il4965_txq_check_empty(struct il_priv *priv,
1054 (q->read_ptr == q->write_ptr)) { 1054 (q->read_ptr == q->write_ptr)) {
1055 u16 ssn = SEQ_TO_SN(tid_data->seq_number); 1055 u16 ssn = SEQ_TO_SN(tid_data->seq_number);
1056 int tx_fifo = il4965_get_fifo_from_tid(ctx, tid); 1056 int tx_fifo = il4965_get_fifo_from_tid(ctx, tid);
1057 IL_DEBUG_HT(priv, 1057 IL_DEBUG_HT(il,
1058 "HW queue empty: continue DELBA flow\n"); 1058 "HW queue empty: continue DELBA flow\n");
1059 il4965_txq_agg_disable(priv, txq_id, ssn, tx_fifo); 1059 il4965_txq_agg_disable(il, txq_id, ssn, tx_fifo);
1060 tid_data->agg.state = IL_AGG_OFF; 1060 tid_data->agg.state = IL_AGG_OFF;
1061 ieee80211_stop_tx_ba_cb_irqsafe(ctx->vif, addr, tid); 1061 ieee80211_stop_tx_ba_cb_irqsafe(ctx->vif, addr, tid);
1062 } 1062 }
@@ -1064,7 +1064,7 @@ int il4965_txq_check_empty(struct il_priv *priv,
1064 case IL_EMPTYING_HW_QUEUE_ADDBA: 1064 case IL_EMPTYING_HW_QUEUE_ADDBA:
1065 /* We are reclaiming the last packet of the queue */ 1065 /* We are reclaiming the last packet of the queue */
1066 if (tid_data->tfds_in_queue == 0) { 1066 if (tid_data->tfds_in_queue == 0) {
1067 IL_DEBUG_HT(priv, 1067 IL_DEBUG_HT(il,
1068 "HW queue empty: continue ADDBA flow\n"); 1068 "HW queue empty: continue ADDBA flow\n");
1069 tid_data->agg.state = IL_AGG_ON; 1069 tid_data->agg.state = IL_AGG_ON;
1070 ieee80211_start_tx_ba_cb_irqsafe(ctx->vif, addr, tid); 1070 ieee80211_start_tx_ba_cb_irqsafe(ctx->vif, addr, tid);
@@ -1075,7 +1075,7 @@ int il4965_txq_check_empty(struct il_priv *priv,
1075 return 0; 1075 return 0;
1076} 1076}
1077 1077
1078static void il4965_non_agg_tx_status(struct il_priv *priv, 1078static void il4965_non_agg_tx_status(struct il_priv *il,
1079 struct il_rxon_context *ctx, 1079 struct il_rxon_context *ctx,
1080 const u8 *addr1) 1080 const u8 *addr1)
1081{ 1081{
@@ -1089,33 +1089,33 @@ static void il4965_non_agg_tx_status(struct il_priv *priv,
1089 /* avoid atomic ops if this isn't a client */ 1089 /* avoid atomic ops if this isn't a client */
1090 if (sta_priv->client && 1090 if (sta_priv->client &&
1091 atomic_dec_return(&sta_priv->pending_frames) == 0) 1091 atomic_dec_return(&sta_priv->pending_frames) == 0)
1092 ieee80211_sta_block_awake(priv->hw, sta, false); 1092 ieee80211_sta_block_awake(il->hw, sta, false);
1093 } 1093 }
1094 rcu_read_unlock(); 1094 rcu_read_unlock();
1095} 1095}
1096 1096
1097static void 1097static void
1098il4965_tx_status(struct il_priv *priv, struct il_tx_info *tx_info, 1098il4965_tx_status(struct il_priv *il, struct il_tx_info *tx_info,
1099 bool is_agg) 1099 bool is_agg)
1100{ 1100{
1101 struct ieee80211_hdr *hdr = (struct ieee80211_hdr *) tx_info->skb->data; 1101 struct ieee80211_hdr *hdr = (struct ieee80211_hdr *) tx_info->skb->data;
1102 1102
1103 if (!is_agg) 1103 if (!is_agg)
1104 il4965_non_agg_tx_status(priv, tx_info->ctx, hdr->addr1); 1104 il4965_non_agg_tx_status(il, tx_info->ctx, hdr->addr1);
1105 1105
1106 ieee80211_tx_status_irqsafe(priv->hw, tx_info->skb); 1106 ieee80211_tx_status_irqsafe(il->hw, tx_info->skb);
1107} 1107}
1108 1108
1109int il4965_tx_queue_reclaim(struct il_priv *priv, int txq_id, int index) 1109int il4965_tx_queue_reclaim(struct il_priv *il, int txq_id, int index)
1110{ 1110{
1111 struct il_tx_queue *txq = &priv->txq[txq_id]; 1111 struct il_tx_queue *txq = &il->txq[txq_id];
1112 struct il_queue *q = &txq->q; 1112 struct il_queue *q = &txq->q;
1113 struct il_tx_info *tx_info; 1113 struct il_tx_info *tx_info;
1114 int nfreed = 0; 1114 int nfreed = 0;
1115 struct ieee80211_hdr *hdr; 1115 struct ieee80211_hdr *hdr;
1116 1116
1117 if ((index >= q->n_bd) || (il_queue_used(q, index) == 0)) { 1117 if ((index >= q->n_bd) || (il_queue_used(q, index) == 0)) {
1118 IL_ERR(priv, "Read index for DMA queue txq id (%d), index %d, " 1118 IL_ERR(il, "Read index for DMA queue txq id (%d), index %d, "
1119 "is out of range [0-%d] %d %d.\n", txq_id, 1119 "is out of range [0-%d] %d %d.\n", txq_id,
1120 index, q->n_bd, q->write_ptr, q->read_ptr); 1120 index, q->n_bd, q->write_ptr, q->read_ptr);
1121 return 0; 1121 return 0;
@@ -1134,11 +1134,11 @@ int il4965_tx_queue_reclaim(struct il_priv *priv, int txq_id, int index)
1134 if (ieee80211_is_data_qos(hdr->frame_control)) 1134 if (ieee80211_is_data_qos(hdr->frame_control))
1135 nfreed++; 1135 nfreed++;
1136 1136
1137 il4965_tx_status(priv, tx_info, 1137 il4965_tx_status(il, tx_info,
1138 txq_id >= IWL4965_FIRST_AMPDU_QUEUE); 1138 txq_id >= IWL4965_FIRST_AMPDU_QUEUE);
1139 tx_info->skb = NULL; 1139 tx_info->skb = NULL;
1140 1140
1141 priv->cfg->ops->lib->txq_free_tfd(priv, txq); 1141 il->cfg->ops->lib->txq_free_tfd(il, txq);
1142 } 1142 }
1143 return nfreed; 1143 return nfreed;
1144} 1144}
@@ -1149,7 +1149,7 @@ int il4965_tx_queue_reclaim(struct il_priv *priv, int txq_id, int index)
1149 * Go through block-ack's bitmap of ACK'd frames, update driver's record of 1149 * Go through block-ack's bitmap of ACK'd frames, update driver's record of
1150 * ACK vs. not. This gets sent to mac80211, then to rate scaling algo. 1150 * ACK vs. not. This gets sent to mac80211, then to rate scaling algo.
1151 */ 1151 */
1152static int il4965_tx_status_reply_compressed_ba(struct il_priv *priv, 1152static int il4965_tx_status_reply_compressed_ba(struct il_priv *il,
1153 struct il_ht_agg *agg, 1153 struct il_ht_agg *agg,
1154 struct il_compressed_ba_resp *ba_resp) 1154 struct il_compressed_ba_resp *ba_resp)
1155 1155
@@ -1163,13 +1163,13 @@ static int il4965_tx_status_reply_compressed_ba(struct il_priv *priv,
1163 1163
1164 if (unlikely(!agg->wait_for_ba)) { 1164 if (unlikely(!agg->wait_for_ba)) {
1165 if (unlikely(ba_resp->bitmap)) 1165 if (unlikely(ba_resp->bitmap))
1166 IL_ERR(priv, "Received BA when not expected\n"); 1166 IL_ERR(il, "Received BA when not expected\n");
1167 return -EINVAL; 1167 return -EINVAL;
1168 } 1168 }
1169 1169
1170 /* Mark that the expected block-ack response arrived */ 1170 /* Mark that the expected block-ack response arrived */
1171 agg->wait_for_ba = 0; 1171 agg->wait_for_ba = 0;
1172 IL_DEBUG_TX_REPLY(priv, "BA %d %d\n", agg->start_idx, 1172 IL_DEBUG_TX_REPLY(il, "BA %d %d\n", agg->start_idx,
1173 ba_resp->seq_ctl); 1173 ba_resp->seq_ctl);
1174 1174
1175 /* Calculate shift to align block-ack bits with our Tx window bits */ 1175 /* Calculate shift to align block-ack bits with our Tx window bits */
@@ -1178,7 +1178,7 @@ static int il4965_tx_status_reply_compressed_ba(struct il_priv *priv,
1178 sh += 0x100; 1178 sh += 0x100;
1179 1179
1180 if (agg->frame_count > (64 - sh)) { 1180 if (agg->frame_count > (64 - sh)) {
1181 IL_DEBUG_TX_REPLY(priv, "more frames than bitmap size"); 1181 IL_DEBUG_TX_REPLY(il, "more frames than bitmap size");
1182 return -1; 1182 return -1;
1183 } 1183 }
1184 1184
@@ -1195,7 +1195,7 @@ static int il4965_tx_status_reply_compressed_ba(struct il_priv *priv,
1195 while (sent_bitmap) { 1195 while (sent_bitmap) {
1196 ack = sent_bitmap & 1ULL; 1196 ack = sent_bitmap & 1ULL;
1197 successes += ack; 1197 successes += ack;
1198 IL_DEBUG_TX_REPLY(priv, "%s ON i=%d idx=%d raw=%d\n", 1198 IL_DEBUG_TX_REPLY(il, "%s ON i=%d idx=%d raw=%d\n",
1199 ack ? "ACK" : "NACK", i, 1199 ack ? "ACK" : "NACK", i,
1200 (agg->start_idx + i) & 0xff, 1200 (agg->start_idx + i) & 0xff,
1201 agg->start_idx + i); 1201 agg->start_idx + i);
@@ -1203,16 +1203,16 @@ static int il4965_tx_status_reply_compressed_ba(struct il_priv *priv,
1203 ++i; 1203 ++i;
1204 } 1204 }
1205 1205
1206 IL_DEBUG_TX_REPLY(priv, "Bitmap %llx\n", 1206 IL_DEBUG_TX_REPLY(il, "Bitmap %llx\n",
1207 (unsigned long long)bitmap); 1207 (unsigned long long)bitmap);
1208 1208
1209 info = IEEE80211_SKB_CB(priv->txq[scd_flow].txb[agg->start_idx].skb); 1209 info = IEEE80211_SKB_CB(il->txq[scd_flow].txb[agg->start_idx].skb);
1210 memset(&info->status, 0, sizeof(info->status)); 1210 memset(&info->status, 0, sizeof(info->status));
1211 info->flags |= IEEE80211_TX_STAT_ACK; 1211 info->flags |= IEEE80211_TX_STAT_ACK;
1212 info->flags |= IEEE80211_TX_STAT_AMPDU; 1212 info->flags |= IEEE80211_TX_STAT_AMPDU;
1213 info->status.ampdu_ack_len = successes; 1213 info->status.ampdu_ack_len = successes;
1214 info->status.ampdu_len = agg->frame_count; 1214 info->status.ampdu_len = agg->frame_count;
1215 il4965_hwrate_to_tx_control(priv, agg->rate_n_flags, info); 1215 il4965_hwrate_to_tx_control(il, agg->rate_n_flags, info);
1216 1216
1217 return 0; 1217 return 0;
1218} 1218}
@@ -1220,7 +1220,7 @@ static int il4965_tx_status_reply_compressed_ba(struct il_priv *priv,
1220/** 1220/**
1221 * translate ucode response to mac80211 tx status control values 1221 * translate ucode response to mac80211 tx status control values
1222 */ 1222 */
1223void il4965_hwrate_to_tx_control(struct il_priv *priv, u32 rate_n_flags, 1223void il4965_hwrate_to_tx_control(struct il_priv *il, u32 rate_n_flags,
1224 struct ieee80211_tx_info *info) 1224 struct ieee80211_tx_info *info)
1225{ 1225{
1226 struct ieee80211_tx_rate *r = &info->control.rates[0]; 1226 struct ieee80211_tx_rate *r = &info->control.rates[0];
@@ -1246,7 +1246,7 @@ void il4965_hwrate_to_tx_control(struct il_priv *priv, u32 rate_n_flags,
1246 * Handles block-acknowledge notification from device, which reports success 1246 * Handles block-acknowledge notification from device, which reports success
1247 * of frames sent via aggregation. 1247 * of frames sent via aggregation.
1248 */ 1248 */
1249void il4965_rx_reply_compressed_ba(struct il_priv *priv, 1249void il4965_rx_reply_compressed_ba(struct il_priv *il,
1250 struct il_rx_mem_buffer *rxb) 1250 struct il_rx_mem_buffer *rxb)
1251{ 1251{
1252 struct il_rx_packet *pkt = rxb_addr(rxb); 1252 struct il_rx_packet *pkt = rxb_addr(rxb);
@@ -1265,16 +1265,16 @@ void il4965_rx_reply_compressed_ba(struct il_priv *priv,
1265 * (in Tx queue's circular buffer) of first TFD/frame in window */ 1265 * (in Tx queue's circular buffer) of first TFD/frame in window */
1266 u16 ba_resp_scd_ssn = le16_to_cpu(ba_resp->scd_ssn); 1266 u16 ba_resp_scd_ssn = le16_to_cpu(ba_resp->scd_ssn);
1267 1267
1268 if (scd_flow >= priv->hw_params.max_txq_num) { 1268 if (scd_flow >= il->hw_params.max_txq_num) {
1269 IL_ERR(priv, 1269 IL_ERR(il,
1270 "BUG_ON scd_flow is bigger than number of queues\n"); 1270 "BUG_ON scd_flow is bigger than number of queues\n");
1271 return; 1271 return;
1272 } 1272 }
1273 1273
1274 txq = &priv->txq[scd_flow]; 1274 txq = &il->txq[scd_flow];
1275 sta_id = ba_resp->sta_id; 1275 sta_id = ba_resp->sta_id;
1276 tid = ba_resp->tid; 1276 tid = ba_resp->tid;
1277 agg = &priv->stations[sta_id].tid[tid].agg; 1277 agg = &il->stations[sta_id].tid[tid].agg;
1278 if (unlikely(agg->txq_id != scd_flow)) { 1278 if (unlikely(agg->txq_id != scd_flow)) {
1279 /* 1279 /*
1280 * FIXME: this is a uCode bug which need to be addressed, 1280 * FIXME: this is a uCode bug which need to be addressed,
@@ -1282,7 +1282,7 @@ void il4965_rx_reply_compressed_ba(struct il_priv *priv,
1282 * since it is possible happen very often and in order 1282 * since it is possible happen very often and in order
1283 * not to fill the syslog, don't enable the logging by default 1283 * not to fill the syslog, don't enable the logging by default
1284 */ 1284 */
1285 IL_DEBUG_TX_REPLY(priv, 1285 IL_DEBUG_TX_REPLY(il,
1286 "BA scd_flow %d does not match txq_id %d\n", 1286 "BA scd_flow %d does not match txq_id %d\n",
1287 scd_flow, agg->txq_id); 1287 scd_flow, agg->txq_id);
1288 return; 1288 return;
@@ -1291,14 +1291,14 @@ void il4965_rx_reply_compressed_ba(struct il_priv *priv,
1291 /* Find index just before block-ack window */ 1291 /* Find index just before block-ack window */
1292 index = il_queue_dec_wrap(ba_resp_scd_ssn & 0xff, txq->q.n_bd); 1292 index = il_queue_dec_wrap(ba_resp_scd_ssn & 0xff, txq->q.n_bd);
1293 1293
1294 spin_lock_irqsave(&priv->sta_lock, flags); 1294 spin_lock_irqsave(&il->sta_lock, flags);
1295 1295
1296 IL_DEBUG_TX_REPLY(priv, "REPLY_COMPRESSED_BA [%d] Received from %pM, " 1296 IL_DEBUG_TX_REPLY(il, "REPLY_COMPRESSED_BA [%d] Received from %pM, "
1297 "sta_id = %d\n", 1297 "sta_id = %d\n",
1298 agg->wait_for_ba, 1298 agg->wait_for_ba,
1299 (u8 *) &ba_resp->sta_addr_lo32, 1299 (u8 *) &ba_resp->sta_addr_lo32,
1300 ba_resp->sta_id); 1300 ba_resp->sta_id);
1301 IL_DEBUG_TX_REPLY(priv, "TID = %d, SeqCtl = %d, bitmap = 0x%llx," 1301 IL_DEBUG_TX_REPLY(il, "TID = %d, SeqCtl = %d, bitmap = 0x%llx,"
1302 "scd_flow = " 1302 "scd_flow = "
1303 "%d, scd_ssn = %d\n", 1303 "%d, scd_ssn = %d\n",
1304 ba_resp->tid, 1304 ba_resp->tid,
@@ -1306,30 +1306,30 @@ void il4965_rx_reply_compressed_ba(struct il_priv *priv,
1306 (unsigned long long)le64_to_cpu(ba_resp->bitmap), 1306 (unsigned long long)le64_to_cpu(ba_resp->bitmap),
1307 ba_resp->scd_flow, 1307 ba_resp->scd_flow,
1308 ba_resp->scd_ssn); 1308 ba_resp->scd_ssn);
1309 IL_DEBUG_TX_REPLY(priv, "DAT start_idx = %d, bitmap = 0x%llx\n", 1309 IL_DEBUG_TX_REPLY(il, "DAT start_idx = %d, bitmap = 0x%llx\n",
1310 agg->start_idx, 1310 agg->start_idx,
1311 (unsigned long long)agg->bitmap); 1311 (unsigned long long)agg->bitmap);
1312 1312
1313 /* Update driver's record of ACK vs. not for each frame in window */ 1313 /* Update driver's record of ACK vs. not for each frame in window */
1314 il4965_tx_status_reply_compressed_ba(priv, agg, ba_resp); 1314 il4965_tx_status_reply_compressed_ba(il, agg, ba_resp);
1315 1315
1316 /* Release all TFDs before the SSN, i.e. all TFDs in front of 1316 /* Release all TFDs before the SSN, i.e. all TFDs in front of
1317 * block-ack window (we assume that they've been successfully 1317 * block-ack window (we assume that they've been successfully
1318 * transmitted ... if not, it's too late anyway). */ 1318 * transmitted ... if not, it's too late anyway). */
1319 if (txq->q.read_ptr != (ba_resp_scd_ssn & 0xff)) { 1319 if (txq->q.read_ptr != (ba_resp_scd_ssn & 0xff)) {
1320 /* calculate mac80211 ampdu sw queue to wake */ 1320 /* calculate mac80211 ampdu sw queue to wake */
1321 int freed = il4965_tx_queue_reclaim(priv, scd_flow, index); 1321 int freed = il4965_tx_queue_reclaim(il, scd_flow, index);
1322 il4965_free_tfds_in_queue(priv, sta_id, tid, freed); 1322 il4965_free_tfds_in_queue(il, sta_id, tid, freed);
1323 1323
1324 if ((il_queue_space(&txq->q) > txq->q.low_mark) && 1324 if ((il_queue_space(&txq->q) > txq->q.low_mark) &&
1325 priv->mac80211_registered && 1325 il->mac80211_registered &&
1326 (agg->state != IL_EMPTYING_HW_QUEUE_DELBA)) 1326 (agg->state != IL_EMPTYING_HW_QUEUE_DELBA))
1327 il_wake_queue(priv, txq); 1327 il_wake_queue(il, txq);
1328 1328
1329 il4965_txq_check_empty(priv, sta_id, tid, scd_flow); 1329 il4965_txq_check_empty(il, sta_id, tid, scd_flow);
1330 } 1330 }
1331 1331
1332 spin_unlock_irqrestore(&priv->sta_lock, flags); 1332 spin_unlock_irqrestore(&il->sta_lock, flags);
1333} 1333}
1334 1334
1335#ifdef CONFIG_IWLWIFI_LEGACY_DEBUG 1335#ifdef CONFIG_IWLWIFI_LEGACY_DEBUG
diff --git a/drivers/net/wireless/iwlegacy/iwl-4965-ucode.c b/drivers/net/wireless/iwlegacy/iwl-4965-ucode.c
index 3c9df1bb5afe..d4dc597452ea 100644
--- a/drivers/net/wireless/iwlegacy/iwl-4965-ucode.c
+++ b/drivers/net/wireless/iwlegacy/iwl-4965-ucode.c
@@ -48,22 +48,22 @@
48 * it's a pretty good bet that everything between them is good, too. 48 * it's a pretty good bet that everything between them is good, too.
49 */ 49 */
50static int 50static int
51il4965_verify_inst_sparse(struct il_priv *priv, __le32 *image, u32 len) 51il4965_verify_inst_sparse(struct il_priv *il, __le32 *image, u32 len)
52{ 52{
53 u32 val; 53 u32 val;
54 int ret = 0; 54 int ret = 0;
55 u32 errcnt = 0; 55 u32 errcnt = 0;
56 u32 i; 56 u32 i;
57 57
58 IL_DEBUG_INFO(priv, "ucode inst image size is %u\n", len); 58 IL_DEBUG_INFO(il, "ucode inst image size is %u\n", len);
59 59
60 for (i = 0; i < len; i += 100, image += 100/sizeof(u32)) { 60 for (i = 0; i < len; i += 100, image += 100/sizeof(u32)) {
61 /* read data comes through single port, auto-incr addr */ 61 /* read data comes through single port, auto-incr addr */
62 /* NOTE: Use the debugless read so we don't flood kernel log 62 /* NOTE: Use the debugless read so we don't flood kernel log
63 * if IL_DL_IO is set */ 63 * if IL_DL_IO is set */
64 il_write_direct32(priv, HBUS_TARG_MEM_RADDR, 64 il_write_direct32(il, HBUS_TARG_MEM_RADDR,
65 i + IWL4965_RTC_INST_LOWER_BOUND); 65 i + IWL4965_RTC_INST_LOWER_BOUND);
66 val = _il_read_direct32(priv, HBUS_TARG_MEM_RDAT); 66 val = _il_read_direct32(il, HBUS_TARG_MEM_RDAT);
67 if (val != le32_to_cpu(*image)) { 67 if (val != le32_to_cpu(*image)) {
68 ret = -EIO; 68 ret = -EIO;
69 errcnt++; 69 errcnt++;
@@ -79,7 +79,7 @@ il4965_verify_inst_sparse(struct il_priv *priv, __le32 *image, u32 len)
79 * il4965_verify_inst_full - verify runtime uCode image in card vs. host, 79 * il4965_verify_inst_full - verify runtime uCode image in card vs. host,
80 * looking at all data. 80 * looking at all data.
81 */ 81 */
82static int il4965_verify_inst_full(struct il_priv *priv, __le32 *image, 82static int il4965_verify_inst_full(struct il_priv *il, __le32 *image,
83 u32 len) 83 u32 len)
84{ 84{
85 u32 val; 85 u32 val;
@@ -87,9 +87,9 @@ static int il4965_verify_inst_full(struct il_priv *priv, __le32 *image,
87 int ret = 0; 87 int ret = 0;
88 u32 errcnt; 88 u32 errcnt;
89 89
90 IL_DEBUG_INFO(priv, "ucode inst image size is %u\n", len); 90 IL_DEBUG_INFO(il, "ucode inst image size is %u\n", len);
91 91
92 il_write_direct32(priv, HBUS_TARG_MEM_RADDR, 92 il_write_direct32(il, HBUS_TARG_MEM_RADDR,
93 IWL4965_RTC_INST_LOWER_BOUND); 93 IWL4965_RTC_INST_LOWER_BOUND);
94 94
95 errcnt = 0; 95 errcnt = 0;
@@ -97,9 +97,9 @@ static int il4965_verify_inst_full(struct il_priv *priv, __le32 *image,
97 /* read data comes through single port, auto-incr addr */ 97 /* read data comes through single port, auto-incr addr */
98 /* NOTE: Use the debugless read so we don't flood kernel log 98 /* NOTE: Use the debugless read so we don't flood kernel log
99 * if IL_DL_IO is set */ 99 * if IL_DL_IO is set */
100 val = _il_read_direct32(priv, HBUS_TARG_MEM_RDAT); 100 val = _il_read_direct32(il, HBUS_TARG_MEM_RDAT);
101 if (val != le32_to_cpu(*image)) { 101 if (val != le32_to_cpu(*image)) {
102 IL_ERR(priv, "uCode INST section is invalid at " 102 IL_ERR(il, "uCode INST section is invalid at "
103 "offset 0x%x, is 0x%x, s/b 0x%x\n", 103 "offset 0x%x, is 0x%x, s/b 0x%x\n",
104 save_len - len, val, le32_to_cpu(*image)); 104 save_len - len, val, le32_to_cpu(*image));
105 ret = -EIO; 105 ret = -EIO;
@@ -110,7 +110,7 @@ static int il4965_verify_inst_full(struct il_priv *priv, __le32 *image,
110 } 110 }
111 111
112 if (!errcnt) 112 if (!errcnt)
113 IL_DEBUG_INFO(priv, 113 IL_DEBUG_INFO(il,
114 "ucode image in INSTRUCTION memory is good\n"); 114 "ucode image in INSTRUCTION memory is good\n");
115 115
116 return ret; 116 return ret;
@@ -120,47 +120,47 @@ static int il4965_verify_inst_full(struct il_priv *priv, __le32 *image,
120 * il4965_verify_ucode - determine which instruction image is in SRAM, 120 * il4965_verify_ucode - determine which instruction image is in SRAM,
121 * and verify its contents 121 * and verify its contents
122 */ 122 */
123int il4965_verify_ucode(struct il_priv *priv) 123int il4965_verify_ucode(struct il_priv *il)
124{ 124{
125 __le32 *image; 125 __le32 *image;
126 u32 len; 126 u32 len;
127 int ret; 127 int ret;
128 128
129 /* Try bootstrap */ 129 /* Try bootstrap */
130 image = (__le32 *)priv->ucode_boot.v_addr; 130 image = (__le32 *)il->ucode_boot.v_addr;
131 len = priv->ucode_boot.len; 131 len = il->ucode_boot.len;
132 ret = il4965_verify_inst_sparse(priv, image, len); 132 ret = il4965_verify_inst_sparse(il, image, len);
133 if (!ret) { 133 if (!ret) {
134 IL_DEBUG_INFO(priv, "Bootstrap uCode is good in inst SRAM\n"); 134 IL_DEBUG_INFO(il, "Bootstrap uCode is good in inst SRAM\n");
135 return 0; 135 return 0;
136 } 136 }
137 137
138 /* Try initialize */ 138 /* Try initialize */
139 image = (__le32 *)priv->ucode_init.v_addr; 139 image = (__le32 *)il->ucode_init.v_addr;
140 len = priv->ucode_init.len; 140 len = il->ucode_init.len;
141 ret = il4965_verify_inst_sparse(priv, image, len); 141 ret = il4965_verify_inst_sparse(il, image, len);
142 if (!ret) { 142 if (!ret) {
143 IL_DEBUG_INFO(priv, "Initialize uCode is good in inst SRAM\n"); 143 IL_DEBUG_INFO(il, "Initialize uCode is good in inst SRAM\n");
144 return 0; 144 return 0;
145 } 145 }
146 146
147 /* Try runtime/protocol */ 147 /* Try runtime/protocol */
148 image = (__le32 *)priv->ucode_code.v_addr; 148 image = (__le32 *)il->ucode_code.v_addr;
149 len = priv->ucode_code.len; 149 len = il->ucode_code.len;
150 ret = il4965_verify_inst_sparse(priv, image, len); 150 ret = il4965_verify_inst_sparse(il, image, len);
151 if (!ret) { 151 if (!ret) {
152 IL_DEBUG_INFO(priv, "Runtime uCode is good in inst SRAM\n"); 152 IL_DEBUG_INFO(il, "Runtime uCode is good in inst SRAM\n");
153 return 0; 153 return 0;
154 } 154 }
155 155
156 IL_ERR(priv, "NO VALID UCODE IMAGE IN INSTRUCTION SRAM!!\n"); 156 IL_ERR(il, "NO VALID UCODE IMAGE IN INSTRUCTION SRAM!!\n");
157 157
158 /* Since nothing seems to match, show first several data entries in 158 /* Since nothing seems to match, show first several data entries in
159 * instruction SRAM, so maybe visual inspection will give a clue. 159 * instruction SRAM, so maybe visual inspection will give a clue.
160 * Selection of bootstrap image (vs. other images) is arbitrary. */ 160 * Selection of bootstrap image (vs. other images) is arbitrary. */
161 image = (__le32 *)priv->ucode_boot.v_addr; 161 image = (__le32 *)il->ucode_boot.v_addr;
162 len = priv->ucode_boot.len; 162 len = il->ucode_boot.len;
163 ret = il4965_verify_inst_full(priv, image, len); 163 ret = il4965_verify_inst_full(il, image, len);
164 164
165 return ret; 165 return ret;
166} 166}
diff --git a/drivers/net/wireless/iwlegacy/iwl-4965.c b/drivers/net/wireless/iwlegacy/iwl-4965.c
index 0f2bc5f767da..d3c818354ca5 100644
--- a/drivers/net/wireless/iwlegacy/iwl-4965.c
+++ b/drivers/net/wireless/iwlegacy/iwl-4965.c
@@ -48,8 +48,8 @@
48#include "iwl-4965.h" 48#include "iwl-4965.h"
49#include "iwl-4965-debugfs.h" 49#include "iwl-4965-debugfs.h"
50 50
51static int il4965_send_tx_power(struct il_priv *priv); 51static int il4965_send_tx_power(struct il_priv *il);
52static int il4965_hw_get_temperature(struct il_priv *priv); 52static int il4965_hw_get_temperature(struct il_priv *il);
53 53
54/* Highest firmware API version supported */ 54/* Highest firmware API version supported */
55#define IWL4965_UCODE_API_MAX 2 55#define IWL4965_UCODE_API_MAX 2
@@ -62,23 +62,23 @@ static int il4965_hw_get_temperature(struct il_priv *priv);
62#define IWL4965_MODULE_FIRMWARE(api) _IWL4965_MODULE_FIRMWARE(api) 62#define IWL4965_MODULE_FIRMWARE(api) _IWL4965_MODULE_FIRMWARE(api)
63 63
64/* check contents of special bootstrap uCode SRAM */ 64/* check contents of special bootstrap uCode SRAM */
65static int il4965_verify_bsm(struct il_priv *priv) 65static int il4965_verify_bsm(struct il_priv *il)
66{ 66{
67 __le32 *image = priv->ucode_boot.v_addr; 67 __le32 *image = il->ucode_boot.v_addr;
68 u32 len = priv->ucode_boot.len; 68 u32 len = il->ucode_boot.len;
69 u32 reg; 69 u32 reg;
70 u32 val; 70 u32 val;
71 71
72 IL_DEBUG_INFO(priv, "Begin verify bsm\n"); 72 IL_DEBUG_INFO(il, "Begin verify bsm\n");
73 73
74 /* verify BSM SRAM contents */ 74 /* verify BSM SRAM contents */
75 val = il_read_prph(priv, BSM_WR_DWCOUNT_REG); 75 val = il_read_prph(il, BSM_WR_DWCOUNT_REG);
76 for (reg = BSM_SRAM_LOWER_BOUND; 76 for (reg = BSM_SRAM_LOWER_BOUND;
77 reg < BSM_SRAM_LOWER_BOUND + len; 77 reg < BSM_SRAM_LOWER_BOUND + len;
78 reg += sizeof(u32), image++) { 78 reg += sizeof(u32), image++) {
79 val = il_read_prph(priv, reg); 79 val = il_read_prph(il, reg);
80 if (val != le32_to_cpu(*image)) { 80 if (val != le32_to_cpu(*image)) {
81 IL_ERR(priv, "BSM uCode verification failed at " 81 IL_ERR(il, "BSM uCode verification failed at "
82 "addr 0x%08X+%u (of %u), is 0x%x, s/b 0x%x\n", 82 "addr 0x%08X+%u (of %u), is 0x%x, s/b 0x%x\n",
83 BSM_SRAM_LOWER_BOUND, 83 BSM_SRAM_LOWER_BOUND,
84 reg - BSM_SRAM_LOWER_BOUND, len, 84 reg - BSM_SRAM_LOWER_BOUND, len,
@@ -87,7 +87,7 @@ static int il4965_verify_bsm(struct il_priv *priv)
87 } 87 }
88 } 88 }
89 89
90 IL_DEBUG_INFO(priv, "BSM bootstrap uCode image OK\n"); 90 IL_DEBUG_INFO(il, "BSM bootstrap uCode image OK\n");
91 91
92 return 0; 92 return 0;
93} 93}
@@ -124,10 +124,10 @@ static int il4965_verify_bsm(struct il_priv *priv)
124 * the runtime uCode instructions and the backup data cache into SRAM, 124 * the runtime uCode instructions and the backup data cache into SRAM,
125 * and re-launches the runtime uCode from where it left off. 125 * and re-launches the runtime uCode from where it left off.
126 */ 126 */
127static int il4965_load_bsm(struct il_priv *priv) 127static int il4965_load_bsm(struct il_priv *il)
128{ 128{
129 __le32 *image = priv->ucode_boot.v_addr; 129 __le32 *image = il->ucode_boot.v_addr;
130 u32 len = priv->ucode_boot.len; 130 u32 len = il->ucode_boot.len;
131 dma_addr_t pinst; 131 dma_addr_t pinst;
132 dma_addr_t pdata; 132 dma_addr_t pdata;
133 u32 inst_len; 133 u32 inst_len;
@@ -137,9 +137,9 @@ static int il4965_load_bsm(struct il_priv *priv)
137 u32 reg_offset; 137 u32 reg_offset;
138 int ret; 138 int ret;
139 139
140 IL_DEBUG_INFO(priv, "Begin load bsm\n"); 140 IL_DEBUG_INFO(il, "Begin load bsm\n");
141 141
142 priv->ucode_type = UCODE_RT; 142 il->ucode_type = UCODE_RT;
143 143
144 /* make sure bootstrap program is no larger than BSM's SRAM size */ 144 /* make sure bootstrap program is no larger than BSM's SRAM size */
145 if (len > IWL49_MAX_BSM_SIZE) 145 if (len > IWL49_MAX_BSM_SIZE)
@@ -151,53 +151,53 @@ static int il4965_load_bsm(struct il_priv *priv)
151 * after the "initialize" uCode has run, to point to 151 * after the "initialize" uCode has run, to point to
152 * runtime/protocol instructions and backup data cache. 152 * runtime/protocol instructions and backup data cache.
153 */ 153 */
154 pinst = priv->ucode_init.p_addr >> 4; 154 pinst = il->ucode_init.p_addr >> 4;
155 pdata = priv->ucode_init_data.p_addr >> 4; 155 pdata = il->ucode_init_data.p_addr >> 4;
156 inst_len = priv->ucode_init.len; 156 inst_len = il->ucode_init.len;
157 data_len = priv->ucode_init_data.len; 157 data_len = il->ucode_init_data.len;
158 158
159 il_write_prph(priv, BSM_DRAM_INST_PTR_REG, pinst); 159 il_write_prph(il, BSM_DRAM_INST_PTR_REG, pinst);
160 il_write_prph(priv, BSM_DRAM_DATA_PTR_REG, pdata); 160 il_write_prph(il, BSM_DRAM_DATA_PTR_REG, pdata);
161 il_write_prph(priv, BSM_DRAM_INST_BYTECOUNT_REG, inst_len); 161 il_write_prph(il, BSM_DRAM_INST_BYTECOUNT_REG, inst_len);
162 il_write_prph(priv, BSM_DRAM_DATA_BYTECOUNT_REG, data_len); 162 il_write_prph(il, BSM_DRAM_DATA_BYTECOUNT_REG, data_len);
163 163
164 /* Fill BSM memory with bootstrap instructions */ 164 /* Fill BSM memory with bootstrap instructions */
165 for (reg_offset = BSM_SRAM_LOWER_BOUND; 165 for (reg_offset = BSM_SRAM_LOWER_BOUND;
166 reg_offset < BSM_SRAM_LOWER_BOUND + len; 166 reg_offset < BSM_SRAM_LOWER_BOUND + len;
167 reg_offset += sizeof(u32), image++) 167 reg_offset += sizeof(u32), image++)
168 _il_write_prph(priv, reg_offset, le32_to_cpu(*image)); 168 _il_write_prph(il, reg_offset, le32_to_cpu(*image));
169 169
170 ret = il4965_verify_bsm(priv); 170 ret = il4965_verify_bsm(il);
171 if (ret) 171 if (ret)
172 return ret; 172 return ret;
173 173
174 /* Tell BSM to copy from BSM SRAM into instruction SRAM, when asked */ 174 /* Tell BSM to copy from BSM SRAM into instruction SRAM, when asked */
175 il_write_prph(priv, BSM_WR_MEM_SRC_REG, 0x0); 175 il_write_prph(il, BSM_WR_MEM_SRC_REG, 0x0);
176 il_write_prph(priv, 176 il_write_prph(il,
177 BSM_WR_MEM_DST_REG, IWL49_RTC_INST_LOWER_BOUND); 177 BSM_WR_MEM_DST_REG, IWL49_RTC_INST_LOWER_BOUND);
178 il_write_prph(priv, BSM_WR_DWCOUNT_REG, len / sizeof(u32)); 178 il_write_prph(il, BSM_WR_DWCOUNT_REG, len / sizeof(u32));
179 179
180 /* Load bootstrap code into instruction SRAM now, 180 /* Load bootstrap code into instruction SRAM now,
181 * to prepare to load "initialize" uCode */ 181 * to prepare to load "initialize" uCode */
182 il_write_prph(priv, BSM_WR_CTRL_REG, BSM_WR_CTRL_REG_BIT_START); 182 il_write_prph(il, BSM_WR_CTRL_REG, BSM_WR_CTRL_REG_BIT_START);
183 183
184 /* Wait for load of bootstrap uCode to finish */ 184 /* Wait for load of bootstrap uCode to finish */
185 for (i = 0; i < 100; i++) { 185 for (i = 0; i < 100; i++) {
186 done = il_read_prph(priv, BSM_WR_CTRL_REG); 186 done = il_read_prph(il, BSM_WR_CTRL_REG);
187 if (!(done & BSM_WR_CTRL_REG_BIT_START)) 187 if (!(done & BSM_WR_CTRL_REG_BIT_START))
188 break; 188 break;
189 udelay(10); 189 udelay(10);
190 } 190 }
191 if (i < 100) 191 if (i < 100)
192 IL_DEBUG_INFO(priv, "BSM write complete, poll %d iterations\n", i); 192 IL_DEBUG_INFO(il, "BSM write complete, poll %d iterations\n", i);
193 else { 193 else {
194 IL_ERR(priv, "BSM write did not complete!\n"); 194 IL_ERR(il, "BSM write did not complete!\n");
195 return -EIO; 195 return -EIO;
196 } 196 }
197 197
198 /* Enable future boot loads whenever power management unit triggers it 198 /* Enable future boot loads whenever power management unit triggers it
199 * (e.g. when powering back up after power-save shutdown) */ 199 * (e.g. when powering back up after power-save shutdown) */
200 il_write_prph(priv, 200 il_write_prph(il,
201 BSM_WR_CTRL_REG, BSM_WR_CTRL_REG_BIT_START_EN); 201 BSM_WR_CTRL_REG, BSM_WR_CTRL_REG_BIT_START_EN);
202 202
203 203
@@ -213,27 +213,27 @@ static int il4965_load_bsm(struct il_priv *priv)
213 * We need to replace them to load runtime uCode inst and data, 213 * We need to replace them to load runtime uCode inst and data,
214 * and to save runtime data when powering down. 214 * and to save runtime data when powering down.
215 */ 215 */
216static int il4965_set_ucode_ptrs(struct il_priv *priv) 216static int il4965_set_ucode_ptrs(struct il_priv *il)
217{ 217{
218 dma_addr_t pinst; 218 dma_addr_t pinst;
219 dma_addr_t pdata; 219 dma_addr_t pdata;
220 int ret = 0; 220 int ret = 0;
221 221
222 /* bits 35:4 for 4965 */ 222 /* bits 35:4 for 4965 */
223 pinst = priv->ucode_code.p_addr >> 4; 223 pinst = il->ucode_code.p_addr >> 4;
224 pdata = priv->ucode_data_backup.p_addr >> 4; 224 pdata = il->ucode_data_backup.p_addr >> 4;
225 225
226 /* Tell bootstrap uCode where to find image to load */ 226 /* Tell bootstrap uCode where to find image to load */
227 il_write_prph(priv, BSM_DRAM_INST_PTR_REG, pinst); 227 il_write_prph(il, BSM_DRAM_INST_PTR_REG, pinst);
228 il_write_prph(priv, BSM_DRAM_DATA_PTR_REG, pdata); 228 il_write_prph(il, BSM_DRAM_DATA_PTR_REG, pdata);
229 il_write_prph(priv, BSM_DRAM_DATA_BYTECOUNT_REG, 229 il_write_prph(il, BSM_DRAM_DATA_BYTECOUNT_REG,
230 priv->ucode_data.len); 230 il->ucode_data.len);
231 231
232 /* Inst byte count must be last to set up, bit 31 signals uCode 232 /* Inst byte count must be last to set up, bit 31 signals uCode
233 * that all new ptr/size info is in place */ 233 * that all new ptr/size info is in place */
234 il_write_prph(priv, BSM_DRAM_INST_BYTECOUNT_REG, 234 il_write_prph(il, BSM_DRAM_INST_BYTECOUNT_REG,
235 priv->ucode_code.len | BSM_DRAM_INST_LOAD); 235 il->ucode_code.len | BSM_DRAM_INST_LOAD);
236 IL_DEBUG_INFO(priv, "Runtime uCode pointers are set.\n"); 236 IL_DEBUG_INFO(il, "Runtime uCode pointers are set.\n");
237 237
238 return ret; 238 return ret;
239} 239}
@@ -244,40 +244,40 @@ static int il4965_set_ucode_ptrs(struct il_priv *priv)
244 * Called after REPLY_ALIVE notification received from "initialize" uCode. 244 * Called after REPLY_ALIVE notification received from "initialize" uCode.
245 * 245 *
246 * The 4965 "initialize" ALIVE reply contains calibration data for: 246 * The 4965 "initialize" ALIVE reply contains calibration data for:
247 * Voltage, temperature, and MIMO tx gain correction, now stored in priv 247 * Voltage, temperature, and MIMO tx gain correction, now stored in il
248 * (3945 does not contain this data). 248 * (3945 does not contain this data).
249 * 249 *
250 * Tell "initialize" uCode to go ahead and load the runtime uCode. 250 * Tell "initialize" uCode to go ahead and load the runtime uCode.
251*/ 251*/
252static void il4965_init_alive_start(struct il_priv *priv) 252static void il4965_init_alive_start(struct il_priv *il)
253{ 253{
254 /* Bootstrap uCode has loaded initialize uCode ... verify inst image. 254 /* Bootstrap uCode has loaded initialize uCode ... verify inst image.
255 * This is a paranoid check, because we would not have gotten the 255 * This is a paranoid check, because we would not have gotten the
256 * "initialize" alive if code weren't properly loaded. */ 256 * "initialize" alive if code weren't properly loaded. */
257 if (il4965_verify_ucode(priv)) { 257 if (il4965_verify_ucode(il)) {
258 /* Runtime instruction load was bad; 258 /* Runtime instruction load was bad;
259 * take it all the way back down so we can try again */ 259 * take it all the way back down so we can try again */
260 IL_DEBUG_INFO(priv, "Bad \"initialize\" uCode load.\n"); 260 IL_DEBUG_INFO(il, "Bad \"initialize\" uCode load.\n");
261 goto restart; 261 goto restart;
262 } 262 }
263 263
264 /* Calculate temperature */ 264 /* Calculate temperature */
265 priv->temperature = il4965_hw_get_temperature(priv); 265 il->temperature = il4965_hw_get_temperature(il);
266 266
267 /* Send pointers to protocol/runtime uCode image ... init code will 267 /* Send pointers to protocol/runtime uCode image ... init code will
268 * load and launch runtime uCode, which will send us another "Alive" 268 * load and launch runtime uCode, which will send us another "Alive"
269 * notification. */ 269 * notification. */
270 IL_DEBUG_INFO(priv, "Initialization Alive received.\n"); 270 IL_DEBUG_INFO(il, "Initialization Alive received.\n");
271 if (il4965_set_ucode_ptrs(priv)) { 271 if (il4965_set_ucode_ptrs(il)) {
272 /* Runtime instruction load won't happen; 272 /* Runtime instruction load won't happen;
273 * take it all the way back down so we can try again */ 273 * take it all the way back down so we can try again */
274 IL_DEBUG_INFO(priv, "Couldn't set up uCode pointers.\n"); 274 IL_DEBUG_INFO(il, "Couldn't set up uCode pointers.\n");
275 goto restart; 275 goto restart;
276 } 276 }
277 return; 277 return;
278 278
279restart: 279restart:
280 queue_work(priv->workqueue, &priv->restart); 280 queue_work(il->workqueue, &il->restart);
281} 281}
282 282
283static bool iw4965_is_ht40_channel(__le32 rxon_flags) 283static bool iw4965_is_ht40_channel(__le32 rxon_flags)
@@ -288,43 +288,43 @@ static bool iw4965_is_ht40_channel(__le32 rxon_flags)
288 (chan_mod == CHANNEL_MODE_MIXED)); 288 (chan_mod == CHANNEL_MODE_MIXED));
289} 289}
290 290
291static void il4965_nic_config(struct il_priv *priv) 291static void il4965_nic_config(struct il_priv *il)
292{ 292{
293 unsigned long flags; 293 unsigned long flags;
294 u16 radio_cfg; 294 u16 radio_cfg;
295 295
296 spin_lock_irqsave(&priv->lock, flags); 296 spin_lock_irqsave(&il->lock, flags);
297 297
298 radio_cfg = il_eeprom_query16(priv, EEPROM_RADIO_CONFIG); 298 radio_cfg = il_eeprom_query16(il, EEPROM_RADIO_CONFIG);
299 299
300 /* write radio config values to register */ 300 /* write radio config values to register */
301 if (EEPROM_RF_CFG_TYPE_MSK(radio_cfg) == EEPROM_4965_RF_CFG_TYPE_MAX) 301 if (EEPROM_RF_CFG_TYPE_MSK(radio_cfg) == EEPROM_4965_RF_CFG_TYPE_MAX)
302 il_set_bit(priv, CSR_HW_IF_CONFIG_REG, 302 il_set_bit(il, CSR_HW_IF_CONFIG_REG,
303 EEPROM_RF_CFG_TYPE_MSK(radio_cfg) | 303 EEPROM_RF_CFG_TYPE_MSK(radio_cfg) |
304 EEPROM_RF_CFG_STEP_MSK(radio_cfg) | 304 EEPROM_RF_CFG_STEP_MSK(radio_cfg) |
305 EEPROM_RF_CFG_DASH_MSK(radio_cfg)); 305 EEPROM_RF_CFG_DASH_MSK(radio_cfg));
306 306
307 /* set CSR_HW_CONFIG_REG for uCode use */ 307 /* set CSR_HW_CONFIG_REG for uCode use */
308 il_set_bit(priv, CSR_HW_IF_CONFIG_REG, 308 il_set_bit(il, CSR_HW_IF_CONFIG_REG,
309 CSR_HW_IF_CONFIG_REG_BIT_RADIO_SI | 309 CSR_HW_IF_CONFIG_REG_BIT_RADIO_SI |
310 CSR_HW_IF_CONFIG_REG_BIT_MAC_SI); 310 CSR_HW_IF_CONFIG_REG_BIT_MAC_SI);
311 311
312 priv->calib_info = (struct il_eeprom_calib_info *) 312 il->calib_info = (struct il_eeprom_calib_info *)
313 il_eeprom_query_addr(priv, 313 il_eeprom_query_addr(il,
314 EEPROM_4965_CALIB_TXPOWER_OFFSET); 314 EEPROM_4965_CALIB_TXPOWER_OFFSET);
315 315
316 spin_unlock_irqrestore(&priv->lock, flags); 316 spin_unlock_irqrestore(&il->lock, flags);
317} 317}
318 318
319/* Reset differential Rx gains in NIC to prepare for chain noise calibration. 319/* Reset differential Rx gains in NIC to prepare for chain noise calibration.
320 * Called after every association, but this runs only once! 320 * Called after every association, but this runs only once!
321 * ... once chain noise is calibrated the first time, it's good forever. */ 321 * ... once chain noise is calibrated the first time, it's good forever. */
322static void il4965_chain_noise_reset(struct il_priv *priv) 322static void il4965_chain_noise_reset(struct il_priv *il)
323{ 323{
324 struct il_chain_noise_data *data = &(priv->chain_noise_data); 324 struct il_chain_noise_data *data = &(il->chain_noise_data);
325 325
326 if ((data->state == IL_CHAIN_NOISE_ALIVE) && 326 if ((data->state == IL_CHAIN_NOISE_ALIVE) &&
327 il_is_any_associated(priv)) { 327 il_is_any_associated(il)) {
328 struct il_calib_diff_gain_cmd cmd; 328 struct il_calib_diff_gain_cmd cmd;
329 329
330 /* clear data for chain noise calibration algorithm */ 330 /* clear data for chain noise calibration algorithm */
@@ -341,12 +341,12 @@ static void il4965_chain_noise_reset(struct il_priv *priv)
341 cmd.diff_gain_a = 0; 341 cmd.diff_gain_a = 0;
342 cmd.diff_gain_b = 0; 342 cmd.diff_gain_b = 0;
343 cmd.diff_gain_c = 0; 343 cmd.diff_gain_c = 0;
344 if (il_send_cmd_pdu(priv, REPLY_PHY_CALIBRATION_CMD, 344 if (il_send_cmd_pdu(il, REPLY_PHY_CALIBRATION_CMD,
345 sizeof(cmd), &cmd)) 345 sizeof(cmd), &cmd))
346 IL_ERR(priv, 346 IL_ERR(il,
347 "Could not send REPLY_PHY_CALIBRATION_CMD\n"); 347 "Could not send REPLY_PHY_CALIBRATION_CMD\n");
348 data->state = IL_CHAIN_NOISE_ACCUMULATE; 348 data->state = IL_CHAIN_NOISE_ACCUMULATE;
349 IL_DEBUG_CALIB(priv, "Run chain_noise_calibrate\n"); 349 IL_DEBUG_CALIB(il, "Run chain_noise_calibrate\n");
350 } 350 }
351} 351}
352 352
@@ -377,10 +377,10 @@ static struct il_sensitivity_ranges il4965_sensitivity = {
377 .nrg_th_cca = 62, 377 .nrg_th_cca = 62,
378}; 378};
379 379
380static void il4965_set_ct_threshold(struct il_priv *priv) 380static void il4965_set_ct_threshold(struct il_priv *il)
381{ 381{
382 /* want Kelvin */ 382 /* want Kelvin */
383 priv->hw_params.ct_kill_threshold = 383 il->hw_params.ct_kill_threshold =
384 CELSIUS_TO_KELVIN(CT_KILL_THRESHOLD_LEGACY); 384 CELSIUS_TO_KELVIN(CT_KILL_THRESHOLD_LEGACY);
385} 385}
386 386
@@ -389,37 +389,37 @@ static void il4965_set_ct_threshold(struct il_priv *priv)
389 * 389 *
390 * Called when initializing driver 390 * Called when initializing driver
391 */ 391 */
392static int il4965_hw_set_hw_params(struct il_priv *priv) 392static int il4965_hw_set_hw_params(struct il_priv *il)
393{ 393{
394 if (priv->cfg->mod_params->num_of_queues >= IL_MIN_NUM_QUEUES && 394 if (il->cfg->mod_params->num_of_queues >= IL_MIN_NUM_QUEUES &&
395 priv->cfg->mod_params->num_of_queues <= IWL49_NUM_QUEUES) 395 il->cfg->mod_params->num_of_queues <= IWL49_NUM_QUEUES)
396 priv->cfg->base_params->num_of_queues = 396 il->cfg->base_params->num_of_queues =
397 priv->cfg->mod_params->num_of_queues; 397 il->cfg->mod_params->num_of_queues;
398 398
399 priv->hw_params.max_txq_num = priv->cfg->base_params->num_of_queues; 399 il->hw_params.max_txq_num = il->cfg->base_params->num_of_queues;
400 priv->hw_params.dma_chnl_num = FH49_TCSR_CHNL_NUM; 400 il->hw_params.dma_chnl_num = FH49_TCSR_CHNL_NUM;
401 priv->hw_params.scd_bc_tbls_size = 401 il->hw_params.scd_bc_tbls_size =
402 priv->cfg->base_params->num_of_queues * 402 il->cfg->base_params->num_of_queues *
403 sizeof(struct il4965_scd_bc_tbl); 403 sizeof(struct il4965_scd_bc_tbl);
404 priv->hw_params.tfd_size = sizeof(struct il_tfd); 404 il->hw_params.tfd_size = sizeof(struct il_tfd);
405 priv->hw_params.max_stations = IWL4965_STATION_COUNT; 405 il->hw_params.max_stations = IWL4965_STATION_COUNT;
406 priv->contexts[IL_RXON_CTX_BSS].bcast_sta_id = IWL4965_BROADCAST_ID; 406 il->contexts[IL_RXON_CTX_BSS].bcast_sta_id = IWL4965_BROADCAST_ID;
407 priv->hw_params.max_data_size = IWL49_RTC_DATA_SIZE; 407 il->hw_params.max_data_size = IWL49_RTC_DATA_SIZE;
408 priv->hw_params.max_inst_size = IWL49_RTC_INST_SIZE; 408 il->hw_params.max_inst_size = IWL49_RTC_INST_SIZE;
409 priv->hw_params.max_bsm_size = BSM_SRAM_SIZE; 409 il->hw_params.max_bsm_size = BSM_SRAM_SIZE;
410 priv->hw_params.ht40_channel = BIT(IEEE80211_BAND_5GHZ); 410 il->hw_params.ht40_channel = BIT(IEEE80211_BAND_5GHZ);
411 411
412 priv->hw_params.rx_wrt_ptr_reg = FH_RSCSR_CHNL0_WPTR; 412 il->hw_params.rx_wrt_ptr_reg = FH_RSCSR_CHNL0_WPTR;
413 413
414 priv->hw_params.tx_chains_num = il4965_num_of_ant(priv->cfg->valid_tx_ant); 414 il->hw_params.tx_chains_num = il4965_num_of_ant(il->cfg->valid_tx_ant);
415 priv->hw_params.rx_chains_num = il4965_num_of_ant(priv->cfg->valid_rx_ant); 415 il->hw_params.rx_chains_num = il4965_num_of_ant(il->cfg->valid_rx_ant);
416 priv->hw_params.valid_tx_ant = priv->cfg->valid_tx_ant; 416 il->hw_params.valid_tx_ant = il->cfg->valid_tx_ant;
417 priv->hw_params.valid_rx_ant = priv->cfg->valid_rx_ant; 417 il->hw_params.valid_rx_ant = il->cfg->valid_rx_ant;
418 418
419 il4965_set_ct_threshold(priv); 419 il4965_set_ct_threshold(il);
420 420
421 priv->hw_params.sens = &il4965_sensitivity; 421 il->hw_params.sens = &il4965_sensitivity;
422 priv->hw_params.beacon_time_tsf_bits = IWL4965_EXT_BEACON_TIME_POS; 422 il->hw_params.beacon_time_tsf_bits = IWL4965_EXT_BEACON_TIME_POS;
423 423
424 return 0; 424 return 0;
425} 425}
@@ -498,16 +498,16 @@ static s32 il4965_get_tx_atten_grp(u16 channel)
498 return -EINVAL; 498 return -EINVAL;
499} 499}
500 500
501static u32 il4965_get_sub_band(const struct il_priv *priv, u32 channel) 501static u32 il4965_get_sub_band(const struct il_priv *il, u32 channel)
502{ 502{
503 s32 b = -1; 503 s32 b = -1;
504 504
505 for (b = 0; b < EEPROM_TX_POWER_BANDS; b++) { 505 for (b = 0; b < EEPROM_TX_POWER_BANDS; b++) {
506 if (priv->calib_info->band_info[b].ch_from == 0) 506 if (il->calib_info->band_info[b].ch_from == 0)
507 continue; 507 continue;
508 508
509 if ((channel >= priv->calib_info->band_info[b].ch_from) 509 if ((channel >= il->calib_info->band_info[b].ch_from)
510 && (channel <= priv->calib_info->band_info[b].ch_to)) 510 && (channel <= il->calib_info->band_info[b].ch_to))
511 break; 511 break;
512 } 512 }
513 513
@@ -534,7 +534,7 @@ static s32 il4965_interpolate_value(s32 x, s32 x1, s32 y1, s32 x2, s32 y2)
534 * differences in channel frequencies, which is proportional to differences 534 * differences in channel frequencies, which is proportional to differences
535 * in channel number. 535 * in channel number.
536 */ 536 */
537static int il4965_interpolate_chan(struct il_priv *priv, u32 channel, 537static int il4965_interpolate_chan(struct il_priv *il, u32 channel,
538 struct il_eeprom_calib_ch_info *chan_info) 538 struct il_eeprom_calib_ch_info *chan_info)
539{ 539{
540 s32 s = -1; 540 s32 s = -1;
@@ -546,24 +546,24 @@ static int il4965_interpolate_chan(struct il_priv *priv, u32 channel,
546 u32 ch_i1; 546 u32 ch_i1;
547 u32 ch_i2; 547 u32 ch_i2;
548 548
549 s = il4965_get_sub_band(priv, channel); 549 s = il4965_get_sub_band(il, channel);
550 if (s >= EEPROM_TX_POWER_BANDS) { 550 if (s >= EEPROM_TX_POWER_BANDS) {
551 IL_ERR(priv, "Tx Power can not find channel %d\n", channel); 551 IL_ERR(il, "Tx Power can not find channel %d\n", channel);
552 return -1; 552 return -1;
553 } 553 }
554 554
555 ch_i1 = priv->calib_info->band_info[s].ch1.ch_num; 555 ch_i1 = il->calib_info->band_info[s].ch1.ch_num;
556 ch_i2 = priv->calib_info->band_info[s].ch2.ch_num; 556 ch_i2 = il->calib_info->band_info[s].ch2.ch_num;
557 chan_info->ch_num = (u8) channel; 557 chan_info->ch_num = (u8) channel;
558 558
559 IL_DEBUG_TXPOWER(priv, "channel %d subband %d factory cal ch %d & %d\n", 559 IL_DEBUG_TXPOWER(il, "channel %d subband %d factory cal ch %d & %d\n",
560 channel, s, ch_i1, ch_i2); 560 channel, s, ch_i1, ch_i2);
561 561
562 for (c = 0; c < EEPROM_TX_POWER_TX_CHAINS; c++) { 562 for (c = 0; c < EEPROM_TX_POWER_TX_CHAINS; c++) {
563 for (m = 0; m < EEPROM_TX_POWER_MEASUREMENTS; m++) { 563 for (m = 0; m < EEPROM_TX_POWER_MEASUREMENTS; m++) {
564 m1 = &(priv->calib_info->band_info[s].ch1. 564 m1 = &(il->calib_info->band_info[s].ch1.
565 measurements[c][m]); 565 measurements[c][m]);
566 m2 = &(priv->calib_info->band_info[s].ch2. 566 m2 = &(il->calib_info->band_info[s].ch2.
567 measurements[c][m]); 567 measurements[c][m]);
568 omeas = &(chan_info->measurements[c][m]); 568 omeas = &(chan_info->measurements[c][m]);
569 569
@@ -586,16 +586,16 @@ static int il4965_interpolate_chan(struct il_priv *priv, u32 channel,
586 m1->pa_det, ch_i2, 586 m1->pa_det, ch_i2,
587 m2->pa_det); 587 m2->pa_det);
588 588
589 IL_DEBUG_TXPOWER(priv, 589 IL_DEBUG_TXPOWER(il,
590 "chain %d meas %d AP1=%d AP2=%d AP=%d\n", c, m, 590 "chain %d meas %d AP1=%d AP2=%d AP=%d\n", c, m,
591 m1->actual_pow, m2->actual_pow, omeas->actual_pow); 591 m1->actual_pow, m2->actual_pow, omeas->actual_pow);
592 IL_DEBUG_TXPOWER(priv, 592 IL_DEBUG_TXPOWER(il,
593 "chain %d meas %d NI1=%d NI2=%d NI=%d\n", c, m, 593 "chain %d meas %d NI1=%d NI2=%d NI=%d\n", c, m,
594 m1->gain_idx, m2->gain_idx, omeas->gain_idx); 594 m1->gain_idx, m2->gain_idx, omeas->gain_idx);
595 IL_DEBUG_TXPOWER(priv, 595 IL_DEBUG_TXPOWER(il,
596 "chain %d meas %d PA1=%d PA2=%d PA=%d\n", c, m, 596 "chain %d meas %d PA1=%d PA2=%d PA=%d\n", c, m,
597 m1->pa_det, m2->pa_det, omeas->pa_det); 597 m1->pa_det, m2->pa_det, omeas->pa_det);
598 IL_DEBUG_TXPOWER(priv, 598 IL_DEBUG_TXPOWER(il,
599 "chain %d meas %d T1=%d T2=%d T=%d\n", c, m, 599 "chain %d meas %d T1=%d T2=%d T=%d\n", c, m,
600 m1->temperature, m2->temperature, 600 m1->temperature, m2->temperature,
601 omeas->temperature); 601 omeas->temperature);
@@ -867,7 +867,7 @@ static const struct gain_entry gain_table[2][108] = {
867 } 867 }
868}; 868};
869 869
870static int il4965_fill_txpower_tbl(struct il_priv *priv, u8 band, u16 channel, 870static int il4965_fill_txpower_tbl(struct il_priv *il, u8 band, u16 channel,
871 u8 is_ht40, u8 ctrl_chan_high, 871 u8 is_ht40, u8 ctrl_chan_high,
872 struct il4965_tx_power_db *tx_power_tbl) 872 struct il4965_tx_power_db *tx_power_tbl)
873{ 873{
@@ -897,13 +897,13 @@ static int il4965_fill_txpower_tbl(struct il_priv *priv, u8 band, u16 channel,
897 897
898 /* tx_power_user_lmt is in dBm, convert to half-dBm (half-dB units 898 /* tx_power_user_lmt is in dBm, convert to half-dBm (half-dB units
899 * are used for indexing into txpower table) */ 899 * are used for indexing into txpower table) */
900 user_target_power = 2 * priv->tx_power_user_lmt; 900 user_target_power = 2 * il->tx_power_user_lmt;
901 901
902 /* Get current (RXON) channel, band, width */ 902 /* Get current (RXON) channel, band, width */
903 IL_DEBUG_TXPOWER(priv, "chan %d band %d is_ht40 %d\n", channel, band, 903 IL_DEBUG_TXPOWER(il, "chan %d band %d is_ht40 %d\n", channel, band,
904 is_ht40); 904 is_ht40);
905 905
906 ch_info = il_get_channel_info(priv, priv->band, channel); 906 ch_info = il_get_channel_info(il, il->band, channel);
907 907
908 if (!il_is_channel_valid(ch_info)) 908 if (!il_is_channel_valid(ch_info))
909 return -EINVAL; 909 return -EINVAL;
@@ -912,12 +912,12 @@ static int il4965_fill_txpower_tbl(struct il_priv *priv, u8 band, u16 channel,
912 * and 2) mimo txpower balance between Tx chains. */ 912 * and 2) mimo txpower balance between Tx chains. */
913 txatten_grp = il4965_get_tx_atten_grp(channel); 913 txatten_grp = il4965_get_tx_atten_grp(channel);
914 if (txatten_grp < 0) { 914 if (txatten_grp < 0) {
915 IL_ERR(priv, "Can't find txatten group for channel %d.\n", 915 IL_ERR(il, "Can't find txatten group for channel %d.\n",
916 channel); 916 channel);
917 return txatten_grp; 917 return txatten_grp;
918 } 918 }
919 919
920 IL_DEBUG_TXPOWER(priv, "channel %d belongs to txatten group %d\n", 920 IL_DEBUG_TXPOWER(il, "channel %d belongs to txatten group %d\n",
921 channel, txatten_grp); 921 channel, txatten_grp);
922 922
923 if (is_ht40) { 923 if (is_ht40) {
@@ -930,9 +930,9 @@ static int il4965_fill_txpower_tbl(struct il_priv *priv, u8 band, u16 channel,
930 /* hardware txpower limits ... 930 /* hardware txpower limits ...
931 * saturation (clipping distortion) txpowers are in half-dBm */ 931 * saturation (clipping distortion) txpowers are in half-dBm */
932 if (band) 932 if (band)
933 saturation_power = priv->calib_info->saturation_power24; 933 saturation_power = il->calib_info->saturation_power24;
934 else 934 else
935 saturation_power = priv->calib_info->saturation_power52; 935 saturation_power = il->calib_info->saturation_power52;
936 936
937 if (saturation_power < IL_TX_POWER_SATURATION_MIN || 937 if (saturation_power < IL_TX_POWER_SATURATION_MIN ||
938 saturation_power > IL_TX_POWER_SATURATION_MAX) { 938 saturation_power > IL_TX_POWER_SATURATION_MAX) {
@@ -959,21 +959,21 @@ static int il4965_fill_txpower_tbl(struct il_priv *priv, u8 band, u16 channel,
959 959
960 /* Interpolate txpower calibration values for this channel, 960 /* Interpolate txpower calibration values for this channel,
961 * based on factory calibration tests on spaced channels. */ 961 * based on factory calibration tests on spaced channels. */
962 il4965_interpolate_chan(priv, channel, &ch_eeprom_info); 962 il4965_interpolate_chan(il, channel, &ch_eeprom_info);
963 963
964 /* calculate tx gain adjustment based on power supply voltage */ 964 /* calculate tx gain adjustment based on power supply voltage */
965 voltage = le16_to_cpu(priv->calib_info->voltage); 965 voltage = le16_to_cpu(il->calib_info->voltage);
966 init_voltage = (s32)le32_to_cpu(priv->card_alive_init.voltage); 966 init_voltage = (s32)le32_to_cpu(il->card_alive_init.voltage);
967 voltage_compensation = 967 voltage_compensation =
968 il4965_get_voltage_compensation(voltage, init_voltage); 968 il4965_get_voltage_compensation(voltage, init_voltage);
969 969
970 IL_DEBUG_TXPOWER(priv, "curr volt %d eeprom volt %d volt comp %d\n", 970 IL_DEBUG_TXPOWER(il, "curr volt %d eeprom volt %d volt comp %d\n",
971 init_voltage, 971 init_voltage,
972 voltage, voltage_compensation); 972 voltage, voltage_compensation);
973 973
974 /* get current temperature (Celsius) */ 974 /* get current temperature (Celsius) */
975 current_temp = max(priv->temperature, IL_TX_POWER_TEMPERATURE_MIN); 975 current_temp = max(il->temperature, IL_TX_POWER_TEMPERATURE_MIN);
976 current_temp = min(priv->temperature, IL_TX_POWER_TEMPERATURE_MAX); 976 current_temp = min(il->temperature, IL_TX_POWER_TEMPERATURE_MAX);
977 current_temp = KELVIN_TO_CELSIUS(current_temp); 977 current_temp = KELVIN_TO_CELSIUS(current_temp);
978 978
979 /* select thermal txpower adjustment params, based on channel group 979 /* select thermal txpower adjustment params, based on channel group
@@ -998,13 +998,13 @@ static int il4965_fill_txpower_tbl(struct il_priv *priv, u8 band, u16 channel,
998 factory_gain_index[c] = measurement->gain_idx; 998 factory_gain_index[c] = measurement->gain_idx;
999 factory_actual_pwr[c] = measurement->actual_pow; 999 factory_actual_pwr[c] = measurement->actual_pow;
1000 1000
1001 IL_DEBUG_TXPOWER(priv, "chain = %d\n", c); 1001 IL_DEBUG_TXPOWER(il, "chain = %d\n", c);
1002 IL_DEBUG_TXPOWER(priv, "fctry tmp %d, " 1002 IL_DEBUG_TXPOWER(il, "fctry tmp %d, "
1003 "curr tmp %d, comp %d steps\n", 1003 "curr tmp %d, comp %d steps\n",
1004 factory_temp, current_temp, 1004 factory_temp, current_temp,
1005 temperature_comp[c]); 1005 temperature_comp[c]);
1006 1006
1007 IL_DEBUG_TXPOWER(priv, "fctry idx %d, fctry pwr %d\n", 1007 IL_DEBUG_TXPOWER(il, "fctry idx %d, fctry pwr %d\n",
1008 factory_gain_index[c], 1008 factory_gain_index[c],
1009 factory_actual_pwr[c]); 1009 factory_actual_pwr[c]);
1010 } 1010 }
@@ -1037,7 +1037,7 @@ static int il4965_fill_txpower_tbl(struct il_priv *priv, u8 band, u16 channel,
1037 if (target_power > power_limit) 1037 if (target_power > power_limit)
1038 target_power = power_limit; 1038 target_power = power_limit;
1039 1039
1040 IL_DEBUG_TXPOWER(priv, "rate %d sat %d reg %d usr %d tgt %d\n", 1040 IL_DEBUG_TXPOWER(il, "rate %d sat %d reg %d usr %d tgt %d\n",
1041 i, saturation_power - back_off_table[i], 1041 i, saturation_power - back_off_table[i],
1042 current_regulatory, user_target_power, 1042 current_regulatory, user_target_power,
1043 target_power); 1043 target_power);
@@ -1048,7 +1048,7 @@ static int il4965_fill_txpower_tbl(struct il_priv *priv, u8 band, u16 channel,
1048 1048
1049 if (is_mimo_rate) 1049 if (is_mimo_rate)
1050 atten_value = 1050 atten_value =
1051 (s32)le32_to_cpu(priv->card_alive_init. 1051 (s32)le32_to_cpu(il->card_alive_init.
1052 tx_atten[txatten_grp][c]); 1052 tx_atten[txatten_grp][c]);
1053 else 1053 else
1054 atten_value = 0; 1054 atten_value = 0;
@@ -1061,7 +1061,7 @@ static int il4965_fill_txpower_tbl(struct il_priv *priv, u8 band, u16 channel,
1061 voltage_compensation + 1061 voltage_compensation +
1062 atten_value); 1062 atten_value);
1063 1063
1064/* IL_DEBUG_TXPOWER(priv, "calculated txpower index %d\n", 1064/* IL_DEBUG_TXPOWER(il, "calculated txpower index %d\n",
1065 power_index); */ 1065 power_index); */
1066 1066
1067 if (power_index < get_min_power_index(i, band)) 1067 if (power_index < get_min_power_index(i, band))
@@ -1078,12 +1078,12 @@ static int il4965_fill_txpower_tbl(struct il_priv *priv, u8 band, u16 channel,
1078 1078
1079 /* stay within the table! */ 1079 /* stay within the table! */
1080 if (power_index > 107) { 1080 if (power_index > 107) {
1081 IL_WARN(priv, "txpower index %d > 107\n", 1081 IL_WARN(il, "txpower index %d > 107\n",
1082 power_index); 1082 power_index);
1083 power_index = 107; 1083 power_index = 107;
1084 } 1084 }
1085 if (power_index < 0) { 1085 if (power_index < 0) {
1086 IL_WARN(priv, "txpower index %d < 0\n", 1086 IL_WARN(il, "txpower index %d < 0\n",
1087 power_index); 1087 power_index);
1088 power_index = 0; 1088 power_index = 0;
1089 } 1089 }
@@ -1094,7 +1094,7 @@ static int il4965_fill_txpower_tbl(struct il_priv *priv, u8 band, u16 channel,
1094 tx_power.s.dsp_predis_atten[c] = 1094 tx_power.s.dsp_predis_atten[c] =
1095 gain_table[band][power_index].dsp; 1095 gain_table[band][power_index].dsp;
1096 1096
1097 IL_DEBUG_TXPOWER(priv, "chain %d mimo %d index %d " 1097 IL_DEBUG_TXPOWER(il, "chain %d mimo %d index %d "
1098 "gain 0x%02x dsp %d\n", 1098 "gain 0x%02x dsp %d\n",
1099 c, atten_value, power_index, 1099 c, atten_value, power_index,
1100 tx_power.s.radio_tx_gain[c], 1100 tx_power.s.radio_tx_gain[c],
@@ -1112,22 +1112,22 @@ static int il4965_fill_txpower_tbl(struct il_priv *priv, u8 band, u16 channel,
1112 * il4965_send_tx_power - Configure the TXPOWER level user limit 1112 * il4965_send_tx_power - Configure the TXPOWER level user limit
1113 * 1113 *
1114 * Uses the active RXON for channel, band, and characteristics (ht40, high) 1114 * Uses the active RXON for channel, band, and characteristics (ht40, high)
1115 * The power limit is taken from priv->tx_power_user_lmt. 1115 * The power limit is taken from il->tx_power_user_lmt.
1116 */ 1116 */
1117static int il4965_send_tx_power(struct il_priv *priv) 1117static int il4965_send_tx_power(struct il_priv *il)
1118{ 1118{
1119 struct il4965_txpowertable_cmd cmd = { 0 }; 1119 struct il4965_txpowertable_cmd cmd = { 0 };
1120 int ret; 1120 int ret;
1121 u8 band = 0; 1121 u8 band = 0;
1122 bool is_ht40 = false; 1122 bool is_ht40 = false;
1123 u8 ctrl_chan_high = 0; 1123 u8 ctrl_chan_high = 0;
1124 struct il_rxon_context *ctx = &priv->contexts[IL_RXON_CTX_BSS]; 1124 struct il_rxon_context *ctx = &il->contexts[IL_RXON_CTX_BSS];
1125 1125
1126 if (WARN_ONCE(test_bit(STATUS_SCAN_HW, &priv->status), 1126 if (WARN_ONCE(test_bit(STATUS_SCAN_HW, &il->status),
1127 "TX Power requested while scanning!\n")) 1127 "TX Power requested while scanning!\n"))
1128 return -EAGAIN; 1128 return -EAGAIN;
1129 1129
1130 band = priv->band == IEEE80211_BAND_2GHZ; 1130 band = il->band == IEEE80211_BAND_2GHZ;
1131 1131
1132 is_ht40 = iw4965_is_ht40_channel(ctx->active.flags); 1132 is_ht40 = iw4965_is_ht40_channel(ctx->active.flags);
1133 1133
@@ -1137,20 +1137,20 @@ static int il4965_send_tx_power(struct il_priv *priv)
1137 cmd.band = band; 1137 cmd.band = band;
1138 cmd.channel = ctx->active.channel; 1138 cmd.channel = ctx->active.channel;
1139 1139
1140 ret = il4965_fill_txpower_tbl(priv, band, 1140 ret = il4965_fill_txpower_tbl(il, band,
1141 le16_to_cpu(ctx->active.channel), 1141 le16_to_cpu(ctx->active.channel),
1142 is_ht40, ctrl_chan_high, &cmd.tx_power); 1142 is_ht40, ctrl_chan_high, &cmd.tx_power);
1143 if (ret) 1143 if (ret)
1144 goto out; 1144 goto out;
1145 1145
1146 ret = il_send_cmd_pdu(priv, 1146 ret = il_send_cmd_pdu(il,
1147 REPLY_TX_PWR_TABLE_CMD, sizeof(cmd), &cmd); 1147 REPLY_TX_PWR_TABLE_CMD, sizeof(cmd), &cmd);
1148 1148
1149out: 1149out:
1150 return ret; 1150 return ret;
1151} 1151}
1152 1152
1153static int il4965_send_rxon_assoc(struct il_priv *priv, 1153static int il4965_send_rxon_assoc(struct il_priv *il,
1154 struct il_rxon_context *ctx) 1154 struct il_rxon_context *ctx)
1155{ 1155{
1156 int ret = 0; 1156 int ret = 0;
@@ -1167,7 +1167,7 @@ static int il4965_send_rxon_assoc(struct il_priv *priv,
1167 rxon2->ofdm_ht_dual_stream_basic_rates) && 1167 rxon2->ofdm_ht_dual_stream_basic_rates) &&
1168 (rxon1->rx_chain == rxon2->rx_chain) && 1168 (rxon1->rx_chain == rxon2->rx_chain) &&
1169 (rxon1->ofdm_basic_rates == rxon2->ofdm_basic_rates)) { 1169 (rxon1->ofdm_basic_rates == rxon2->ofdm_basic_rates)) {
1170 IL_DEBUG_INFO(priv, "Using current RXON_ASSOC. Not resending.\n"); 1170 IL_DEBUG_INFO(il, "Using current RXON_ASSOC. Not resending.\n");
1171 return 0; 1171 return 0;
1172 } 1172 }
1173 1173
@@ -1182,13 +1182,13 @@ static int il4965_send_rxon_assoc(struct il_priv *priv,
1182 ctx->staging.ofdm_ht_dual_stream_basic_rates; 1182 ctx->staging.ofdm_ht_dual_stream_basic_rates;
1183 rxon_assoc.rx_chain_select_flags = ctx->staging.rx_chain; 1183 rxon_assoc.rx_chain_select_flags = ctx->staging.rx_chain;
1184 1184
1185 ret = il_send_cmd_pdu_async(priv, REPLY_RXON_ASSOC, 1185 ret = il_send_cmd_pdu_async(il, REPLY_RXON_ASSOC,
1186 sizeof(rxon_assoc), &rxon_assoc, NULL); 1186 sizeof(rxon_assoc), &rxon_assoc, NULL);
1187 1187
1188 return ret; 1188 return ret;
1189} 1189}
1190 1190
1191static int il4965_commit_rxon(struct il_priv *priv, struct il_rxon_context *ctx) 1191static int il4965_commit_rxon(struct il_priv *il, struct il_rxon_context *ctx)
1192{ 1192{
1193 /* cast away the const for active_rxon in this function */ 1193 /* cast away the const for active_rxon in this function */
1194 struct il_rxon_cmd *active_rxon = (void *)&ctx->active; 1194 struct il_rxon_cmd *active_rxon = (void *)&ctx->active;
@@ -1196,7 +1196,7 @@ static int il4965_commit_rxon(struct il_priv *priv, struct il_rxon_context *ctx)
1196 bool new_assoc = 1196 bool new_assoc =
1197 !!(ctx->staging.filter_flags & RXON_FILTER_ASSOC_MSK); 1197 !!(ctx->staging.filter_flags & RXON_FILTER_ASSOC_MSK);
1198 1198
1199 if (!il_is_alive(priv)) 1199 if (!il_is_alive(il))
1200 return -EBUSY; 1200 return -EBUSY;
1201 1201
1202 if (!ctx->is_active) 1202 if (!ctx->is_active)
@@ -1205,9 +1205,9 @@ static int il4965_commit_rxon(struct il_priv *priv, struct il_rxon_context *ctx)
1205 /* always get timestamp with Rx frame */ 1205 /* always get timestamp with Rx frame */
1206 ctx->staging.flags |= RXON_FLG_TSF2HOST_MSK; 1206 ctx->staging.flags |= RXON_FLG_TSF2HOST_MSK;
1207 1207
1208 ret = il_check_rxon_cmd(priv, ctx); 1208 ret = il_check_rxon_cmd(il, ctx);
1209 if (ret) { 1209 if (ret) {
1210 IL_ERR(priv, "Invalid RXON configuration. Not committing.\n"); 1210 IL_ERR(il, "Invalid RXON configuration. Not committing.\n");
1211 return -EINVAL; 1211 return -EINVAL;
1212 } 1212 }
1213 1213
@@ -1215,30 +1215,30 @@ static int il4965_commit_rxon(struct il_priv *priv, struct il_rxon_context *ctx)
1215 * receive commit_rxon request 1215 * receive commit_rxon request
1216 * abort any previous channel switch if still in process 1216 * abort any previous channel switch if still in process
1217 */ 1217 */
1218 if (test_bit(STATUS_CHANNEL_SWITCH_PENDING, &priv->status) && 1218 if (test_bit(STATUS_CHANNEL_SWITCH_PENDING, &il->status) &&
1219 (priv->switch_channel != ctx->staging.channel)) { 1219 (il->switch_channel != ctx->staging.channel)) {
1220 IL_DEBUG_11H(priv, "abort channel switch on %d\n", 1220 IL_DEBUG_11H(il, "abort channel switch on %d\n",
1221 le16_to_cpu(priv->switch_channel)); 1221 le16_to_cpu(il->switch_channel));
1222 il_chswitch_done(priv, false); 1222 il_chswitch_done(il, false);
1223 } 1223 }
1224 1224
1225 /* If we don't need to send a full RXON, we can use 1225 /* If we don't need to send a full RXON, we can use
1226 * il_rxon_assoc_cmd which is used to reconfigure filter 1226 * il_rxon_assoc_cmd which is used to reconfigure filter
1227 * and other flags for the current radio configuration. */ 1227 * and other flags for the current radio configuration. */
1228 if (!il_full_rxon_required(priv, ctx)) { 1228 if (!il_full_rxon_required(il, ctx)) {
1229 ret = il_send_rxon_assoc(priv, ctx); 1229 ret = il_send_rxon_assoc(il, ctx);
1230 if (ret) { 1230 if (ret) {
1231 IL_ERR(priv, "Error setting RXON_ASSOC (%d)\n", ret); 1231 IL_ERR(il, "Error setting RXON_ASSOC (%d)\n", ret);
1232 return ret; 1232 return ret;
1233 } 1233 }
1234 1234
1235 memcpy(active_rxon, &ctx->staging, sizeof(*active_rxon)); 1235 memcpy(active_rxon, &ctx->staging, sizeof(*active_rxon));
1236 il_print_rx_config_cmd(priv, ctx); 1236 il_print_rx_config_cmd(il, ctx);
1237 /* 1237 /*
1238 * We do not commit tx power settings while channel changing, 1238 * We do not commit tx power settings while channel changing,
1239 * do it now if tx power changed. 1239 * do it now if tx power changed.
1240 */ 1240 */
1241 il_set_tx_power(priv, priv->tx_power_next, false); 1241 il_set_tx_power(il, il->tx_power_next, false);
1242 return 0; 1242 return 0;
1243 } 1243 }
1244 1244
@@ -1247,10 +1247,10 @@ static int il4965_commit_rxon(struct il_priv *priv, struct il_rxon_context *ctx)
1247 * we must clear the associated from the active configuration 1247 * we must clear the associated from the active configuration
1248 * before we apply the new config */ 1248 * before we apply the new config */
1249 if (il_is_associated_ctx(ctx) && new_assoc) { 1249 if (il_is_associated_ctx(ctx) && new_assoc) {
1250 IL_DEBUG_INFO(priv, "Toggling associated bit on current RXON\n"); 1250 IL_DEBUG_INFO(il, "Toggling associated bit on current RXON\n");
1251 active_rxon->filter_flags &= ~RXON_FILTER_ASSOC_MSK; 1251 active_rxon->filter_flags &= ~RXON_FILTER_ASSOC_MSK;
1252 1252
1253 ret = il_send_cmd_pdu(priv, ctx->rxon_cmd, 1253 ret = il_send_cmd_pdu(il, ctx->rxon_cmd,
1254 sizeof(struct il_rxon_cmd), 1254 sizeof(struct il_rxon_cmd),
1255 active_rxon); 1255 active_rxon);
1256 1256
@@ -1258,19 +1258,19 @@ static int il4965_commit_rxon(struct il_priv *priv, struct il_rxon_context *ctx)
1258 * active_rxon back to what it was previously */ 1258 * active_rxon back to what it was previously */
1259 if (ret) { 1259 if (ret) {
1260 active_rxon->filter_flags |= RXON_FILTER_ASSOC_MSK; 1260 active_rxon->filter_flags |= RXON_FILTER_ASSOC_MSK;
1261 IL_ERR(priv, "Error clearing ASSOC_MSK (%d)\n", ret); 1261 IL_ERR(il, "Error clearing ASSOC_MSK (%d)\n", ret);
1262 return ret; 1262 return ret;
1263 } 1263 }
1264 il_clear_ucode_stations(priv, ctx); 1264 il_clear_ucode_stations(il, ctx);
1265 il_restore_stations(priv, ctx); 1265 il_restore_stations(il, ctx);
1266 ret = il4965_restore_default_wep_keys(priv, ctx); 1266 ret = il4965_restore_default_wep_keys(il, ctx);
1267 if (ret) { 1267 if (ret) {
1268 IL_ERR(priv, "Failed to restore WEP keys (%d)\n", ret); 1268 IL_ERR(il, "Failed to restore WEP keys (%d)\n", ret);
1269 return ret; 1269 return ret;
1270 } 1270 }
1271 } 1271 }
1272 1272
1273 IL_DEBUG_INFO(priv, "Sending RXON\n" 1273 IL_DEBUG_INFO(il, "Sending RXON\n"
1274 "* with%s RXON_FILTER_ASSOC_MSK\n" 1274 "* with%s RXON_FILTER_ASSOC_MSK\n"
1275 "* channel = %d\n" 1275 "* channel = %d\n"
1276 "* bssid = %pM\n", 1276 "* bssid = %pM\n",
@@ -1278,62 +1278,62 @@ static int il4965_commit_rxon(struct il_priv *priv, struct il_rxon_context *ctx)
1278 le16_to_cpu(ctx->staging.channel), 1278 le16_to_cpu(ctx->staging.channel),
1279 ctx->staging.bssid_addr); 1279 ctx->staging.bssid_addr);
1280 1280
1281 il_set_rxon_hwcrypto(priv, ctx, 1281 il_set_rxon_hwcrypto(il, ctx,
1282 !priv->cfg->mod_params->sw_crypto); 1282 !il->cfg->mod_params->sw_crypto);
1283 1283
1284 /* Apply the new configuration 1284 /* Apply the new configuration
1285 * RXON unassoc clears the station table in uCode so restoration of 1285 * RXON unassoc clears the station table in uCode so restoration of
1286 * stations is needed after it (the RXON command) completes 1286 * stations is needed after it (the RXON command) completes
1287 */ 1287 */
1288 if (!new_assoc) { 1288 if (!new_assoc) {
1289 ret = il_send_cmd_pdu(priv, ctx->rxon_cmd, 1289 ret = il_send_cmd_pdu(il, ctx->rxon_cmd,
1290 sizeof(struct il_rxon_cmd), &ctx->staging); 1290 sizeof(struct il_rxon_cmd), &ctx->staging);
1291 if (ret) { 1291 if (ret) {
1292 IL_ERR(priv, "Error setting new RXON (%d)\n", ret); 1292 IL_ERR(il, "Error setting new RXON (%d)\n", ret);
1293 return ret; 1293 return ret;
1294 } 1294 }
1295 IL_DEBUG_INFO(priv, "Return from !new_assoc RXON.\n"); 1295 IL_DEBUG_INFO(il, "Return from !new_assoc RXON.\n");
1296 memcpy(active_rxon, &ctx->staging, sizeof(*active_rxon)); 1296 memcpy(active_rxon, &ctx->staging, sizeof(*active_rxon));
1297 il_clear_ucode_stations(priv, ctx); 1297 il_clear_ucode_stations(il, ctx);
1298 il_restore_stations(priv, ctx); 1298 il_restore_stations(il, ctx);
1299 ret = il4965_restore_default_wep_keys(priv, ctx); 1299 ret = il4965_restore_default_wep_keys(il, ctx);
1300 if (ret) { 1300 if (ret) {
1301 IL_ERR(priv, "Failed to restore WEP keys (%d)\n", ret); 1301 IL_ERR(il, "Failed to restore WEP keys (%d)\n", ret);
1302 return ret; 1302 return ret;
1303 } 1303 }
1304 } 1304 }
1305 if (new_assoc) { 1305 if (new_assoc) {
1306 priv->start_calib = 0; 1306 il->start_calib = 0;
1307 /* Apply the new configuration 1307 /* Apply the new configuration
1308 * RXON assoc doesn't clear the station table in uCode, 1308 * RXON assoc doesn't clear the station table in uCode,
1309 */ 1309 */
1310 ret = il_send_cmd_pdu(priv, ctx->rxon_cmd, 1310 ret = il_send_cmd_pdu(il, ctx->rxon_cmd,
1311 sizeof(struct il_rxon_cmd), &ctx->staging); 1311 sizeof(struct il_rxon_cmd), &ctx->staging);
1312 if (ret) { 1312 if (ret) {
1313 IL_ERR(priv, "Error setting new RXON (%d)\n", ret); 1313 IL_ERR(il, "Error setting new RXON (%d)\n", ret);
1314 return ret; 1314 return ret;
1315 } 1315 }
1316 memcpy(active_rxon, &ctx->staging, sizeof(*active_rxon)); 1316 memcpy(active_rxon, &ctx->staging, sizeof(*active_rxon));
1317 } 1317 }
1318 il_print_rx_config_cmd(priv, ctx); 1318 il_print_rx_config_cmd(il, ctx);
1319 1319
1320 il4965_init_sensitivity(priv); 1320 il4965_init_sensitivity(il);
1321 1321
1322 /* If we issue a new RXON command which required a tune then we must 1322 /* If we issue a new RXON command which required a tune then we must
1323 * send a new TXPOWER command or we won't be able to Tx any frames */ 1323 * send a new TXPOWER command or we won't be able to Tx any frames */
1324 ret = il_set_tx_power(priv, priv->tx_power_next, true); 1324 ret = il_set_tx_power(il, il->tx_power_next, true);
1325 if (ret) { 1325 if (ret) {
1326 IL_ERR(priv, "Error sending TX power (%d)\n", ret); 1326 IL_ERR(il, "Error sending TX power (%d)\n", ret);
1327 return ret; 1327 return ret;
1328 } 1328 }
1329 1329
1330 return 0; 1330 return 0;
1331} 1331}
1332 1332
1333static int il4965_hw_channel_switch(struct il_priv *priv, 1333static int il4965_hw_channel_switch(struct il_priv *il,
1334 struct ieee80211_channel_switch *ch_switch) 1334 struct ieee80211_channel_switch *ch_switch)
1335{ 1335{
1336 struct il_rxon_context *ctx = &priv->contexts[IL_RXON_CTX_BSS]; 1336 struct il_rxon_context *ctx = &il->contexts[IL_RXON_CTX_BSS];
1337 int rc; 1337 int rc;
1338 u8 band = 0; 1338 u8 band = 0;
1339 bool is_ht40 = false; 1339 bool is_ht40 = false;
@@ -1346,7 +1346,7 @@ static int il4965_hw_channel_switch(struct il_priv *priv,
1346 u8 switch_count; 1346 u8 switch_count;
1347 u16 beacon_interval = le16_to_cpu(ctx->timing.beacon_interval); 1347 u16 beacon_interval = le16_to_cpu(ctx->timing.beacon_interval);
1348 struct ieee80211_vif *vif = ctx->vif; 1348 struct ieee80211_vif *vif = ctx->vif;
1349 band = priv->band == IEEE80211_BAND_2GHZ; 1349 band = il->band == IEEE80211_BAND_2GHZ;
1350 1350
1351 is_ht40 = iw4965_is_ht40_channel(ctx->staging.flags); 1351 is_ht40 = iw4965_is_ht40_channel(ctx->staging.flags);
1352 1352
@@ -1366,57 +1366,57 @@ static int il4965_hw_channel_switch(struct il_priv *priv,
1366 * calculate the ucode channel switch time 1366 * calculate the ucode channel switch time
1367 * adding TSF as one of the factor for when to switch 1367 * adding TSF as one of the factor for when to switch
1368 */ 1368 */
1369 if ((priv->ucode_beacon_time > tsf_low) && beacon_interval) { 1369 if ((il->ucode_beacon_time > tsf_low) && beacon_interval) {
1370 if (switch_count > ((priv->ucode_beacon_time - tsf_low) / 1370 if (switch_count > ((il->ucode_beacon_time - tsf_low) /
1371 beacon_interval)) { 1371 beacon_interval)) {
1372 switch_count -= (priv->ucode_beacon_time - 1372 switch_count -= (il->ucode_beacon_time -
1373 tsf_low) / beacon_interval; 1373 tsf_low) / beacon_interval;
1374 } else 1374 } else
1375 switch_count = 0; 1375 switch_count = 0;
1376 } 1376 }
1377 if (switch_count <= 1) 1377 if (switch_count <= 1)
1378 cmd.switch_time = cpu_to_le32(priv->ucode_beacon_time); 1378 cmd.switch_time = cpu_to_le32(il->ucode_beacon_time);
1379 else { 1379 else {
1380 switch_time_in_usec = 1380 switch_time_in_usec =
1381 vif->bss_conf.beacon_int * switch_count * TIME_UNIT; 1381 vif->bss_conf.beacon_int * switch_count * TIME_UNIT;
1382 ucode_switch_time = il_usecs_to_beacons(priv, 1382 ucode_switch_time = il_usecs_to_beacons(il,
1383 switch_time_in_usec, 1383 switch_time_in_usec,
1384 beacon_interval); 1384 beacon_interval);
1385 cmd.switch_time = il_add_beacon_time(priv, 1385 cmd.switch_time = il_add_beacon_time(il,
1386 priv->ucode_beacon_time, 1386 il->ucode_beacon_time,
1387 ucode_switch_time, 1387 ucode_switch_time,
1388 beacon_interval); 1388 beacon_interval);
1389 } 1389 }
1390 IL_DEBUG_11H(priv, "uCode time for the switch is 0x%x\n", 1390 IL_DEBUG_11H(il, "uCode time for the switch is 0x%x\n",
1391 cmd.switch_time); 1391 cmd.switch_time);
1392 ch_info = il_get_channel_info(priv, priv->band, ch); 1392 ch_info = il_get_channel_info(il, il->band, ch);
1393 if (ch_info) 1393 if (ch_info)
1394 cmd.expect_beacon = il_is_channel_radar(ch_info); 1394 cmd.expect_beacon = il_is_channel_radar(ch_info);
1395 else { 1395 else {
1396 IL_ERR(priv, "invalid channel switch from %u to %u\n", 1396 IL_ERR(il, "invalid channel switch from %u to %u\n",
1397 ctx->active.channel, ch); 1397 ctx->active.channel, ch);
1398 return -EFAULT; 1398 return -EFAULT;
1399 } 1399 }
1400 1400
1401 rc = il4965_fill_txpower_tbl(priv, band, ch, is_ht40, 1401 rc = il4965_fill_txpower_tbl(il, band, ch, is_ht40,
1402 ctrl_chan_high, &cmd.tx_power); 1402 ctrl_chan_high, &cmd.tx_power);
1403 if (rc) { 1403 if (rc) {
1404 IL_DEBUG_11H(priv, "error:%d fill txpower_tbl\n", rc); 1404 IL_DEBUG_11H(il, "error:%d fill txpower_tbl\n", rc);
1405 return rc; 1405 return rc;
1406 } 1406 }
1407 1407
1408 return il_send_cmd_pdu(priv, 1408 return il_send_cmd_pdu(il,
1409 REPLY_CHANNEL_SWITCH, sizeof(cmd), &cmd); 1409 REPLY_CHANNEL_SWITCH, sizeof(cmd), &cmd);
1410} 1410}
1411 1411
1412/** 1412/**
1413 * il4965_txq_update_byte_cnt_tbl - Set up entry in Tx byte-count array 1413 * il4965_txq_update_byte_cnt_tbl - Set up entry in Tx byte-count array
1414 */ 1414 */
1415static void il4965_txq_update_byte_cnt_tbl(struct il_priv *priv, 1415static void il4965_txq_update_byte_cnt_tbl(struct il_priv *il,
1416 struct il_tx_queue *txq, 1416 struct il_tx_queue *txq,
1417 u16 byte_cnt) 1417 u16 byte_cnt)
1418{ 1418{
1419 struct il4965_scd_bc_tbl *scd_bc_tbl = priv->scd_bc_tbls.addr; 1419 struct il4965_scd_bc_tbl *scd_bc_tbl = il->scd_bc_tbls.addr;
1420 int txq_id = txq->q.id; 1420 int txq_id = txq->q.id;
1421 int write_ptr = txq->q.write_ptr; 1421 int write_ptr = txq->q.write_ptr;
1422 int len = byte_cnt + IL_TX_CRC_SIZE + IL_TX_DELIMITER_SIZE; 1422 int len = byte_cnt + IL_TX_CRC_SIZE + IL_TX_DELIMITER_SIZE;
@@ -1440,27 +1440,27 @@ static void il4965_txq_update_byte_cnt_tbl(struct il_priv *priv,
1440 * 1440 *
1441 * A return of <0 indicates bogus data in the statistics 1441 * A return of <0 indicates bogus data in the statistics
1442 */ 1442 */
1443static int il4965_hw_get_temperature(struct il_priv *priv) 1443static int il4965_hw_get_temperature(struct il_priv *il)
1444{ 1444{
1445 s32 temperature; 1445 s32 temperature;
1446 s32 vt; 1446 s32 vt;
1447 s32 R1, R2, R3; 1447 s32 R1, R2, R3;
1448 u32 R4; 1448 u32 R4;
1449 1449
1450 if (test_bit(STATUS_TEMPERATURE, &priv->status) && 1450 if (test_bit(STATUS_TEMPERATURE, &il->status) &&
1451 (priv->_4965.statistics.flag & 1451 (il->_4965.statistics.flag &
1452 STATISTICS_REPLY_FLG_HT40_MODE_MSK)) { 1452 STATISTICS_REPLY_FLG_HT40_MODE_MSK)) {
1453 IL_DEBUG_TEMP(priv, "Running HT40 temperature calibration\n"); 1453 IL_DEBUG_TEMP(il, "Running HT40 temperature calibration\n");
1454 R1 = (s32)le32_to_cpu(priv->card_alive_init.therm_r1[1]); 1454 R1 = (s32)le32_to_cpu(il->card_alive_init.therm_r1[1]);
1455 R2 = (s32)le32_to_cpu(priv->card_alive_init.therm_r2[1]); 1455 R2 = (s32)le32_to_cpu(il->card_alive_init.therm_r2[1]);
1456 R3 = (s32)le32_to_cpu(priv->card_alive_init.therm_r3[1]); 1456 R3 = (s32)le32_to_cpu(il->card_alive_init.therm_r3[1]);
1457 R4 = le32_to_cpu(priv->card_alive_init.therm_r4[1]); 1457 R4 = le32_to_cpu(il->card_alive_init.therm_r4[1]);
1458 } else { 1458 } else {
1459 IL_DEBUG_TEMP(priv, "Running temperature calibration\n"); 1459 IL_DEBUG_TEMP(il, "Running temperature calibration\n");
1460 R1 = (s32)le32_to_cpu(priv->card_alive_init.therm_r1[0]); 1460 R1 = (s32)le32_to_cpu(il->card_alive_init.therm_r1[0]);
1461 R2 = (s32)le32_to_cpu(priv->card_alive_init.therm_r2[0]); 1461 R2 = (s32)le32_to_cpu(il->card_alive_init.therm_r2[0]);
1462 R3 = (s32)le32_to_cpu(priv->card_alive_init.therm_r3[0]); 1462 R3 = (s32)le32_to_cpu(il->card_alive_init.therm_r3[0]);
1463 R4 = le32_to_cpu(priv->card_alive_init.therm_r4[0]); 1463 R4 = le32_to_cpu(il->card_alive_init.therm_r4[0]);
1464 } 1464 }
1465 1465
1466 /* 1466 /*
@@ -1470,16 +1470,16 @@ static int il4965_hw_get_temperature(struct il_priv *priv)
1470 * with an updated temperature, use R4 provided to us in the 1470 * with an updated temperature, use R4 provided to us in the
1471 * "initialize" ALIVE response. 1471 * "initialize" ALIVE response.
1472 */ 1472 */
1473 if (!test_bit(STATUS_TEMPERATURE, &priv->status)) 1473 if (!test_bit(STATUS_TEMPERATURE, &il->status))
1474 vt = sign_extend32(R4, 23); 1474 vt = sign_extend32(R4, 23);
1475 else 1475 else
1476 vt = sign_extend32(le32_to_cpu(priv->_4965.statistics. 1476 vt = sign_extend32(le32_to_cpu(il->_4965.statistics.
1477 general.common.temperature), 23); 1477 general.common.temperature), 23);
1478 1478
1479 IL_DEBUG_TEMP(priv, "Calib values R[1-3]: %d %d %d R4: %d\n", R1, R2, R3, vt); 1479 IL_DEBUG_TEMP(il, "Calib values R[1-3]: %d %d %d R4: %d\n", R1, R2, R3, vt);
1480 1480
1481 if (R3 == R1) { 1481 if (R3 == R1) {
1482 IL_ERR(priv, "Calibration conflict R1 == R3\n"); 1482 IL_ERR(il, "Calibration conflict R1 == R3\n");
1483 return -1; 1483 return -1;
1484 } 1484 }
1485 1485
@@ -1489,7 +1489,7 @@ static int il4965_hw_get_temperature(struct il_priv *priv)
1489 temperature /= (R3 - R1); 1489 temperature /= (R3 - R1);
1490 temperature = (temperature * 97) / 100 + TEMPERATURE_CALIB_KELVIN_OFFSET; 1490 temperature = (temperature * 97) / 100 + TEMPERATURE_CALIB_KELVIN_OFFSET;
1491 1491
1492 IL_DEBUG_TEMP(priv, "Calibrated temperature: %dK, %dC\n", 1492 IL_DEBUG_TEMP(il, "Calibrated temperature: %dK, %dC\n",
1493 temperature, KELVIN_TO_CELSIUS(temperature)); 1493 temperature, KELVIN_TO_CELSIUS(temperature));
1494 1494
1495 return temperature; 1495 return temperature;
@@ -1504,66 +1504,66 @@ static int il4965_hw_get_temperature(struct il_priv *priv)
1504 * If the temperature changed has changed sufficiently, then a recalibration 1504 * If the temperature changed has changed sufficiently, then a recalibration
1505 * is needed. 1505 * is needed.
1506 * 1506 *
1507 * Assumes caller will replace priv->last_temperature once calibration 1507 * Assumes caller will replace il->last_temperature once calibration
1508 * executed. 1508 * executed.
1509 */ 1509 */
1510static int il4965_is_temp_calib_needed(struct il_priv *priv) 1510static int il4965_is_temp_calib_needed(struct il_priv *il)
1511{ 1511{
1512 int temp_diff; 1512 int temp_diff;
1513 1513
1514 if (!test_bit(STATUS_STATISTICS, &priv->status)) { 1514 if (!test_bit(STATUS_STATISTICS, &il->status)) {
1515 IL_DEBUG_TEMP(priv, "Temperature not updated -- no statistics.\n"); 1515 IL_DEBUG_TEMP(il, "Temperature not updated -- no statistics.\n");
1516 return 0; 1516 return 0;
1517 } 1517 }
1518 1518
1519 temp_diff = priv->temperature - priv->last_temperature; 1519 temp_diff = il->temperature - il->last_temperature;
1520 1520
1521 /* get absolute value */ 1521 /* get absolute value */
1522 if (temp_diff < 0) { 1522 if (temp_diff < 0) {
1523 IL_DEBUG_POWER(priv, "Getting cooler, delta %d\n", temp_diff); 1523 IL_DEBUG_POWER(il, "Getting cooler, delta %d\n", temp_diff);
1524 temp_diff = -temp_diff; 1524 temp_diff = -temp_diff;
1525 } else if (temp_diff == 0) 1525 } else if (temp_diff == 0)
1526 IL_DEBUG_POWER(priv, "Temperature unchanged\n"); 1526 IL_DEBUG_POWER(il, "Temperature unchanged\n");
1527 else 1527 else
1528 IL_DEBUG_POWER(priv, "Getting warmer, delta %d\n", temp_diff); 1528 IL_DEBUG_POWER(il, "Getting warmer, delta %d\n", temp_diff);
1529 1529
1530 if (temp_diff < IL_TEMPERATURE_THRESHOLD) { 1530 if (temp_diff < IL_TEMPERATURE_THRESHOLD) {
1531 IL_DEBUG_POWER(priv, " => thermal txpower calib not needed\n"); 1531 IL_DEBUG_POWER(il, " => thermal txpower calib not needed\n");
1532 return 0; 1532 return 0;
1533 } 1533 }
1534 1534
1535 IL_DEBUG_POWER(priv, " => thermal txpower calib needed\n"); 1535 IL_DEBUG_POWER(il, " => thermal txpower calib needed\n");
1536 1536
1537 return 1; 1537 return 1;
1538} 1538}
1539 1539
1540static void il4965_temperature_calib(struct il_priv *priv) 1540static void il4965_temperature_calib(struct il_priv *il)
1541{ 1541{
1542 s32 temp; 1542 s32 temp;
1543 1543
1544 temp = il4965_hw_get_temperature(priv); 1544 temp = il4965_hw_get_temperature(il);
1545 if (IL_TX_POWER_TEMPERATURE_OUT_OF_RANGE(temp)) 1545 if (IL_TX_POWER_TEMPERATURE_OUT_OF_RANGE(temp))
1546 return; 1546 return;
1547 1547
1548 if (priv->temperature != temp) { 1548 if (il->temperature != temp) {
1549 if (priv->temperature) 1549 if (il->temperature)
1550 IL_DEBUG_TEMP(priv, "Temperature changed " 1550 IL_DEBUG_TEMP(il, "Temperature changed "
1551 "from %dC to %dC\n", 1551 "from %dC to %dC\n",
1552 KELVIN_TO_CELSIUS(priv->temperature), 1552 KELVIN_TO_CELSIUS(il->temperature),
1553 KELVIN_TO_CELSIUS(temp)); 1553 KELVIN_TO_CELSIUS(temp));
1554 else 1554 else
1555 IL_DEBUG_TEMP(priv, "Temperature " 1555 IL_DEBUG_TEMP(il, "Temperature "
1556 "initialized to %dC\n", 1556 "initialized to %dC\n",
1557 KELVIN_TO_CELSIUS(temp)); 1557 KELVIN_TO_CELSIUS(temp));
1558 } 1558 }
1559 1559
1560 priv->temperature = temp; 1560 il->temperature = temp;
1561 set_bit(STATUS_TEMPERATURE, &priv->status); 1561 set_bit(STATUS_TEMPERATURE, &il->status);
1562 1562
1563 if (!priv->disable_tx_power_cal && 1563 if (!il->disable_tx_power_cal &&
1564 unlikely(!test_bit(STATUS_SCANNING, &priv->status)) && 1564 unlikely(!test_bit(STATUS_SCANNING, &il->status)) &&
1565 il4965_is_temp_calib_needed(priv)) 1565 il4965_is_temp_calib_needed(il))
1566 queue_work(priv->workqueue, &priv->txpower_work); 1566 queue_work(il->workqueue, &il->txpower_work);
1567} 1567}
1568 1568
1569static u16 il4965_get_hcmd_size(u8 cmd_id, u16 len) 1569static u16 il4965_get_hcmd_size(u8 cmd_id, u16 len)
@@ -1604,7 +1604,7 @@ static inline u32 il4965_get_scd_ssn(struct il4965_tx_resp *tx_resp)
1604/** 1604/**
1605 * il4965_tx_status_reply_tx - Handle Tx response for frames in aggregation queue 1605 * il4965_tx_status_reply_tx - Handle Tx response for frames in aggregation queue
1606 */ 1606 */
1607static int il4965_tx_status_reply_tx(struct il_priv *priv, 1607static int il4965_tx_status_reply_tx(struct il_priv *il,
1608 struct il_ht_agg *agg, 1608 struct il_ht_agg *agg,
1609 struct il4965_tx_resp *tx_resp, 1609 struct il4965_tx_resp *tx_resp,
1610 int txq_id, u16 start_idx) 1610 int txq_id, u16 start_idx)
@@ -1617,7 +1617,7 @@ static int il4965_tx_status_reply_tx(struct il_priv *priv,
1617 int i, sh, idx; 1617 int i, sh, idx;
1618 u16 seq; 1618 u16 seq;
1619 if (agg->wait_for_ba) 1619 if (agg->wait_for_ba)
1620 IL_DEBUG_TX_REPLY(priv, "got tx response w/o block-ack\n"); 1620 IL_DEBUG_TX_REPLY(il, "got tx response w/o block-ack\n");
1621 1621
1622 agg->frame_count = tx_resp->frame_count; 1622 agg->frame_count = tx_resp->frame_count;
1623 agg->start_idx = start_idx; 1623 agg->start_idx = start_idx;
@@ -1630,18 +1630,18 @@ static int il4965_tx_status_reply_tx(struct il_priv *priv,
1630 status = le16_to_cpu(frame_status[0].status); 1630 status = le16_to_cpu(frame_status[0].status);
1631 idx = start_idx; 1631 idx = start_idx;
1632 1632
1633 IL_DEBUG_TX_REPLY(priv, "FrameCnt = %d, StartIdx=%d idx=%d\n", 1633 IL_DEBUG_TX_REPLY(il, "FrameCnt = %d, StartIdx=%d idx=%d\n",
1634 agg->frame_count, agg->start_idx, idx); 1634 agg->frame_count, agg->start_idx, idx);
1635 1635
1636 info = IEEE80211_SKB_CB(priv->txq[txq_id].txb[idx].skb); 1636 info = IEEE80211_SKB_CB(il->txq[txq_id].txb[idx].skb);
1637 info->status.rates[0].count = tx_resp->failure_frame + 1; 1637 info->status.rates[0].count = tx_resp->failure_frame + 1;
1638 info->flags &= ~IEEE80211_TX_CTL_AMPDU; 1638 info->flags &= ~IEEE80211_TX_CTL_AMPDU;
1639 info->flags |= il4965_tx_status_to_mac80211(status); 1639 info->flags |= il4965_tx_status_to_mac80211(status);
1640 il4965_hwrate_to_tx_control(priv, rate_n_flags, info); 1640 il4965_hwrate_to_tx_control(il, rate_n_flags, info);
1641 1641
1642 IL_DEBUG_TX_REPLY(priv, "1 Frame 0x%x failure :%d\n", 1642 IL_DEBUG_TX_REPLY(il, "1 Frame 0x%x failure :%d\n",
1643 status & 0xff, tx_resp->failure_frame); 1643 status & 0xff, tx_resp->failure_frame);
1644 IL_DEBUG_TX_REPLY(priv, "Rate Info rate_n_flags=%x\n", rate_n_flags); 1644 IL_DEBUG_TX_REPLY(il, "Rate Info rate_n_flags=%x\n", rate_n_flags);
1645 1645
1646 agg->wait_for_ba = 0; 1646 agg->wait_for_ba = 0;
1647 } else { 1647 } else {
@@ -1661,12 +1661,12 @@ static int il4965_tx_status_reply_tx(struct il_priv *priv,
1661 AGG_TX_STATE_ABORT_MSK)) 1661 AGG_TX_STATE_ABORT_MSK))
1662 continue; 1662 continue;
1663 1663
1664 IL_DEBUG_TX_REPLY(priv, "FrameCnt = %d, txq_id=%d idx=%d\n", 1664 IL_DEBUG_TX_REPLY(il, "FrameCnt = %d, txq_id=%d idx=%d\n",
1665 agg->frame_count, txq_id, idx); 1665 agg->frame_count, txq_id, idx);
1666 1666
1667 hdr = il_tx_queue_get_hdr(priv, txq_id, idx); 1667 hdr = il_tx_queue_get_hdr(il, txq_id, idx);
1668 if (!hdr) { 1668 if (!hdr) {
1669 IL_ERR(priv, 1669 IL_ERR(il,
1670 "BUG_ON idx doesn't point to valid skb" 1670 "BUG_ON idx doesn't point to valid skb"
1671 " idx=%d, txq_id=%d\n", idx, txq_id); 1671 " idx=%d, txq_id=%d\n", idx, txq_id);
1672 return -1; 1672 return -1;
@@ -1674,14 +1674,14 @@ static int il4965_tx_status_reply_tx(struct il_priv *priv,
1674 1674
1675 sc = le16_to_cpu(hdr->seq_ctrl); 1675 sc = le16_to_cpu(hdr->seq_ctrl);
1676 if (idx != (SEQ_TO_SN(sc) & 0xff)) { 1676 if (idx != (SEQ_TO_SN(sc) & 0xff)) {
1677 IL_ERR(priv, 1677 IL_ERR(il,
1678 "BUG_ON idx doesn't match seq control" 1678 "BUG_ON idx doesn't match seq control"
1679 " idx=%d, seq_idx=%d, seq=%d\n", 1679 " idx=%d, seq_idx=%d, seq=%d\n",
1680 idx, SEQ_TO_SN(sc), hdr->seq_ctrl); 1680 idx, SEQ_TO_SN(sc), hdr->seq_ctrl);
1681 return -1; 1681 return -1;
1682 } 1682 }
1683 1683
1684 IL_DEBUG_TX_REPLY(priv, "AGG Frame i=%d idx %d seq=%d\n", 1684 IL_DEBUG_TX_REPLY(il, "AGG Frame i=%d idx %d seq=%d\n",
1685 i, idx, SEQ_TO_SN(sc)); 1685 i, idx, SEQ_TO_SN(sc));
1686 1686
1687 sh = idx - start; 1687 sh = idx - start;
@@ -1699,13 +1699,13 @@ static int il4965_tx_status_reply_tx(struct il_priv *priv,
1699 sh = 0; 1699 sh = 0;
1700 } 1700 }
1701 bitmap |= 1ULL << sh; 1701 bitmap |= 1ULL << sh;
1702 IL_DEBUG_TX_REPLY(priv, "start=%d bitmap=0x%llx\n", 1702 IL_DEBUG_TX_REPLY(il, "start=%d bitmap=0x%llx\n",
1703 start, (unsigned long long)bitmap); 1703 start, (unsigned long long)bitmap);
1704 } 1704 }
1705 1705
1706 agg->bitmap = bitmap; 1706 agg->bitmap = bitmap;
1707 agg->start_idx = start; 1707 agg->start_idx = start;
1708 IL_DEBUG_TX_REPLY(priv, "Frames %d start_idx=%d bitmap=0x%llx\n", 1708 IL_DEBUG_TX_REPLY(il, "Frames %d start_idx=%d bitmap=0x%llx\n",
1709 agg->frame_count, agg->start_idx, 1709 agg->frame_count, agg->start_idx,
1710 (unsigned long long)agg->bitmap); 1710 (unsigned long long)agg->bitmap);
1711 1711
@@ -1715,30 +1715,30 @@ static int il4965_tx_status_reply_tx(struct il_priv *priv,
1715 return 0; 1715 return 0;
1716} 1716}
1717 1717
1718static u8 il4965_find_station(struct il_priv *priv, const u8 *addr) 1718static u8 il4965_find_station(struct il_priv *il, const u8 *addr)
1719{ 1719{
1720 int i; 1720 int i;
1721 int start = 0; 1721 int start = 0;
1722 int ret = IL_INVALID_STATION; 1722 int ret = IL_INVALID_STATION;
1723 unsigned long flags; 1723 unsigned long flags;
1724 1724
1725 if ((priv->iw_mode == NL80211_IFTYPE_ADHOC)) 1725 if ((il->iw_mode == NL80211_IFTYPE_ADHOC))
1726 start = IL_STA_ID; 1726 start = IL_STA_ID;
1727 1727
1728 if (is_broadcast_ether_addr(addr)) 1728 if (is_broadcast_ether_addr(addr))
1729 return priv->contexts[IL_RXON_CTX_BSS].bcast_sta_id; 1729 return il->contexts[IL_RXON_CTX_BSS].bcast_sta_id;
1730 1730
1731 spin_lock_irqsave(&priv->sta_lock, flags); 1731 spin_lock_irqsave(&il->sta_lock, flags);
1732 for (i = start; i < priv->hw_params.max_stations; i++) 1732 for (i = start; i < il->hw_params.max_stations; i++)
1733 if (priv->stations[i].used && 1733 if (il->stations[i].used &&
1734 (!compare_ether_addr(priv->stations[i].sta.sta.addr, 1734 (!compare_ether_addr(il->stations[i].sta.sta.addr,
1735 addr))) { 1735 addr))) {
1736 ret = i; 1736 ret = i;
1737 goto out; 1737 goto out;
1738 } 1738 }
1739 1739
1740 IL_DEBUG_ASSOC_LIMIT(priv, "can not find STA %pM total %d\n", 1740 IL_DEBUG_ASSOC_LIMIT(il, "can not find STA %pM total %d\n",
1741 addr, priv->num_stations); 1741 addr, il->num_stations);
1742 1742
1743 out: 1743 out:
1744 /* 1744 /*
@@ -1747,38 +1747,38 @@ static u8 il4965_find_station(struct il_priv *priv, const u8 *addr)
1747 * station 1747 * station
1748 */ 1748 */
1749 if (ret != IL_INVALID_STATION && 1749 if (ret != IL_INVALID_STATION &&
1750 (!(priv->stations[ret].used & IL_STA_UCODE_ACTIVE) || 1750 (!(il->stations[ret].used & IL_STA_UCODE_ACTIVE) ||
1751 ((priv->stations[ret].used & IL_STA_UCODE_ACTIVE) && 1751 ((il->stations[ret].used & IL_STA_UCODE_ACTIVE) &&
1752 (priv->stations[ret].used & IL_STA_UCODE_INPROGRESS)))) { 1752 (il->stations[ret].used & IL_STA_UCODE_INPROGRESS)))) {
1753 IL_ERR(priv, "Requested station info for sta %d before ready.\n", 1753 IL_ERR(il, "Requested station info for sta %d before ready.\n",
1754 ret); 1754 ret);
1755 ret = IL_INVALID_STATION; 1755 ret = IL_INVALID_STATION;
1756 } 1756 }
1757 spin_unlock_irqrestore(&priv->sta_lock, flags); 1757 spin_unlock_irqrestore(&il->sta_lock, flags);
1758 return ret; 1758 return ret;
1759} 1759}
1760 1760
1761static int il4965_get_ra_sta_id(struct il_priv *priv, struct ieee80211_hdr *hdr) 1761static int il4965_get_ra_sta_id(struct il_priv *il, struct ieee80211_hdr *hdr)
1762{ 1762{
1763 if (priv->iw_mode == NL80211_IFTYPE_STATION) { 1763 if (il->iw_mode == NL80211_IFTYPE_STATION) {
1764 return IL_AP_ID; 1764 return IL_AP_ID;
1765 } else { 1765 } else {
1766 u8 *da = ieee80211_get_DA(hdr); 1766 u8 *da = ieee80211_get_DA(hdr);
1767 return il4965_find_station(priv, da); 1767 return il4965_find_station(il, da);
1768 } 1768 }
1769} 1769}
1770 1770
1771/** 1771/**
1772 * il4965_rx_reply_tx - Handle standard (non-aggregation) Tx response 1772 * il4965_rx_reply_tx - Handle standard (non-aggregation) Tx response
1773 */ 1773 */
1774static void il4965_rx_reply_tx(struct il_priv *priv, 1774static void il4965_rx_reply_tx(struct il_priv *il,
1775 struct il_rx_mem_buffer *rxb) 1775 struct il_rx_mem_buffer *rxb)
1776{ 1776{
1777 struct il_rx_packet *pkt = rxb_addr(rxb); 1777 struct il_rx_packet *pkt = rxb_addr(rxb);
1778 u16 sequence = le16_to_cpu(pkt->hdr.sequence); 1778 u16 sequence = le16_to_cpu(pkt->hdr.sequence);
1779 int txq_id = SEQ_TO_QUEUE(sequence); 1779 int txq_id = SEQ_TO_QUEUE(sequence);
1780 int index = SEQ_TO_INDEX(sequence); 1780 int index = SEQ_TO_INDEX(sequence);
1781 struct il_tx_queue *txq = &priv->txq[txq_id]; 1781 struct il_tx_queue *txq = &il->txq[txq_id];
1782 struct ieee80211_hdr *hdr; 1782 struct ieee80211_hdr *hdr;
1783 struct ieee80211_tx_info *info; 1783 struct ieee80211_tx_info *info;
1784 struct il4965_tx_resp *tx_resp = (void *)&pkt->u.raw[0]; 1784 struct il4965_tx_resp *tx_resp = (void *)&pkt->u.raw[0];
@@ -1790,7 +1790,7 @@ static void il4965_rx_reply_tx(struct il_priv *priv,
1790 unsigned long flags; 1790 unsigned long flags;
1791 1791
1792 if ((index >= txq->q.n_bd) || (il_queue_used(&txq->q, index) == 0)) { 1792 if ((index >= txq->q.n_bd) || (il_queue_used(&txq->q, index) == 0)) {
1793 IL_ERR(priv, "Read index for DMA queue txq_id (%d) index %d " 1793 IL_ERR(il, "Read index for DMA queue txq_id (%d) index %d "
1794 "is out of range [0-%d] %d %d\n", txq_id, 1794 "is out of range [0-%d] %d %d\n", txq_id,
1795 index, txq->q.n_bd, txq->q.write_ptr, 1795 index, txq->q.n_bd, txq->q.write_ptr,
1796 txq->q.read_ptr); 1796 txq->q.read_ptr);
@@ -1801,27 +1801,27 @@ static void il4965_rx_reply_tx(struct il_priv *priv,
1801 info = IEEE80211_SKB_CB(txq->txb[txq->q.read_ptr].skb); 1801 info = IEEE80211_SKB_CB(txq->txb[txq->q.read_ptr].skb);
1802 memset(&info->status, 0, sizeof(info->status)); 1802 memset(&info->status, 0, sizeof(info->status));
1803 1803
1804 hdr = il_tx_queue_get_hdr(priv, txq_id, index); 1804 hdr = il_tx_queue_get_hdr(il, txq_id, index);
1805 if (ieee80211_is_data_qos(hdr->frame_control)) { 1805 if (ieee80211_is_data_qos(hdr->frame_control)) {
1806 qc = ieee80211_get_qos_ctl(hdr); 1806 qc = ieee80211_get_qos_ctl(hdr);
1807 tid = qc[0] & 0xf; 1807 tid = qc[0] & 0xf;
1808 } 1808 }
1809 1809
1810 sta_id = il4965_get_ra_sta_id(priv, hdr); 1810 sta_id = il4965_get_ra_sta_id(il, hdr);
1811 if (txq->sched_retry && unlikely(sta_id == IL_INVALID_STATION)) { 1811 if (txq->sched_retry && unlikely(sta_id == IL_INVALID_STATION)) {
1812 IL_ERR(priv, "Station not known\n"); 1812 IL_ERR(il, "Station not known\n");
1813 return; 1813 return;
1814 } 1814 }
1815 1815
1816 spin_lock_irqsave(&priv->sta_lock, flags); 1816 spin_lock_irqsave(&il->sta_lock, flags);
1817 if (txq->sched_retry) { 1817 if (txq->sched_retry) {
1818 const u32 scd_ssn = il4965_get_scd_ssn(tx_resp); 1818 const u32 scd_ssn = il4965_get_scd_ssn(tx_resp);
1819 struct il_ht_agg *agg = NULL; 1819 struct il_ht_agg *agg = NULL;
1820 WARN_ON(!qc); 1820 WARN_ON(!qc);
1821 1821
1822 agg = &priv->stations[sta_id].tid[tid].agg; 1822 agg = &il->stations[sta_id].tid[tid].agg;
1823 1823
1824 il4965_tx_status_reply_tx(priv, agg, tx_resp, txq_id, index); 1824 il4965_tx_status_reply_tx(il, agg, tx_resp, txq_id, index);
1825 1825
1826 /* check if BAR is needed */ 1826 /* check if BAR is needed */
1827 if ((tx_resp->frame_count == 1) && !il4965_is_tx_success(status)) 1827 if ((tx_resp->frame_count == 1) && !il4965_is_tx_success(status))
@@ -1830,51 +1830,51 @@ static void il4965_rx_reply_tx(struct il_priv *priv,
1830 if (txq->q.read_ptr != (scd_ssn & 0xff)) { 1830 if (txq->q.read_ptr != (scd_ssn & 0xff)) {
1831 index = il_queue_dec_wrap(scd_ssn & 0xff, 1831 index = il_queue_dec_wrap(scd_ssn & 0xff,
1832 txq->q.n_bd); 1832 txq->q.n_bd);
1833 IL_DEBUG_TX_REPLY(priv, "Retry scheduler reclaim scd_ssn " 1833 IL_DEBUG_TX_REPLY(il, "Retry scheduler reclaim scd_ssn "
1834 "%d index %d\n", scd_ssn , index); 1834 "%d index %d\n", scd_ssn , index);
1835 freed = il4965_tx_queue_reclaim(priv, txq_id, index); 1835 freed = il4965_tx_queue_reclaim(il, txq_id, index);
1836 if (qc) 1836 if (qc)
1837 il4965_free_tfds_in_queue(priv, sta_id, 1837 il4965_free_tfds_in_queue(il, sta_id,
1838 tid, freed); 1838 tid, freed);
1839 1839
1840 if (priv->mac80211_registered && 1840 if (il->mac80211_registered &&
1841 (il_queue_space(&txq->q) > txq->q.low_mark) 1841 (il_queue_space(&txq->q) > txq->q.low_mark)
1842 && (agg->state != IL_EMPTYING_HW_QUEUE_DELBA)) 1842 && (agg->state != IL_EMPTYING_HW_QUEUE_DELBA))
1843 il_wake_queue(priv, txq); 1843 il_wake_queue(il, txq);
1844 } 1844 }
1845 } else { 1845 } else {
1846 info->status.rates[0].count = tx_resp->failure_frame + 1; 1846 info->status.rates[0].count = tx_resp->failure_frame + 1;
1847 info->flags |= il4965_tx_status_to_mac80211(status); 1847 info->flags |= il4965_tx_status_to_mac80211(status);
1848 il4965_hwrate_to_tx_control(priv, 1848 il4965_hwrate_to_tx_control(il,
1849 le32_to_cpu(tx_resp->rate_n_flags), 1849 le32_to_cpu(tx_resp->rate_n_flags),
1850 info); 1850 info);
1851 1851
1852 IL_DEBUG_TX_REPLY(priv, "TXQ %d status %s (0x%08x) " 1852 IL_DEBUG_TX_REPLY(il, "TXQ %d status %s (0x%08x) "
1853 "rate_n_flags 0x%x retries %d\n", 1853 "rate_n_flags 0x%x retries %d\n",
1854 txq_id, 1854 txq_id,
1855 il4965_get_tx_fail_reason(status), status, 1855 il4965_get_tx_fail_reason(status), status,
1856 le32_to_cpu(tx_resp->rate_n_flags), 1856 le32_to_cpu(tx_resp->rate_n_flags),
1857 tx_resp->failure_frame); 1857 tx_resp->failure_frame);
1858 1858
1859 freed = il4965_tx_queue_reclaim(priv, txq_id, index); 1859 freed = il4965_tx_queue_reclaim(il, txq_id, index);
1860 if (qc && likely(sta_id != IL_INVALID_STATION)) 1860 if (qc && likely(sta_id != IL_INVALID_STATION))
1861 il4965_free_tfds_in_queue(priv, sta_id, tid, freed); 1861 il4965_free_tfds_in_queue(il, sta_id, tid, freed);
1862 else if (sta_id == IL_INVALID_STATION) 1862 else if (sta_id == IL_INVALID_STATION)
1863 IL_DEBUG_TX_REPLY(priv, "Station not known\n"); 1863 IL_DEBUG_TX_REPLY(il, "Station not known\n");
1864 1864
1865 if (priv->mac80211_registered && 1865 if (il->mac80211_registered &&
1866 (il_queue_space(&txq->q) > txq->q.low_mark)) 1866 (il_queue_space(&txq->q) > txq->q.low_mark))
1867 il_wake_queue(priv, txq); 1867 il_wake_queue(il, txq);
1868 } 1868 }
1869 if (qc && likely(sta_id != IL_INVALID_STATION)) 1869 if (qc && likely(sta_id != IL_INVALID_STATION))
1870 il4965_txq_check_empty(priv, sta_id, tid, txq_id); 1870 il4965_txq_check_empty(il, sta_id, tid, txq_id);
1871 1871
1872 il4965_check_abort_status(priv, tx_resp->frame_count, status); 1872 il4965_check_abort_status(il, tx_resp->frame_count, status);
1873 1873
1874 spin_unlock_irqrestore(&priv->sta_lock, flags); 1874 spin_unlock_irqrestore(&il->sta_lock, flags);
1875} 1875}
1876 1876
1877static void il4965_rx_beacon_notif(struct il_priv *priv, 1877static void il4965_rx_beacon_notif(struct il_priv *il,
1878 struct il_rx_mem_buffer *rxb) 1878 struct il_rx_mem_buffer *rxb)
1879{ 1879{
1880 struct il_rx_packet *pkt = rxb_addr(rxb); 1880 struct il_rx_packet *pkt = rxb_addr(rxb);
@@ -1882,7 +1882,7 @@ static void il4965_rx_beacon_notif(struct il_priv *priv,
1882 u8 rate __maybe_unused = 1882 u8 rate __maybe_unused =
1883 il4965_hw_get_rate(beacon->beacon_notify_hdr.rate_n_flags); 1883 il4965_hw_get_rate(beacon->beacon_notify_hdr.rate_n_flags);
1884 1884
1885 IL_DEBUG_RX(priv, "beacon status %#x, retries:%d ibssmgr:%d " 1885 IL_DEBUG_RX(il, "beacon status %#x, retries:%d ibssmgr:%d "
1886 "tsf:0x%.8x%.8x rate:%d\n", 1886 "tsf:0x%.8x%.8x rate:%d\n",
1887 le32_to_cpu(beacon->beacon_notify_hdr.u.status) & TX_STATUS_MSK, 1887 le32_to_cpu(beacon->beacon_notify_hdr.u.status) & TX_STATUS_MSK,
1888 beacon->beacon_notify_hdr.failure_frame, 1888 beacon->beacon_notify_hdr.failure_frame,
@@ -1890,17 +1890,17 @@ static void il4965_rx_beacon_notif(struct il_priv *priv,
1890 le32_to_cpu(beacon->high_tsf), 1890 le32_to_cpu(beacon->high_tsf),
1891 le32_to_cpu(beacon->low_tsf), rate); 1891 le32_to_cpu(beacon->low_tsf), rate);
1892 1892
1893 priv->ibss_manager = le32_to_cpu(beacon->ibss_mgr_status); 1893 il->ibss_manager = le32_to_cpu(beacon->ibss_mgr_status);
1894} 1894}
1895 1895
1896/* Set up 4965-specific Rx frame reply handlers */ 1896/* Set up 4965-specific Rx frame reply handlers */
1897static void il4965_rx_handler_setup(struct il_priv *priv) 1897static void il4965_rx_handler_setup(struct il_priv *il)
1898{ 1898{
1899 /* Legacy Rx frames */ 1899 /* Legacy Rx frames */
1900 priv->rx_handlers[REPLY_RX] = il4965_rx_reply_rx; 1900 il->rx_handlers[REPLY_RX] = il4965_rx_reply_rx;
1901 /* Tx response */ 1901 /* Tx response */
1902 priv->rx_handlers[REPLY_TX] = il4965_rx_reply_tx; 1902 il->rx_handlers[REPLY_TX] = il4965_rx_reply_tx;
1903 priv->rx_handlers[BEACON_NOTIFICATION] = il4965_rx_beacon_notif; 1903 il->rx_handlers[BEACON_NOTIFICATION] = il4965_rx_beacon_notif;
1904} 1904}
1905 1905
1906static struct il_hcmd_ops il4965_hcmd = { 1906static struct il_hcmd_ops il4965_hcmd = {
@@ -1909,53 +1909,53 @@ static struct il_hcmd_ops il4965_hcmd = {
1909 .set_rxon_chain = il4965_set_rxon_chain, 1909 .set_rxon_chain = il4965_set_rxon_chain,
1910}; 1910};
1911 1911
1912static void il4965_post_scan(struct il_priv *priv) 1912static void il4965_post_scan(struct il_priv *il)
1913{ 1913{
1914 struct il_rxon_context *ctx = &priv->contexts[IL_RXON_CTX_BSS]; 1914 struct il_rxon_context *ctx = &il->contexts[IL_RXON_CTX_BSS];
1915 1915
1916 /* 1916 /*
1917 * Since setting the RXON may have been deferred while 1917 * Since setting the RXON may have been deferred while
1918 * performing the scan, fire one off if needed 1918 * performing the scan, fire one off if needed
1919 */ 1919 */
1920 if (memcmp(&ctx->staging, &ctx->active, sizeof(ctx->staging))) 1920 if (memcmp(&ctx->staging, &ctx->active, sizeof(ctx->staging)))
1921 il_commit_rxon(priv, ctx); 1921 il_commit_rxon(il, ctx);
1922} 1922}
1923 1923
1924static void il4965_post_associate(struct il_priv *priv) 1924static void il4965_post_associate(struct il_priv *il)
1925{ 1925{
1926 struct il_rxon_context *ctx = &priv->contexts[IL_RXON_CTX_BSS]; 1926 struct il_rxon_context *ctx = &il->contexts[IL_RXON_CTX_BSS];
1927 struct ieee80211_vif *vif = ctx->vif; 1927 struct ieee80211_vif *vif = ctx->vif;
1928 struct ieee80211_conf *conf = NULL; 1928 struct ieee80211_conf *conf = NULL;
1929 int ret = 0; 1929 int ret = 0;
1930 1930
1931 if (!vif || !priv->is_open) 1931 if (!vif || !il->is_open)
1932 return; 1932 return;
1933 1933
1934 if (test_bit(STATUS_EXIT_PENDING, &priv->status)) 1934 if (test_bit(STATUS_EXIT_PENDING, &il->status))
1935 return; 1935 return;
1936 1936
1937 il_scan_cancel_timeout(priv, 200); 1937 il_scan_cancel_timeout(il, 200);
1938 1938
1939 conf = il_ieee80211_get_hw_conf(priv->hw); 1939 conf = il_ieee80211_get_hw_conf(il->hw);
1940 1940
1941 ctx->staging.filter_flags &= ~RXON_FILTER_ASSOC_MSK; 1941 ctx->staging.filter_flags &= ~RXON_FILTER_ASSOC_MSK;
1942 il_commit_rxon(priv, ctx); 1942 il_commit_rxon(il, ctx);
1943 1943
1944 ret = il_send_rxon_timing(priv, ctx); 1944 ret = il_send_rxon_timing(il, ctx);
1945 if (ret) 1945 if (ret)
1946 IL_WARN(priv, "RXON timing - " 1946 IL_WARN(il, "RXON timing - "
1947 "Attempting to continue.\n"); 1947 "Attempting to continue.\n");
1948 1948
1949 ctx->staging.filter_flags |= RXON_FILTER_ASSOC_MSK; 1949 ctx->staging.filter_flags |= RXON_FILTER_ASSOC_MSK;
1950 1950
1951 il_set_rxon_ht(priv, &priv->current_ht_config); 1951 il_set_rxon_ht(il, &il->current_ht_config);
1952 1952
1953 if (priv->cfg->ops->hcmd->set_rxon_chain) 1953 if (il->cfg->ops->hcmd->set_rxon_chain)
1954 priv->cfg->ops->hcmd->set_rxon_chain(priv, ctx); 1954 il->cfg->ops->hcmd->set_rxon_chain(il, ctx);
1955 1955
1956 ctx->staging.assoc_id = cpu_to_le16(vif->bss_conf.aid); 1956 ctx->staging.assoc_id = cpu_to_le16(vif->bss_conf.aid);
1957 1957
1958 IL_DEBUG_ASSOC(priv, "assoc id %d beacon interval %d\n", 1958 IL_DEBUG_ASSOC(il, "assoc id %d beacon interval %d\n",
1959 vif->bss_conf.aid, vif->bss_conf.beacon_int); 1959 vif->bss_conf.aid, vif->bss_conf.beacon_int);
1960 1960
1961 if (vif->bss_conf.use_short_preamble) 1961 if (vif->bss_conf.use_short_preamble)
@@ -1970,19 +1970,19 @@ static void il4965_post_associate(struct il_priv *priv)
1970 ctx->staging.flags &= ~RXON_FLG_SHORT_SLOT_MSK; 1970 ctx->staging.flags &= ~RXON_FLG_SHORT_SLOT_MSK;
1971 } 1971 }
1972 1972
1973 il_commit_rxon(priv, ctx); 1973 il_commit_rxon(il, ctx);
1974 1974
1975 IL_DEBUG_ASSOC(priv, "Associated as %d to: %pM\n", 1975 IL_DEBUG_ASSOC(il, "Associated as %d to: %pM\n",
1976 vif->bss_conf.aid, ctx->active.bssid_addr); 1976 vif->bss_conf.aid, ctx->active.bssid_addr);
1977 1977
1978 switch (vif->type) { 1978 switch (vif->type) {
1979 case NL80211_IFTYPE_STATION: 1979 case NL80211_IFTYPE_STATION:
1980 break; 1980 break;
1981 case NL80211_IFTYPE_ADHOC: 1981 case NL80211_IFTYPE_ADHOC:
1982 il4965_send_beacon_cmd(priv); 1982 il4965_send_beacon_cmd(il);
1983 break; 1983 break;
1984 default: 1984 default:
1985 IL_ERR(priv, "%s Should not be called in %d mode\n", 1985 IL_ERR(il, "%s Should not be called in %d mode\n",
1986 __func__, vif->type); 1986 __func__, vif->type);
1987 break; 1987 break;
1988 } 1988 }
@@ -1990,23 +1990,23 @@ static void il4965_post_associate(struct il_priv *priv)
1990 /* the chain noise calibration will enabled PM upon completion 1990 /* the chain noise calibration will enabled PM upon completion
1991 * If chain noise has already been run, then we need to enable 1991 * If chain noise has already been run, then we need to enable
1992 * power management here */ 1992 * power management here */
1993 if (priv->chain_noise_data.state == IL_CHAIN_NOISE_DONE) 1993 if (il->chain_noise_data.state == IL_CHAIN_NOISE_DONE)
1994 il_power_update_mode(priv, false); 1994 il_power_update_mode(il, false);
1995 1995
1996 /* Enable Rx differential gain and sensitivity calibrations */ 1996 /* Enable Rx differential gain and sensitivity calibrations */
1997 il4965_chain_noise_reset(priv); 1997 il4965_chain_noise_reset(il);
1998 priv->start_calib = 1; 1998 il->start_calib = 1;
1999} 1999}
2000 2000
2001static void il4965_config_ap(struct il_priv *priv) 2001static void il4965_config_ap(struct il_priv *il)
2002{ 2002{
2003 struct il_rxon_context *ctx = &priv->contexts[IL_RXON_CTX_BSS]; 2003 struct il_rxon_context *ctx = &il->contexts[IL_RXON_CTX_BSS];
2004 struct ieee80211_vif *vif = ctx->vif; 2004 struct ieee80211_vif *vif = ctx->vif;
2005 int ret = 0; 2005 int ret = 0;
2006 2006
2007 lockdep_assert_held(&priv->mutex); 2007 lockdep_assert_held(&il->mutex);
2008 2008
2009 if (test_bit(STATUS_EXIT_PENDING, &priv->status)) 2009 if (test_bit(STATUS_EXIT_PENDING, &il->status))
2010 return; 2010 return;
2011 2011
2012 /* The following should be done only at AP bring up */ 2012 /* The following should be done only at AP bring up */
@@ -2014,20 +2014,20 @@ static void il4965_config_ap(struct il_priv *priv)
2014 2014
2015 /* RXON - unassoc (to set timing command) */ 2015 /* RXON - unassoc (to set timing command) */
2016 ctx->staging.filter_flags &= ~RXON_FILTER_ASSOC_MSK; 2016 ctx->staging.filter_flags &= ~RXON_FILTER_ASSOC_MSK;
2017 il_commit_rxon(priv, ctx); 2017 il_commit_rxon(il, ctx);
2018 2018
2019 /* RXON Timing */ 2019 /* RXON Timing */
2020 ret = il_send_rxon_timing(priv, ctx); 2020 ret = il_send_rxon_timing(il, ctx);
2021 if (ret) 2021 if (ret)
2022 IL_WARN(priv, "RXON timing failed - " 2022 IL_WARN(il, "RXON timing failed - "
2023 "Attempting to continue.\n"); 2023 "Attempting to continue.\n");
2024 2024
2025 /* AP has all antennas */ 2025 /* AP has all antennas */
2026 priv->chain_noise_data.active_chains = 2026 il->chain_noise_data.active_chains =
2027 priv->hw_params.valid_rx_ant; 2027 il->hw_params.valid_rx_ant;
2028 il_set_rxon_ht(priv, &priv->current_ht_config); 2028 il_set_rxon_ht(il, &il->current_ht_config);
2029 if (priv->cfg->ops->hcmd->set_rxon_chain) 2029 if (il->cfg->ops->hcmd->set_rxon_chain)
2030 priv->cfg->ops->hcmd->set_rxon_chain(priv, ctx); 2030 il->cfg->ops->hcmd->set_rxon_chain(il, ctx);
2031 2031
2032 ctx->staging.assoc_id = 0; 2032 ctx->staging.assoc_id = 0;
2033 2033
@@ -2047,12 +2047,12 @@ static void il4965_config_ap(struct il_priv *priv)
2047 ~RXON_FLG_SHORT_SLOT_MSK; 2047 ~RXON_FLG_SHORT_SLOT_MSK;
2048 } 2048 }
2049 /* need to send beacon cmd before committing assoc RXON! */ 2049 /* need to send beacon cmd before committing assoc RXON! */
2050 il4965_send_beacon_cmd(priv); 2050 il4965_send_beacon_cmd(il);
2051 /* restore RXON assoc */ 2051 /* restore RXON assoc */
2052 ctx->staging.filter_flags |= RXON_FILTER_ASSOC_MSK; 2052 ctx->staging.filter_flags |= RXON_FILTER_ASSOC_MSK;
2053 il_commit_rxon(priv, ctx); 2053 il_commit_rxon(il, ctx);
2054 } 2054 }
2055 il4965_send_beacon_cmd(priv); 2055 il4965_send_beacon_cmd(il);
2056} 2056}
2057 2057
2058static struct il_hcmd_utils_ops il4965_hcmd_utils = { 2058static struct il_hcmd_utils_ops il4965_hcmd_utils = {
diff --git a/drivers/net/wireless/iwlegacy/iwl-4965.h b/drivers/net/wireless/iwlegacy/iwl-4965.h
index 7b322168bfc5..ea2a98e3a4a2 100644
--- a/drivers/net/wireless/iwlegacy/iwl-4965.h
+++ b/drivers/net/wireless/iwlegacy/iwl-4965.h
@@ -73,75 +73,75 @@ extern struct il_mod_params il4965_mod_params;
73extern struct ieee80211_ops il4965_hw_ops; 73extern struct ieee80211_ops il4965_hw_ops;
74 74
75/* tx queue */ 75/* tx queue */
76void il4965_free_tfds_in_queue(struct il_priv *priv, 76void il4965_free_tfds_in_queue(struct il_priv *il,
77 int sta_id, int tid, int freed); 77 int sta_id, int tid, int freed);
78 78
79/* RXON */ 79/* RXON */
80void il4965_set_rxon_chain(struct il_priv *priv, 80void il4965_set_rxon_chain(struct il_priv *il,
81 struct il_rxon_context *ctx); 81 struct il_rxon_context *ctx);
82 82
83/* uCode */ 83/* uCode */
84int il4965_verify_ucode(struct il_priv *priv); 84int il4965_verify_ucode(struct il_priv *il);
85 85
86/* lib */ 86/* lib */
87void il4965_check_abort_status(struct il_priv *priv, 87void il4965_check_abort_status(struct il_priv *il,
88 u8 frame_count, u32 status); 88 u8 frame_count, u32 status);
89 89
90void il4965_rx_queue_reset(struct il_priv *priv, struct il_rx_queue *rxq); 90void il4965_rx_queue_reset(struct il_priv *il, struct il_rx_queue *rxq);
91int il4965_rx_init(struct il_priv *priv, struct il_rx_queue *rxq); 91int il4965_rx_init(struct il_priv *il, struct il_rx_queue *rxq);
92int il4965_hw_nic_init(struct il_priv *priv); 92int il4965_hw_nic_init(struct il_priv *il);
93int il4965_dump_fh(struct il_priv *priv, char **buf, bool display); 93int il4965_dump_fh(struct il_priv *il, char **buf, bool display);
94 94
95/* rx */ 95/* rx */
96void il4965_rx_queue_restock(struct il_priv *priv); 96void il4965_rx_queue_restock(struct il_priv *il);
97void il4965_rx_replenish(struct il_priv *priv); 97void il4965_rx_replenish(struct il_priv *il);
98void il4965_rx_replenish_now(struct il_priv *priv); 98void il4965_rx_replenish_now(struct il_priv *il);
99void il4965_rx_queue_free(struct il_priv *priv, struct il_rx_queue *rxq); 99void il4965_rx_queue_free(struct il_priv *il, struct il_rx_queue *rxq);
100int il4965_rxq_stop(struct il_priv *priv); 100int il4965_rxq_stop(struct il_priv *il);
101int il4965_hwrate_to_mac80211_idx(u32 rate_n_flags, enum ieee80211_band band); 101int il4965_hwrate_to_mac80211_idx(u32 rate_n_flags, enum ieee80211_band band);
102void il4965_rx_reply_rx(struct il_priv *priv, 102void il4965_rx_reply_rx(struct il_priv *il,
103 struct il_rx_mem_buffer *rxb); 103 struct il_rx_mem_buffer *rxb);
104void il4965_rx_reply_rx_phy(struct il_priv *priv, 104void il4965_rx_reply_rx_phy(struct il_priv *il,
105 struct il_rx_mem_buffer *rxb); 105 struct il_rx_mem_buffer *rxb);
106void il4965_rx_handle(struct il_priv *priv); 106void il4965_rx_handle(struct il_priv *il);
107 107
108/* tx */ 108/* tx */
109void il4965_hw_txq_free_tfd(struct il_priv *priv, struct il_tx_queue *txq); 109void il4965_hw_txq_free_tfd(struct il_priv *il, struct il_tx_queue *txq);
110int il4965_hw_txq_attach_buf_to_tfd(struct il_priv *priv, 110int il4965_hw_txq_attach_buf_to_tfd(struct il_priv *il,
111 struct il_tx_queue *txq, 111 struct il_tx_queue *txq,
112 dma_addr_t addr, u16 len, u8 reset, u8 pad); 112 dma_addr_t addr, u16 len, u8 reset, u8 pad);
113int il4965_hw_tx_queue_init(struct il_priv *priv, 113int il4965_hw_tx_queue_init(struct il_priv *il,
114 struct il_tx_queue *txq); 114 struct il_tx_queue *txq);
115void il4965_hwrate_to_tx_control(struct il_priv *priv, u32 rate_n_flags, 115void il4965_hwrate_to_tx_control(struct il_priv *il, u32 rate_n_flags,
116 struct ieee80211_tx_info *info); 116 struct ieee80211_tx_info *info);
117int il4965_tx_skb(struct il_priv *priv, struct sk_buff *skb); 117int il4965_tx_skb(struct il_priv *il, struct sk_buff *skb);
118int il4965_tx_agg_start(struct il_priv *priv, struct ieee80211_vif *vif, 118int il4965_tx_agg_start(struct il_priv *il, struct ieee80211_vif *vif,
119 struct ieee80211_sta *sta, u16 tid, u16 *ssn); 119 struct ieee80211_sta *sta, u16 tid, u16 *ssn);
120int il4965_tx_agg_stop(struct il_priv *priv, struct ieee80211_vif *vif, 120int il4965_tx_agg_stop(struct il_priv *il, struct ieee80211_vif *vif,
121 struct ieee80211_sta *sta, u16 tid); 121 struct ieee80211_sta *sta, u16 tid);
122int il4965_txq_check_empty(struct il_priv *priv, 122int il4965_txq_check_empty(struct il_priv *il,
123 int sta_id, u8 tid, int txq_id); 123 int sta_id, u8 tid, int txq_id);
124void il4965_rx_reply_compressed_ba(struct il_priv *priv, 124void il4965_rx_reply_compressed_ba(struct il_priv *il,
125 struct il_rx_mem_buffer *rxb); 125 struct il_rx_mem_buffer *rxb);
126int il4965_tx_queue_reclaim(struct il_priv *priv, int txq_id, int index); 126int il4965_tx_queue_reclaim(struct il_priv *il, int txq_id, int index);
127void il4965_hw_txq_ctx_free(struct il_priv *priv); 127void il4965_hw_txq_ctx_free(struct il_priv *il);
128int il4965_txq_ctx_alloc(struct il_priv *priv); 128int il4965_txq_ctx_alloc(struct il_priv *il);
129void il4965_txq_ctx_reset(struct il_priv *priv); 129void il4965_txq_ctx_reset(struct il_priv *il);
130void il4965_txq_ctx_stop(struct il_priv *priv); 130void il4965_txq_ctx_stop(struct il_priv *il);
131void il4965_txq_set_sched(struct il_priv *priv, u32 mask); 131void il4965_txq_set_sched(struct il_priv *il, u32 mask);
132 132
133/* 133/*
134 * Acquire priv->lock before calling this function ! 134 * Acquire il->lock before calling this function !
135 */ 135 */
136void il4965_set_wr_ptrs(struct il_priv *priv, int txq_id, u32 index); 136void il4965_set_wr_ptrs(struct il_priv *il, int txq_id, u32 index);
137/** 137/**
138 * il4965_tx_queue_set_status - (optionally) start Tx/Cmd queue 138 * il4965_tx_queue_set_status - (optionally) start Tx/Cmd queue
139 * @tx_fifo_id: Tx DMA/FIFO channel (range 0-7) that the queue will feed 139 * @tx_fifo_id: Tx DMA/FIFO channel (range 0-7) that the queue will feed
140 * @scd_retry: (1) Indicates queue will be used in aggregation mode 140 * @scd_retry: (1) Indicates queue will be used in aggregation mode
141 * 141 *
142 * NOTE: Acquire priv->lock before calling this function ! 142 * NOTE: Acquire il->lock before calling this function !
143 */ 143 */
144void il4965_tx_queue_set_status(struct il_priv *priv, 144void il4965_tx_queue_set_status(struct il_priv *il,
145 struct il_tx_queue *txq, 145 struct il_tx_queue *txq,
146 int tx_fifo_id, int scd_retry); 146 int tx_fifo_id, int scd_retry);
147 147
@@ -167,27 +167,27 @@ static inline bool il4965_is_tx_success(u32 status)
167 (status == TX_STATUS_DIRECT_DONE); 167 (status == TX_STATUS_DIRECT_DONE);
168} 168}
169 169
170u8 il4965_toggle_tx_ant(struct il_priv *priv, u8 ant_idx, u8 valid); 170u8 il4965_toggle_tx_ant(struct il_priv *il, u8 ant_idx, u8 valid);
171 171
172/* rx */ 172/* rx */
173void il4965_rx_missed_beacon_notif(struct il_priv *priv, 173void il4965_rx_missed_beacon_notif(struct il_priv *il,
174 struct il_rx_mem_buffer *rxb); 174 struct il_rx_mem_buffer *rxb);
175bool il4965_good_plcp_health(struct il_priv *priv, 175bool il4965_good_plcp_health(struct il_priv *il,
176 struct il_rx_packet *pkt); 176 struct il_rx_packet *pkt);
177void il4965_rx_statistics(struct il_priv *priv, 177void il4965_rx_statistics(struct il_priv *il,
178 struct il_rx_mem_buffer *rxb); 178 struct il_rx_mem_buffer *rxb);
179void il4965_reply_statistics(struct il_priv *priv, 179void il4965_reply_statistics(struct il_priv *il,
180 struct il_rx_mem_buffer *rxb); 180 struct il_rx_mem_buffer *rxb);
181 181
182/* scan */ 182/* scan */
183int il4965_request_scan(struct il_priv *priv, struct ieee80211_vif *vif); 183int il4965_request_scan(struct il_priv *il, struct ieee80211_vif *vif);
184 184
185/* station mgmt */ 185/* station mgmt */
186int il4965_manage_ibss_station(struct il_priv *priv, 186int il4965_manage_ibss_station(struct il_priv *il,
187 struct ieee80211_vif *vif, bool add); 187 struct ieee80211_vif *vif, bool add);
188 188
189/* hcmd */ 189/* hcmd */
190int il4965_send_beacon_cmd(struct il_priv *priv); 190int il4965_send_beacon_cmd(struct il_priv *il);
191 191
192#ifdef CONFIG_IWLWIFI_LEGACY_DEBUG 192#ifdef CONFIG_IWLWIFI_LEGACY_DEBUG
193const char *il4965_get_tx_fail_reason(u32 status); 193const char *il4965_get_tx_fail_reason(u32 status);
@@ -197,38 +197,38 @@ il4965_get_tx_fail_reason(u32 status) { return ""; }
197#endif 197#endif
198 198
199/* station management */ 199/* station management */
200int il4965_alloc_bcast_station(struct il_priv *priv, 200int il4965_alloc_bcast_station(struct il_priv *il,
201 struct il_rxon_context *ctx); 201 struct il_rxon_context *ctx);
202int il4965_add_bssid_station(struct il_priv *priv, 202int il4965_add_bssid_station(struct il_priv *il,
203 struct il_rxon_context *ctx, 203 struct il_rxon_context *ctx,
204 const u8 *addr, u8 *sta_id_r); 204 const u8 *addr, u8 *sta_id_r);
205int il4965_remove_default_wep_key(struct il_priv *priv, 205int il4965_remove_default_wep_key(struct il_priv *il,
206 struct il_rxon_context *ctx, 206 struct il_rxon_context *ctx,
207 struct ieee80211_key_conf *key); 207 struct ieee80211_key_conf *key);
208int il4965_set_default_wep_key(struct il_priv *priv, 208int il4965_set_default_wep_key(struct il_priv *il,
209 struct il_rxon_context *ctx, 209 struct il_rxon_context *ctx,
210 struct ieee80211_key_conf *key); 210 struct ieee80211_key_conf *key);
211int il4965_restore_default_wep_keys(struct il_priv *priv, 211int il4965_restore_default_wep_keys(struct il_priv *il,
212 struct il_rxon_context *ctx); 212 struct il_rxon_context *ctx);
213int il4965_set_dynamic_key(struct il_priv *priv, 213int il4965_set_dynamic_key(struct il_priv *il,
214 struct il_rxon_context *ctx, 214 struct il_rxon_context *ctx,
215 struct ieee80211_key_conf *key, u8 sta_id); 215 struct ieee80211_key_conf *key, u8 sta_id);
216int il4965_remove_dynamic_key(struct il_priv *priv, 216int il4965_remove_dynamic_key(struct il_priv *il,
217 struct il_rxon_context *ctx, 217 struct il_rxon_context *ctx,
218 struct ieee80211_key_conf *key, u8 sta_id); 218 struct ieee80211_key_conf *key, u8 sta_id);
219void il4965_update_tkip_key(struct il_priv *priv, 219void il4965_update_tkip_key(struct il_priv *il,
220 struct il_rxon_context *ctx, 220 struct il_rxon_context *ctx,
221 struct ieee80211_key_conf *keyconf, 221 struct ieee80211_key_conf *keyconf,
222 struct ieee80211_sta *sta, u32 iv32, u16 *phase1key); 222 struct ieee80211_sta *sta, u32 iv32, u16 *phase1key);
223int il4965_sta_tx_modify_enable_tid(struct il_priv *priv, 223int il4965_sta_tx_modify_enable_tid(struct il_priv *il,
224 int sta_id, int tid); 224 int sta_id, int tid);
225int il4965_sta_rx_agg_start(struct il_priv *priv, struct ieee80211_sta *sta, 225int il4965_sta_rx_agg_start(struct il_priv *il, struct ieee80211_sta *sta,
226 int tid, u16 ssn); 226 int tid, u16 ssn);
227int il4965_sta_rx_agg_stop(struct il_priv *priv, struct ieee80211_sta *sta, 227int il4965_sta_rx_agg_stop(struct il_priv *il, struct ieee80211_sta *sta,
228 int tid); 228 int tid);
229void il4965_sta_modify_sleep_tx_count(struct il_priv *priv, 229void il4965_sta_modify_sleep_tx_count(struct il_priv *il,
230 int sta_id, int cnt); 230 int sta_id, int cnt);
231int il4965_update_bcast_stations(struct il_priv *priv); 231int il4965_update_bcast_stations(struct il_priv *il);
232 232
233/* rate */ 233/* rate */
234static inline u32 il4965_ant_idx_to_flags(u8 ant_idx) 234static inline u32 il4965_ant_idx_to_flags(u8 ant_idx)
@@ -247,10 +247,10 @@ static inline __le32 il4965_hw_set_rate_n_flags(u8 rate, u32 flags)
247} 247}
248 248
249/* eeprom */ 249/* eeprom */
250void il4965_eeprom_get_mac(const struct il_priv *priv, u8 *mac); 250void il4965_eeprom_get_mac(const struct il_priv *il, u8 *mac);
251int il4965_eeprom_acquire_semaphore(struct il_priv *priv); 251int il4965_eeprom_acquire_semaphore(struct il_priv *il);
252void il4965_eeprom_release_semaphore(struct il_priv *priv); 252void il4965_eeprom_release_semaphore(struct il_priv *il);
253int il4965_eeprom_check_version(struct il_priv *priv); 253int il4965_eeprom_check_version(struct il_priv *il);
254 254
255/* mac80211 handlers (for 4965) */ 255/* mac80211 handlers (for 4965) */
256void il4965_mac_tx(struct ieee80211_hw *hw, struct sk_buff *skb); 256void il4965_mac_tx(struct ieee80211_hw *hw, struct sk_buff *skb);
diff --git a/drivers/net/wireless/iwlegacy/iwl-core.c b/drivers/net/wireless/iwlegacy/iwl-core.c
index 7eae279e4c69..80ec543dd894 100644
--- a/drivers/net/wireless/iwlegacy/iwl-core.c
+++ b/drivers/net/wireless/iwlegacy/iwl-core.c
@@ -75,12 +75,12 @@ const u8 iwlegacy_bcast_addr[ETH_ALEN] = { 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF };
75EXPORT_SYMBOL(iwlegacy_bcast_addr); 75EXPORT_SYMBOL(iwlegacy_bcast_addr);
76 76
77 77
78/* This function both allocates and initializes hw and priv. */ 78/* This function both allocates and initializes hw and il. */
79struct ieee80211_hw *il_alloc_all(struct il_cfg *cfg) 79struct ieee80211_hw *il_alloc_all(struct il_cfg *cfg)
80{ 80{
81 struct il_priv *priv; 81 struct il_priv *il;
82 /* mac80211 allocates memory for this device instance, including 82 /* mac80211 allocates memory for this device instance, including
83 * space for this driver's private structure */ 83 * space for this driver's ilate structure */
84 struct ieee80211_hw *hw; 84 struct ieee80211_hw *hw;
85 85
86 hw = ieee80211_alloc_hw(sizeof(struct il_priv), 86 hw = ieee80211_alloc_hw(sizeof(struct il_priv),
@@ -91,8 +91,8 @@ struct ieee80211_hw *il_alloc_all(struct il_cfg *cfg)
91 goto out; 91 goto out;
92 } 92 }
93 93
94 priv = hw->priv; 94 il = hw->priv;
95 priv->hw = hw; 95 il->hw = hw;
96 96
97out: 97out:
98 return hw; 98 return hw;
@@ -101,13 +101,13 @@ EXPORT_SYMBOL(il_alloc_all);
101 101
102#define MAX_BIT_RATE_40_MHZ 150 /* Mbps */ 102#define MAX_BIT_RATE_40_MHZ 150 /* Mbps */
103#define MAX_BIT_RATE_20_MHZ 72 /* Mbps */ 103#define MAX_BIT_RATE_20_MHZ 72 /* Mbps */
104static void il_init_ht_hw_capab(const struct il_priv *priv, 104static void il_init_ht_hw_capab(const struct il_priv *il,
105 struct ieee80211_sta_ht_cap *ht_info, 105 struct ieee80211_sta_ht_cap *ht_info,
106 enum ieee80211_band band) 106 enum ieee80211_band band)
107{ 107{
108 u16 max_bit_rate = 0; 108 u16 max_bit_rate = 0;
109 u8 rx_chains_num = priv->hw_params.rx_chains_num; 109 u8 rx_chains_num = il->hw_params.rx_chains_num;
110 u8 tx_chains_num = priv->hw_params.tx_chains_num; 110 u8 tx_chains_num = il->hw_params.tx_chains_num;
111 111
112 ht_info->cap = 0; 112 ht_info->cap = 0;
113 memset(&ht_info->mcs, 0, sizeof(ht_info->mcs)); 113 memset(&ht_info->mcs, 0, sizeof(ht_info->mcs));
@@ -116,14 +116,14 @@ static void il_init_ht_hw_capab(const struct il_priv *priv,
116 116
117 ht_info->cap |= IEEE80211_HT_CAP_SGI_20; 117 ht_info->cap |= IEEE80211_HT_CAP_SGI_20;
118 max_bit_rate = MAX_BIT_RATE_20_MHZ; 118 max_bit_rate = MAX_BIT_RATE_20_MHZ;
119 if (priv->hw_params.ht40_channel & BIT(band)) { 119 if (il->hw_params.ht40_channel & BIT(band)) {
120 ht_info->cap |= IEEE80211_HT_CAP_SUP_WIDTH_20_40; 120 ht_info->cap |= IEEE80211_HT_CAP_SUP_WIDTH_20_40;
121 ht_info->cap |= IEEE80211_HT_CAP_SGI_40; 121 ht_info->cap |= IEEE80211_HT_CAP_SGI_40;
122 ht_info->mcs.rx_mask[4] = 0x01; 122 ht_info->mcs.rx_mask[4] = 0x01;
123 max_bit_rate = MAX_BIT_RATE_40_MHZ; 123 max_bit_rate = MAX_BIT_RATE_40_MHZ;
124 } 124 }
125 125
126 if (priv->cfg->mod_params->amsdu_size_8K) 126 if (il->cfg->mod_params->amsdu_size_8K)
127 ht_info->cap |= IEEE80211_HT_CAP_MAX_AMSDU; 127 ht_info->cap |= IEEE80211_HT_CAP_MAX_AMSDU;
128 128
129 ht_info->ampdu_factor = CFG_HT_RX_AMPDU_FACTOR_DEF; 129 ht_info->ampdu_factor = CFG_HT_RX_AMPDU_FACTOR_DEF;
@@ -152,7 +152,7 @@ static void il_init_ht_hw_capab(const struct il_priv *priv,
152/** 152/**
153 * il_init_geos - Initialize mac80211's geo/channel info based from eeprom 153 * il_init_geos - Initialize mac80211's geo/channel info based from eeprom
154 */ 154 */
155int il_init_geos(struct il_priv *priv) 155int il_init_geos(struct il_priv *il)
156{ 156{
157 struct il_channel_info *ch; 157 struct il_channel_info *ch;
158 struct ieee80211_supported_band *sband; 158 struct ieee80211_supported_band *sband;
@@ -162,15 +162,15 @@ int il_init_geos(struct il_priv *priv)
162 int i = 0; 162 int i = 0;
163 s8 max_tx_power = 0; 163 s8 max_tx_power = 0;
164 164
165 if (priv->bands[IEEE80211_BAND_2GHZ].n_bitrates || 165 if (il->bands[IEEE80211_BAND_2GHZ].n_bitrates ||
166 priv->bands[IEEE80211_BAND_5GHZ].n_bitrates) { 166 il->bands[IEEE80211_BAND_5GHZ].n_bitrates) {
167 IL_DEBUG_INFO(priv, "Geography modes already initialized.\n"); 167 IL_DEBUG_INFO(il, "Geography modes already initialized.\n");
168 set_bit(STATUS_GEO_CONFIGURED, &priv->status); 168 set_bit(STATUS_GEO_CONFIGURED, &il->status);
169 return 0; 169 return 0;
170 } 170 }
171 171
172 channels = kzalloc(sizeof(struct ieee80211_channel) * 172 channels = kzalloc(sizeof(struct ieee80211_channel) *
173 priv->channel_count, GFP_KERNEL); 173 il->channel_count, GFP_KERNEL);
174 if (!channels) 174 if (!channels)
175 return -ENOMEM; 175 return -ENOMEM;
176 176
@@ -182,36 +182,36 @@ int il_init_geos(struct il_priv *priv)
182 } 182 }
183 183
184 /* 5.2GHz channels start after the 2.4GHz channels */ 184 /* 5.2GHz channels start after the 2.4GHz channels */
185 sband = &priv->bands[IEEE80211_BAND_5GHZ]; 185 sband = &il->bands[IEEE80211_BAND_5GHZ];
186 sband->channels = &channels[ARRAY_SIZE(iwlegacy_eeprom_band_1)]; 186 sband->channels = &channels[ARRAY_SIZE(iwlegacy_eeprom_band_1)];
187 /* just OFDM */ 187 /* just OFDM */
188 sband->bitrates = &rates[IL_FIRST_OFDM_RATE]; 188 sband->bitrates = &rates[IL_FIRST_OFDM_RATE];
189 sband->n_bitrates = IL_RATE_COUNT_LEGACY - IL_FIRST_OFDM_RATE; 189 sband->n_bitrates = IL_RATE_COUNT_LEGACY - IL_FIRST_OFDM_RATE;
190 190
191 if (priv->cfg->sku & IL_SKU_N) 191 if (il->cfg->sku & IL_SKU_N)
192 il_init_ht_hw_capab(priv, &sband->ht_cap, 192 il_init_ht_hw_capab(il, &sband->ht_cap,
193 IEEE80211_BAND_5GHZ); 193 IEEE80211_BAND_5GHZ);
194 194
195 sband = &priv->bands[IEEE80211_BAND_2GHZ]; 195 sband = &il->bands[IEEE80211_BAND_2GHZ];
196 sband->channels = channels; 196 sband->channels = channels;
197 /* OFDM & CCK */ 197 /* OFDM & CCK */
198 sband->bitrates = rates; 198 sband->bitrates = rates;
199 sband->n_bitrates = IL_RATE_COUNT_LEGACY; 199 sband->n_bitrates = IL_RATE_COUNT_LEGACY;
200 200
201 if (priv->cfg->sku & IL_SKU_N) 201 if (il->cfg->sku & IL_SKU_N)
202 il_init_ht_hw_capab(priv, &sband->ht_cap, 202 il_init_ht_hw_capab(il, &sband->ht_cap,
203 IEEE80211_BAND_2GHZ); 203 IEEE80211_BAND_2GHZ);
204 204
205 priv->ieee_channels = channels; 205 il->ieee_channels = channels;
206 priv->ieee_rates = rates; 206 il->ieee_rates = rates;
207 207
208 for (i = 0; i < priv->channel_count; i++) { 208 for (i = 0; i < il->channel_count; i++) {
209 ch = &priv->channel_info[i]; 209 ch = &il->channel_info[i];
210 210
211 if (!il_is_channel_valid(ch)) 211 if (!il_is_channel_valid(ch))
212 continue; 212 continue;
213 213
214 sband = &priv->bands[ch->band]; 214 sband = &il->bands[ch->band];
215 215
216 geo_ch = &sband->channels[sband->n_channels++]; 216 geo_ch = &sband->channels[sband->n_channels++];
217 217
@@ -239,7 +239,7 @@ int il_init_geos(struct il_priv *priv)
239 geo_ch->flags |= IEEE80211_CHAN_DISABLED; 239 geo_ch->flags |= IEEE80211_CHAN_DISABLED;
240 } 240 }
241 241
242 IL_DEBUG_INFO(priv, "Channel %d Freq=%d[%sGHz] %s flag=0x%X\n", 242 IL_DEBUG_INFO(il, "Channel %d Freq=%d[%sGHz] %s flag=0x%X\n",
243 ch->channel, geo_ch->center_freq, 243 ch->channel, geo_ch->center_freq,
244 il_is_channel_a_band(ch) ? "5.2" : "2.4", 244 il_is_channel_a_band(ch) ? "5.2" : "2.4",
245 geo_ch->flags & IEEE80211_CHAN_DISABLED ? 245 geo_ch->flags & IEEE80211_CHAN_DISABLED ?
@@ -247,24 +247,24 @@ int il_init_geos(struct il_priv *priv)
247 geo_ch->flags); 247 geo_ch->flags);
248 } 248 }
249 249
250 priv->tx_power_device_lmt = max_tx_power; 250 il->tx_power_device_lmt = max_tx_power;
251 priv->tx_power_user_lmt = max_tx_power; 251 il->tx_power_user_lmt = max_tx_power;
252 priv->tx_power_next = max_tx_power; 252 il->tx_power_next = max_tx_power;
253 253
254 if ((priv->bands[IEEE80211_BAND_5GHZ].n_channels == 0) && 254 if ((il->bands[IEEE80211_BAND_5GHZ].n_channels == 0) &&
255 priv->cfg->sku & IL_SKU_A) { 255 il->cfg->sku & IL_SKU_A) {
256 IL_INFO(priv, "Incorrectly detected BG card as ABG. " 256 IL_INFO(il, "Incorrectly detected BG card as ABG. "
257 "Please send your PCI ID 0x%04X:0x%04X to maintainer.\n", 257 "Please send your PCI ID 0x%04X:0x%04X to maintainer.\n",
258 priv->pci_dev->device, 258 il->pci_dev->device,
259 priv->pci_dev->subsystem_device); 259 il->pci_dev->subsystem_device);
260 priv->cfg->sku &= ~IL_SKU_A; 260 il->cfg->sku &= ~IL_SKU_A;
261 } 261 }
262 262
263 IL_INFO(priv, "Tunable channels: %d 802.11bg, %d 802.11a channels\n", 263 IL_INFO(il, "Tunable channels: %d 802.11bg, %d 802.11a channels\n",
264 priv->bands[IEEE80211_BAND_2GHZ].n_channels, 264 il->bands[IEEE80211_BAND_2GHZ].n_channels,
265 priv->bands[IEEE80211_BAND_5GHZ].n_channels); 265 il->bands[IEEE80211_BAND_5GHZ].n_channels);
266 266
267 set_bit(STATUS_GEO_CONFIGURED, &priv->status); 267 set_bit(STATUS_GEO_CONFIGURED, &il->status);
268 268
269 return 0; 269 return 0;
270} 270}
@@ -273,21 +273,21 @@ EXPORT_SYMBOL(il_init_geos);
273/* 273/*
274 * il_free_geos - undo allocations in il_init_geos 274 * il_free_geos - undo allocations in il_init_geos
275 */ 275 */
276void il_free_geos(struct il_priv *priv) 276void il_free_geos(struct il_priv *il)
277{ 277{
278 kfree(priv->ieee_channels); 278 kfree(il->ieee_channels);
279 kfree(priv->ieee_rates); 279 kfree(il->ieee_rates);
280 clear_bit(STATUS_GEO_CONFIGURED, &priv->status); 280 clear_bit(STATUS_GEO_CONFIGURED, &il->status);
281} 281}
282EXPORT_SYMBOL(il_free_geos); 282EXPORT_SYMBOL(il_free_geos);
283 283
284static bool il_is_channel_extension(struct il_priv *priv, 284static bool il_is_channel_extension(struct il_priv *il,
285 enum ieee80211_band band, 285 enum ieee80211_band band,
286 u16 channel, u8 extension_chan_offset) 286 u16 channel, u8 extension_chan_offset)
287{ 287{
288 const struct il_channel_info *ch_info; 288 const struct il_channel_info *ch_info;
289 289
290 ch_info = il_get_channel_info(priv, band, channel); 290 ch_info = il_get_channel_info(il, band, channel);
291 if (!il_is_channel_valid(ch_info)) 291 if (!il_is_channel_valid(ch_info))
292 return false; 292 return false;
293 293
@@ -301,7 +301,7 @@ static bool il_is_channel_extension(struct il_priv *priv,
301 return false; 301 return false;
302} 302}
303 303
304bool il_is_ht40_tx_allowed(struct il_priv *priv, 304bool il_is_ht40_tx_allowed(struct il_priv *il,
305 struct il_rxon_context *ctx, 305 struct il_rxon_context *ctx,
306 struct ieee80211_sta_ht_cap *ht_cap) 306 struct ieee80211_sta_ht_cap *ht_cap)
307{ 307{
@@ -316,11 +316,11 @@ bool il_is_ht40_tx_allowed(struct il_priv *priv,
316 return false; 316 return false;
317 317
318#ifdef CONFIG_IWLWIFI_LEGACY_DEBUGFS 318#ifdef CONFIG_IWLWIFI_LEGACY_DEBUGFS
319 if (priv->disable_ht40) 319 if (il->disable_ht40)
320 return false; 320 return false;
321#endif 321#endif
322 322
323 return il_is_channel_extension(priv, priv->band, 323 return il_is_channel_extension(il, il->band,
324 le16_to_cpu(ctx->staging.channel), 324 le16_to_cpu(ctx->staging.channel),
325 ctx->ht.extension_chan_offset); 325 ctx->ht.extension_chan_offset);
326} 326}
@@ -360,7 +360,7 @@ static u16 il_adjust_beacon_interval(u16 beacon_val, u16 max_beacon_val)
360} 360}
361 361
362int 362int
363il_send_rxon_timing(struct il_priv *priv, struct il_rxon_context *ctx) 363il_send_rxon_timing(struct il_priv *il, struct il_rxon_context *ctx)
364{ 364{
365 u64 tsf; 365 u64 tsf;
366 s32 interval_tm, rem; 366 s32 interval_tm, rem;
@@ -368,13 +368,13 @@ il_send_rxon_timing(struct il_priv *priv, struct il_rxon_context *ctx)
368 u16 beacon_int; 368 u16 beacon_int;
369 struct ieee80211_vif *vif = ctx->vif; 369 struct ieee80211_vif *vif = ctx->vif;
370 370
371 conf = il_ieee80211_get_hw_conf(priv->hw); 371 conf = il_ieee80211_get_hw_conf(il->hw);
372 372
373 lockdep_assert_held(&priv->mutex); 373 lockdep_assert_held(&il->mutex);
374 374
375 memset(&ctx->timing, 0, sizeof(struct il_rxon_time_cmd)); 375 memset(&ctx->timing, 0, sizeof(struct il_rxon_time_cmd));
376 376
377 ctx->timing.timestamp = cpu_to_le64(priv->timestamp); 377 ctx->timing.timestamp = cpu_to_le64(il->timestamp);
378 ctx->timing.listen_interval = cpu_to_le16(conf->listen_interval); 378 ctx->timing.listen_interval = cpu_to_le16(conf->listen_interval);
379 379
380 beacon_int = vif ? vif->bss_conf.beacon_int : 0; 380 beacon_int = vif ? vif->bss_conf.beacon_int : 0;
@@ -386,29 +386,29 @@ il_send_rxon_timing(struct il_priv *priv, struct il_rxon_context *ctx)
386 ctx->timing.atim_window = 0; 386 ctx->timing.atim_window = 0;
387 387
388 beacon_int = il_adjust_beacon_interval(beacon_int, 388 beacon_int = il_adjust_beacon_interval(beacon_int,
389 priv->hw_params.max_beacon_itrvl * TIME_UNIT); 389 il->hw_params.max_beacon_itrvl * TIME_UNIT);
390 ctx->timing.beacon_interval = cpu_to_le16(beacon_int); 390 ctx->timing.beacon_interval = cpu_to_le16(beacon_int);
391 391
392 tsf = priv->timestamp; /* tsf is modifed by do_div: copy it */ 392 tsf = il->timestamp; /* tsf is modifed by do_div: copy it */
393 interval_tm = beacon_int * TIME_UNIT; 393 interval_tm = beacon_int * TIME_UNIT;
394 rem = do_div(tsf, interval_tm); 394 rem = do_div(tsf, interval_tm);
395 ctx->timing.beacon_init_val = cpu_to_le32(interval_tm - rem); 395 ctx->timing.beacon_init_val = cpu_to_le32(interval_tm - rem);
396 396
397 ctx->timing.dtim_period = vif ? (vif->bss_conf.dtim_period ?: 1) : 1; 397 ctx->timing.dtim_period = vif ? (vif->bss_conf.dtim_period ?: 1) : 1;
398 398
399 IL_DEBUG_ASSOC(priv, 399 IL_DEBUG_ASSOC(il,
400 "beacon interval %d beacon timer %d beacon tim %d\n", 400 "beacon interval %d beacon timer %d beacon tim %d\n",
401 le16_to_cpu(ctx->timing.beacon_interval), 401 le16_to_cpu(ctx->timing.beacon_interval),
402 le32_to_cpu(ctx->timing.beacon_init_val), 402 le32_to_cpu(ctx->timing.beacon_init_val),
403 le16_to_cpu(ctx->timing.atim_window)); 403 le16_to_cpu(ctx->timing.atim_window));
404 404
405 return il_send_cmd_pdu(priv, ctx->rxon_timing_cmd, 405 return il_send_cmd_pdu(il, ctx->rxon_timing_cmd,
406 sizeof(ctx->timing), &ctx->timing); 406 sizeof(ctx->timing), &ctx->timing);
407} 407}
408EXPORT_SYMBOL(il_send_rxon_timing); 408EXPORT_SYMBOL(il_send_rxon_timing);
409 409
410void 410void
411il_set_rxon_hwcrypto(struct il_priv *priv, 411il_set_rxon_hwcrypto(struct il_priv *il,
412 struct il_rxon_context *ctx, 412 struct il_rxon_context *ctx,
413 int hw_decrypt) 413 int hw_decrypt)
414{ 414{
@@ -424,72 +424,72 @@ EXPORT_SYMBOL(il_set_rxon_hwcrypto);
424 424
425/* validate RXON structure is valid */ 425/* validate RXON structure is valid */
426int 426int
427il_check_rxon_cmd(struct il_priv *priv, struct il_rxon_context *ctx) 427il_check_rxon_cmd(struct il_priv *il, struct il_rxon_context *ctx)
428{ 428{
429 struct il_rxon_cmd *rxon = &ctx->staging; 429 struct il_rxon_cmd *rxon = &ctx->staging;
430 bool error = false; 430 bool error = false;
431 431
432 if (rxon->flags & RXON_FLG_BAND_24G_MSK) { 432 if (rxon->flags & RXON_FLG_BAND_24G_MSK) {
433 if (rxon->flags & RXON_FLG_TGJ_NARROW_BAND_MSK) { 433 if (rxon->flags & RXON_FLG_TGJ_NARROW_BAND_MSK) {
434 IL_WARN(priv, "check 2.4G: wrong narrow\n"); 434 IL_WARN(il, "check 2.4G: wrong narrow\n");
435 error = true; 435 error = true;
436 } 436 }
437 if (rxon->flags & RXON_FLG_RADAR_DETECT_MSK) { 437 if (rxon->flags & RXON_FLG_RADAR_DETECT_MSK) {
438 IL_WARN(priv, "check 2.4G: wrong radar\n"); 438 IL_WARN(il, "check 2.4G: wrong radar\n");
439 error = true; 439 error = true;
440 } 440 }
441 } else { 441 } else {
442 if (!(rxon->flags & RXON_FLG_SHORT_SLOT_MSK)) { 442 if (!(rxon->flags & RXON_FLG_SHORT_SLOT_MSK)) {
443 IL_WARN(priv, "check 5.2G: not short slot!\n"); 443 IL_WARN(il, "check 5.2G: not short slot!\n");
444 error = true; 444 error = true;
445 } 445 }
446 if (rxon->flags & RXON_FLG_CCK_MSK) { 446 if (rxon->flags & RXON_FLG_CCK_MSK) {
447 IL_WARN(priv, "check 5.2G: CCK!\n"); 447 IL_WARN(il, "check 5.2G: CCK!\n");
448 error = true; 448 error = true;
449 } 449 }
450 } 450 }
451 if ((rxon->node_addr[0] | rxon->bssid_addr[0]) & 0x1) { 451 if ((rxon->node_addr[0] | rxon->bssid_addr[0]) & 0x1) {
452 IL_WARN(priv, "mac/bssid mcast!\n"); 452 IL_WARN(il, "mac/bssid mcast!\n");
453 error = true; 453 error = true;
454 } 454 }
455 455
456 /* make sure basic rates 6Mbps and 1Mbps are supported */ 456 /* make sure basic rates 6Mbps and 1Mbps are supported */
457 if ((rxon->ofdm_basic_rates & IL_RATE_6M_MASK) == 0 && 457 if ((rxon->ofdm_basic_rates & IL_RATE_6M_MASK) == 0 &&
458 (rxon->cck_basic_rates & IL_RATE_1M_MASK) == 0) { 458 (rxon->cck_basic_rates & IL_RATE_1M_MASK) == 0) {
459 IL_WARN(priv, "neither 1 nor 6 are basic\n"); 459 IL_WARN(il, "neither 1 nor 6 are basic\n");
460 error = true; 460 error = true;
461 } 461 }
462 462
463 if (le16_to_cpu(rxon->assoc_id) > 2007) { 463 if (le16_to_cpu(rxon->assoc_id) > 2007) {
464 IL_WARN(priv, "aid > 2007\n"); 464 IL_WARN(il, "aid > 2007\n");
465 error = true; 465 error = true;
466 } 466 }
467 467
468 if ((rxon->flags & (RXON_FLG_CCK_MSK | RXON_FLG_SHORT_SLOT_MSK)) 468 if ((rxon->flags & (RXON_FLG_CCK_MSK | RXON_FLG_SHORT_SLOT_MSK))
469 == (RXON_FLG_CCK_MSK | RXON_FLG_SHORT_SLOT_MSK)) { 469 == (RXON_FLG_CCK_MSK | RXON_FLG_SHORT_SLOT_MSK)) {
470 IL_WARN(priv, "CCK and short slot\n"); 470 IL_WARN(il, "CCK and short slot\n");
471 error = true; 471 error = true;
472 } 472 }
473 473
474 if ((rxon->flags & (RXON_FLG_CCK_MSK | RXON_FLG_AUTO_DETECT_MSK)) 474 if ((rxon->flags & (RXON_FLG_CCK_MSK | RXON_FLG_AUTO_DETECT_MSK))
475 == (RXON_FLG_CCK_MSK | RXON_FLG_AUTO_DETECT_MSK)) { 475 == (RXON_FLG_CCK_MSK | RXON_FLG_AUTO_DETECT_MSK)) {
476 IL_WARN(priv, "CCK and auto detect"); 476 IL_WARN(il, "CCK and auto detect");
477 error = true; 477 error = true;
478 } 478 }
479 479
480 if ((rxon->flags & (RXON_FLG_AUTO_DETECT_MSK | 480 if ((rxon->flags & (RXON_FLG_AUTO_DETECT_MSK |
481 RXON_FLG_TGG_PROTECT_MSK)) == 481 RXON_FLG_TGG_PROTECT_MSK)) ==
482 RXON_FLG_TGG_PROTECT_MSK) { 482 RXON_FLG_TGG_PROTECT_MSK) {
483 IL_WARN(priv, "TGg but no auto-detect\n"); 483 IL_WARN(il, "TGg but no auto-detect\n");
484 error = true; 484 error = true;
485 } 485 }
486 486
487 if (error) 487 if (error)
488 IL_WARN(priv, "Tuning to channel %d\n", 488 IL_WARN(il, "Tuning to channel %d\n",
489 le16_to_cpu(rxon->channel)); 489 le16_to_cpu(rxon->channel));
490 490
491 if (error) { 491 if (error) {
492 IL_ERR(priv, "Invalid RXON\n"); 492 IL_ERR(il, "Invalid RXON\n");
493 return -EINVAL; 493 return -EINVAL;
494 } 494 }
495 return 0; 495 return 0;
@@ -498,13 +498,13 @@ EXPORT_SYMBOL(il_check_rxon_cmd);
498 498
499/** 499/**
500 * il_full_rxon_required - check if full RXON (vs RXON_ASSOC) cmd is needed 500 * il_full_rxon_required - check if full RXON (vs RXON_ASSOC) cmd is needed
501 * @priv: staging_rxon is compared to active_rxon 501 * @il: staging_rxon is compared to active_rxon
502 * 502 *
503 * If the RXON structure is changing enough to require a new tune, 503 * If the RXON structure is changing enough to require a new tune,
504 * or is clearing the RXON_FILTER_ASSOC_MSK, then return 1 to indicate that 504 * or is clearing the RXON_FILTER_ASSOC_MSK, then return 1 to indicate that
505 * a new tune (full RXON command, rather than RXON_ASSOC cmd) is required. 505 * a new tune (full RXON command, rather than RXON_ASSOC cmd) is required.
506 */ 506 */
507int il_full_rxon_required(struct il_priv *priv, 507int il_full_rxon_required(struct il_priv *il,
508 struct il_rxon_context *ctx) 508 struct il_rxon_context *ctx)
509{ 509{
510 const struct il_rxon_cmd *staging = &ctx->staging; 510 const struct il_rxon_cmd *staging = &ctx->staging;
@@ -512,13 +512,13 @@ int il_full_rxon_required(struct il_priv *priv,
512 512
513#define CHK(cond) \ 513#define CHK(cond) \
514 if ((cond)) { \ 514 if ((cond)) { \
515 IL_DEBUG_INFO(priv, "need full RXON - " #cond "\n"); \ 515 IL_DEBUG_INFO(il, "need full RXON - " #cond "\n"); \
516 return 1; \ 516 return 1; \
517 } 517 }
518 518
519#define CHK_NEQ(c1, c2) \ 519#define CHK_NEQ(c1, c2) \
520 if ((c1) != (c2)) { \ 520 if ((c1) != (c2)) { \
521 IL_DEBUG_INFO(priv, "need full RXON - " \ 521 IL_DEBUG_INFO(il, "need full RXON - " \
522 #c1 " != " #c2 " - %d != %d\n", \ 522 #c1 " != " #c2 " - %d != %d\n", \
523 (c1), (c2)); \ 523 (c1), (c2)); \
524 return 1; \ 524 return 1; \
@@ -558,7 +558,7 @@ int il_full_rxon_required(struct il_priv *priv,
558} 558}
559EXPORT_SYMBOL(il_full_rxon_required); 559EXPORT_SYMBOL(il_full_rxon_required);
560 560
561u8 il_get_lowest_plcp(struct il_priv *priv, 561u8 il_get_lowest_plcp(struct il_priv *il,
562 struct il_rxon_context *ctx) 562 struct il_rxon_context *ctx)
563{ 563{
564 /* 564 /*
@@ -572,7 +572,7 @@ u8 il_get_lowest_plcp(struct il_priv *priv,
572} 572}
573EXPORT_SYMBOL(il_get_lowest_plcp); 573EXPORT_SYMBOL(il_get_lowest_plcp);
574 574
575static void _il_set_rxon_ht(struct il_priv *priv, 575static void _il_set_rxon_ht(struct il_priv *il,
576 struct il_ht_config *ht_conf, 576 struct il_ht_config *ht_conf,
577 struct il_rxon_context *ctx) 577 struct il_rxon_context *ctx)
578{ 578{
@@ -594,7 +594,7 @@ static void _il_set_rxon_ht(struct il_priv *priv,
594 /* clear the HT channel mode before set the mode */ 594 /* clear the HT channel mode before set the mode */
595 rxon->flags &= ~(RXON_FLG_CHANNEL_MODE_MSK | 595 rxon->flags &= ~(RXON_FLG_CHANNEL_MODE_MSK |
596 RXON_FLG_CTRL_CHANNEL_LOC_HI_MSK); 596 RXON_FLG_CTRL_CHANNEL_LOC_HI_MSK);
597 if (il_is_ht40_tx_allowed(priv, ctx, NULL)) { 597 if (il_is_ht40_tx_allowed(il, ctx, NULL)) {
598 /* pure ht40 */ 598 /* pure ht40 */
599 if (ctx->ht.protection == 599 if (ctx->ht.protection ==
600 IEEE80211_HT_OP_MODE_PROTECTION_20MHZ) { 600 IEEE80211_HT_OP_MODE_PROTECTION_20MHZ) {
@@ -626,7 +626,7 @@ static void _il_set_rxon_ht(struct il_priv *priv,
626 case IEEE80211_HT_PARAM_CHA_SEC_NONE: 626 case IEEE80211_HT_PARAM_CHA_SEC_NONE:
627 default: 627 default:
628 /* channel location only valid if in Mixed mode */ 628 /* channel location only valid if in Mixed mode */
629 IL_ERR(priv, 629 IL_ERR(il,
630 "invalid extension channel offset\n"); 630 "invalid extension channel offset\n");
631 break; 631 break;
632 } 632 }
@@ -635,26 +635,26 @@ static void _il_set_rxon_ht(struct il_priv *priv,
635 rxon->flags |= RXON_FLG_CHANNEL_MODE_LEGACY; 635 rxon->flags |= RXON_FLG_CHANNEL_MODE_LEGACY;
636 } 636 }
637 637
638 if (priv->cfg->ops->hcmd->set_rxon_chain) 638 if (il->cfg->ops->hcmd->set_rxon_chain)
639 priv->cfg->ops->hcmd->set_rxon_chain(priv, ctx); 639 il->cfg->ops->hcmd->set_rxon_chain(il, ctx);
640 640
641 IL_DEBUG_ASSOC(priv, "rxon flags 0x%X operation mode :0x%X " 641 IL_DEBUG_ASSOC(il, "rxon flags 0x%X operation mode :0x%X "
642 "extension channel offset 0x%x\n", 642 "extension channel offset 0x%x\n",
643 le32_to_cpu(rxon->flags), ctx->ht.protection, 643 le32_to_cpu(rxon->flags), ctx->ht.protection,
644 ctx->ht.extension_chan_offset); 644 ctx->ht.extension_chan_offset);
645} 645}
646 646
647void il_set_rxon_ht(struct il_priv *priv, struct il_ht_config *ht_conf) 647void il_set_rxon_ht(struct il_priv *il, struct il_ht_config *ht_conf)
648{ 648{
649 struct il_rxon_context *ctx; 649 struct il_rxon_context *ctx;
650 650
651 for_each_context(priv, ctx) 651 for_each_context(il, ctx)
652 _il_set_rxon_ht(priv, ht_conf, ctx); 652 _il_set_rxon_ht(il, ht_conf, ctx);
653} 653}
654EXPORT_SYMBOL(il_set_rxon_ht); 654EXPORT_SYMBOL(il_set_rxon_ht);
655 655
656/* Return valid, unused, channel for a passive scan to reset the RF */ 656/* Return valid, unused, channel for a passive scan to reset the RF */
657u8 il_get_single_channel_number(struct il_priv *priv, 657u8 il_get_single_channel_number(struct il_priv *il,
658 enum ieee80211_band band) 658 enum ieee80211_band band)
659{ 659{
660 const struct il_channel_info *ch_info; 660 const struct il_channel_info *ch_info;
@@ -665,7 +665,7 @@ u8 il_get_single_channel_number(struct il_priv *priv,
665 665
666 if (band == IEEE80211_BAND_5GHZ) { 666 if (band == IEEE80211_BAND_5GHZ) {
667 min = 14; 667 min = 14;
668 max = priv->channel_count; 668 max = il->channel_count;
669 } else { 669 } else {
670 min = 0; 670 min = 0;
671 max = 14; 671 max = 14;
@@ -674,8 +674,8 @@ u8 il_get_single_channel_number(struct il_priv *priv,
674 for (i = min; i < max; i++) { 674 for (i = min; i < max; i++) {
675 bool busy = false; 675 bool busy = false;
676 676
677 for_each_context(priv, ctx) { 677 for_each_context(il, ctx) {
678 busy = priv->channel_info[i].channel == 678 busy = il->channel_info[i].channel ==
679 le16_to_cpu(ctx->staging.channel); 679 le16_to_cpu(ctx->staging.channel);
680 if (busy) 680 if (busy)
681 break; 681 break;
@@ -684,8 +684,8 @@ u8 il_get_single_channel_number(struct il_priv *priv,
684 if (busy) 684 if (busy)
685 continue; 685 continue;
686 686
687 channel = priv->channel_info[i].channel; 687 channel = il->channel_info[i].channel;
688 ch_info = il_get_channel_info(priv, band, channel); 688 ch_info = il_get_channel_info(il, band, channel);
689 if (il_is_channel_valid(ch_info)) 689 if (il_is_channel_valid(ch_info))
690 break; 690 break;
691 } 691 }
@@ -702,14 +702,14 @@ EXPORT_SYMBOL(il_get_single_channel_number);
702 * in the staging RXON flag structure based on the ch->band 702 * in the staging RXON flag structure based on the ch->band
703 */ 703 */
704int 704int
705il_set_rxon_channel(struct il_priv *priv, struct ieee80211_channel *ch, 705il_set_rxon_channel(struct il_priv *il, struct ieee80211_channel *ch,
706 struct il_rxon_context *ctx) 706 struct il_rxon_context *ctx)
707{ 707{
708 enum ieee80211_band band = ch->band; 708 enum ieee80211_band band = ch->band;
709 u16 channel = ch->hw_value; 709 u16 channel = ch->hw_value;
710 710
711 if ((le16_to_cpu(ctx->staging.channel) == channel) && 711 if ((le16_to_cpu(ctx->staging.channel) == channel) &&
712 (priv->band == band)) 712 (il->band == band))
713 return 0; 713 return 0;
714 714
715 ctx->staging.channel = cpu_to_le16(channel); 715 ctx->staging.channel = cpu_to_le16(channel);
@@ -718,15 +718,15 @@ il_set_rxon_channel(struct il_priv *priv, struct ieee80211_channel *ch,
718 else 718 else
719 ctx->staging.flags |= RXON_FLG_BAND_24G_MSK; 719 ctx->staging.flags |= RXON_FLG_BAND_24G_MSK;
720 720
721 priv->band = band; 721 il->band = band;
722 722
723 IL_DEBUG_INFO(priv, "Staging channel set to %d [%d]\n", channel, band); 723 IL_DEBUG_INFO(il, "Staging channel set to %d [%d]\n", channel, band);
724 724
725 return 0; 725 return 0;
726} 726}
727EXPORT_SYMBOL(il_set_rxon_channel); 727EXPORT_SYMBOL(il_set_rxon_channel);
728 728
729void il_set_flags_for_band(struct il_priv *priv, 729void il_set_flags_for_band(struct il_priv *il,
730 struct il_rxon_context *ctx, 730 struct il_rxon_context *ctx,
731 enum ieee80211_band band, 731 enum ieee80211_band band,
732 struct ieee80211_vif *vif) 732 struct ieee80211_vif *vif)
@@ -753,7 +753,7 @@ EXPORT_SYMBOL(il_set_flags_for_band);
753/* 753/*
754 * initialize rxon structure with default values from eeprom 754 * initialize rxon structure with default values from eeprom
755 */ 755 */
756void il_connection_init_rx_config(struct il_priv *priv, 756void il_connection_init_rx_config(struct il_priv *il,
757 struct il_rxon_context *ctx) 757 struct il_rxon_context *ctx)
758{ 758{
759 const struct il_channel_info *ch_info; 759 const struct il_channel_info *ch_info;
@@ -778,7 +778,7 @@ void il_connection_init_rx_config(struct il_priv *priv,
778 break; 778 break;
779 779
780 default: 780 default:
781 IL_ERR(priv, "Unsupported interface type %d\n", 781 IL_ERR(il, "Unsupported interface type %d\n",
782 ctx->vif->type); 782 ctx->vif->type);
783 break; 783 break;
784 } 784 }
@@ -786,22 +786,22 @@ void il_connection_init_rx_config(struct il_priv *priv,
786#if 0 786#if 0
787 /* TODO: Figure out when short_preamble would be set and cache from 787 /* TODO: Figure out when short_preamble would be set and cache from
788 * that */ 788 * that */
789 if (!hw_to_local(priv->hw)->short_preamble) 789 if (!hw_to_local(il->hw)->short_preamble)
790 ctx->staging.flags &= ~RXON_FLG_SHORT_PREAMBLE_MSK; 790 ctx->staging.flags &= ~RXON_FLG_SHORT_PREAMBLE_MSK;
791 else 791 else
792 ctx->staging.flags |= RXON_FLG_SHORT_PREAMBLE_MSK; 792 ctx->staging.flags |= RXON_FLG_SHORT_PREAMBLE_MSK;
793#endif 793#endif
794 794
795 ch_info = il_get_channel_info(priv, priv->band, 795 ch_info = il_get_channel_info(il, il->band,
796 le16_to_cpu(ctx->active.channel)); 796 le16_to_cpu(ctx->active.channel));
797 797
798 if (!ch_info) 798 if (!ch_info)
799 ch_info = &priv->channel_info[0]; 799 ch_info = &il->channel_info[0];
800 800
801 ctx->staging.channel = cpu_to_le16(ch_info->channel); 801 ctx->staging.channel = cpu_to_le16(ch_info->channel);
802 priv->band = ch_info->band; 802 il->band = ch_info->band;
803 803
804 il_set_flags_for_band(priv, ctx, priv->band, ctx->vif); 804 il_set_flags_for_band(il, ctx, il->band, ctx->vif);
805 805
806 ctx->staging.ofdm_basic_rates = 806 ctx->staging.ofdm_basic_rates =
807 (IL_OFDM_RATES_MASK >> IL_FIRST_OFDM_RATE) & 0xFF; 807 (IL_OFDM_RATES_MASK >> IL_FIRST_OFDM_RATE) & 0xFF;
@@ -819,30 +819,30 @@ void il_connection_init_rx_config(struct il_priv *priv,
819} 819}
820EXPORT_SYMBOL(il_connection_init_rx_config); 820EXPORT_SYMBOL(il_connection_init_rx_config);
821 821
822void il_set_rate(struct il_priv *priv) 822void il_set_rate(struct il_priv *il)
823{ 823{
824 const struct ieee80211_supported_band *hw = NULL; 824 const struct ieee80211_supported_band *hw = NULL;
825 struct ieee80211_rate *rate; 825 struct ieee80211_rate *rate;
826 struct il_rxon_context *ctx; 826 struct il_rxon_context *ctx;
827 int i; 827 int i;
828 828
829 hw = il_get_hw_mode(priv, priv->band); 829 hw = il_get_hw_mode(il, il->band);
830 if (!hw) { 830 if (!hw) {
831 IL_ERR(priv, "Failed to set rate: unable to get hw mode\n"); 831 IL_ERR(il, "Failed to set rate: unable to get hw mode\n");
832 return; 832 return;
833 } 833 }
834 834
835 priv->active_rate = 0; 835 il->active_rate = 0;
836 836
837 for (i = 0; i < hw->n_bitrates; i++) { 837 for (i = 0; i < hw->n_bitrates; i++) {
838 rate = &(hw->bitrates[i]); 838 rate = &(hw->bitrates[i]);
839 if (rate->hw_value < IL_RATE_COUNT_LEGACY) 839 if (rate->hw_value < IL_RATE_COUNT_LEGACY)
840 priv->active_rate |= (1 << rate->hw_value); 840 il->active_rate |= (1 << rate->hw_value);
841 } 841 }
842 842
843 IL_DEBUG_RATE(priv, "Set active_rate = %0x\n", priv->active_rate); 843 IL_DEBUG_RATE(il, "Set active_rate = %0x\n", il->active_rate);
844 844
845 for_each_context(priv, ctx) { 845 for_each_context(il, ctx) {
846 ctx->staging.cck_basic_rates = 846 ctx->staging.cck_basic_rates =
847 (IL_CCK_BASIC_RATES_MASK >> IL_FIRST_CCK_RATE) & 0xF; 847 (IL_CCK_BASIC_RATES_MASK >> IL_FIRST_CCK_RATE) & 0xF;
848 848
@@ -852,64 +852,64 @@ void il_set_rate(struct il_priv *priv)
852} 852}
853EXPORT_SYMBOL(il_set_rate); 853EXPORT_SYMBOL(il_set_rate);
854 854
855void il_chswitch_done(struct il_priv *priv, bool is_success) 855void il_chswitch_done(struct il_priv *il, bool is_success)
856{ 856{
857 struct il_rxon_context *ctx = &priv->contexts[IL_RXON_CTX_BSS]; 857 struct il_rxon_context *ctx = &il->contexts[IL_RXON_CTX_BSS];
858 858
859 if (test_bit(STATUS_EXIT_PENDING, &priv->status)) 859 if (test_bit(STATUS_EXIT_PENDING, &il->status))
860 return; 860 return;
861 861
862 if (test_and_clear_bit(STATUS_CHANNEL_SWITCH_PENDING, &priv->status)) 862 if (test_and_clear_bit(STATUS_CHANNEL_SWITCH_PENDING, &il->status))
863 ieee80211_chswitch_done(ctx->vif, is_success); 863 ieee80211_chswitch_done(ctx->vif, is_success);
864} 864}
865EXPORT_SYMBOL(il_chswitch_done); 865EXPORT_SYMBOL(il_chswitch_done);
866 866
867void il_rx_csa(struct il_priv *priv, struct il_rx_mem_buffer *rxb) 867void il_rx_csa(struct il_priv *il, struct il_rx_mem_buffer *rxb)
868{ 868{
869 struct il_rx_packet *pkt = rxb_addr(rxb); 869 struct il_rx_packet *pkt = rxb_addr(rxb);
870 struct il_csa_notification *csa = &(pkt->u.csa_notif); 870 struct il_csa_notification *csa = &(pkt->u.csa_notif);
871 871
872 struct il_rxon_context *ctx = &priv->contexts[IL_RXON_CTX_BSS]; 872 struct il_rxon_context *ctx = &il->contexts[IL_RXON_CTX_BSS];
873 struct il_rxon_cmd *rxon = (void *)&ctx->active; 873 struct il_rxon_cmd *rxon = (void *)&ctx->active;
874 874
875 if (!test_bit(STATUS_CHANNEL_SWITCH_PENDING, &priv->status)) 875 if (!test_bit(STATUS_CHANNEL_SWITCH_PENDING, &il->status))
876 return; 876 return;
877 877
878 if (!le32_to_cpu(csa->status) && csa->channel == priv->switch_channel) { 878 if (!le32_to_cpu(csa->status) && csa->channel == il->switch_channel) {
879 rxon->channel = csa->channel; 879 rxon->channel = csa->channel;
880 ctx->staging.channel = csa->channel; 880 ctx->staging.channel = csa->channel;
881 IL_DEBUG_11H(priv, "CSA notif: channel %d\n", 881 IL_DEBUG_11H(il, "CSA notif: channel %d\n",
882 le16_to_cpu(csa->channel)); 882 le16_to_cpu(csa->channel));
883 il_chswitch_done(priv, true); 883 il_chswitch_done(il, true);
884 } else { 884 } else {
885 IL_ERR(priv, "CSA notif (fail) : channel %d\n", 885 IL_ERR(il, "CSA notif (fail) : channel %d\n",
886 le16_to_cpu(csa->channel)); 886 le16_to_cpu(csa->channel));
887 il_chswitch_done(priv, false); 887 il_chswitch_done(il, false);
888 } 888 }
889} 889}
890EXPORT_SYMBOL(il_rx_csa); 890EXPORT_SYMBOL(il_rx_csa);
891 891
892#ifdef CONFIG_IWLWIFI_LEGACY_DEBUG 892#ifdef CONFIG_IWLWIFI_LEGACY_DEBUG
893void il_print_rx_config_cmd(struct il_priv *priv, 893void il_print_rx_config_cmd(struct il_priv *il,
894 struct il_rxon_context *ctx) 894 struct il_rxon_context *ctx)
895{ 895{
896 struct il_rxon_cmd *rxon = &ctx->staging; 896 struct il_rxon_cmd *rxon = &ctx->staging;
897 897
898 IL_DEBUG_RADIO(priv, "RX CONFIG:\n"); 898 IL_DEBUG_RADIO(il, "RX CONFIG:\n");
899 il_print_hex_dump(priv, IL_DL_RADIO, (u8 *) rxon, sizeof(*rxon)); 899 il_print_hex_dump(il, IL_DL_RADIO, (u8 *) rxon, sizeof(*rxon));
900 IL_DEBUG_RADIO(priv, "u16 channel: 0x%x\n", 900 IL_DEBUG_RADIO(il, "u16 channel: 0x%x\n",
901 le16_to_cpu(rxon->channel)); 901 le16_to_cpu(rxon->channel));
902 IL_DEBUG_RADIO(priv, "u32 flags: 0x%08X\n", le32_to_cpu(rxon->flags)); 902 IL_DEBUG_RADIO(il, "u32 flags: 0x%08X\n", le32_to_cpu(rxon->flags));
903 IL_DEBUG_RADIO(priv, "u32 filter_flags: 0x%08x\n", 903 IL_DEBUG_RADIO(il, "u32 filter_flags: 0x%08x\n",
904 le32_to_cpu(rxon->filter_flags)); 904 le32_to_cpu(rxon->filter_flags));
905 IL_DEBUG_RADIO(priv, "u8 dev_type: 0x%x\n", rxon->dev_type); 905 IL_DEBUG_RADIO(il, "u8 dev_type: 0x%x\n", rxon->dev_type);
906 IL_DEBUG_RADIO(priv, "u8 ofdm_basic_rates: 0x%02x\n", 906 IL_DEBUG_RADIO(il, "u8 ofdm_basic_rates: 0x%02x\n",
907 rxon->ofdm_basic_rates); 907 rxon->ofdm_basic_rates);
908 IL_DEBUG_RADIO(priv, "u8 cck_basic_rates: 0x%02x\n", 908 IL_DEBUG_RADIO(il, "u8 cck_basic_rates: 0x%02x\n",
909 rxon->cck_basic_rates); 909 rxon->cck_basic_rates);
910 IL_DEBUG_RADIO(priv, "u8[6] node_addr: %pM\n", rxon->node_addr); 910 IL_DEBUG_RADIO(il, "u8[6] node_addr: %pM\n", rxon->node_addr);
911 IL_DEBUG_RADIO(priv, "u8[6] bssid_addr: %pM\n", rxon->bssid_addr); 911 IL_DEBUG_RADIO(il, "u8[6] bssid_addr: %pM\n", rxon->bssid_addr);
912 IL_DEBUG_RADIO(priv, "u16 assoc_id: 0x%x\n", 912 IL_DEBUG_RADIO(il, "u16 assoc_id: 0x%x\n",
913 le16_to_cpu(rxon->assoc_id)); 913 le16_to_cpu(rxon->assoc_id));
914} 914}
915EXPORT_SYMBOL(il_print_rx_config_cmd); 915EXPORT_SYMBOL(il_print_rx_config_cmd);
@@ -917,68 +917,68 @@ EXPORT_SYMBOL(il_print_rx_config_cmd);
917/** 917/**
918 * il_irq_handle_error - called for HW or SW error interrupt from card 918 * il_irq_handle_error - called for HW or SW error interrupt from card
919 */ 919 */
920void il_irq_handle_error(struct il_priv *priv) 920void il_irq_handle_error(struct il_priv *il)
921{ 921{
922 /* Set the FW error flag -- cleared on il_down */ 922 /* Set the FW error flag -- cleared on il_down */
923 set_bit(STATUS_FW_ERROR, &priv->status); 923 set_bit(STATUS_FW_ERROR, &il->status);
924 924
925 /* Cancel currently queued command. */ 925 /* Cancel currently queued command. */
926 clear_bit(STATUS_HCMD_ACTIVE, &priv->status); 926 clear_bit(STATUS_HCMD_ACTIVE, &il->status);
927 927
928 IL_ERR(priv, "Loaded firmware version: %s\n", 928 IL_ERR(il, "Loaded firmware version: %s\n",
929 priv->hw->wiphy->fw_version); 929 il->hw->wiphy->fw_version);
930 930
931 priv->cfg->ops->lib->dump_nic_error_log(priv); 931 il->cfg->ops->lib->dump_nic_error_log(il);
932 if (priv->cfg->ops->lib->dump_fh) 932 if (il->cfg->ops->lib->dump_fh)
933 priv->cfg->ops->lib->dump_fh(priv, NULL, false); 933 il->cfg->ops->lib->dump_fh(il, NULL, false);
934#ifdef CONFIG_IWLWIFI_LEGACY_DEBUG 934#ifdef CONFIG_IWLWIFI_LEGACY_DEBUG
935 if (il_get_debug_level(priv) & IL_DL_FW_ERRORS) 935 if (il_get_debug_level(il) & IL_DL_FW_ERRORS)
936 il_print_rx_config_cmd(priv, 936 il_print_rx_config_cmd(il,
937 &priv->contexts[IL_RXON_CTX_BSS]); 937 &il->contexts[IL_RXON_CTX_BSS]);
938#endif 938#endif
939 939
940 wake_up(&priv->wait_command_queue); 940 wake_up(&il->wait_command_queue);
941 941
942 /* Keep the restart process from trying to send host 942 /* Keep the restart process from trying to send host
943 * commands by clearing the INIT status bit */ 943 * commands by clearing the INIT status bit */
944 clear_bit(STATUS_READY, &priv->status); 944 clear_bit(STATUS_READY, &il->status);
945 945
946 if (!test_bit(STATUS_EXIT_PENDING, &priv->status)) { 946 if (!test_bit(STATUS_EXIT_PENDING, &il->status)) {
947 IL_DEBUG(priv, IL_DL_FW_ERRORS, 947 IL_DEBUG(il, IL_DL_FW_ERRORS,
948 "Restarting adapter due to uCode error.\n"); 948 "Restarting adapter due to uCode error.\n");
949 949
950 if (priv->cfg->mod_params->restart_fw) 950 if (il->cfg->mod_params->restart_fw)
951 queue_work(priv->workqueue, &priv->restart); 951 queue_work(il->workqueue, &il->restart);
952 } 952 }
953} 953}
954EXPORT_SYMBOL(il_irq_handle_error); 954EXPORT_SYMBOL(il_irq_handle_error);
955 955
956static int il_apm_stop_master(struct il_priv *priv) 956static int il_apm_stop_master(struct il_priv *il)
957{ 957{
958 int ret = 0; 958 int ret = 0;
959 959
960 /* stop device's busmaster DMA activity */ 960 /* stop device's busmaster DMA activity */
961 il_set_bit(priv, CSR_RESET, CSR_RESET_REG_FLAG_STOP_MASTER); 961 il_set_bit(il, CSR_RESET, CSR_RESET_REG_FLAG_STOP_MASTER);
962 962
963 ret = il_poll_bit(priv, CSR_RESET, CSR_RESET_REG_FLAG_MASTER_DISABLED, 963 ret = il_poll_bit(il, CSR_RESET, CSR_RESET_REG_FLAG_MASTER_DISABLED,
964 CSR_RESET_REG_FLAG_MASTER_DISABLED, 100); 964 CSR_RESET_REG_FLAG_MASTER_DISABLED, 100);
965 if (ret) 965 if (ret)
966 IL_WARN(priv, "Master Disable Timed Out, 100 usec\n"); 966 IL_WARN(il, "Master Disable Timed Out, 100 usec\n");
967 967
968 IL_DEBUG_INFO(priv, "stop master\n"); 968 IL_DEBUG_INFO(il, "stop master\n");
969 969
970 return ret; 970 return ret;
971} 971}
972 972
973void il_apm_stop(struct il_priv *priv) 973void il_apm_stop(struct il_priv *il)
974{ 974{
975 IL_DEBUG_INFO(priv, "Stop card, put in low power state\n"); 975 IL_DEBUG_INFO(il, "Stop card, put in low power state\n");
976 976
977 /* Stop device's DMA activity */ 977 /* Stop device's DMA activity */
978 il_apm_stop_master(priv); 978 il_apm_stop_master(il);
979 979
980 /* Reset the entire device */ 980 /* Reset the entire device */
981 il_set_bit(priv, CSR_RESET, CSR_RESET_REG_FLAG_SW_RESET); 981 il_set_bit(il, CSR_RESET, CSR_RESET_REG_FLAG_SW_RESET);
982 982
983 udelay(10); 983 udelay(10);
984 984
@@ -986,7 +986,7 @@ void il_apm_stop(struct il_priv *priv)
986 * Clear "initialization complete" bit to move adapter from 986 * Clear "initialization complete" bit to move adapter from
987 * D0A* (powered-up Active) --> D0U* (Uninitialized) state. 987 * D0A* (powered-up Active) --> D0U* (Uninitialized) state.
988 */ 988 */
989 il_clear_bit(priv, CSR_GP_CNTRL, 989 il_clear_bit(il, CSR_GP_CNTRL,
990 CSR_GP_CNTRL_REG_FLAG_INIT_DONE); 990 CSR_GP_CNTRL_REG_FLAG_INIT_DONE);
991} 991}
992EXPORT_SYMBOL(il_apm_stop); 992EXPORT_SYMBOL(il_apm_stop);
@@ -997,12 +997,12 @@ EXPORT_SYMBOL(il_apm_stop);
997 * (e.g. after platform boot, or shutdown via il_apm_stop()) 997 * (e.g. after platform boot, or shutdown via il_apm_stop())
998 * NOTE: This does not load uCode nor start the embedded processor 998 * NOTE: This does not load uCode nor start the embedded processor
999 */ 999 */
1000int il_apm_init(struct il_priv *priv) 1000int il_apm_init(struct il_priv *il)
1001{ 1001{
1002 int ret = 0; 1002 int ret = 0;
1003 u16 lctl; 1003 u16 lctl;
1004 1004
1005 IL_DEBUG_INFO(priv, "Init card's basic functions\n"); 1005 IL_DEBUG_INFO(il, "Init card's basic functions\n");
1006 1006
1007 /* 1007 /*
1008 * Use "set_bit" below rather than "write", to preserve any hardware 1008 * Use "set_bit" below rather than "write", to preserve any hardware
@@ -1010,18 +1010,18 @@ int il_apm_init(struct il_priv *priv)
1010 */ 1010 */
1011 1011
1012 /* Disable L0S exit timer (platform NMI Work/Around) */ 1012 /* Disable L0S exit timer (platform NMI Work/Around) */
1013 il_set_bit(priv, CSR_GIO_CHICKEN_BITS, 1013 il_set_bit(il, CSR_GIO_CHICKEN_BITS,
1014 CSR_GIO_CHICKEN_BITS_REG_BIT_DIS_L0S_EXIT_TIMER); 1014 CSR_GIO_CHICKEN_BITS_REG_BIT_DIS_L0S_EXIT_TIMER);
1015 1015
1016 /* 1016 /*
1017 * Disable L0s without affecting L1; 1017 * Disable L0s without affecting L1;
1018 * don't wait for ICH L0s (ICH bug W/A) 1018 * don't wait for ICH L0s (ICH bug W/A)
1019 */ 1019 */
1020 il_set_bit(priv, CSR_GIO_CHICKEN_BITS, 1020 il_set_bit(il, CSR_GIO_CHICKEN_BITS,
1021 CSR_GIO_CHICKEN_BITS_REG_BIT_L1A_NO_L0S_RX); 1021 CSR_GIO_CHICKEN_BITS_REG_BIT_L1A_NO_L0S_RX);
1022 1022
1023 /* Set FH wait threshold to maximum (HW error during stress W/A) */ 1023 /* Set FH wait threshold to maximum (HW error during stress W/A) */
1024 il_set_bit(priv, CSR_DBG_HPET_MEM_REG, 1024 il_set_bit(il, CSR_DBG_HPET_MEM_REG,
1025 CSR_DBG_HPET_MEM_REG_VAL); 1025 CSR_DBG_HPET_MEM_REG_VAL);
1026 1026
1027 /* 1027 /*
@@ -1029,7 +1029,7 @@ int il_apm_init(struct il_priv *priv)
1029 * wake device's PCI Express link L1a -> L0s 1029 * wake device's PCI Express link L1a -> L0s
1030 * NOTE: This is no-op for 3945 (non-existent bit) 1030 * NOTE: This is no-op for 3945 (non-existent bit)
1031 */ 1031 */
1032 il_set_bit(priv, CSR_HW_IF_CONFIG_REG, 1032 il_set_bit(il, CSR_HW_IF_CONFIG_REG,
1033 CSR_HW_IF_CONFIG_REG_BIT_HAP_WAKE_L1A); 1033 CSR_HW_IF_CONFIG_REG_BIT_HAP_WAKE_L1A);
1034 1034
1035 /* 1035 /*
@@ -1040,43 +1040,43 @@ int il_apm_init(struct il_priv *priv)
1040 * If not (unlikely), enable L0S, so there is at least some 1040 * If not (unlikely), enable L0S, so there is at least some
1041 * power savings, even without L1. 1041 * power savings, even without L1.
1042 */ 1042 */
1043 if (priv->cfg->base_params->set_l0s) { 1043 if (il->cfg->base_params->set_l0s) {
1044 lctl = il_pcie_link_ctl(priv); 1044 lctl = il_pcie_link_ctl(il);
1045 if ((lctl & PCI_CFG_LINK_CTRL_VAL_L1_EN) == 1045 if ((lctl & PCI_CFG_LINK_CTRL_VAL_L1_EN) ==
1046 PCI_CFG_LINK_CTRL_VAL_L1_EN) { 1046 PCI_CFG_LINK_CTRL_VAL_L1_EN) {
1047 /* L1-ASPM enabled; disable(!) L0S */ 1047 /* L1-ASPM enabled; disable(!) L0S */
1048 il_set_bit(priv, CSR_GIO_REG, 1048 il_set_bit(il, CSR_GIO_REG,
1049 CSR_GIO_REG_VAL_L0S_ENABLED); 1049 CSR_GIO_REG_VAL_L0S_ENABLED);
1050 IL_DEBUG_POWER(priv, "L1 Enabled; Disabling L0S\n"); 1050 IL_DEBUG_POWER(il, "L1 Enabled; Disabling L0S\n");
1051 } else { 1051 } else {
1052 /* L1-ASPM disabled; enable(!) L0S */ 1052 /* L1-ASPM disabled; enable(!) L0S */
1053 il_clear_bit(priv, CSR_GIO_REG, 1053 il_clear_bit(il, CSR_GIO_REG,
1054 CSR_GIO_REG_VAL_L0S_ENABLED); 1054 CSR_GIO_REG_VAL_L0S_ENABLED);
1055 IL_DEBUG_POWER(priv, "L1 Disabled; Enabling L0S\n"); 1055 IL_DEBUG_POWER(il, "L1 Disabled; Enabling L0S\n");
1056 } 1056 }
1057 } 1057 }
1058 1058
1059 /* Configure analog phase-lock-loop before activating to D0A */ 1059 /* Configure analog phase-lock-loop before activating to D0A */
1060 if (priv->cfg->base_params->pll_cfg_val) 1060 if (il->cfg->base_params->pll_cfg_val)
1061 il_set_bit(priv, CSR_ANA_PLL_CFG, 1061 il_set_bit(il, CSR_ANA_PLL_CFG,
1062 priv->cfg->base_params->pll_cfg_val); 1062 il->cfg->base_params->pll_cfg_val);
1063 1063
1064 /* 1064 /*
1065 * Set "initialization complete" bit to move adapter from 1065 * Set "initialization complete" bit to move adapter from
1066 * D0U* --> D0A* (powered-up active) state. 1066 * D0U* --> D0A* (powered-up active) state.
1067 */ 1067 */
1068 il_set_bit(priv, CSR_GP_CNTRL, CSR_GP_CNTRL_REG_FLAG_INIT_DONE); 1068 il_set_bit(il, CSR_GP_CNTRL, CSR_GP_CNTRL_REG_FLAG_INIT_DONE);
1069 1069
1070 /* 1070 /*
1071 * Wait for clock stabilization; once stabilized, access to 1071 * Wait for clock stabilization; once stabilized, access to
1072 * device-internal resources is supported, e.g. il_write_prph() 1072 * device-internal resources is supported, e.g. il_write_prph()
1073 * and accesses to uCode SRAM. 1073 * and accesses to uCode SRAM.
1074 */ 1074 */
1075 ret = il_poll_bit(priv, CSR_GP_CNTRL, 1075 ret = il_poll_bit(il, CSR_GP_CNTRL,
1076 CSR_GP_CNTRL_REG_FLAG_MAC_CLOCK_READY, 1076 CSR_GP_CNTRL_REG_FLAG_MAC_CLOCK_READY,
1077 CSR_GP_CNTRL_REG_FLAG_MAC_CLOCK_READY, 25000); 1077 CSR_GP_CNTRL_REG_FLAG_MAC_CLOCK_READY, 25000);
1078 if (ret < 0) { 1078 if (ret < 0) {
1079 IL_DEBUG_INFO(priv, "Failed to init the card\n"); 1079 IL_DEBUG_INFO(il, "Failed to init the card\n");
1080 goto out; 1080 goto out;
1081 } 1081 }
1082 1082
@@ -1088,16 +1088,16 @@ int il_apm_init(struct il_priv *priv)
1088 * do not disable clocks. This preserves any hardware bits already 1088 * do not disable clocks. This preserves any hardware bits already
1089 * set by default in "CLK_CTRL_REG" after reset. 1089 * set by default in "CLK_CTRL_REG" after reset.
1090 */ 1090 */
1091 if (priv->cfg->base_params->use_bsm) 1091 if (il->cfg->base_params->use_bsm)
1092 il_write_prph(priv, APMG_CLK_EN_REG, 1092 il_write_prph(il, APMG_CLK_EN_REG,
1093 APMG_CLK_VAL_DMA_CLK_RQT | APMG_CLK_VAL_BSM_CLK_RQT); 1093 APMG_CLK_VAL_DMA_CLK_RQT | APMG_CLK_VAL_BSM_CLK_RQT);
1094 else 1094 else
1095 il_write_prph(priv, APMG_CLK_EN_REG, 1095 il_write_prph(il, APMG_CLK_EN_REG,
1096 APMG_CLK_VAL_DMA_CLK_RQT); 1096 APMG_CLK_VAL_DMA_CLK_RQT);
1097 udelay(20); 1097 udelay(20);
1098 1098
1099 /* Disable L1-Active */ 1099 /* Disable L1-Active */
1100 il_set_bits_prph(priv, APMG_PCIDEV_STT_REG, 1100 il_set_bits_prph(il, APMG_PCIDEV_STT_REG,
1101 APMG_PCIDEV_STT_VAL_L1_ACT_DIS); 1101 APMG_PCIDEV_STT_VAL_L1_ACT_DIS);
1102 1102
1103out: 1103out:
@@ -1106,66 +1106,66 @@ out:
1106EXPORT_SYMBOL(il_apm_init); 1106EXPORT_SYMBOL(il_apm_init);
1107 1107
1108 1108
1109int il_set_tx_power(struct il_priv *priv, s8 tx_power, bool force) 1109int il_set_tx_power(struct il_priv *il, s8 tx_power, bool force)
1110{ 1110{
1111 int ret; 1111 int ret;
1112 s8 prev_tx_power; 1112 s8 prev_tx_power;
1113 bool defer; 1113 bool defer;
1114 struct il_rxon_context *ctx = &priv->contexts[IL_RXON_CTX_BSS]; 1114 struct il_rxon_context *ctx = &il->contexts[IL_RXON_CTX_BSS];
1115 1115
1116 lockdep_assert_held(&priv->mutex); 1116 lockdep_assert_held(&il->mutex);
1117 1117
1118 if (priv->tx_power_user_lmt == tx_power && !force) 1118 if (il->tx_power_user_lmt == tx_power && !force)
1119 return 0; 1119 return 0;
1120 1120
1121 if (!priv->cfg->ops->lib->send_tx_power) 1121 if (!il->cfg->ops->lib->send_tx_power)
1122 return -EOPNOTSUPP; 1122 return -EOPNOTSUPP;
1123 1123
1124 /* 0 dBm mean 1 milliwatt */ 1124 /* 0 dBm mean 1 milliwatt */
1125 if (tx_power < 0) { 1125 if (tx_power < 0) {
1126 IL_WARN(priv, 1126 IL_WARN(il,
1127 "Requested user TXPOWER %d below 1 mW.\n", 1127 "Requested user TXPOWER %d below 1 mW.\n",
1128 tx_power); 1128 tx_power);
1129 return -EINVAL; 1129 return -EINVAL;
1130 } 1130 }
1131 1131
1132 if (tx_power > priv->tx_power_device_lmt) { 1132 if (tx_power > il->tx_power_device_lmt) {
1133 IL_WARN(priv, 1133 IL_WARN(il,
1134 "Requested user TXPOWER %d above upper limit %d.\n", 1134 "Requested user TXPOWER %d above upper limit %d.\n",
1135 tx_power, priv->tx_power_device_lmt); 1135 tx_power, il->tx_power_device_lmt);
1136 return -EINVAL; 1136 return -EINVAL;
1137 } 1137 }
1138 1138
1139 if (!il_is_ready_rf(priv)) 1139 if (!il_is_ready_rf(il))
1140 return -EIO; 1140 return -EIO;
1141 1141
1142 /* scan complete and commit_rxon use tx_power_next value, 1142 /* scan complete and commit_rxon use tx_power_next value,
1143 * it always need to be updated for newest request */ 1143 * it always need to be updated for newest request */
1144 priv->tx_power_next = tx_power; 1144 il->tx_power_next = tx_power;
1145 1145
1146 /* do not set tx power when scanning or channel changing */ 1146 /* do not set tx power when scanning or channel changing */
1147 defer = test_bit(STATUS_SCANNING, &priv->status) || 1147 defer = test_bit(STATUS_SCANNING, &il->status) ||
1148 memcmp(&ctx->active, &ctx->staging, sizeof(ctx->staging)); 1148 memcmp(&ctx->active, &ctx->staging, sizeof(ctx->staging));
1149 if (defer && !force) { 1149 if (defer && !force) {
1150 IL_DEBUG_INFO(priv, "Deferring tx power set\n"); 1150 IL_DEBUG_INFO(il, "Deferring tx power set\n");
1151 return 0; 1151 return 0;
1152 } 1152 }
1153 1153
1154 prev_tx_power = priv->tx_power_user_lmt; 1154 prev_tx_power = il->tx_power_user_lmt;
1155 priv->tx_power_user_lmt = tx_power; 1155 il->tx_power_user_lmt = tx_power;
1156 1156
1157 ret = priv->cfg->ops->lib->send_tx_power(priv); 1157 ret = il->cfg->ops->lib->send_tx_power(il);
1158 1158
1159 /* if fail to set tx_power, restore the orig. tx power */ 1159 /* if fail to set tx_power, restore the orig. tx power */
1160 if (ret) { 1160 if (ret) {
1161 priv->tx_power_user_lmt = prev_tx_power; 1161 il->tx_power_user_lmt = prev_tx_power;
1162 priv->tx_power_next = prev_tx_power; 1162 il->tx_power_next = prev_tx_power;
1163 } 1163 }
1164 return ret; 1164 return ret;
1165} 1165}
1166EXPORT_SYMBOL(il_set_tx_power); 1166EXPORT_SYMBOL(il_set_tx_power);
1167 1167
1168void il_send_bt_config(struct il_priv *priv) 1168void il_send_bt_config(struct il_priv *il)
1169{ 1169{
1170 struct il_bt_cmd bt_cmd = { 1170 struct il_bt_cmd bt_cmd = {
1171 .lead_time = BT_LEAD_TIME_DEF, 1171 .lead_time = BT_LEAD_TIME_DEF,
@@ -1179,16 +1179,16 @@ void il_send_bt_config(struct il_priv *priv)
1179 else 1179 else
1180 bt_cmd.flags = BT_COEX_ENABLE; 1180 bt_cmd.flags = BT_COEX_ENABLE;
1181 1181
1182 IL_DEBUG_INFO(priv, "BT coex %s\n", 1182 IL_DEBUG_INFO(il, "BT coex %s\n",
1183 (bt_cmd.flags == BT_COEX_DISABLE) ? "disable" : "active"); 1183 (bt_cmd.flags == BT_COEX_DISABLE) ? "disable" : "active");
1184 1184
1185 if (il_send_cmd_pdu(priv, REPLY_BT_CONFIG, 1185 if (il_send_cmd_pdu(il, REPLY_BT_CONFIG,
1186 sizeof(struct il_bt_cmd), &bt_cmd)) 1186 sizeof(struct il_bt_cmd), &bt_cmd))
1187 IL_ERR(priv, "failed to send BT Coex Config\n"); 1187 IL_ERR(il, "failed to send BT Coex Config\n");
1188} 1188}
1189EXPORT_SYMBOL(il_send_bt_config); 1189EXPORT_SYMBOL(il_send_bt_config);
1190 1190
1191int il_send_statistics_request(struct il_priv *priv, u8 flags, bool clear) 1191int il_send_statistics_request(struct il_priv *il, u8 flags, bool clear)
1192{ 1192{
1193 struct il_statistics_cmd statistics_cmd = { 1193 struct il_statistics_cmd statistics_cmd = {
1194 .configuration_flags = 1194 .configuration_flags =
@@ -1196,46 +1196,46 @@ int il_send_statistics_request(struct il_priv *priv, u8 flags, bool clear)
1196 }; 1196 };
1197 1197
1198 if (flags & CMD_ASYNC) 1198 if (flags & CMD_ASYNC)
1199 return il_send_cmd_pdu_async(priv, REPLY_STATISTICS_CMD, 1199 return il_send_cmd_pdu_async(il, REPLY_STATISTICS_CMD,
1200 sizeof(struct il_statistics_cmd), 1200 sizeof(struct il_statistics_cmd),
1201 &statistics_cmd, NULL); 1201 &statistics_cmd, NULL);
1202 else 1202 else
1203 return il_send_cmd_pdu(priv, REPLY_STATISTICS_CMD, 1203 return il_send_cmd_pdu(il, REPLY_STATISTICS_CMD,
1204 sizeof(struct il_statistics_cmd), 1204 sizeof(struct il_statistics_cmd),
1205 &statistics_cmd); 1205 &statistics_cmd);
1206} 1206}
1207EXPORT_SYMBOL(il_send_statistics_request); 1207EXPORT_SYMBOL(il_send_statistics_request);
1208 1208
1209void il_rx_pm_sleep_notif(struct il_priv *priv, 1209void il_rx_pm_sleep_notif(struct il_priv *il,
1210 struct il_rx_mem_buffer *rxb) 1210 struct il_rx_mem_buffer *rxb)
1211{ 1211{
1212#ifdef CONFIG_IWLWIFI_LEGACY_DEBUG 1212#ifdef CONFIG_IWLWIFI_LEGACY_DEBUG
1213 struct il_rx_packet *pkt = rxb_addr(rxb); 1213 struct il_rx_packet *pkt = rxb_addr(rxb);
1214 struct il_sleep_notification *sleep = &(pkt->u.sleep_notif); 1214 struct il_sleep_notification *sleep = &(pkt->u.sleep_notif);
1215 IL_DEBUG_RX(priv, "sleep mode: %d, src: %d\n", 1215 IL_DEBUG_RX(il, "sleep mode: %d, src: %d\n",
1216 sleep->pm_sleep_mode, sleep->pm_wakeup_src); 1216 sleep->pm_sleep_mode, sleep->pm_wakeup_src);
1217#endif 1217#endif
1218} 1218}
1219EXPORT_SYMBOL(il_rx_pm_sleep_notif); 1219EXPORT_SYMBOL(il_rx_pm_sleep_notif);
1220 1220
1221void il_rx_pm_debug_statistics_notif(struct il_priv *priv, 1221void il_rx_pm_debug_statistics_notif(struct il_priv *il,
1222 struct il_rx_mem_buffer *rxb) 1222 struct il_rx_mem_buffer *rxb)
1223{ 1223{
1224 struct il_rx_packet *pkt = rxb_addr(rxb); 1224 struct il_rx_packet *pkt = rxb_addr(rxb);
1225 u32 len = le32_to_cpu(pkt->len_n_flags) & FH_RSCSR_FRAME_SIZE_MSK; 1225 u32 len = le32_to_cpu(pkt->len_n_flags) & FH_RSCSR_FRAME_SIZE_MSK;
1226 IL_DEBUG_RADIO(priv, "Dumping %d bytes of unhandled " 1226 IL_DEBUG_RADIO(il, "Dumping %d bytes of unhandled "
1227 "notification for %s:\n", len, 1227 "notification for %s:\n", len,
1228 il_get_cmd_string(pkt->hdr.cmd)); 1228 il_get_cmd_string(pkt->hdr.cmd));
1229 il_print_hex_dump(priv, IL_DL_RADIO, pkt->u.raw, len); 1229 il_print_hex_dump(il, IL_DL_RADIO, pkt->u.raw, len);
1230} 1230}
1231EXPORT_SYMBOL(il_rx_pm_debug_statistics_notif); 1231EXPORT_SYMBOL(il_rx_pm_debug_statistics_notif);
1232 1232
1233void il_rx_reply_error(struct il_priv *priv, 1233void il_rx_reply_error(struct il_priv *il,
1234 struct il_rx_mem_buffer *rxb) 1234 struct il_rx_mem_buffer *rxb)
1235{ 1235{
1236 struct il_rx_packet *pkt = rxb_addr(rxb); 1236 struct il_rx_packet *pkt = rxb_addr(rxb);
1237 1237
1238 IL_ERR(priv, "Error Reply type 0x%08X cmd %s (0x%02X) " 1238 IL_ERR(il, "Error Reply type 0x%08X cmd %s (0x%02X) "
1239 "seq 0x%04X ser 0x%08X\n", 1239 "seq 0x%04X ser 0x%08X\n",
1240 le32_to_cpu(pkt->u.err_resp.error_type), 1240 le32_to_cpu(pkt->u.err_resp.error_type),
1241 il_get_cmd_string(pkt->u.err_resp.cmd_id), 1241 il_get_cmd_string(pkt->u.err_resp.cmd_id),
@@ -1245,37 +1245,37 @@ void il_rx_reply_error(struct il_priv *priv,
1245} 1245}
1246EXPORT_SYMBOL(il_rx_reply_error); 1246EXPORT_SYMBOL(il_rx_reply_error);
1247 1247
1248void il_clear_isr_stats(struct il_priv *priv) 1248void il_clear_isr_stats(struct il_priv *il)
1249{ 1249{
1250 memset(&priv->isr_stats, 0, sizeof(priv->isr_stats)); 1250 memset(&il->isr_stats, 0, sizeof(il->isr_stats));
1251} 1251}
1252 1252
1253int il_mac_conf_tx(struct ieee80211_hw *hw, 1253int il_mac_conf_tx(struct ieee80211_hw *hw,
1254 struct ieee80211_vif *vif, u16 queue, 1254 struct ieee80211_vif *vif, u16 queue,
1255 const struct ieee80211_tx_queue_params *params) 1255 const struct ieee80211_tx_queue_params *params)
1256{ 1256{
1257 struct il_priv *priv = hw->priv; 1257 struct il_priv *il = hw->priv;
1258 struct il_rxon_context *ctx; 1258 struct il_rxon_context *ctx;
1259 unsigned long flags; 1259 unsigned long flags;
1260 int q; 1260 int q;
1261 1261
1262 IL_DEBUG_MAC80211(priv, "enter\n"); 1262 IL_DEBUG_MAC80211(il, "enter\n");
1263 1263
1264 if (!il_is_ready_rf(priv)) { 1264 if (!il_is_ready_rf(il)) {
1265 IL_DEBUG_MAC80211(priv, "leave - RF not ready\n"); 1265 IL_DEBUG_MAC80211(il, "leave - RF not ready\n");
1266 return -EIO; 1266 return -EIO;
1267 } 1267 }
1268 1268
1269 if (queue >= AC_NUM) { 1269 if (queue >= AC_NUM) {
1270 IL_DEBUG_MAC80211(priv, "leave - queue >= AC_NUM %d\n", queue); 1270 IL_DEBUG_MAC80211(il, "leave - queue >= AC_NUM %d\n", queue);
1271 return 0; 1271 return 0;
1272 } 1272 }
1273 1273
1274 q = AC_NUM - 1 - queue; 1274 q = AC_NUM - 1 - queue;
1275 1275
1276 spin_lock_irqsave(&priv->lock, flags); 1276 spin_lock_irqsave(&il->lock, flags);
1277 1277
1278 for_each_context(priv, ctx) { 1278 for_each_context(il, ctx) {
1279 ctx->qos_data.def_qos_parm.ac[q].cw_min = 1279 ctx->qos_data.def_qos_parm.ac[q].cw_min =
1280 cpu_to_le16(params->cw_min); 1280 cpu_to_le16(params->cw_min);
1281 ctx->qos_data.def_qos_parm.ac[q].cw_max = 1281 ctx->qos_data.def_qos_parm.ac[q].cw_max =
@@ -1287,50 +1287,50 @@ int il_mac_conf_tx(struct ieee80211_hw *hw,
1287 ctx->qos_data.def_qos_parm.ac[q].reserved1 = 0; 1287 ctx->qos_data.def_qos_parm.ac[q].reserved1 = 0;
1288 } 1288 }
1289 1289
1290 spin_unlock_irqrestore(&priv->lock, flags); 1290 spin_unlock_irqrestore(&il->lock, flags);
1291 1291
1292 IL_DEBUG_MAC80211(priv, "leave\n"); 1292 IL_DEBUG_MAC80211(il, "leave\n");
1293 return 0; 1293 return 0;
1294} 1294}
1295EXPORT_SYMBOL(il_mac_conf_tx); 1295EXPORT_SYMBOL(il_mac_conf_tx);
1296 1296
1297int il_mac_tx_last_beacon(struct ieee80211_hw *hw) 1297int il_mac_tx_last_beacon(struct ieee80211_hw *hw)
1298{ 1298{
1299 struct il_priv *priv = hw->priv; 1299 struct il_priv *il = hw->priv;
1300 1300
1301 return priv->ibss_manager == IL_IBSS_MANAGER; 1301 return il->ibss_manager == IL_IBSS_MANAGER;
1302} 1302}
1303EXPORT_SYMBOL_GPL(il_mac_tx_last_beacon); 1303EXPORT_SYMBOL_GPL(il_mac_tx_last_beacon);
1304 1304
1305static int 1305static int
1306il_set_mode(struct il_priv *priv, struct il_rxon_context *ctx) 1306il_set_mode(struct il_priv *il, struct il_rxon_context *ctx)
1307{ 1307{
1308 il_connection_init_rx_config(priv, ctx); 1308 il_connection_init_rx_config(il, ctx);
1309 1309
1310 if (priv->cfg->ops->hcmd->set_rxon_chain) 1310 if (il->cfg->ops->hcmd->set_rxon_chain)
1311 priv->cfg->ops->hcmd->set_rxon_chain(priv, ctx); 1311 il->cfg->ops->hcmd->set_rxon_chain(il, ctx);
1312 1312
1313 return il_commit_rxon(priv, ctx); 1313 return il_commit_rxon(il, ctx);
1314} 1314}
1315 1315
1316static int il_setup_interface(struct il_priv *priv, 1316static int il_setup_interface(struct il_priv *il,
1317 struct il_rxon_context *ctx) 1317 struct il_rxon_context *ctx)
1318{ 1318{
1319 struct ieee80211_vif *vif = ctx->vif; 1319 struct ieee80211_vif *vif = ctx->vif;
1320 int err; 1320 int err;
1321 1321
1322 lockdep_assert_held(&priv->mutex); 1322 lockdep_assert_held(&il->mutex);
1323 1323
1324 /* 1324 /*
1325 * This variable will be correct only when there's just 1325 * This variable will be correct only when there's just
1326 * a single context, but all code using it is for hardware 1326 * a single context, but all code using it is for hardware
1327 * that supports only one context. 1327 * that supports only one context.
1328 */ 1328 */
1329 priv->iw_mode = vif->type; 1329 il->iw_mode = vif->type;
1330 1330
1331 ctx->is_active = true; 1331 ctx->is_active = true;
1332 1332
1333 err = il_set_mode(priv, ctx); 1333 err = il_set_mode(il, ctx);
1334 if (err) { 1334 if (err) {
1335 if (!ctx->always_active) 1335 if (!ctx->always_active)
1336 ctx->is_active = false; 1336 ctx->is_active = false;
@@ -1343,23 +1343,23 @@ static int il_setup_interface(struct il_priv *priv,
1343int 1343int
1344il_mac_add_interface(struct ieee80211_hw *hw, struct ieee80211_vif *vif) 1344il_mac_add_interface(struct ieee80211_hw *hw, struct ieee80211_vif *vif)
1345{ 1345{
1346 struct il_priv *priv = hw->priv; 1346 struct il_priv *il = hw->priv;
1347 struct il_vif_priv *vif_priv = (void *)vif->drv_priv; 1347 struct il_vif_priv *vif_priv = (void *)vif->drv_priv;
1348 struct il_rxon_context *tmp, *ctx = NULL; 1348 struct il_rxon_context *tmp, *ctx = NULL;
1349 int err; 1349 int err;
1350 1350
1351 IL_DEBUG_MAC80211(priv, "enter: type %d, addr %pM\n", 1351 IL_DEBUG_MAC80211(il, "enter: type %d, addr %pM\n",
1352 vif->type, vif->addr); 1352 vif->type, vif->addr);
1353 1353
1354 mutex_lock(&priv->mutex); 1354 mutex_lock(&il->mutex);
1355 1355
1356 if (!il_is_ready_rf(priv)) { 1356 if (!il_is_ready_rf(il)) {
1357 IL_WARN(priv, "Try to add interface when device not ready\n"); 1357 IL_WARN(il, "Try to add interface when device not ready\n");
1358 err = -EINVAL; 1358 err = -EINVAL;
1359 goto out; 1359 goto out;
1360 } 1360 }
1361 1361
1362 for_each_context(priv, tmp) { 1362 for_each_context(il, tmp) {
1363 u32 possible_modes = 1363 u32 possible_modes =
1364 tmp->interface_modes | tmp->exclusive_interface_modes; 1364 tmp->interface_modes | tmp->exclusive_interface_modes;
1365 1365
@@ -1389,35 +1389,35 @@ il_mac_add_interface(struct ieee80211_hw *hw, struct ieee80211_vif *vif)
1389 vif_priv->ctx = ctx; 1389 vif_priv->ctx = ctx;
1390 ctx->vif = vif; 1390 ctx->vif = vif;
1391 1391
1392 err = il_setup_interface(priv, ctx); 1392 err = il_setup_interface(il, ctx);
1393 if (!err) 1393 if (!err)
1394 goto out; 1394 goto out;
1395 1395
1396 ctx->vif = NULL; 1396 ctx->vif = NULL;
1397 priv->iw_mode = NL80211_IFTYPE_STATION; 1397 il->iw_mode = NL80211_IFTYPE_STATION;
1398 out: 1398 out:
1399 mutex_unlock(&priv->mutex); 1399 mutex_unlock(&il->mutex);
1400 1400
1401 IL_DEBUG_MAC80211(priv, "leave\n"); 1401 IL_DEBUG_MAC80211(il, "leave\n");
1402 return err; 1402 return err;
1403} 1403}
1404EXPORT_SYMBOL(il_mac_add_interface); 1404EXPORT_SYMBOL(il_mac_add_interface);
1405 1405
1406static void il_teardown_interface(struct il_priv *priv, 1406static void il_teardown_interface(struct il_priv *il,
1407 struct ieee80211_vif *vif, 1407 struct ieee80211_vif *vif,
1408 bool mode_change) 1408 bool mode_change)
1409{ 1409{
1410 struct il_rxon_context *ctx = il_rxon_ctx_from_vif(vif); 1410 struct il_rxon_context *ctx = il_rxon_ctx_from_vif(vif);
1411 1411
1412 lockdep_assert_held(&priv->mutex); 1412 lockdep_assert_held(&il->mutex);
1413 1413
1414 if (priv->scan_vif == vif) { 1414 if (il->scan_vif == vif) {
1415 il_scan_cancel_timeout(priv, 200); 1415 il_scan_cancel_timeout(il, 200);
1416 il_force_scan_end(priv); 1416 il_force_scan_end(il);
1417 } 1417 }
1418 1418
1419 if (!mode_change) { 1419 if (!mode_change) {
1420 il_set_mode(priv, ctx); 1420 il_set_mode(il, ctx);
1421 if (!ctx->always_active) 1421 if (!ctx->always_active)
1422 ctx->is_active = false; 1422 ctx->is_active = false;
1423 } 1423 }
@@ -1426,45 +1426,45 @@ static void il_teardown_interface(struct il_priv *priv,
1426void il_mac_remove_interface(struct ieee80211_hw *hw, 1426void il_mac_remove_interface(struct ieee80211_hw *hw,
1427 struct ieee80211_vif *vif) 1427 struct ieee80211_vif *vif)
1428{ 1428{
1429 struct il_priv *priv = hw->priv; 1429 struct il_priv *il = hw->priv;
1430 struct il_rxon_context *ctx = il_rxon_ctx_from_vif(vif); 1430 struct il_rxon_context *ctx = il_rxon_ctx_from_vif(vif);
1431 1431
1432 IL_DEBUG_MAC80211(priv, "enter\n"); 1432 IL_DEBUG_MAC80211(il, "enter\n");
1433 1433
1434 mutex_lock(&priv->mutex); 1434 mutex_lock(&il->mutex);
1435 1435
1436 WARN_ON(ctx->vif != vif); 1436 WARN_ON(ctx->vif != vif);
1437 ctx->vif = NULL; 1437 ctx->vif = NULL;
1438 1438
1439 il_teardown_interface(priv, vif, false); 1439 il_teardown_interface(il, vif, false);
1440 1440
1441 memset(priv->bssid, 0, ETH_ALEN); 1441 memset(il->bssid, 0, ETH_ALEN);
1442 mutex_unlock(&priv->mutex); 1442 mutex_unlock(&il->mutex);
1443 1443
1444 IL_DEBUG_MAC80211(priv, "leave\n"); 1444 IL_DEBUG_MAC80211(il, "leave\n");
1445 1445
1446} 1446}
1447EXPORT_SYMBOL(il_mac_remove_interface); 1447EXPORT_SYMBOL(il_mac_remove_interface);
1448 1448
1449int il_alloc_txq_mem(struct il_priv *priv) 1449int il_alloc_txq_mem(struct il_priv *il)
1450{ 1450{
1451 if (!priv->txq) 1451 if (!il->txq)
1452 priv->txq = kzalloc( 1452 il->txq = kzalloc(
1453 sizeof(struct il_tx_queue) * 1453 sizeof(struct il_tx_queue) *
1454 priv->cfg->base_params->num_of_queues, 1454 il->cfg->base_params->num_of_queues,
1455 GFP_KERNEL); 1455 GFP_KERNEL);
1456 if (!priv->txq) { 1456 if (!il->txq) {
1457 IL_ERR(priv, "Not enough memory for txq\n"); 1457 IL_ERR(il, "Not enough memory for txq\n");
1458 return -ENOMEM; 1458 return -ENOMEM;
1459 } 1459 }
1460 return 0; 1460 return 0;
1461} 1461}
1462EXPORT_SYMBOL(il_alloc_txq_mem); 1462EXPORT_SYMBOL(il_alloc_txq_mem);
1463 1463
1464void il_txq_mem(struct il_priv *priv) 1464void il_txq_mem(struct il_priv *il)
1465{ 1465{
1466 kfree(priv->txq); 1466 kfree(il->txq);
1467 priv->txq = NULL; 1467 il->txq = NULL;
1468} 1468}
1469EXPORT_SYMBOL(il_txq_mem); 1469EXPORT_SYMBOL(il_txq_mem);
1470 1470
@@ -1472,52 +1472,52 @@ EXPORT_SYMBOL(il_txq_mem);
1472 1472
1473#define IL_TRAFFIC_DUMP_SIZE (IL_TRAFFIC_ENTRY_SIZE * IL_TRAFFIC_ENTRIES) 1473#define IL_TRAFFIC_DUMP_SIZE (IL_TRAFFIC_ENTRY_SIZE * IL_TRAFFIC_ENTRIES)
1474 1474
1475void il_reset_traffic_log(struct il_priv *priv) 1475void il_reset_traffic_log(struct il_priv *il)
1476{ 1476{
1477 priv->tx_traffic_idx = 0; 1477 il->tx_traffic_idx = 0;
1478 priv->rx_traffic_idx = 0; 1478 il->rx_traffic_idx = 0;
1479 if (priv->tx_traffic) 1479 if (il->tx_traffic)
1480 memset(priv->tx_traffic, 0, IL_TRAFFIC_DUMP_SIZE); 1480 memset(il->tx_traffic, 0, IL_TRAFFIC_DUMP_SIZE);
1481 if (priv->rx_traffic) 1481 if (il->rx_traffic)
1482 memset(priv->rx_traffic, 0, IL_TRAFFIC_DUMP_SIZE); 1482 memset(il->rx_traffic, 0, IL_TRAFFIC_DUMP_SIZE);
1483} 1483}
1484 1484
1485int il_alloc_traffic_mem(struct il_priv *priv) 1485int il_alloc_traffic_mem(struct il_priv *il)
1486{ 1486{
1487 u32 traffic_size = IL_TRAFFIC_DUMP_SIZE; 1487 u32 traffic_size = IL_TRAFFIC_DUMP_SIZE;
1488 1488
1489 if (iwlegacy_debug_level & IL_DL_TX) { 1489 if (iwlegacy_debug_level & IL_DL_TX) {
1490 if (!priv->tx_traffic) { 1490 if (!il->tx_traffic) {
1491 priv->tx_traffic = 1491 il->tx_traffic =
1492 kzalloc(traffic_size, GFP_KERNEL); 1492 kzalloc(traffic_size, GFP_KERNEL);
1493 if (!priv->tx_traffic) 1493 if (!il->tx_traffic)
1494 return -ENOMEM; 1494 return -ENOMEM;
1495 } 1495 }
1496 } 1496 }
1497 if (iwlegacy_debug_level & IL_DL_RX) { 1497 if (iwlegacy_debug_level & IL_DL_RX) {
1498 if (!priv->rx_traffic) { 1498 if (!il->rx_traffic) {
1499 priv->rx_traffic = 1499 il->rx_traffic =
1500 kzalloc(traffic_size, GFP_KERNEL); 1500 kzalloc(traffic_size, GFP_KERNEL);
1501 if (!priv->rx_traffic) 1501 if (!il->rx_traffic)
1502 return -ENOMEM; 1502 return -ENOMEM;
1503 } 1503 }
1504 } 1504 }
1505 il_reset_traffic_log(priv); 1505 il_reset_traffic_log(il);
1506 return 0; 1506 return 0;
1507} 1507}
1508EXPORT_SYMBOL(il_alloc_traffic_mem); 1508EXPORT_SYMBOL(il_alloc_traffic_mem);
1509 1509
1510void il_free_traffic_mem(struct il_priv *priv) 1510void il_free_traffic_mem(struct il_priv *il)
1511{ 1511{
1512 kfree(priv->tx_traffic); 1512 kfree(il->tx_traffic);
1513 priv->tx_traffic = NULL; 1513 il->tx_traffic = NULL;
1514 1514
1515 kfree(priv->rx_traffic); 1515 kfree(il->rx_traffic);
1516 priv->rx_traffic = NULL; 1516 il->rx_traffic = NULL;
1517} 1517}
1518EXPORT_SYMBOL(il_free_traffic_mem); 1518EXPORT_SYMBOL(il_free_traffic_mem);
1519 1519
1520void il_dbg_log_tx_data_frame(struct il_priv *priv, 1520void il_dbg_log_tx_data_frame(struct il_priv *il,
1521 u16 length, struct ieee80211_hdr *header) 1521 u16 length, struct ieee80211_hdr *header)
1522{ 1522{
1523 __le16 fc; 1523 __le16 fc;
@@ -1526,23 +1526,23 @@ void il_dbg_log_tx_data_frame(struct il_priv *priv,
1526 if (likely(!(iwlegacy_debug_level & IL_DL_TX))) 1526 if (likely(!(iwlegacy_debug_level & IL_DL_TX)))
1527 return; 1527 return;
1528 1528
1529 if (!priv->tx_traffic) 1529 if (!il->tx_traffic)
1530 return; 1530 return;
1531 1531
1532 fc = header->frame_control; 1532 fc = header->frame_control;
1533 if (ieee80211_is_data(fc)) { 1533 if (ieee80211_is_data(fc)) {
1534 len = (length > IL_TRAFFIC_ENTRY_SIZE) 1534 len = (length > IL_TRAFFIC_ENTRY_SIZE)
1535 ? IL_TRAFFIC_ENTRY_SIZE : length; 1535 ? IL_TRAFFIC_ENTRY_SIZE : length;
1536 memcpy((priv->tx_traffic + 1536 memcpy((il->tx_traffic +
1537 (priv->tx_traffic_idx * IL_TRAFFIC_ENTRY_SIZE)), 1537 (il->tx_traffic_idx * IL_TRAFFIC_ENTRY_SIZE)),
1538 header, len); 1538 header, len);
1539 priv->tx_traffic_idx = 1539 il->tx_traffic_idx =
1540 (priv->tx_traffic_idx + 1) % IL_TRAFFIC_ENTRIES; 1540 (il->tx_traffic_idx + 1) % IL_TRAFFIC_ENTRIES;
1541 } 1541 }
1542} 1542}
1543EXPORT_SYMBOL(il_dbg_log_tx_data_frame); 1543EXPORT_SYMBOL(il_dbg_log_tx_data_frame);
1544 1544
1545void il_dbg_log_rx_data_frame(struct il_priv *priv, 1545void il_dbg_log_rx_data_frame(struct il_priv *il,
1546 u16 length, struct ieee80211_hdr *header) 1546 u16 length, struct ieee80211_hdr *header)
1547{ 1547{
1548 __le16 fc; 1548 __le16 fc;
@@ -1551,18 +1551,18 @@ void il_dbg_log_rx_data_frame(struct il_priv *priv,
1551 if (likely(!(iwlegacy_debug_level & IL_DL_RX))) 1551 if (likely(!(iwlegacy_debug_level & IL_DL_RX)))
1552 return; 1552 return;
1553 1553
1554 if (!priv->rx_traffic) 1554 if (!il->rx_traffic)
1555 return; 1555 return;
1556 1556
1557 fc = header->frame_control; 1557 fc = header->frame_control;
1558 if (ieee80211_is_data(fc)) { 1558 if (ieee80211_is_data(fc)) {
1559 len = (length > IL_TRAFFIC_ENTRY_SIZE) 1559 len = (length > IL_TRAFFIC_ENTRY_SIZE)
1560 ? IL_TRAFFIC_ENTRY_SIZE : length; 1560 ? IL_TRAFFIC_ENTRY_SIZE : length;
1561 memcpy((priv->rx_traffic + 1561 memcpy((il->rx_traffic +
1562 (priv->rx_traffic_idx * IL_TRAFFIC_ENTRY_SIZE)), 1562 (il->rx_traffic_idx * IL_TRAFFIC_ENTRY_SIZE)),
1563 header, len); 1563 header, len);
1564 priv->rx_traffic_idx = 1564 il->rx_traffic_idx =
1565 (priv->rx_traffic_idx + 1) % IL_TRAFFIC_ENTRIES; 1565 (il->rx_traffic_idx + 1) % IL_TRAFFIC_ENTRIES;
1566 } 1566 }
1567} 1567}
1568EXPORT_SYMBOL(il_dbg_log_rx_data_frame); 1568EXPORT_SYMBOL(il_dbg_log_rx_data_frame);
@@ -1605,10 +1605,10 @@ const char *il_get_ctrl_string(int cmd)
1605 } 1605 }
1606} 1606}
1607 1607
1608void il_clear_traffic_stats(struct il_priv *priv) 1608void il_clear_traffic_stats(struct il_priv *il)
1609{ 1609{
1610 memset(&priv->tx_stats, 0, sizeof(struct traffic_stats)); 1610 memset(&il->tx_stats, 0, sizeof(struct traffic_stats));
1611 memset(&priv->rx_stats, 0, sizeof(struct traffic_stats)); 1611 memset(&il->rx_stats, 0, sizeof(struct traffic_stats));
1612} 1612}
1613 1613
1614/* 1614/*
@@ -1623,14 +1623,14 @@ void il_clear_traffic_stats(struct il_priv *priv)
1623 * 1623 *
1624 */ 1624 */
1625void 1625void
1626il_update_stats(struct il_priv *priv, bool is_tx, __le16 fc, u16 len) 1626il_update_stats(struct il_priv *il, bool is_tx, __le16 fc, u16 len)
1627{ 1627{
1628 struct traffic_stats *stats; 1628 struct traffic_stats *stats;
1629 1629
1630 if (is_tx) 1630 if (is_tx)
1631 stats = &priv->tx_stats; 1631 stats = &il->tx_stats;
1632 else 1632 else
1633 stats = &priv->rx_stats; 1633 stats = &il->rx_stats;
1634 1634
1635 if (ieee80211_is_mgmt(fc)) { 1635 if (ieee80211_is_mgmt(fc)) {
1636 switch (fc & cpu_to_le16(IEEE80211_FCTL_STYPE)) { 1636 switch (fc & cpu_to_le16(IEEE80211_FCTL_STYPE)) {
@@ -1707,20 +1707,20 @@ il_update_stats(struct il_priv *priv, bool is_tx, __le16 fc, u16 len)
1707EXPORT_SYMBOL(il_update_stats); 1707EXPORT_SYMBOL(il_update_stats);
1708#endif 1708#endif
1709 1709
1710int il_force_reset(struct il_priv *priv, bool external) 1710int il_force_reset(struct il_priv *il, bool external)
1711{ 1711{
1712 struct il_force_reset *force_reset; 1712 struct il_force_reset *force_reset;
1713 1713
1714 if (test_bit(STATUS_EXIT_PENDING, &priv->status)) 1714 if (test_bit(STATUS_EXIT_PENDING, &il->status))
1715 return -EINVAL; 1715 return -EINVAL;
1716 1716
1717 force_reset = &priv->force_reset; 1717 force_reset = &il->force_reset;
1718 force_reset->reset_request_count++; 1718 force_reset->reset_request_count++;
1719 if (!external) { 1719 if (!external) {
1720 if (force_reset->last_force_reset_jiffies && 1720 if (force_reset->last_force_reset_jiffies &&
1721 time_after(force_reset->last_force_reset_jiffies + 1721 time_after(force_reset->last_force_reset_jiffies +
1722 force_reset->reset_duration, jiffies)) { 1722 force_reset->reset_duration, jiffies)) {
1723 IL_DEBUG_INFO(priv, "force reset rejected\n"); 1723 IL_DEBUG_INFO(il, "force reset rejected\n");
1724 force_reset->reset_reject_count++; 1724 force_reset->reset_reject_count++;
1725 return -EAGAIN; 1725 return -EAGAIN;
1726 } 1726 }
@@ -1737,23 +1737,23 @@ int il_force_reset(struct il_priv *priv, bool external)
1737 * need to be check before performing firmware reload 1737 * need to be check before performing firmware reload
1738 */ 1738 */
1739 1739
1740 if (!external && !priv->cfg->mod_params->restart_fw) { 1740 if (!external && !il->cfg->mod_params->restart_fw) {
1741 IL_DEBUG_INFO(priv, "Cancel firmware reload based on " 1741 IL_DEBUG_INFO(il, "Cancel firmware reload based on "
1742 "module parameter setting\n"); 1742 "module parameter setting\n");
1743 return 0; 1743 return 0;
1744 } 1744 }
1745 1745
1746 IL_ERR(priv, "On demand firmware reload\n"); 1746 IL_ERR(il, "On demand firmware reload\n");
1747 1747
1748 /* Set the FW error flag -- cleared on il_down */ 1748 /* Set the FW error flag -- cleared on il_down */
1749 set_bit(STATUS_FW_ERROR, &priv->status); 1749 set_bit(STATUS_FW_ERROR, &il->status);
1750 wake_up(&priv->wait_command_queue); 1750 wake_up(&il->wait_command_queue);
1751 /* 1751 /*
1752 * Keep the restart process from trying to send host 1752 * Keep the restart process from trying to send host
1753 * commands by clearing the INIT status bit 1753 * commands by clearing the INIT status bit
1754 */ 1754 */
1755 clear_bit(STATUS_READY, &priv->status); 1755 clear_bit(STATUS_READY, &il->status);
1756 queue_work(priv->workqueue, &priv->restart); 1756 queue_work(il->workqueue, &il->restart);
1757 1757
1758 return 0; 1758 return 0;
1759} 1759}
@@ -1763,7 +1763,7 @@ il_mac_change_interface(struct ieee80211_hw *hw,
1763 struct ieee80211_vif *vif, 1763 struct ieee80211_vif *vif,
1764 enum nl80211_iftype newtype, bool newp2p) 1764 enum nl80211_iftype newtype, bool newp2p)
1765{ 1765{
1766 struct il_priv *priv = hw->priv; 1766 struct il_priv *il = hw->priv;
1767 struct il_rxon_context *ctx = il_rxon_ctx_from_vif(vif); 1767 struct il_rxon_context *ctx = il_rxon_ctx_from_vif(vif);
1768 struct il_rxon_context *tmp; 1768 struct il_rxon_context *tmp;
1769 u32 interface_modes; 1769 u32 interface_modes;
@@ -1771,9 +1771,9 @@ il_mac_change_interface(struct ieee80211_hw *hw,
1771 1771
1772 newtype = ieee80211_iftype_p2p(newtype, newp2p); 1772 newtype = ieee80211_iftype_p2p(newtype, newp2p);
1773 1773
1774 mutex_lock(&priv->mutex); 1774 mutex_lock(&il->mutex);
1775 1775
1776 if (!ctx->vif || !il_is_ready_rf(priv)) { 1776 if (!ctx->vif || !il_is_ready_rf(il)) {
1777 /* 1777 /*
1778 * Huh? But wait ... this can maybe happen when 1778 * Huh? But wait ... this can maybe happen when
1779 * we're in the middle of a firmware restart! 1779 * we're in the middle of a firmware restart!
@@ -1790,7 +1790,7 @@ il_mac_change_interface(struct ieee80211_hw *hw,
1790 } 1790 }
1791 1791
1792 if (ctx->exclusive_interface_modes & BIT(newtype)) { 1792 if (ctx->exclusive_interface_modes & BIT(newtype)) {
1793 for_each_context(priv, tmp) { 1793 for_each_context(il, tmp) {
1794 if (ctx == tmp) 1794 if (ctx == tmp)
1795 continue; 1795 continue;
1796 1796
@@ -1807,10 +1807,10 @@ il_mac_change_interface(struct ieee80211_hw *hw,
1807 } 1807 }
1808 1808
1809 /* success */ 1809 /* success */
1810 il_teardown_interface(priv, vif, true); 1810 il_teardown_interface(il, vif, true);
1811 vif->type = newtype; 1811 vif->type = newtype;
1812 vif->p2p = newp2p; 1812 vif->p2p = newp2p;
1813 err = il_setup_interface(priv, ctx); 1813 err = il_setup_interface(il, ctx);
1814 WARN_ON(err); 1814 WARN_ON(err);
1815 /* 1815 /*
1816 * We've switched internally, but submitting to the 1816 * We've switched internally, but submitting to the
@@ -1822,7 +1822,7 @@ il_mac_change_interface(struct ieee80211_hw *hw,
1822 err = 0; 1822 err = 0;
1823 1823
1824 out: 1824 out:
1825 mutex_unlock(&priv->mutex); 1825 mutex_unlock(&il->mutex);
1826 return err; 1826 return err;
1827} 1827}
1828EXPORT_SYMBOL(il_mac_change_interface); 1828EXPORT_SYMBOL(il_mac_change_interface);
@@ -1831,9 +1831,9 @@ EXPORT_SYMBOL(il_mac_change_interface);
1831 * On every watchdog tick we check (latest) time stamp. If it does not 1831 * On every watchdog tick we check (latest) time stamp. If it does not
1832 * change during timeout period and queue is not empty we reset firmware. 1832 * change during timeout period and queue is not empty we reset firmware.
1833 */ 1833 */
1834static int il_check_stuck_queue(struct il_priv *priv, int cnt) 1834static int il_check_stuck_queue(struct il_priv *il, int cnt)
1835{ 1835{
1836 struct il_tx_queue *txq = &priv->txq[cnt]; 1836 struct il_tx_queue *txq = &il->txq[cnt];
1837 struct il_queue *q = &txq->q; 1837 struct il_queue *q = &txq->q;
1838 unsigned long timeout; 1838 unsigned long timeout;
1839 int ret; 1839 int ret;
@@ -1844,12 +1844,12 @@ static int il_check_stuck_queue(struct il_priv *priv, int cnt)
1844 } 1844 }
1845 1845
1846 timeout = txq->time_stamp + 1846 timeout = txq->time_stamp +
1847 msecs_to_jiffies(priv->cfg->base_params->wd_timeout); 1847 msecs_to_jiffies(il->cfg->base_params->wd_timeout);
1848 1848
1849 if (time_after(jiffies, timeout)) { 1849 if (time_after(jiffies, timeout)) {
1850 IL_ERR(priv, "Queue %d stuck for %u ms.\n", 1850 IL_ERR(il, "Queue %d stuck for %u ms.\n",
1851 q->id, priv->cfg->base_params->wd_timeout); 1851 q->id, il->cfg->base_params->wd_timeout);
1852 ret = il_force_reset(priv, false); 1852 ret = il_force_reset(il, false);
1853 return (ret == -EAGAIN) ? 0 : 1; 1853 return (ret == -EAGAIN) ? 0 : 1;
1854 } 1854 }
1855 1855
@@ -1868,46 +1868,46 @@ static int il_check_stuck_queue(struct il_priv *priv, int cnt)
1868 */ 1868 */
1869void il_bg_watchdog(unsigned long data) 1869void il_bg_watchdog(unsigned long data)
1870{ 1870{
1871 struct il_priv *priv = (struct il_priv *)data; 1871 struct il_priv *il = (struct il_priv *)data;
1872 int cnt; 1872 int cnt;
1873 unsigned long timeout; 1873 unsigned long timeout;
1874 1874
1875 if (test_bit(STATUS_EXIT_PENDING, &priv->status)) 1875 if (test_bit(STATUS_EXIT_PENDING, &il->status))
1876 return; 1876 return;
1877 1877
1878 timeout = priv->cfg->base_params->wd_timeout; 1878 timeout = il->cfg->base_params->wd_timeout;
1879 if (timeout == 0) 1879 if (timeout == 0)
1880 return; 1880 return;
1881 1881
1882 /* monitor and check for stuck cmd queue */ 1882 /* monitor and check for stuck cmd queue */
1883 if (il_check_stuck_queue(priv, priv->cmd_queue)) 1883 if (il_check_stuck_queue(il, il->cmd_queue))
1884 return; 1884 return;
1885 1885
1886 /* monitor and check for other stuck queues */ 1886 /* monitor and check for other stuck queues */
1887 if (il_is_any_associated(priv)) { 1887 if (il_is_any_associated(il)) {
1888 for (cnt = 0; cnt < priv->hw_params.max_txq_num; cnt++) { 1888 for (cnt = 0; cnt < il->hw_params.max_txq_num; cnt++) {
1889 /* skip as we already checked the command queue */ 1889 /* skip as we already checked the command queue */
1890 if (cnt == priv->cmd_queue) 1890 if (cnt == il->cmd_queue)
1891 continue; 1891 continue;
1892 if (il_check_stuck_queue(priv, cnt)) 1892 if (il_check_stuck_queue(il, cnt))
1893 return; 1893 return;
1894 } 1894 }
1895 } 1895 }
1896 1896
1897 mod_timer(&priv->watchdog, jiffies + 1897 mod_timer(&il->watchdog, jiffies +
1898 msecs_to_jiffies(IL_WD_TICK(timeout))); 1898 msecs_to_jiffies(IL_WD_TICK(timeout)));
1899} 1899}
1900EXPORT_SYMBOL(il_bg_watchdog); 1900EXPORT_SYMBOL(il_bg_watchdog);
1901 1901
1902void il_setup_watchdog(struct il_priv *priv) 1902void il_setup_watchdog(struct il_priv *il)
1903{ 1903{
1904 unsigned int timeout = priv->cfg->base_params->wd_timeout; 1904 unsigned int timeout = il->cfg->base_params->wd_timeout;
1905 1905
1906 if (timeout) 1906 if (timeout)
1907 mod_timer(&priv->watchdog, 1907 mod_timer(&il->watchdog,
1908 jiffies + msecs_to_jiffies(IL_WD_TICK(timeout))); 1908 jiffies + msecs_to_jiffies(IL_WD_TICK(timeout)));
1909 else 1909 else
1910 del_timer(&priv->watchdog); 1910 del_timer(&il->watchdog);
1911} 1911}
1912EXPORT_SYMBOL(il_setup_watchdog); 1912EXPORT_SYMBOL(il_setup_watchdog);
1913 1913
@@ -1918,7 +1918,7 @@ EXPORT_SYMBOL(il_setup_watchdog);
1918 * the internal part is the time in usec within one beacon interval 1918 * the internal part is the time in usec within one beacon interval
1919 */ 1919 */
1920u32 1920u32
1921il_usecs_to_beacons(struct il_priv *priv, 1921il_usecs_to_beacons(struct il_priv *il,
1922 u32 usec, u32 beacon_interval) 1922 u32 usec, u32 beacon_interval)
1923{ 1923{
1924 u32 quot; 1924 u32 quot;
@@ -1929,39 +1929,39 @@ il_usecs_to_beacons(struct il_priv *priv,
1929 return 0; 1929 return 0;
1930 1930
1931 quot = (usec / interval) & 1931 quot = (usec / interval) &
1932 (il_beacon_time_mask_high(priv, 1932 (il_beacon_time_mask_high(il,
1933 priv->hw_params.beacon_time_tsf_bits) >> 1933 il->hw_params.beacon_time_tsf_bits) >>
1934 priv->hw_params.beacon_time_tsf_bits); 1934 il->hw_params.beacon_time_tsf_bits);
1935 rem = (usec % interval) & il_beacon_time_mask_low(priv, 1935 rem = (usec % interval) & il_beacon_time_mask_low(il,
1936 priv->hw_params.beacon_time_tsf_bits); 1936 il->hw_params.beacon_time_tsf_bits);
1937 1937
1938 return (quot << priv->hw_params.beacon_time_tsf_bits) + rem; 1938 return (quot << il->hw_params.beacon_time_tsf_bits) + rem;
1939} 1939}
1940EXPORT_SYMBOL(il_usecs_to_beacons); 1940EXPORT_SYMBOL(il_usecs_to_beacons);
1941 1941
1942/* base is usually what we get from ucode with each received frame, 1942/* base is usually what we get from ucode with each received frame,
1943 * the same as HW timer counter counting down 1943 * the same as HW timer counter counting down
1944 */ 1944 */
1945__le32 il_add_beacon_time(struct il_priv *priv, u32 base, 1945__le32 il_add_beacon_time(struct il_priv *il, u32 base,
1946 u32 addon, u32 beacon_interval) 1946 u32 addon, u32 beacon_interval)
1947{ 1947{
1948 u32 base_low = base & il_beacon_time_mask_low(priv, 1948 u32 base_low = base & il_beacon_time_mask_low(il,
1949 priv->hw_params.beacon_time_tsf_bits); 1949 il->hw_params.beacon_time_tsf_bits);
1950 u32 addon_low = addon & il_beacon_time_mask_low(priv, 1950 u32 addon_low = addon & il_beacon_time_mask_low(il,
1951 priv->hw_params.beacon_time_tsf_bits); 1951 il->hw_params.beacon_time_tsf_bits);
1952 u32 interval = beacon_interval * TIME_UNIT; 1952 u32 interval = beacon_interval * TIME_UNIT;
1953 u32 res = (base & il_beacon_time_mask_high(priv, 1953 u32 res = (base & il_beacon_time_mask_high(il,
1954 priv->hw_params.beacon_time_tsf_bits)) + 1954 il->hw_params.beacon_time_tsf_bits)) +
1955 (addon & il_beacon_time_mask_high(priv, 1955 (addon & il_beacon_time_mask_high(il,
1956 priv->hw_params.beacon_time_tsf_bits)); 1956 il->hw_params.beacon_time_tsf_bits));
1957 1957
1958 if (base_low > addon_low) 1958 if (base_low > addon_low)
1959 res += base_low - addon_low; 1959 res += base_low - addon_low;
1960 else if (base_low < addon_low) { 1960 else if (base_low < addon_low) {
1961 res += interval + base_low - addon_low; 1961 res += interval + base_low - addon_low;
1962 res += (1 << priv->hw_params.beacon_time_tsf_bits); 1962 res += (1 << il->hw_params.beacon_time_tsf_bits);
1963 } else 1963 } else
1964 res += (1 << priv->hw_params.beacon_time_tsf_bits); 1964 res += (1 << il->hw_params.beacon_time_tsf_bits);
1965 1965
1966 return cpu_to_le32(res); 1966 return cpu_to_le32(res);
1967} 1967}
@@ -1972,7 +1972,7 @@ EXPORT_SYMBOL(il_add_beacon_time);
1972int il_pci_suspend(struct device *device) 1972int il_pci_suspend(struct device *device)
1973{ 1973{
1974 struct pci_dev *pdev = to_pci_dev(device); 1974 struct pci_dev *pdev = to_pci_dev(device);
1975 struct il_priv *priv = pci_get_drvdata(pdev); 1975 struct il_priv *il = pci_get_drvdata(pdev);
1976 1976
1977 /* 1977 /*
1978 * This function is called when system goes into suspend state 1978 * This function is called when system goes into suspend state
@@ -1981,7 +1981,7 @@ int il_pci_suspend(struct device *device)
1981 * it will not call apm_ops.stop() to stop the DMA operation. 1981 * it will not call apm_ops.stop() to stop the DMA operation.
1982 * Calling apm_ops.stop here to make sure we stop the DMA. 1982 * Calling apm_ops.stop here to make sure we stop the DMA.
1983 */ 1983 */
1984 il_apm_stop(priv); 1984 il_apm_stop(il);
1985 1985
1986 return 0; 1986 return 0;
1987} 1987}
@@ -1990,7 +1990,7 @@ EXPORT_SYMBOL(il_pci_suspend);
1990int il_pci_resume(struct device *device) 1990int il_pci_resume(struct device *device)
1991{ 1991{
1992 struct pci_dev *pdev = to_pci_dev(device); 1992 struct pci_dev *pdev = to_pci_dev(device);
1993 struct il_priv *priv = pci_get_drvdata(pdev); 1993 struct il_priv *il = pci_get_drvdata(pdev);
1994 bool hw_rfkill = false; 1994 bool hw_rfkill = false;
1995 1995
1996 /* 1996 /*
@@ -1999,18 +1999,18 @@ int il_pci_resume(struct device *device)
1999 */ 1999 */
2000 pci_write_config_byte(pdev, PCI_CFG_RETRY_TIMEOUT, 0x00); 2000 pci_write_config_byte(pdev, PCI_CFG_RETRY_TIMEOUT, 0x00);
2001 2001
2002 il_enable_interrupts(priv); 2002 il_enable_interrupts(il);
2003 2003
2004 if (!(il_read32(priv, CSR_GP_CNTRL) & 2004 if (!(il_read32(il, CSR_GP_CNTRL) &
2005 CSR_GP_CNTRL_REG_FLAG_HW_RF_KILL_SW)) 2005 CSR_GP_CNTRL_REG_FLAG_HW_RF_KILL_SW))
2006 hw_rfkill = true; 2006 hw_rfkill = true;
2007 2007
2008 if (hw_rfkill) 2008 if (hw_rfkill)
2009 set_bit(STATUS_RF_KILL_HW, &priv->status); 2009 set_bit(STATUS_RF_KILL_HW, &il->status);
2010 else 2010 else
2011 clear_bit(STATUS_RF_KILL_HW, &priv->status); 2011 clear_bit(STATUS_RF_KILL_HW, &il->status);
2012 2012
2013 wiphy_rfkill_set_hw_state(priv->hw->wiphy, hw_rfkill); 2013 wiphy_rfkill_set_hw_state(il->hw->wiphy, hw_rfkill);
2014 2014
2015 return 0; 2015 return 0;
2016} 2016}
@@ -2029,9 +2029,9 @@ EXPORT_SYMBOL(il_pm_ops);
2029#endif /* CONFIG_PM */ 2029#endif /* CONFIG_PM */
2030 2030
2031static void 2031static void
2032il_update_qos(struct il_priv *priv, struct il_rxon_context *ctx) 2032il_update_qos(struct il_priv *il, struct il_rxon_context *ctx)
2033{ 2033{
2034 if (test_bit(STATUS_EXIT_PENDING, &priv->status)) 2034 if (test_bit(STATUS_EXIT_PENDING, &il->status))
2035 return; 2035 return;
2036 2036
2037 if (!ctx->is_active) 2037 if (!ctx->is_active)
@@ -2046,11 +2046,11 @@ il_update_qos(struct il_priv *priv, struct il_rxon_context *ctx)
2046 if (ctx->ht.enabled) 2046 if (ctx->ht.enabled)
2047 ctx->qos_data.def_qos_parm.qos_flags |= QOS_PARAM_FLG_TGN_MSK; 2047 ctx->qos_data.def_qos_parm.qos_flags |= QOS_PARAM_FLG_TGN_MSK;
2048 2048
2049 IL_DEBUG_QOS(priv, "send QoS cmd with Qos active=%d FLAGS=0x%X\n", 2049 IL_DEBUG_QOS(il, "send QoS cmd with Qos active=%d FLAGS=0x%X\n",
2050 ctx->qos_data.qos_active, 2050 ctx->qos_data.qos_active,
2051 ctx->qos_data.def_qos_parm.qos_flags); 2051 ctx->qos_data.def_qos_parm.qos_flags);
2052 2052
2053 il_send_cmd_pdu_async(priv, ctx->qos_cmd, 2053 il_send_cmd_pdu_async(il, ctx->qos_cmd,
2054 sizeof(struct il_qosparam_cmd), 2054 sizeof(struct il_qosparam_cmd),
2055 &ctx->qos_data.def_qos_parm, NULL); 2055 &ctx->qos_data.def_qos_parm, NULL);
2056} 2056}
@@ -2060,11 +2060,11 @@ il_update_qos(struct il_priv *priv, struct il_rxon_context *ctx)
2060 */ 2060 */
2061int il_mac_config(struct ieee80211_hw *hw, u32 changed) 2061int il_mac_config(struct ieee80211_hw *hw, u32 changed)
2062{ 2062{
2063 struct il_priv *priv = hw->priv; 2063 struct il_priv *il = hw->priv;
2064 const struct il_channel_info *ch_info; 2064 const struct il_channel_info *ch_info;
2065 struct ieee80211_conf *conf = &hw->conf; 2065 struct ieee80211_conf *conf = &hw->conf;
2066 struct ieee80211_channel *channel = conf->channel; 2066 struct ieee80211_channel *channel = conf->channel;
2067 struct il_ht_config *ht_conf = &priv->current_ht_config; 2067 struct il_ht_config *ht_conf = &il->current_ht_config;
2068 struct il_rxon_context *ctx; 2068 struct il_rxon_context *ctx;
2069 unsigned long flags = 0; 2069 unsigned long flags = 0;
2070 int ret = 0; 2070 int ret = 0;
@@ -2072,23 +2072,23 @@ int il_mac_config(struct ieee80211_hw *hw, u32 changed)
2072 int scan_active = 0; 2072 int scan_active = 0;
2073 bool ht_changed[NUM_IL_RXON_CTX] = {}; 2073 bool ht_changed[NUM_IL_RXON_CTX] = {};
2074 2074
2075 if (WARN_ON(!priv->cfg->ops->legacy)) 2075 if (WARN_ON(!il->cfg->ops->legacy))
2076 return -EOPNOTSUPP; 2076 return -EOPNOTSUPP;
2077 2077
2078 mutex_lock(&priv->mutex); 2078 mutex_lock(&il->mutex);
2079 2079
2080 IL_DEBUG_MAC80211(priv, "enter to channel %d changed 0x%X\n", 2080 IL_DEBUG_MAC80211(il, "enter to channel %d changed 0x%X\n",
2081 channel->hw_value, changed); 2081 channel->hw_value, changed);
2082 2082
2083 if (unlikely(test_bit(STATUS_SCANNING, &priv->status))) { 2083 if (unlikely(test_bit(STATUS_SCANNING, &il->status))) {
2084 scan_active = 1; 2084 scan_active = 1;
2085 IL_DEBUG_MAC80211(priv, "scan active\n"); 2085 IL_DEBUG_MAC80211(il, "scan active\n");
2086 } 2086 }
2087 2087
2088 if (changed & (IEEE80211_CONF_CHANGE_SMPS | 2088 if (changed & (IEEE80211_CONF_CHANGE_SMPS |
2089 IEEE80211_CONF_CHANGE_CHANNEL)) { 2089 IEEE80211_CONF_CHANGE_CHANNEL)) {
2090 /* mac80211 uses static for non-HT which is what we want */ 2090 /* mac80211 uses static for non-HT which is what we want */
2091 priv->current_ht_config.smps = conf->smps_mode; 2091 il->current_ht_config.smps = conf->smps_mode;
2092 2092
2093 /* 2093 /*
2094 * Recalculate chain counts. 2094 * Recalculate chain counts.
@@ -2097,9 +2097,9 @@ int il_mac_config(struct ieee80211_hw *hw, u32 changed)
2097 * set up the SM PS mode to OFF if an HT channel is 2097 * set up the SM PS mode to OFF if an HT channel is
2098 * configured. 2098 * configured.
2099 */ 2099 */
2100 if (priv->cfg->ops->hcmd->set_rxon_chain) 2100 if (il->cfg->ops->hcmd->set_rxon_chain)
2101 for_each_context(priv, ctx) 2101 for_each_context(il, ctx)
2102 priv->cfg->ops->hcmd->set_rxon_chain(priv, ctx); 2102 il->cfg->ops->hcmd->set_rxon_chain(il, ctx);
2103 } 2103 }
2104 2104
2105 /* during scanning mac80211 will delay channel setting until 2105 /* during scanning mac80211 will delay channel setting until
@@ -2110,23 +2110,23 @@ int il_mac_config(struct ieee80211_hw *hw, u32 changed)
2110 goto set_ch_out; 2110 goto set_ch_out;
2111 2111
2112 ch = channel->hw_value; 2112 ch = channel->hw_value;
2113 ch_info = il_get_channel_info(priv, channel->band, ch); 2113 ch_info = il_get_channel_info(il, channel->band, ch);
2114 if (!il_is_channel_valid(ch_info)) { 2114 if (!il_is_channel_valid(ch_info)) {
2115 IL_DEBUG_MAC80211(priv, "leave - invalid channel\n"); 2115 IL_DEBUG_MAC80211(il, "leave - invalid channel\n");
2116 ret = -EINVAL; 2116 ret = -EINVAL;
2117 goto set_ch_out; 2117 goto set_ch_out;
2118 } 2118 }
2119 2119
2120 if (priv->iw_mode == NL80211_IFTYPE_ADHOC && 2120 if (il->iw_mode == NL80211_IFTYPE_ADHOC &&
2121 !il_is_channel_ibss(ch_info)) { 2121 !il_is_channel_ibss(ch_info)) {
2122 IL_DEBUG_MAC80211(priv, "leave - not IBSS channel\n"); 2122 IL_DEBUG_MAC80211(il, "leave - not IBSS channel\n");
2123 ret = -EINVAL; 2123 ret = -EINVAL;
2124 goto set_ch_out; 2124 goto set_ch_out;
2125 } 2125 }
2126 2126
2127 spin_lock_irqsave(&priv->lock, flags); 2127 spin_lock_irqsave(&il->lock, flags);
2128 2128
2129 for_each_context(priv, ctx) { 2129 for_each_context(il, ctx) {
2130 /* Configure HT40 channels */ 2130 /* Configure HT40 channels */
2131 if (ctx->ht.enabled != conf_is_ht(conf)) { 2131 if (ctx->ht.enabled != conf_is_ht(conf)) {
2132 ctx->ht.enabled = conf_is_ht(conf); 2132 ctx->ht.enabled = conf_is_ht(conf);
@@ -2162,61 +2162,61 @@ int il_mac_config(struct ieee80211_hw *hw, u32 changed)
2162 if ((le16_to_cpu(ctx->staging.channel) != ch)) 2162 if ((le16_to_cpu(ctx->staging.channel) != ch))
2163 ctx->staging.flags = 0; 2163 ctx->staging.flags = 0;
2164 2164
2165 il_set_rxon_channel(priv, channel, ctx); 2165 il_set_rxon_channel(il, channel, ctx);
2166 il_set_rxon_ht(priv, ht_conf); 2166 il_set_rxon_ht(il, ht_conf);
2167 2167
2168 il_set_flags_for_band(priv, ctx, channel->band, 2168 il_set_flags_for_band(il, ctx, channel->band,
2169 ctx->vif); 2169 ctx->vif);
2170 } 2170 }
2171 2171
2172 spin_unlock_irqrestore(&priv->lock, flags); 2172 spin_unlock_irqrestore(&il->lock, flags);
2173 2173
2174 if (priv->cfg->ops->legacy->update_bcast_stations) 2174 if (il->cfg->ops->legacy->update_bcast_stations)
2175 ret = 2175 ret =
2176 priv->cfg->ops->legacy->update_bcast_stations(priv); 2176 il->cfg->ops->legacy->update_bcast_stations(il);
2177 2177
2178 set_ch_out: 2178 set_ch_out:
2179 /* The list of supported rates and rate mask can be different 2179 /* The list of supported rates and rate mask can be different
2180 * for each band; since the band may have changed, reset 2180 * for each band; since the band may have changed, reset
2181 * the rate mask to what mac80211 lists */ 2181 * the rate mask to what mac80211 lists */
2182 il_set_rate(priv); 2182 il_set_rate(il);
2183 } 2183 }
2184 2184
2185 if (changed & (IEEE80211_CONF_CHANGE_PS | 2185 if (changed & (IEEE80211_CONF_CHANGE_PS |
2186 IEEE80211_CONF_CHANGE_IDLE)) { 2186 IEEE80211_CONF_CHANGE_IDLE)) {
2187 ret = il_power_update_mode(priv, false); 2187 ret = il_power_update_mode(il, false);
2188 if (ret) 2188 if (ret)
2189 IL_DEBUG_MAC80211(priv, "Error setting sleep level\n"); 2189 IL_DEBUG_MAC80211(il, "Error setting sleep level\n");
2190 } 2190 }
2191 2191
2192 if (changed & IEEE80211_CONF_CHANGE_POWER) { 2192 if (changed & IEEE80211_CONF_CHANGE_POWER) {
2193 IL_DEBUG_MAC80211(priv, "TX Power old=%d new=%d\n", 2193 IL_DEBUG_MAC80211(il, "TX Power old=%d new=%d\n",
2194 priv->tx_power_user_lmt, conf->power_level); 2194 il->tx_power_user_lmt, conf->power_level);
2195 2195
2196 il_set_tx_power(priv, conf->power_level, false); 2196 il_set_tx_power(il, conf->power_level, false);
2197 } 2197 }
2198 2198
2199 if (!il_is_ready(priv)) { 2199 if (!il_is_ready(il)) {
2200 IL_DEBUG_MAC80211(priv, "leave - not ready\n"); 2200 IL_DEBUG_MAC80211(il, "leave - not ready\n");
2201 goto out; 2201 goto out;
2202 } 2202 }
2203 2203
2204 if (scan_active) 2204 if (scan_active)
2205 goto out; 2205 goto out;
2206 2206
2207 for_each_context(priv, ctx) { 2207 for_each_context(il, ctx) {
2208 if (memcmp(&ctx->active, &ctx->staging, sizeof(ctx->staging))) 2208 if (memcmp(&ctx->active, &ctx->staging, sizeof(ctx->staging)))
2209 il_commit_rxon(priv, ctx); 2209 il_commit_rxon(il, ctx);
2210 else 2210 else
2211 IL_DEBUG_INFO(priv, 2211 IL_DEBUG_INFO(il,
2212 "Not re-sending same RXON configuration.\n"); 2212 "Not re-sending same RXON configuration.\n");
2213 if (ht_changed[ctx->ctxid]) 2213 if (ht_changed[ctx->ctxid])
2214 il_update_qos(priv, ctx); 2214 il_update_qos(il, ctx);
2215 } 2215 }
2216 2216
2217out: 2217out:
2218 IL_DEBUG_MAC80211(priv, "leave\n"); 2218 IL_DEBUG_MAC80211(il, "leave\n");
2219 mutex_unlock(&priv->mutex); 2219 mutex_unlock(&il->mutex);
2220 return ret; 2220 return ret;
2221} 2221}
2222EXPORT_SYMBOL(il_mac_config); 2222EXPORT_SYMBOL(il_mac_config);
@@ -2224,37 +2224,37 @@ EXPORT_SYMBOL(il_mac_config);
2224void il_mac_reset_tsf(struct ieee80211_hw *hw, 2224void il_mac_reset_tsf(struct ieee80211_hw *hw,
2225 struct ieee80211_vif *vif) 2225 struct ieee80211_vif *vif)
2226{ 2226{
2227 struct il_priv *priv = hw->priv; 2227 struct il_priv *il = hw->priv;
2228 unsigned long flags; 2228 unsigned long flags;
2229 /* IBSS can only be the IL_RXON_CTX_BSS context */ 2229 /* IBSS can only be the IL_RXON_CTX_BSS context */
2230 struct il_rxon_context *ctx = &priv->contexts[IL_RXON_CTX_BSS]; 2230 struct il_rxon_context *ctx = &il->contexts[IL_RXON_CTX_BSS];
2231 2231
2232 if (WARN_ON(!priv->cfg->ops->legacy)) 2232 if (WARN_ON(!il->cfg->ops->legacy))
2233 return; 2233 return;
2234 2234
2235 mutex_lock(&priv->mutex); 2235 mutex_lock(&il->mutex);
2236 IL_DEBUG_MAC80211(priv, "enter\n"); 2236 IL_DEBUG_MAC80211(il, "enter\n");
2237 2237
2238 spin_lock_irqsave(&priv->lock, flags); 2238 spin_lock_irqsave(&il->lock, flags);
2239 memset(&priv->current_ht_config, 0, sizeof(struct il_ht_config)); 2239 memset(&il->current_ht_config, 0, sizeof(struct il_ht_config));
2240 spin_unlock_irqrestore(&priv->lock, flags); 2240 spin_unlock_irqrestore(&il->lock, flags);
2241 2241
2242 spin_lock_irqsave(&priv->lock, flags); 2242 spin_lock_irqsave(&il->lock, flags);
2243 2243
2244 /* new association get rid of ibss beacon skb */ 2244 /* new association get rid of ibss beacon skb */
2245 if (priv->beacon_skb) 2245 if (il->beacon_skb)
2246 dev_kfree_skb(priv->beacon_skb); 2246 dev_kfree_skb(il->beacon_skb);
2247 2247
2248 priv->beacon_skb = NULL; 2248 il->beacon_skb = NULL;
2249 2249
2250 priv->timestamp = 0; 2250 il->timestamp = 0;
2251 2251
2252 spin_unlock_irqrestore(&priv->lock, flags); 2252 spin_unlock_irqrestore(&il->lock, flags);
2253 2253
2254 il_scan_cancel_timeout(priv, 100); 2254 il_scan_cancel_timeout(il, 100);
2255 if (!il_is_ready_rf(priv)) { 2255 if (!il_is_ready_rf(il)) {
2256 IL_DEBUG_MAC80211(priv, "leave - not ready\n"); 2256 IL_DEBUG_MAC80211(il, "leave - not ready\n");
2257 mutex_unlock(&priv->mutex); 2257 mutex_unlock(&il->mutex);
2258 return; 2258 return;
2259 } 2259 }
2260 2260
@@ -2262,25 +2262,25 @@ void il_mac_reset_tsf(struct ieee80211_hw *hw,
2262 * clear RXON_FILTER_ASSOC_MSK bit 2262 * clear RXON_FILTER_ASSOC_MSK bit
2263 */ 2263 */
2264 ctx->staging.filter_flags &= ~RXON_FILTER_ASSOC_MSK; 2264 ctx->staging.filter_flags &= ~RXON_FILTER_ASSOC_MSK;
2265 il_commit_rxon(priv, ctx); 2265 il_commit_rxon(il, ctx);
2266 2266
2267 il_set_rate(priv); 2267 il_set_rate(il);
2268 2268
2269 mutex_unlock(&priv->mutex); 2269 mutex_unlock(&il->mutex);
2270 2270
2271 IL_DEBUG_MAC80211(priv, "leave\n"); 2271 IL_DEBUG_MAC80211(il, "leave\n");
2272} 2272}
2273EXPORT_SYMBOL(il_mac_reset_tsf); 2273EXPORT_SYMBOL(il_mac_reset_tsf);
2274 2274
2275static void il_ht_conf(struct il_priv *priv, 2275static void il_ht_conf(struct il_priv *il,
2276 struct ieee80211_vif *vif) 2276 struct ieee80211_vif *vif)
2277{ 2277{
2278 struct il_ht_config *ht_conf = &priv->current_ht_config; 2278 struct il_ht_config *ht_conf = &il->current_ht_config;
2279 struct ieee80211_sta *sta; 2279 struct ieee80211_sta *sta;
2280 struct ieee80211_bss_conf *bss_conf = &vif->bss_conf; 2280 struct ieee80211_bss_conf *bss_conf = &vif->bss_conf;
2281 struct il_rxon_context *ctx = il_rxon_ctx_from_vif(vif); 2281 struct il_rxon_context *ctx = il_rxon_ctx_from_vif(vif);
2282 2282
2283 IL_DEBUG_ASSOC(priv, "enter:\n"); 2283 IL_DEBUG_ASSOC(il, "enter:\n");
2284 2284
2285 if (!ctx->ht.enabled) 2285 if (!ctx->ht.enabled)
2286 return; 2286 return;
@@ -2329,10 +2329,10 @@ static void il_ht_conf(struct il_priv *priv,
2329 break; 2329 break;
2330 } 2330 }
2331 2331
2332 IL_DEBUG_ASSOC(priv, "leave\n"); 2332 IL_DEBUG_ASSOC(il, "leave\n");
2333} 2333}
2334 2334
2335static inline void il_set_no_assoc(struct il_priv *priv, 2335static inline void il_set_no_assoc(struct il_priv *il,
2336 struct ieee80211_vif *vif) 2336 struct ieee80211_vif *vif)
2337{ 2337{
2338 struct il_rxon_context *ctx = il_rxon_ctx_from_vif(vif); 2338 struct il_rxon_context *ctx = il_rxon_ctx_from_vif(vif);
@@ -2344,13 +2344,13 @@ static inline void il_set_no_assoc(struct il_priv *priv,
2344 */ 2344 */
2345 ctx->staging.filter_flags &= ~RXON_FILTER_ASSOC_MSK; 2345 ctx->staging.filter_flags &= ~RXON_FILTER_ASSOC_MSK;
2346 ctx->staging.assoc_id = 0; 2346 ctx->staging.assoc_id = 0;
2347 il_commit_rxon(priv, ctx); 2347 il_commit_rxon(il, ctx);
2348} 2348}
2349 2349
2350static void il_beacon_update(struct ieee80211_hw *hw, 2350static void il_beacon_update(struct ieee80211_hw *hw,
2351 struct ieee80211_vif *vif) 2351 struct ieee80211_vif *vif)
2352{ 2352{
2353 struct il_priv *priv = hw->priv; 2353 struct il_priv *il = hw->priv;
2354 unsigned long flags; 2354 unsigned long flags;
2355 __le64 timestamp; 2355 __le64 timestamp;
2356 struct sk_buff *skb = ieee80211_beacon_get(hw, vif); 2356 struct sk_buff *skb = ieee80211_beacon_get(hw, vif);
@@ -2358,35 +2358,35 @@ static void il_beacon_update(struct ieee80211_hw *hw,
2358 if (!skb) 2358 if (!skb)
2359 return; 2359 return;
2360 2360
2361 IL_DEBUG_MAC80211(priv, "enter\n"); 2361 IL_DEBUG_MAC80211(il, "enter\n");
2362 2362
2363 lockdep_assert_held(&priv->mutex); 2363 lockdep_assert_held(&il->mutex);
2364 2364
2365 if (!priv->beacon_ctx) { 2365 if (!il->beacon_ctx) {
2366 IL_ERR(priv, "update beacon but no beacon context!\n"); 2366 IL_ERR(il, "update beacon but no beacon context!\n");
2367 dev_kfree_skb(skb); 2367 dev_kfree_skb(skb);
2368 return; 2368 return;
2369 } 2369 }
2370 2370
2371 spin_lock_irqsave(&priv->lock, flags); 2371 spin_lock_irqsave(&il->lock, flags);
2372 2372
2373 if (priv->beacon_skb) 2373 if (il->beacon_skb)
2374 dev_kfree_skb(priv->beacon_skb); 2374 dev_kfree_skb(il->beacon_skb);
2375 2375
2376 priv->beacon_skb = skb; 2376 il->beacon_skb = skb;
2377 2377
2378 timestamp = ((struct ieee80211_mgmt *)skb->data)->u.beacon.timestamp; 2378 timestamp = ((struct ieee80211_mgmt *)skb->data)->u.beacon.timestamp;
2379 priv->timestamp = le64_to_cpu(timestamp); 2379 il->timestamp = le64_to_cpu(timestamp);
2380 2380
2381 IL_DEBUG_MAC80211(priv, "leave\n"); 2381 IL_DEBUG_MAC80211(il, "leave\n");
2382 spin_unlock_irqrestore(&priv->lock, flags); 2382 spin_unlock_irqrestore(&il->lock, flags);
2383 2383
2384 if (!il_is_ready_rf(priv)) { 2384 if (!il_is_ready_rf(il)) {
2385 IL_DEBUG_MAC80211(priv, "leave - RF not ready\n"); 2385 IL_DEBUG_MAC80211(il, "leave - RF not ready\n");
2386 return; 2386 return;
2387 } 2387 }
2388 2388
2389 priv->cfg->ops->legacy->post_associate(priv); 2389 il->cfg->ops->legacy->post_associate(il);
2390} 2390}
2391 2391
2392void il_mac_bss_info_changed(struct ieee80211_hw *hw, 2392void il_mac_bss_info_changed(struct ieee80211_hw *hw,
@@ -2394,29 +2394,29 @@ void il_mac_bss_info_changed(struct ieee80211_hw *hw,
2394 struct ieee80211_bss_conf *bss_conf, 2394 struct ieee80211_bss_conf *bss_conf,
2395 u32 changes) 2395 u32 changes)
2396{ 2396{
2397 struct il_priv *priv = hw->priv; 2397 struct il_priv *il = hw->priv;
2398 struct il_rxon_context *ctx = il_rxon_ctx_from_vif(vif); 2398 struct il_rxon_context *ctx = il_rxon_ctx_from_vif(vif);
2399 int ret; 2399 int ret;
2400 2400
2401 if (WARN_ON(!priv->cfg->ops->legacy)) 2401 if (WARN_ON(!il->cfg->ops->legacy))
2402 return; 2402 return;
2403 2403
2404 IL_DEBUG_MAC80211(priv, "changes = 0x%X\n", changes); 2404 IL_DEBUG_MAC80211(il, "changes = 0x%X\n", changes);
2405 2405
2406 mutex_lock(&priv->mutex); 2406 mutex_lock(&il->mutex);
2407 2407
2408 if (!il_is_alive(priv)) { 2408 if (!il_is_alive(il)) {
2409 mutex_unlock(&priv->mutex); 2409 mutex_unlock(&il->mutex);
2410 return; 2410 return;
2411 } 2411 }
2412 2412
2413 if (changes & BSS_CHANGED_QOS) { 2413 if (changes & BSS_CHANGED_QOS) {
2414 unsigned long flags; 2414 unsigned long flags;
2415 2415
2416 spin_lock_irqsave(&priv->lock, flags); 2416 spin_lock_irqsave(&il->lock, flags);
2417 ctx->qos_data.qos_active = bss_conf->qos; 2417 ctx->qos_data.qos_active = bss_conf->qos;
2418 il_update_qos(priv, ctx); 2418 il_update_qos(il, ctx);
2419 spin_unlock_irqrestore(&priv->lock, flags); 2419 spin_unlock_irqrestore(&il->lock, flags);
2420 } 2420 }
2421 2421
2422 if (changes & BSS_CHANGED_BEACON_ENABLED) { 2422 if (changes & BSS_CHANGED_BEACON_ENABLED) {
@@ -2426,25 +2426,25 @@ void il_mac_bss_info_changed(struct ieee80211_hw *hw,
2426 * any time. 2426 * any time.
2427 */ 2427 */
2428 if (vif->bss_conf.enable_beacon) 2428 if (vif->bss_conf.enable_beacon)
2429 priv->beacon_ctx = ctx; 2429 il->beacon_ctx = ctx;
2430 else 2430 else
2431 priv->beacon_ctx = NULL; 2431 il->beacon_ctx = NULL;
2432 } 2432 }
2433 2433
2434 if (changes & BSS_CHANGED_BSSID) { 2434 if (changes & BSS_CHANGED_BSSID) {
2435 IL_DEBUG_MAC80211(priv, "BSSID %pM\n", bss_conf->bssid); 2435 IL_DEBUG_MAC80211(il, "BSSID %pM\n", bss_conf->bssid);
2436 2436
2437 /* 2437 /*
2438 * If there is currently a HW scan going on in the 2438 * If there is currently a HW scan going on in the
2439 * background then we need to cancel it else the RXON 2439 * background then we need to cancel it else the RXON
2440 * below/in post_associate will fail. 2440 * below/in post_associate will fail.
2441 */ 2441 */
2442 if (il_scan_cancel_timeout(priv, 100)) { 2442 if (il_scan_cancel_timeout(il, 100)) {
2443 IL_WARN(priv, 2443 IL_WARN(il,
2444 "Aborted scan still in progress after 100ms\n"); 2444 "Aborted scan still in progress after 100ms\n");
2445 IL_DEBUG_MAC80211(priv, 2445 IL_DEBUG_MAC80211(il,
2446 "leaving - scan abort failed.\n"); 2446 "leaving - scan abort failed.\n");
2447 mutex_unlock(&priv->mutex); 2447 mutex_unlock(&il->mutex);
2448 return; 2448 return;
2449 } 2449 }
2450 2450
@@ -2454,7 +2454,7 @@ void il_mac_bss_info_changed(struct ieee80211_hw *hw,
2454 bss_conf->bssid, ETH_ALEN); 2454 bss_conf->bssid, ETH_ALEN);
2455 2455
2456 /* currently needed in a few places */ 2456 /* currently needed in a few places */
2457 memcpy(priv->bssid, bss_conf->bssid, ETH_ALEN); 2457 memcpy(il->bssid, bss_conf->bssid, ETH_ALEN);
2458 } else { 2458 } else {
2459 ctx->staging.filter_flags &= 2459 ctx->staging.filter_flags &=
2460 ~RXON_FILTER_ASSOC_MSK; 2460 ~RXON_FILTER_ASSOC_MSK;
@@ -2471,7 +2471,7 @@ void il_mac_bss_info_changed(struct ieee80211_hw *hw,
2471 il_beacon_update(hw, vif); 2471 il_beacon_update(hw, vif);
2472 2472
2473 if (changes & BSS_CHANGED_ERP_PREAMBLE) { 2473 if (changes & BSS_CHANGED_ERP_PREAMBLE) {
2474 IL_DEBUG_MAC80211(priv, "ERP_PREAMBLE %d\n", 2474 IL_DEBUG_MAC80211(il, "ERP_PREAMBLE %d\n",
2475 bss_conf->use_short_preamble); 2475 bss_conf->use_short_preamble);
2476 if (bss_conf->use_short_preamble) 2476 if (bss_conf->use_short_preamble)
2477 ctx->staging.flags |= RXON_FLG_SHORT_PREAMBLE_MSK; 2477 ctx->staging.flags |= RXON_FLG_SHORT_PREAMBLE_MSK;
@@ -2480,10 +2480,10 @@ void il_mac_bss_info_changed(struct ieee80211_hw *hw,
2480 } 2480 }
2481 2481
2482 if (changes & BSS_CHANGED_ERP_CTS_PROT) { 2482 if (changes & BSS_CHANGED_ERP_CTS_PROT) {
2483 IL_DEBUG_MAC80211(priv, 2483 IL_DEBUG_MAC80211(il,
2484 "ERP_CTS %d\n", bss_conf->use_cts_prot); 2484 "ERP_CTS %d\n", bss_conf->use_cts_prot);
2485 if (bss_conf->use_cts_prot && 2485 if (bss_conf->use_cts_prot &&
2486 (priv->band != IEEE80211_BAND_5GHZ)) 2486 (il->band != IEEE80211_BAND_5GHZ))
2487 ctx->staging.flags |= RXON_FLG_TGG_PROTECT_MSK; 2487 ctx->staging.flags |= RXON_FLG_TGG_PROTECT_MSK;
2488 else 2488 else
2489 ctx->staging.flags &= ~RXON_FLG_TGG_PROTECT_MSK; 2489 ctx->staging.flags &= ~RXON_FLG_TGG_PROTECT_MSK;
@@ -2511,27 +2511,27 @@ void il_mac_bss_info_changed(struct ieee80211_hw *hw,
2511 } 2511 }
2512 2512
2513 if (changes & BSS_CHANGED_HT) { 2513 if (changes & BSS_CHANGED_HT) {
2514 il_ht_conf(priv, vif); 2514 il_ht_conf(il, vif);
2515 2515
2516 if (priv->cfg->ops->hcmd->set_rxon_chain) 2516 if (il->cfg->ops->hcmd->set_rxon_chain)
2517 priv->cfg->ops->hcmd->set_rxon_chain(priv, ctx); 2517 il->cfg->ops->hcmd->set_rxon_chain(il, ctx);
2518 } 2518 }
2519 2519
2520 if (changes & BSS_CHANGED_ASSOC) { 2520 if (changes & BSS_CHANGED_ASSOC) {
2521 IL_DEBUG_MAC80211(priv, "ASSOC %d\n", bss_conf->assoc); 2521 IL_DEBUG_MAC80211(il, "ASSOC %d\n", bss_conf->assoc);
2522 if (bss_conf->assoc) { 2522 if (bss_conf->assoc) {
2523 priv->timestamp = bss_conf->timestamp; 2523 il->timestamp = bss_conf->timestamp;
2524 2524
2525 if (!il_is_rfkill(priv)) 2525 if (!il_is_rfkill(il))
2526 priv->cfg->ops->legacy->post_associate(priv); 2526 il->cfg->ops->legacy->post_associate(il);
2527 } else 2527 } else
2528 il_set_no_assoc(priv, vif); 2528 il_set_no_assoc(il, vif);
2529 } 2529 }
2530 2530
2531 if (changes && il_is_associated_ctx(ctx) && bss_conf->aid) { 2531 if (changes && il_is_associated_ctx(ctx) && bss_conf->aid) {
2532 IL_DEBUG_MAC80211(priv, "Changes (%#x) while associated\n", 2532 IL_DEBUG_MAC80211(il, "Changes (%#x) while associated\n",
2533 changes); 2533 changes);
2534 ret = il_send_rxon_assoc(priv, ctx); 2534 ret = il_send_rxon_assoc(il, ctx);
2535 if (!ret) { 2535 if (!ret) {
2536 /* Sync active_rxon with latest change. */ 2536 /* Sync active_rxon with latest change. */
2537 memcpy((void *)&ctx->active, 2537 memcpy((void *)&ctx->active,
@@ -2544,54 +2544,54 @@ void il_mac_bss_info_changed(struct ieee80211_hw *hw,
2544 if (vif->bss_conf.enable_beacon) { 2544 if (vif->bss_conf.enable_beacon) {
2545 memcpy(ctx->staging.bssid_addr, 2545 memcpy(ctx->staging.bssid_addr,
2546 bss_conf->bssid, ETH_ALEN); 2546 bss_conf->bssid, ETH_ALEN);
2547 memcpy(priv->bssid, bss_conf->bssid, ETH_ALEN); 2547 memcpy(il->bssid, bss_conf->bssid, ETH_ALEN);
2548 priv->cfg->ops->legacy->config_ap(priv); 2548 il->cfg->ops->legacy->config_ap(il);
2549 } else 2549 } else
2550 il_set_no_assoc(priv, vif); 2550 il_set_no_assoc(il, vif);
2551 } 2551 }
2552 2552
2553 if (changes & BSS_CHANGED_IBSS) { 2553 if (changes & BSS_CHANGED_IBSS) {
2554 ret = priv->cfg->ops->legacy->manage_ibss_station(priv, vif, 2554 ret = il->cfg->ops->legacy->manage_ibss_station(il, vif,
2555 bss_conf->ibss_joined); 2555 bss_conf->ibss_joined);
2556 if (ret) 2556 if (ret)
2557 IL_ERR(priv, "failed to %s IBSS station %pM\n", 2557 IL_ERR(il, "failed to %s IBSS station %pM\n",
2558 bss_conf->ibss_joined ? "add" : "remove", 2558 bss_conf->ibss_joined ? "add" : "remove",
2559 bss_conf->bssid); 2559 bss_conf->bssid);
2560 } 2560 }
2561 2561
2562 mutex_unlock(&priv->mutex); 2562 mutex_unlock(&il->mutex);
2563 2563
2564 IL_DEBUG_MAC80211(priv, "leave\n"); 2564 IL_DEBUG_MAC80211(il, "leave\n");
2565} 2565}
2566EXPORT_SYMBOL(il_mac_bss_info_changed); 2566EXPORT_SYMBOL(il_mac_bss_info_changed);
2567 2567
2568irqreturn_t il_isr(int irq, void *data) 2568irqreturn_t il_isr(int irq, void *data)
2569{ 2569{
2570 struct il_priv *priv = data; 2570 struct il_priv *il = data;
2571 u32 inta, inta_mask; 2571 u32 inta, inta_mask;
2572 u32 inta_fh; 2572 u32 inta_fh;
2573 unsigned long flags; 2573 unsigned long flags;
2574 if (!priv) 2574 if (!il)
2575 return IRQ_NONE; 2575 return IRQ_NONE;
2576 2576
2577 spin_lock_irqsave(&priv->lock, flags); 2577 spin_lock_irqsave(&il->lock, flags);
2578 2578
2579 /* Disable (but don't clear!) interrupts here to avoid 2579 /* Disable (but don't clear!) interrupts here to avoid
2580 * back-to-back ISRs and sporadic interrupts from our NIC. 2580 * back-to-back ISRs and sporadic interrupts from our NIC.
2581 * If we have something to service, the tasklet will re-enable ints. 2581 * If we have something to service, the tasklet will re-enable ints.
2582 * If we *don't* have something, we'll re-enable before leaving here. */ 2582 * If we *don't* have something, we'll re-enable before leaving here. */
2583 inta_mask = il_read32(priv, CSR_INT_MASK); /* just for debug */ 2583 inta_mask = il_read32(il, CSR_INT_MASK); /* just for debug */
2584 il_write32(priv, CSR_INT_MASK, 0x00000000); 2584 il_write32(il, CSR_INT_MASK, 0x00000000);
2585 2585
2586 /* Discover which interrupts are active/pending */ 2586 /* Discover which interrupts are active/pending */
2587 inta = il_read32(priv, CSR_INT); 2587 inta = il_read32(il, CSR_INT);
2588 inta_fh = il_read32(priv, CSR_FH_INT_STATUS); 2588 inta_fh = il_read32(il, CSR_FH_INT_STATUS);
2589 2589
2590 /* Ignore interrupt if there's nothing in NIC to service. 2590 /* Ignore interrupt if there's nothing in NIC to service.
2591 * This may be due to IRQ shared with another device, 2591 * This may be due to IRQ shared with another device,
2592 * or due to sporadic interrupts thrown from our NIC. */ 2592 * or due to sporadic interrupts thrown from our NIC. */
2593 if (!inta && !inta_fh) { 2593 if (!inta && !inta_fh) {
2594 IL_DEBUG_ISR(priv, 2594 IL_DEBUG_ISR(il,
2595 "Ignore interrupt, inta == 0, inta_fh == 0\n"); 2595 "Ignore interrupt, inta == 0, inta_fh == 0\n");
2596 goto none; 2596 goto none;
2597 } 2597 }
@@ -2599,29 +2599,29 @@ irqreturn_t il_isr(int irq, void *data)
2599 if ((inta == 0xFFFFFFFF) || ((inta & 0xFFFFFFF0) == 0xa5a5a5a0)) { 2599 if ((inta == 0xFFFFFFFF) || ((inta & 0xFFFFFFF0) == 0xa5a5a5a0)) {
2600 /* Hardware disappeared. It might have already raised 2600 /* Hardware disappeared. It might have already raised
2601 * an interrupt */ 2601 * an interrupt */
2602 IL_WARN(priv, "HARDWARE GONE?? INTA == 0x%08x\n", inta); 2602 IL_WARN(il, "HARDWARE GONE?? INTA == 0x%08x\n", inta);
2603 goto unplugged; 2603 goto unplugged;
2604 } 2604 }
2605 2605
2606 IL_DEBUG_ISR(priv, "ISR inta 0x%08x, enabled 0x%08x, fh 0x%08x\n", 2606 IL_DEBUG_ISR(il, "ISR inta 0x%08x, enabled 0x%08x, fh 0x%08x\n",
2607 inta, inta_mask, inta_fh); 2607 inta, inta_mask, inta_fh);
2608 2608
2609 inta &= ~CSR_INT_BIT_SCD; 2609 inta &= ~CSR_INT_BIT_SCD;
2610 2610
2611 /* il_irq_tasklet() will service interrupts and re-enable them */ 2611 /* il_irq_tasklet() will service interrupts and re-enable them */
2612 if (likely(inta || inta_fh)) 2612 if (likely(inta || inta_fh))
2613 tasklet_schedule(&priv->irq_tasklet); 2613 tasklet_schedule(&il->irq_tasklet);
2614 2614
2615unplugged: 2615unplugged:
2616 spin_unlock_irqrestore(&priv->lock, flags); 2616 spin_unlock_irqrestore(&il->lock, flags);
2617 return IRQ_HANDLED; 2617 return IRQ_HANDLED;
2618 2618
2619none: 2619none:
2620 /* re-enable interrupts here since we don't have anything to service. */ 2620 /* re-enable interrupts here since we don't have anything to service. */
2621 /* only Re-enable if disabled by irq */ 2621 /* only Re-enable if disabled by irq */
2622 if (test_bit(STATUS_INT_ENABLED, &priv->status)) 2622 if (test_bit(STATUS_INT_ENABLED, &il->status))
2623 il_enable_interrupts(priv); 2623 il_enable_interrupts(il);
2624 spin_unlock_irqrestore(&priv->lock, flags); 2624 spin_unlock_irqrestore(&il->lock, flags);
2625 return IRQ_NONE; 2625 return IRQ_NONE;
2626} 2626}
2627EXPORT_SYMBOL(il_isr); 2627EXPORT_SYMBOL(il_isr);
@@ -2630,7 +2630,7 @@ EXPORT_SYMBOL(il_isr);
2630 * il_tx_cmd_protection: Set rts/cts. 3945 and 4965 only share this 2630 * il_tx_cmd_protection: Set rts/cts. 3945 and 4965 only share this
2631 * function. 2631 * function.
2632 */ 2632 */
2633void il_tx_cmd_protection(struct il_priv *priv, 2633void il_tx_cmd_protection(struct il_priv *il,
2634 struct ieee80211_tx_info *info, 2634 struct ieee80211_tx_info *info,
2635 __le16 fc, __le32 *tx_flags) 2635 __le16 fc, __le32 *tx_flags)
2636{ 2636{
diff --git a/drivers/net/wireless/iwlegacy/iwl-core.h b/drivers/net/wireless/iwlegacy/iwl-core.h
index 92f37c981797..1803954cbc5a 100644
--- a/drivers/net/wireless/iwlegacy/iwl-core.h
+++ b/drivers/net/wireless/iwlegacy/iwl-core.h
@@ -88,9 +88,9 @@ struct il_cmd;
88#define IL_CMD(x) case x: return #x 88#define IL_CMD(x) case x: return #x
89 89
90struct il_hcmd_ops { 90struct il_hcmd_ops {
91 int (*rxon_assoc)(struct il_priv *priv, struct il_rxon_context *ctx); 91 int (*rxon_assoc)(struct il_priv *il, struct il_rxon_context *ctx);
92 int (*commit_rxon)(struct il_priv *priv, struct il_rxon_context *ctx); 92 int (*commit_rxon)(struct il_priv *il, struct il_rxon_context *ctx);
93 void (*set_rxon_chain)(struct il_priv *priv, 93 void (*set_rxon_chain)(struct il_priv *il,
94 struct il_rxon_context *ctx); 94 struct il_rxon_context *ctx);
95}; 95};
96 96
@@ -98,13 +98,13 @@ struct il_hcmd_utils_ops {
98 u16 (*get_hcmd_size)(u8 cmd_id, u16 len); 98 u16 (*get_hcmd_size)(u8 cmd_id, u16 len);
99 u16 (*build_addsta_hcmd)(const struct il_addsta_cmd *cmd, 99 u16 (*build_addsta_hcmd)(const struct il_addsta_cmd *cmd,
100 u8 *data); 100 u8 *data);
101 int (*request_scan)(struct il_priv *priv, struct ieee80211_vif *vif); 101 int (*request_scan)(struct il_priv *il, struct ieee80211_vif *vif);
102 void (*post_scan)(struct il_priv *priv); 102 void (*post_scan)(struct il_priv *il);
103}; 103};
104 104
105struct il_apm_ops { 105struct il_apm_ops {
106 int (*init)(struct il_priv *priv); 106 int (*init)(struct il_priv *il);
107 void (*config)(struct il_priv *priv); 107 void (*config)(struct il_priv *il);
108}; 108};
109 109
110struct il_debugfs_ops { 110struct il_debugfs_ops {
@@ -117,43 +117,43 @@ struct il_debugfs_ops {
117}; 117};
118 118
119struct il_temp_ops { 119struct il_temp_ops {
120 void (*temperature)(struct il_priv *priv); 120 void (*temperature)(struct il_priv *il);
121}; 121};
122 122
123struct il_lib_ops { 123struct il_lib_ops {
124 /* set hw dependent parameters */ 124 /* set hw dependent parameters */
125 int (*set_hw_params)(struct il_priv *priv); 125 int (*set_hw_params)(struct il_priv *il);
126 /* Handling TX */ 126 /* Handling TX */
127 void (*txq_update_byte_cnt_tbl)(struct il_priv *priv, 127 void (*txq_update_byte_cnt_tbl)(struct il_priv *il,
128 struct il_tx_queue *txq, 128 struct il_tx_queue *txq,
129 u16 byte_cnt); 129 u16 byte_cnt);
130 int (*txq_attach_buf_to_tfd)(struct il_priv *priv, 130 int (*txq_attach_buf_to_tfd)(struct il_priv *il,
131 struct il_tx_queue *txq, 131 struct il_tx_queue *txq,
132 dma_addr_t addr, 132 dma_addr_t addr,
133 u16 len, u8 reset, u8 pad); 133 u16 len, u8 reset, u8 pad);
134 void (*txq_free_tfd)(struct il_priv *priv, 134 void (*txq_free_tfd)(struct il_priv *il,
135 struct il_tx_queue *txq); 135 struct il_tx_queue *txq);
136 int (*txq_init)(struct il_priv *priv, 136 int (*txq_init)(struct il_priv *il,
137 struct il_tx_queue *txq); 137 struct il_tx_queue *txq);
138 /* setup Rx handler */ 138 /* setup Rx handler */
139 void (*rx_handler_setup)(struct il_priv *priv); 139 void (*rx_handler_setup)(struct il_priv *il);
140 /* alive notification after init uCode load */ 140 /* alive notification after init uCode load */
141 void (*init_alive_start)(struct il_priv *priv); 141 void (*init_alive_start)(struct il_priv *il);
142 /* check validity of rtc data address */ 142 /* check validity of rtc data address */
143 int (*is_valid_rtc_data_addr)(u32 addr); 143 int (*is_valid_rtc_data_addr)(u32 addr);
144 /* 1st ucode load */ 144 /* 1st ucode load */
145 int (*load_ucode)(struct il_priv *priv); 145 int (*load_ucode)(struct il_priv *il);
146 146
147 void (*dump_nic_error_log)(struct il_priv *priv); 147 void (*dump_nic_error_log)(struct il_priv *il);
148 int (*dump_fh)(struct il_priv *priv, char **buf, bool display); 148 int (*dump_fh)(struct il_priv *il, char **buf, bool display);
149 int (*set_channel_switch)(struct il_priv *priv, 149 int (*set_channel_switch)(struct il_priv *il,
150 struct ieee80211_channel_switch *ch_switch); 150 struct ieee80211_channel_switch *ch_switch);
151 /* power management */ 151 /* power management */
152 struct il_apm_ops apm_ops; 152 struct il_apm_ops apm_ops;
153 153
154 /* power */ 154 /* power */
155 int (*send_tx_power) (struct il_priv *priv); 155 int (*send_tx_power) (struct il_priv *il);
156 void (*update_chain_flags)(struct il_priv *priv); 156 void (*update_chain_flags)(struct il_priv *il);
157 157
158 /* eeprom operations (as defined in iwl-eeprom.h) */ 158 /* eeprom operations (as defined in iwl-eeprom.h) */
159 struct il_eeprom_ops eeprom_ops; 159 struct il_eeprom_ops eeprom_ops;
@@ -166,15 +166,15 @@ struct il_lib_ops {
166}; 166};
167 167
168struct il_led_ops { 168struct il_led_ops {
169 int (*cmd)(struct il_priv *priv, struct il_led_cmd *led_cmd); 169 int (*cmd)(struct il_priv *il, struct il_led_cmd *led_cmd);
170}; 170};
171 171
172struct il_legacy_ops { 172struct il_legacy_ops {
173 void (*post_associate)(struct il_priv *priv); 173 void (*post_associate)(struct il_priv *il);
174 void (*config_ap)(struct il_priv *priv); 174 void (*config_ap)(struct il_priv *il);
175 /* station management */ 175 /* station management */
176 int (*update_bcast_stations)(struct il_priv *priv); 176 int (*update_bcast_stations)(struct il_priv *il);
177 int (*manage_ibss_station)(struct il_priv *priv, 177 int (*manage_ibss_station)(struct il_priv *il,
178 struct ieee80211_vif *vif, bool add); 178 struct ieee80211_vif *vif, bool add);
179}; 179};
180 180
@@ -247,7 +247,7 @@ struct il_base_params {
247 * on firmware version used. 247 * on firmware version used.
248 * 248 *
249 * For example, 249 * For example,
250 * if (IL_UCODE_API(priv->ucode_ver) >= 2) { 250 * if (IL_UCODE_API(il->ucode_ver) >= 2) {
251 * Driver interacts with Firmware API version >= 2. 251 * Driver interacts with Firmware API version >= 2.
252 * } else { 252 * } else {
253 * Driver interacts with Firmware API version 1. 253 * Driver interacts with Firmware API version 1.
@@ -290,35 +290,35 @@ int il_mac_conf_tx(struct ieee80211_hw *hw,
290 struct ieee80211_vif *vif, u16 queue, 290 struct ieee80211_vif *vif, u16 queue,
291 const struct ieee80211_tx_queue_params *params); 291 const struct ieee80211_tx_queue_params *params);
292int il_mac_tx_last_beacon(struct ieee80211_hw *hw); 292int il_mac_tx_last_beacon(struct ieee80211_hw *hw);
293void il_set_rxon_hwcrypto(struct il_priv *priv, 293void il_set_rxon_hwcrypto(struct il_priv *il,
294 struct il_rxon_context *ctx, 294 struct il_rxon_context *ctx,
295 int hw_decrypt); 295 int hw_decrypt);
296int il_check_rxon_cmd(struct il_priv *priv, 296int il_check_rxon_cmd(struct il_priv *il,
297 struct il_rxon_context *ctx); 297 struct il_rxon_context *ctx);
298int il_full_rxon_required(struct il_priv *priv, 298int il_full_rxon_required(struct il_priv *il,
299 struct il_rxon_context *ctx); 299 struct il_rxon_context *ctx);
300int il_set_rxon_channel(struct il_priv *priv, 300int il_set_rxon_channel(struct il_priv *il,
301 struct ieee80211_channel *ch, 301 struct ieee80211_channel *ch,
302 struct il_rxon_context *ctx); 302 struct il_rxon_context *ctx);
303void il_set_flags_for_band(struct il_priv *priv, 303void il_set_flags_for_band(struct il_priv *il,
304 struct il_rxon_context *ctx, 304 struct il_rxon_context *ctx,
305 enum ieee80211_band band, 305 enum ieee80211_band band,
306 struct ieee80211_vif *vif); 306 struct ieee80211_vif *vif);
307u8 il_get_single_channel_number(struct il_priv *priv, 307u8 il_get_single_channel_number(struct il_priv *il,
308 enum ieee80211_band band); 308 enum ieee80211_band band);
309void il_set_rxon_ht(struct il_priv *priv, 309void il_set_rxon_ht(struct il_priv *il,
310 struct il_ht_config *ht_conf); 310 struct il_ht_config *ht_conf);
311bool il_is_ht40_tx_allowed(struct il_priv *priv, 311bool il_is_ht40_tx_allowed(struct il_priv *il,
312 struct il_rxon_context *ctx, 312 struct il_rxon_context *ctx,
313 struct ieee80211_sta_ht_cap *ht_cap); 313 struct ieee80211_sta_ht_cap *ht_cap);
314void il_connection_init_rx_config(struct il_priv *priv, 314void il_connection_init_rx_config(struct il_priv *il,
315 struct il_rxon_context *ctx); 315 struct il_rxon_context *ctx);
316void il_set_rate(struct il_priv *priv); 316void il_set_rate(struct il_priv *il);
317int il_set_decrypted_flag(struct il_priv *priv, 317int il_set_decrypted_flag(struct il_priv *il,
318 struct ieee80211_hdr *hdr, 318 struct ieee80211_hdr *hdr,
319 u32 decrypt_res, 319 u32 decrypt_res,
320 struct ieee80211_rx_status *stats); 320 struct ieee80211_rx_status *stats);
321void il_irq_handle_error(struct il_priv *priv); 321void il_irq_handle_error(struct il_priv *il);
322int il_mac_add_interface(struct ieee80211_hw *hw, 322int il_mac_add_interface(struct ieee80211_hw *hw,
323 struct ieee80211_vif *vif); 323 struct ieee80211_vif *vif);
324void il_mac_remove_interface(struct ieee80211_hw *hw, 324void il_mac_remove_interface(struct ieee80211_hw *hw,
@@ -326,42 +326,42 @@ void il_mac_remove_interface(struct ieee80211_hw *hw,
326int il_mac_change_interface(struct ieee80211_hw *hw, 326int il_mac_change_interface(struct ieee80211_hw *hw,
327 struct ieee80211_vif *vif, 327 struct ieee80211_vif *vif,
328 enum nl80211_iftype newtype, bool newp2p); 328 enum nl80211_iftype newtype, bool newp2p);
329int il_alloc_txq_mem(struct il_priv *priv); 329int il_alloc_txq_mem(struct il_priv *il);
330void il_txq_mem(struct il_priv *priv); 330void il_txq_mem(struct il_priv *il);
331 331
332#ifdef CONFIG_IWLWIFI_LEGACY_DEBUGFS 332#ifdef CONFIG_IWLWIFI_LEGACY_DEBUGFS
333int il_alloc_traffic_mem(struct il_priv *priv); 333int il_alloc_traffic_mem(struct il_priv *il);
334void il_free_traffic_mem(struct il_priv *priv); 334void il_free_traffic_mem(struct il_priv *il);
335void il_reset_traffic_log(struct il_priv *priv); 335void il_reset_traffic_log(struct il_priv *il);
336void il_dbg_log_tx_data_frame(struct il_priv *priv, 336void il_dbg_log_tx_data_frame(struct il_priv *il,
337 u16 length, struct ieee80211_hdr *header); 337 u16 length, struct ieee80211_hdr *header);
338void il_dbg_log_rx_data_frame(struct il_priv *priv, 338void il_dbg_log_rx_data_frame(struct il_priv *il,
339 u16 length, struct ieee80211_hdr *header); 339 u16 length, struct ieee80211_hdr *header);
340const char *il_get_mgmt_string(int cmd); 340const char *il_get_mgmt_string(int cmd);
341const char *il_get_ctrl_string(int cmd); 341const char *il_get_ctrl_string(int cmd);
342void il_clear_traffic_stats(struct il_priv *priv); 342void il_clear_traffic_stats(struct il_priv *il);
343void il_update_stats(struct il_priv *priv, bool is_tx, __le16 fc, 343void il_update_stats(struct il_priv *il, bool is_tx, __le16 fc,
344 u16 len); 344 u16 len);
345#else 345#else
346static inline int il_alloc_traffic_mem(struct il_priv *priv) 346static inline int il_alloc_traffic_mem(struct il_priv *il)
347{ 347{
348 return 0; 348 return 0;
349} 349}
350static inline void il_free_traffic_mem(struct il_priv *priv) 350static inline void il_free_traffic_mem(struct il_priv *il)
351{ 351{
352} 352}
353static inline void il_reset_traffic_log(struct il_priv *priv) 353static inline void il_reset_traffic_log(struct il_priv *il)
354{ 354{
355} 355}
356static inline void il_dbg_log_tx_data_frame(struct il_priv *priv, 356static inline void il_dbg_log_tx_data_frame(struct il_priv *il,
357 u16 length, struct ieee80211_hdr *header) 357 u16 length, struct ieee80211_hdr *header)
358{ 358{
359} 359}
360static inline void il_dbg_log_rx_data_frame(struct il_priv *priv, 360static inline void il_dbg_log_rx_data_frame(struct il_priv *il,
361 u16 length, struct ieee80211_hdr *header) 361 u16 length, struct ieee80211_hdr *header)
362{ 362{
363} 363}
364static inline void il_update_stats(struct il_priv *priv, bool is_tx, 364static inline void il_update_stats(struct il_priv *il, bool is_tx,
365 __le16 fc, u16 len) 365 __le16 fc, u16 len)
366{ 366{
367} 367}
@@ -369,83 +369,83 @@ static inline void il_update_stats(struct il_priv *priv, bool is_tx,
369/***************************************************** 369/*****************************************************
370 * RX handlers. 370 * RX handlers.
371 * **************************************************/ 371 * **************************************************/
372void il_rx_pm_sleep_notif(struct il_priv *priv, 372void il_rx_pm_sleep_notif(struct il_priv *il,
373 struct il_rx_mem_buffer *rxb); 373 struct il_rx_mem_buffer *rxb);
374void il_rx_pm_debug_statistics_notif(struct il_priv *priv, 374void il_rx_pm_debug_statistics_notif(struct il_priv *il,
375 struct il_rx_mem_buffer *rxb); 375 struct il_rx_mem_buffer *rxb);
376void il_rx_reply_error(struct il_priv *priv, 376void il_rx_reply_error(struct il_priv *il,
377 struct il_rx_mem_buffer *rxb); 377 struct il_rx_mem_buffer *rxb);
378 378
379/***************************************************** 379/*****************************************************
380* RX 380* RX
381******************************************************/ 381******************************************************/
382void il_cmd_queue_unmap(struct il_priv *priv); 382void il_cmd_queue_unmap(struct il_priv *il);
383void il_cmd_queue_free(struct il_priv *priv); 383void il_cmd_queue_free(struct il_priv *il);
384int il_rx_queue_alloc(struct il_priv *priv); 384int il_rx_queue_alloc(struct il_priv *il);
385void il_rx_queue_update_write_ptr(struct il_priv *priv, 385void il_rx_queue_update_write_ptr(struct il_priv *il,
386 struct il_rx_queue *q); 386 struct il_rx_queue *q);
387int il_rx_queue_space(const struct il_rx_queue *q); 387int il_rx_queue_space(const struct il_rx_queue *q);
388void il_tx_cmd_complete(struct il_priv *priv, 388void il_tx_cmd_complete(struct il_priv *il,
389 struct il_rx_mem_buffer *rxb); 389 struct il_rx_mem_buffer *rxb);
390/* Handlers */ 390/* Handlers */
391void il_rx_spectrum_measure_notif(struct il_priv *priv, 391void il_rx_spectrum_measure_notif(struct il_priv *il,
392 struct il_rx_mem_buffer *rxb); 392 struct il_rx_mem_buffer *rxb);
393void il_recover_from_statistics(struct il_priv *priv, 393void il_recover_from_statistics(struct il_priv *il,
394 struct il_rx_packet *pkt); 394 struct il_rx_packet *pkt);
395void il_chswitch_done(struct il_priv *priv, bool is_success); 395void il_chswitch_done(struct il_priv *il, bool is_success);
396void il_rx_csa(struct il_priv *priv, struct il_rx_mem_buffer *rxb); 396void il_rx_csa(struct il_priv *il, struct il_rx_mem_buffer *rxb);
397 397
398/* TX helpers */ 398/* TX helpers */
399 399
400/***************************************************** 400/*****************************************************
401* TX 401* TX
402******************************************************/ 402******************************************************/
403void il_txq_update_write_ptr(struct il_priv *priv, 403void il_txq_update_write_ptr(struct il_priv *il,
404 struct il_tx_queue *txq); 404 struct il_tx_queue *txq);
405int il_tx_queue_init(struct il_priv *priv, struct il_tx_queue *txq, 405int il_tx_queue_init(struct il_priv *il, struct il_tx_queue *txq,
406 int slots_num, u32 txq_id); 406 int slots_num, u32 txq_id);
407void il_tx_queue_reset(struct il_priv *priv, 407void il_tx_queue_reset(struct il_priv *il,
408 struct il_tx_queue *txq, 408 struct il_tx_queue *txq,
409 int slots_num, u32 txq_id); 409 int slots_num, u32 txq_id);
410void il_tx_queue_unmap(struct il_priv *priv, int txq_id); 410void il_tx_queue_unmap(struct il_priv *il, int txq_id);
411void il_tx_queue_free(struct il_priv *priv, int txq_id); 411void il_tx_queue_free(struct il_priv *il, int txq_id);
412void il_setup_watchdog(struct il_priv *priv); 412void il_setup_watchdog(struct il_priv *il);
413/***************************************************** 413/*****************************************************
414 * TX power 414 * TX power
415 ****************************************************/ 415 ****************************************************/
416int il_set_tx_power(struct il_priv *priv, s8 tx_power, bool force); 416int il_set_tx_power(struct il_priv *il, s8 tx_power, bool force);
417 417
418/******************************************************************************* 418/*******************************************************************************
419 * Rate 419 * Rate
420 ******************************************************************************/ 420 ******************************************************************************/
421 421
422u8 il_get_lowest_plcp(struct il_priv *priv, 422u8 il_get_lowest_plcp(struct il_priv *il,
423 struct il_rxon_context *ctx); 423 struct il_rxon_context *ctx);
424 424
425/******************************************************************************* 425/*******************************************************************************
426 * Scanning 426 * Scanning
427 ******************************************************************************/ 427 ******************************************************************************/
428void il_init_scan_params(struct il_priv *priv); 428void il_init_scan_params(struct il_priv *il);
429int il_scan_cancel(struct il_priv *priv); 429int il_scan_cancel(struct il_priv *il);
430int il_scan_cancel_timeout(struct il_priv *priv, unsigned long ms); 430int il_scan_cancel_timeout(struct il_priv *il, unsigned long ms);
431void il_force_scan_end(struct il_priv *priv); 431void il_force_scan_end(struct il_priv *il);
432int il_mac_hw_scan(struct ieee80211_hw *hw, 432int il_mac_hw_scan(struct ieee80211_hw *hw,
433 struct ieee80211_vif *vif, 433 struct ieee80211_vif *vif,
434 struct cfg80211_scan_request *req); 434 struct cfg80211_scan_request *req);
435void il_internal_short_hw_scan(struct il_priv *priv); 435void il_internal_short_hw_scan(struct il_priv *il);
436int il_force_reset(struct il_priv *priv, bool external); 436int il_force_reset(struct il_priv *il, bool external);
437u16 il_fill_probe_req(struct il_priv *priv, 437u16 il_fill_probe_req(struct il_priv *il,
438 struct ieee80211_mgmt *frame, 438 struct ieee80211_mgmt *frame,
439 const u8 *ta, const u8 *ie, int ie_len, int left); 439 const u8 *ta, const u8 *ie, int ie_len, int left);
440void il_setup_rx_scan_handlers(struct il_priv *priv); 440void il_setup_rx_scan_handlers(struct il_priv *il);
441u16 il_get_active_dwell_time(struct il_priv *priv, 441u16 il_get_active_dwell_time(struct il_priv *il,
442 enum ieee80211_band band, 442 enum ieee80211_band band,
443 u8 n_probes); 443 u8 n_probes);
444u16 il_get_passive_dwell_time(struct il_priv *priv, 444u16 il_get_passive_dwell_time(struct il_priv *il,
445 enum ieee80211_band band, 445 enum ieee80211_band band,
446 struct ieee80211_vif *vif); 446 struct ieee80211_vif *vif);
447void il_setup_scan_deferred_work(struct il_priv *priv); 447void il_setup_scan_deferred_work(struct il_priv *il);
448void il_cancel_scan_deferred_work(struct il_priv *priv); 448void il_cancel_scan_deferred_work(struct il_priv *il);
449 449
450/* For faster active scanning, scan will move to the next channel if fewer than 450/* For faster active scanning, scan will move to the next channel if fewer than
451 * PLCP_QUIET_THRESH packets are heard on this channel within 451 * PLCP_QUIET_THRESH packets are heard on this channel within
@@ -463,37 +463,37 @@ void il_cancel_scan_deferred_work(struct il_priv *priv);
463 *****************************************************/ 463 *****************************************************/
464 464
465const char *il_get_cmd_string(u8 cmd); 465const char *il_get_cmd_string(u8 cmd);
466int __must_check il_send_cmd_sync(struct il_priv *priv, 466int __must_check il_send_cmd_sync(struct il_priv *il,
467 struct il_host_cmd *cmd); 467 struct il_host_cmd *cmd);
468int il_send_cmd(struct il_priv *priv, struct il_host_cmd *cmd); 468int il_send_cmd(struct il_priv *il, struct il_host_cmd *cmd);
469int __must_check il_send_cmd_pdu(struct il_priv *priv, u8 id, 469int __must_check il_send_cmd_pdu(struct il_priv *il, u8 id,
470 u16 len, const void *data); 470 u16 len, const void *data);
471int il_send_cmd_pdu_async(struct il_priv *priv, u8 id, u16 len, 471int il_send_cmd_pdu_async(struct il_priv *il, u8 id, u16 len,
472 const void *data, 472 const void *data,
473 void (*callback)(struct il_priv *priv, 473 void (*callback)(struct il_priv *il,
474 struct il_device_cmd *cmd, 474 struct il_device_cmd *cmd,
475 struct il_rx_packet *pkt)); 475 struct il_rx_packet *pkt));
476 476
477int il_enqueue_hcmd(struct il_priv *priv, struct il_host_cmd *cmd); 477int il_enqueue_hcmd(struct il_priv *il, struct il_host_cmd *cmd);
478 478
479 479
480/***************************************************** 480/*****************************************************
481 * PCI * 481 * PCI *
482 *****************************************************/ 482 *****************************************************/
483 483
484static inline u16 il_pcie_link_ctl(struct il_priv *priv) 484static inline u16 il_pcie_link_ctl(struct il_priv *il)
485{ 485{
486 int pos; 486 int pos;
487 u16 pci_lnk_ctl; 487 u16 pci_lnk_ctl;
488 pos = pci_pcie_cap(priv->pci_dev); 488 pos = pci_pcie_cap(il->pci_dev);
489 pci_read_config_word(priv->pci_dev, pos + PCI_EXP_LNKCTL, &pci_lnk_ctl); 489 pci_read_config_word(il->pci_dev, pos + PCI_EXP_LNKCTL, &pci_lnk_ctl);
490 return pci_lnk_ctl; 490 return pci_lnk_ctl;
491} 491}
492 492
493void il_bg_watchdog(unsigned long data); 493void il_bg_watchdog(unsigned long data);
494u32 il_usecs_to_beacons(struct il_priv *priv, 494u32 il_usecs_to_beacons(struct il_priv *il,
495 u32 usec, u32 beacon_interval); 495 u32 usec, u32 beacon_interval);
496__le32 il_add_beacon_time(struct il_priv *priv, u32 base, 496__le32 il_add_beacon_time(struct il_priv *il, u32 base,
497 u32 addon, u32 beacon_interval); 497 u32 addon, u32 beacon_interval);
498 498
499#ifdef CONFIG_PM 499#ifdef CONFIG_PM
@@ -512,24 +512,24 @@ extern const struct dev_pm_ops il_pm_ops;
512/***************************************************** 512/*****************************************************
513* Error Handling Debugging 513* Error Handling Debugging
514******************************************************/ 514******************************************************/
515void il4965_dump_nic_error_log(struct il_priv *priv); 515void il4965_dump_nic_error_log(struct il_priv *il);
516#ifdef CONFIG_IWLWIFI_LEGACY_DEBUG 516#ifdef CONFIG_IWLWIFI_LEGACY_DEBUG
517void il_print_rx_config_cmd(struct il_priv *priv, 517void il_print_rx_config_cmd(struct il_priv *il,
518 struct il_rxon_context *ctx); 518 struct il_rxon_context *ctx);
519#else 519#else
520static inline void il_print_rx_config_cmd(struct il_priv *priv, 520static inline void il_print_rx_config_cmd(struct il_priv *il,
521 struct il_rxon_context *ctx) 521 struct il_rxon_context *ctx)
522{ 522{
523} 523}
524#endif 524#endif
525 525
526void il_clear_isr_stats(struct il_priv *priv); 526void il_clear_isr_stats(struct il_priv *il);
527 527
528/***************************************************** 528/*****************************************************
529* GEOS 529* GEOS
530******************************************************/ 530******************************************************/
531int il_init_geos(struct il_priv *priv); 531int il_init_geos(struct il_priv *il);
532void il_free_geos(struct il_priv *priv); 532void il_free_geos(struct il_priv *il);
533 533
534/*************** DRIVER STATUS FUNCTIONS *****/ 534/*************** DRIVER STATUS FUNCTIONS *****/
535 535
@@ -552,71 +552,71 @@ void il_free_geos(struct il_priv *priv);
552#define STATUS_FW_ERROR 17 552#define STATUS_FW_ERROR 17
553#define STATUS_CHANNEL_SWITCH_PENDING 18 553#define STATUS_CHANNEL_SWITCH_PENDING 18
554 554
555static inline int il_is_ready(struct il_priv *priv) 555static inline int il_is_ready(struct il_priv *il)
556{ 556{
557 /* The adapter is 'ready' if READY and GEO_CONFIGURED bits are 557 /* The adapter is 'ready' if READY and GEO_CONFIGURED bits are
558 * set but EXIT_PENDING is not */ 558 * set but EXIT_PENDING is not */
559 return test_bit(STATUS_READY, &priv->status) && 559 return test_bit(STATUS_READY, &il->status) &&
560 test_bit(STATUS_GEO_CONFIGURED, &priv->status) && 560 test_bit(STATUS_GEO_CONFIGURED, &il->status) &&
561 !test_bit(STATUS_EXIT_PENDING, &priv->status); 561 !test_bit(STATUS_EXIT_PENDING, &il->status);
562} 562}
563 563
564static inline int il_is_alive(struct il_priv *priv) 564static inline int il_is_alive(struct il_priv *il)
565{ 565{
566 return test_bit(STATUS_ALIVE, &priv->status); 566 return test_bit(STATUS_ALIVE, &il->status);
567} 567}
568 568
569static inline int il_is_init(struct il_priv *priv) 569static inline int il_is_init(struct il_priv *il)
570{ 570{
571 return test_bit(STATUS_INIT, &priv->status); 571 return test_bit(STATUS_INIT, &il->status);
572} 572}
573 573
574static inline int il_is_rfkill_hw(struct il_priv *priv) 574static inline int il_is_rfkill_hw(struct il_priv *il)
575{ 575{
576 return test_bit(STATUS_RF_KILL_HW, &priv->status); 576 return test_bit(STATUS_RF_KILL_HW, &il->status);
577} 577}
578 578
579static inline int il_is_rfkill(struct il_priv *priv) 579static inline int il_is_rfkill(struct il_priv *il)
580{ 580{
581 return il_is_rfkill_hw(priv); 581 return il_is_rfkill_hw(il);
582} 582}
583 583
584static inline int il_is_ctkill(struct il_priv *priv) 584static inline int il_is_ctkill(struct il_priv *il)
585{ 585{
586 return test_bit(STATUS_CT_KILL, &priv->status); 586 return test_bit(STATUS_CT_KILL, &il->status);
587} 587}
588 588
589static inline int il_is_ready_rf(struct il_priv *priv) 589static inline int il_is_ready_rf(struct il_priv *il)
590{ 590{
591 591
592 if (il_is_rfkill(priv)) 592 if (il_is_rfkill(il))
593 return 0; 593 return 0;
594 594
595 return il_is_ready(priv); 595 return il_is_ready(il);
596} 596}
597 597
598extern void il_send_bt_config(struct il_priv *priv); 598extern void il_send_bt_config(struct il_priv *il);
599extern int il_send_statistics_request(struct il_priv *priv, 599extern int il_send_statistics_request(struct il_priv *il,
600 u8 flags, bool clear); 600 u8 flags, bool clear);
601void il_apm_stop(struct il_priv *priv); 601void il_apm_stop(struct il_priv *il);
602int il_apm_init(struct il_priv *priv); 602int il_apm_init(struct il_priv *il);
603 603
604int il_send_rxon_timing(struct il_priv *priv, 604int il_send_rxon_timing(struct il_priv *il,
605 struct il_rxon_context *ctx); 605 struct il_rxon_context *ctx);
606static inline int il_send_rxon_assoc(struct il_priv *priv, 606static inline int il_send_rxon_assoc(struct il_priv *il,
607 struct il_rxon_context *ctx) 607 struct il_rxon_context *ctx)
608{ 608{
609 return priv->cfg->ops->hcmd->rxon_assoc(priv, ctx); 609 return il->cfg->ops->hcmd->rxon_assoc(il, ctx);
610} 610}
611static inline int il_commit_rxon(struct il_priv *priv, 611static inline int il_commit_rxon(struct il_priv *il,
612 struct il_rxon_context *ctx) 612 struct il_rxon_context *ctx)
613{ 613{
614 return priv->cfg->ops->hcmd->commit_rxon(priv, ctx); 614 return il->cfg->ops->hcmd->commit_rxon(il, ctx);
615} 615}
616static inline const struct ieee80211_supported_band *il_get_hw_mode( 616static inline const struct ieee80211_supported_band *il_get_hw_mode(
617 struct il_priv *priv, enum ieee80211_band band) 617 struct il_priv *il, enum ieee80211_band band)
618{ 618{
619 return priv->hw->wiphy->bands[band]; 619 return il->hw->wiphy->bands[band];
620} 620}
621 621
622/* mac80211 handlers */ 622/* mac80211 handlers */
@@ -627,7 +627,7 @@ void il_mac_bss_info_changed(struct ieee80211_hw *hw,
627 struct ieee80211_vif *vif, 627 struct ieee80211_vif *vif,
628 struct ieee80211_bss_conf *bss_conf, 628 struct ieee80211_bss_conf *bss_conf,
629 u32 changes); 629 u32 changes);
630void il_tx_cmd_protection(struct il_priv *priv, 630void il_tx_cmd_protection(struct il_priv *il,
631 struct ieee80211_tx_info *info, 631 struct ieee80211_tx_info *info,
632 __le16 fc, __le32 *tx_flags); 632 __le16 fc, __le32 *tx_flags);
633 633
diff --git a/drivers/net/wireless/iwlegacy/iwl-debug.h b/drivers/net/wireless/iwlegacy/iwl-debug.h
index 1bbad766aac7..657da25a2354 100644
--- a/drivers/net/wireless/iwlegacy/iwl-debug.h
+++ b/drivers/net/wireless/iwlegacy/iwl-debug.h
@@ -37,7 +37,7 @@ extern u32 iwlegacy_debug_level;
37#define IL_INFO(p, f, a...) dev_info(&((p)->pci_dev->dev), f, ## a) 37#define IL_INFO(p, f, a...) dev_info(&((p)->pci_dev->dev), f, ## a)
38#define IL_CRIT(p, f, a...) dev_crit(&((p)->pci_dev->dev), f, ## a) 38#define IL_CRIT(p, f, a...) dev_crit(&((p)->pci_dev->dev), f, ## a)
39 39
40#define il_print_hex_error(priv, p, len) \ 40#define il_print_hex_error(il, p, len) \
41do { \ 41do { \
42 print_hex_dump(KERN_ERR, "iwl data: ", \ 42 print_hex_dump(KERN_ERR, "iwl data: ", \
43 DUMP_PREFIX_OFFSET, 16, 1, p, len, 1); \ 43 DUMP_PREFIX_OFFSET, 16, 1, p, len, 1); \
@@ -60,9 +60,9 @@ do { \
60 __func__ , ## args); \ 60 __func__ , ## args); \
61} while (0) 61} while (0)
62 62
63#define il_print_hex_dump(priv, level, p, len) \ 63#define il_print_hex_dump(il, level, p, len) \
64do { \ 64do { \
65 if (il_get_debug_level(priv) & level) \ 65 if (il_get_debug_level(il) & level) \
66 print_hex_dump(KERN_DEBUG, "iwl data: ", \ 66 print_hex_dump(KERN_DEBUG, "iwl data: ", \
67 DUMP_PREFIX_OFFSET, 16, 1, p, len, 1); \ 67 DUMP_PREFIX_OFFSET, 16, 1, p, len, 1); \
68} while (0) 68} while (0)
@@ -70,21 +70,21 @@ do { \
70#else 70#else
71#define IL_DEBUG(__priv, level, fmt, args...) 71#define IL_DEBUG(__priv, level, fmt, args...)
72#define IL_DEBUG_LIMIT(__priv, level, fmt, args...) 72#define IL_DEBUG_LIMIT(__priv, level, fmt, args...)
73static inline void il_print_hex_dump(struct il_priv *priv, int level, 73static inline void il_print_hex_dump(struct il_priv *il, int level,
74 const void *p, u32 len) 74 const void *p, u32 len)
75{} 75{}
76#endif /* CONFIG_IWLWIFI_LEGACY_DEBUG */ 76#endif /* CONFIG_IWLWIFI_LEGACY_DEBUG */
77 77
78#ifdef CONFIG_IWLWIFI_LEGACY_DEBUGFS 78#ifdef CONFIG_IWLWIFI_LEGACY_DEBUGFS
79int il_dbgfs_register(struct il_priv *priv, const char *name); 79int il_dbgfs_register(struct il_priv *il, const char *name);
80void il_dbgfs_unregister(struct il_priv *priv); 80void il_dbgfs_unregister(struct il_priv *il);
81#else 81#else
82static inline int 82static inline int
83il_dbgfs_register(struct il_priv *priv, const char *name) 83il_dbgfs_register(struct il_priv *il, const char *name)
84{ 84{
85 return 0; 85 return 0;
86} 86}
87static inline void il_dbgfs_unregister(struct il_priv *priv) 87static inline void il_dbgfs_unregister(struct il_priv *il)
88{ 88{
89} 89}
90#endif /* CONFIG_IWLWIFI_LEGACY_DEBUGFS */ 90#endif /* CONFIG_IWLWIFI_LEGACY_DEBUGFS */
diff --git a/drivers/net/wireless/iwlegacy/iwl-debugfs.c b/drivers/net/wireless/iwlegacy/iwl-debugfs.c
index 057dec5b178c..f2f2eba7d3ea 100644
--- a/drivers/net/wireless/iwlegacy/iwl-debugfs.c
+++ b/drivers/net/wireless/iwlegacy/iwl-debugfs.c
@@ -36,7 +36,7 @@
36 36
37/* create and remove of files */ 37/* create and remove of files */
38#define DEBUGFS_ADD_FILE(name, parent, mode) do { \ 38#define DEBUGFS_ADD_FILE(name, parent, mode) do { \
39 if (!debugfs_create_file(#name, mode, parent, priv, \ 39 if (!debugfs_create_file(#name, mode, parent, il, \
40 &il_dbgfs_##name##_ops)) \ 40 &il_dbgfs_##name##_ops)) \
41 goto err; \ 41 goto err; \
42} while (0) 42} while (0)
@@ -106,7 +106,7 @@ static ssize_t il_dbgfs_tx_statistics_read(struct file *file,
106 char __user *user_buf, 106 char __user *user_buf,
107 size_t count, loff_t *ppos) { 107 size_t count, loff_t *ppos) {
108 108
109 struct il_priv *priv = file->private_data; 109 struct il_priv *il = file->private_data;
110 char *buf; 110 char *buf;
111 int pos = 0; 111 int pos = 0;
112 112
@@ -122,20 +122,20 @@ static ssize_t il_dbgfs_tx_statistics_read(struct file *file,
122 pos += scnprintf(buf + pos, bufsz - pos, 122 pos += scnprintf(buf + pos, bufsz - pos,
123 "\t%25s\t\t: %u\n", 123 "\t%25s\t\t: %u\n",
124 il_get_mgmt_string(cnt), 124 il_get_mgmt_string(cnt),
125 priv->tx_stats.mgmt[cnt]); 125 il->tx_stats.mgmt[cnt]);
126 } 126 }
127 pos += scnprintf(buf + pos, bufsz - pos, "Control\n"); 127 pos += scnprintf(buf + pos, bufsz - pos, "Control\n");
128 for (cnt = 0; cnt < CONTROL_MAX; cnt++) { 128 for (cnt = 0; cnt < CONTROL_MAX; cnt++) {
129 pos += scnprintf(buf + pos, bufsz - pos, 129 pos += scnprintf(buf + pos, bufsz - pos,
130 "\t%25s\t\t: %u\n", 130 "\t%25s\t\t: %u\n",
131 il_get_ctrl_string(cnt), 131 il_get_ctrl_string(cnt),
132 priv->tx_stats.ctrl[cnt]); 132 il->tx_stats.ctrl[cnt]);
133 } 133 }
134 pos += scnprintf(buf + pos, bufsz - pos, "Data:\n"); 134 pos += scnprintf(buf + pos, bufsz - pos, "Data:\n");
135 pos += scnprintf(buf + pos, bufsz - pos, "\tcnt: %u\n", 135 pos += scnprintf(buf + pos, bufsz - pos, "\tcnt: %u\n",
136 priv->tx_stats.data_cnt); 136 il->tx_stats.data_cnt);
137 pos += scnprintf(buf + pos, bufsz - pos, "\tbytes: %llu\n", 137 pos += scnprintf(buf + pos, bufsz - pos, "\tbytes: %llu\n",
138 priv->tx_stats.data_bytes); 138 il->tx_stats.data_bytes);
139 ret = simple_read_from_buffer(user_buf, count, ppos, buf, pos); 139 ret = simple_read_from_buffer(user_buf, count, ppos, buf, pos);
140 kfree(buf); 140 kfree(buf);
141 return ret; 141 return ret;
@@ -146,7 +146,7 @@ il_dbgfs_clear_traffic_statistics_write(struct file *file,
146 const char __user *user_buf, 146 const char __user *user_buf,
147 size_t count, loff_t *ppos) 147 size_t count, loff_t *ppos)
148{ 148{
149 struct il_priv *priv = file->private_data; 149 struct il_priv *il = file->private_data;
150 u32 clear_flag; 150 u32 clear_flag;
151 char buf[8]; 151 char buf[8];
152 int buf_size; 152 int buf_size;
@@ -157,7 +157,7 @@ il_dbgfs_clear_traffic_statistics_write(struct file *file,
157 return -EFAULT; 157 return -EFAULT;
158 if (sscanf(buf, "%x", &clear_flag) != 1) 158 if (sscanf(buf, "%x", &clear_flag) != 1)
159 return -EFAULT; 159 return -EFAULT;
160 il_clear_traffic_stats(priv); 160 il_clear_traffic_stats(il);
161 161
162 return count; 162 return count;
163} 163}
@@ -166,7 +166,7 @@ static ssize_t il_dbgfs_rx_statistics_read(struct file *file,
166 char __user *user_buf, 166 char __user *user_buf,
167 size_t count, loff_t *ppos) { 167 size_t count, loff_t *ppos) {
168 168
169 struct il_priv *priv = file->private_data; 169 struct il_priv *il = file->private_data;
170 char *buf; 170 char *buf;
171 int pos = 0; 171 int pos = 0;
172 int cnt; 172 int cnt;
@@ -182,20 +182,20 @@ static ssize_t il_dbgfs_rx_statistics_read(struct file *file,
182 pos += scnprintf(buf + pos, bufsz - pos, 182 pos += scnprintf(buf + pos, bufsz - pos,
183 "\t%25s\t\t: %u\n", 183 "\t%25s\t\t: %u\n",
184 il_get_mgmt_string(cnt), 184 il_get_mgmt_string(cnt),
185 priv->rx_stats.mgmt[cnt]); 185 il->rx_stats.mgmt[cnt]);
186 } 186 }
187 pos += scnprintf(buf + pos, bufsz - pos, "Control:\n"); 187 pos += scnprintf(buf + pos, bufsz - pos, "Control:\n");
188 for (cnt = 0; cnt < CONTROL_MAX; cnt++) { 188 for (cnt = 0; cnt < CONTROL_MAX; cnt++) {
189 pos += scnprintf(buf + pos, bufsz - pos, 189 pos += scnprintf(buf + pos, bufsz - pos,
190 "\t%25s\t\t: %u\n", 190 "\t%25s\t\t: %u\n",
191 il_get_ctrl_string(cnt), 191 il_get_ctrl_string(cnt),
192 priv->rx_stats.ctrl[cnt]); 192 il->rx_stats.ctrl[cnt]);
193 } 193 }
194 pos += scnprintf(buf + pos, bufsz - pos, "Data:\n"); 194 pos += scnprintf(buf + pos, bufsz - pos, "Data:\n");
195 pos += scnprintf(buf + pos, bufsz - pos, "\tcnt: %u\n", 195 pos += scnprintf(buf + pos, bufsz - pos, "\tcnt: %u\n",
196 priv->rx_stats.data_cnt); 196 il->rx_stats.data_cnt);
197 pos += scnprintf(buf + pos, bufsz - pos, "\tbytes: %llu\n", 197 pos += scnprintf(buf + pos, bufsz - pos, "\tbytes: %llu\n",
198 priv->rx_stats.data_bytes); 198 il->rx_stats.data_bytes);
199 199
200 ret = simple_read_from_buffer(user_buf, count, ppos, buf, pos); 200 ret = simple_read_from_buffer(user_buf, count, ppos, buf, pos);
201 kfree(buf); 201 kfree(buf);
@@ -214,28 +214,28 @@ static ssize_t il_dbgfs_sram_read(struct file *file,
214 ssize_t ret; 214 ssize_t ret;
215 int i; 215 int i;
216 int pos = 0; 216 int pos = 0;
217 struct il_priv *priv = file->private_data; 217 struct il_priv *il = file->private_data;
218 size_t bufsz; 218 size_t bufsz;
219 219
220 /* default is to dump the entire data segment */ 220 /* default is to dump the entire data segment */
221 if (!priv->dbgfs_sram_offset && !priv->dbgfs_sram_len) { 221 if (!il->dbgfs_sram_offset && !il->dbgfs_sram_len) {
222 priv->dbgfs_sram_offset = 0x800000; 222 il->dbgfs_sram_offset = 0x800000;
223 if (priv->ucode_type == UCODE_INIT) 223 if (il->ucode_type == UCODE_INIT)
224 priv->dbgfs_sram_len = priv->ucode_init_data.len; 224 il->dbgfs_sram_len = il->ucode_init_data.len;
225 else 225 else
226 priv->dbgfs_sram_len = priv->ucode_data.len; 226 il->dbgfs_sram_len = il->ucode_data.len;
227 } 227 }
228 bufsz = 30 + priv->dbgfs_sram_len * sizeof(char) * 10; 228 bufsz = 30 + il->dbgfs_sram_len * sizeof(char) * 10;
229 buf = kmalloc(bufsz, GFP_KERNEL); 229 buf = kmalloc(bufsz, GFP_KERNEL);
230 if (!buf) 230 if (!buf)
231 return -ENOMEM; 231 return -ENOMEM;
232 pos += scnprintf(buf + pos, bufsz - pos, "sram_len: 0x%x\n", 232 pos += scnprintf(buf + pos, bufsz - pos, "sram_len: 0x%x\n",
233 priv->dbgfs_sram_len); 233 il->dbgfs_sram_len);
234 pos += scnprintf(buf + pos, bufsz - pos, "sram_offset: 0x%x\n", 234 pos += scnprintf(buf + pos, bufsz - pos, "sram_offset: 0x%x\n",
235 priv->dbgfs_sram_offset); 235 il->dbgfs_sram_offset);
236 for (i = priv->dbgfs_sram_len; i > 0; i -= 4) { 236 for (i = il->dbgfs_sram_len; i > 0; i -= 4) {
237 val = il_read_targ_mem(priv, priv->dbgfs_sram_offset + \ 237 val = il_read_targ_mem(il, il->dbgfs_sram_offset + \
238 priv->dbgfs_sram_len - i); 238 il->dbgfs_sram_len - i);
239 if (i < 4) { 239 if (i < 4) {
240 switch (i) { 240 switch (i) {
241 case 1: 241 case 1:
@@ -264,7 +264,7 @@ static ssize_t il_dbgfs_sram_write(struct file *file,
264 const char __user *user_buf, 264 const char __user *user_buf,
265 size_t count, loff_t *ppos) 265 size_t count, loff_t *ppos)
266{ 266{
267 struct il_priv *priv = file->private_data; 267 struct il_priv *il = file->private_data;
268 char buf[64]; 268 char buf[64];
269 int buf_size; 269 int buf_size;
270 u32 offset, len; 270 u32 offset, len;
@@ -275,11 +275,11 @@ static ssize_t il_dbgfs_sram_write(struct file *file,
275 return -EFAULT; 275 return -EFAULT;
276 276
277 if (sscanf(buf, "%x,%x", &offset, &len) == 2) { 277 if (sscanf(buf, "%x,%x", &offset, &len) == 2) {
278 priv->dbgfs_sram_offset = offset; 278 il->dbgfs_sram_offset = offset;
279 priv->dbgfs_sram_len = len; 279 il->dbgfs_sram_len = len;
280 } else { 280 } else {
281 priv->dbgfs_sram_offset = 0; 281 il->dbgfs_sram_offset = 0;
282 priv->dbgfs_sram_len = 0; 282 il->dbgfs_sram_len = 0;
283 } 283 }
284 284
285 return count; 285 return count;
@@ -289,24 +289,24 @@ static ssize_t
289il_dbgfs_stations_read(struct file *file, char __user *user_buf, 289il_dbgfs_stations_read(struct file *file, char __user *user_buf,
290 size_t count, loff_t *ppos) 290 size_t count, loff_t *ppos)
291{ 291{
292 struct il_priv *priv = file->private_data; 292 struct il_priv *il = file->private_data;
293 struct il_station_entry *station; 293 struct il_station_entry *station;
294 int max_sta = priv->hw_params.max_stations; 294 int max_sta = il->hw_params.max_stations;
295 char *buf; 295 char *buf;
296 int i, j, pos = 0; 296 int i, j, pos = 0;
297 ssize_t ret; 297 ssize_t ret;
298 /* Add 30 for initial string */ 298 /* Add 30 for initial string */
299 const size_t bufsz = 30 + sizeof(char) * 500 * (priv->num_stations); 299 const size_t bufsz = 30 + sizeof(char) * 500 * (il->num_stations);
300 300
301 buf = kmalloc(bufsz, GFP_KERNEL); 301 buf = kmalloc(bufsz, GFP_KERNEL);
302 if (!buf) 302 if (!buf)
303 return -ENOMEM; 303 return -ENOMEM;
304 304
305 pos += scnprintf(buf + pos, bufsz - pos, "num of stations: %d\n\n", 305 pos += scnprintf(buf + pos, bufsz - pos, "num of stations: %d\n\n",
306 priv->num_stations); 306 il->num_stations);
307 307
308 for (i = 0; i < max_sta; i++) { 308 for (i = 0; i < max_sta; i++) {
309 station = &priv->stations[i]; 309 station = &il->stations[i];
310 if (!station->used) 310 if (!station->used)
311 continue; 311 continue;
312 pos += scnprintf(buf + pos, bufsz - pos, 312 pos += scnprintf(buf + pos, bufsz - pos,
@@ -349,32 +349,32 @@ static ssize_t il_dbgfs_nvm_read(struct file *file,
349 loff_t *ppos) 349 loff_t *ppos)
350{ 350{
351 ssize_t ret; 351 ssize_t ret;
352 struct il_priv *priv = file->private_data; 352 struct il_priv *il = file->private_data;
353 int pos = 0, ofs = 0, buf_size = 0; 353 int pos = 0, ofs = 0, buf_size = 0;
354 const u8 *ptr; 354 const u8 *ptr;
355 char *buf; 355 char *buf;
356 u16 eeprom_ver; 356 u16 eeprom_ver;
357 size_t eeprom_len = priv->cfg->base_params->eeprom_size; 357 size_t eeprom_len = il->cfg->base_params->eeprom_size;
358 buf_size = 4 * eeprom_len + 256; 358 buf_size = 4 * eeprom_len + 256;
359 359
360 if (eeprom_len % 16) { 360 if (eeprom_len % 16) {
361 IL_ERR(priv, "NVM size is not multiple of 16.\n"); 361 IL_ERR(il, "NVM size is not multiple of 16.\n");
362 return -ENODATA; 362 return -ENODATA;
363 } 363 }
364 364
365 ptr = priv->eeprom; 365 ptr = il->eeprom;
366 if (!ptr) { 366 if (!ptr) {
367 IL_ERR(priv, "Invalid EEPROM memory\n"); 367 IL_ERR(il, "Invalid EEPROM memory\n");
368 return -ENOMEM; 368 return -ENOMEM;
369 } 369 }
370 370
371 /* 4 characters for byte 0xYY */ 371 /* 4 characters for byte 0xYY */
372 buf = kzalloc(buf_size, GFP_KERNEL); 372 buf = kzalloc(buf_size, GFP_KERNEL);
373 if (!buf) { 373 if (!buf) {
374 IL_ERR(priv, "Can not allocate Buffer\n"); 374 IL_ERR(il, "Can not allocate Buffer\n");
375 return -ENOMEM; 375 return -ENOMEM;
376 } 376 }
377 eeprom_ver = il_eeprom_query16(priv, EEPROM_VERSION); 377 eeprom_ver = il_eeprom_query16(il, EEPROM_VERSION);
378 pos += scnprintf(buf + pos, buf_size - pos, "EEPROM " 378 pos += scnprintf(buf + pos, buf_size - pos, "EEPROM "
379 "version: 0x%x\n", eeprom_ver); 379 "version: 0x%x\n", eeprom_ver);
380 for (ofs = 0 ; ofs < eeprom_len ; ofs += 16) { 380 for (ofs = 0 ; ofs < eeprom_len ; ofs += 16) {
@@ -395,23 +395,23 @@ static ssize_t
395il_dbgfs_channels_read(struct file *file, char __user *user_buf, 395il_dbgfs_channels_read(struct file *file, char __user *user_buf,
396 size_t count, loff_t *ppos) 396 size_t count, loff_t *ppos)
397{ 397{
398 struct il_priv *priv = file->private_data; 398 struct il_priv *il = file->private_data;
399 struct ieee80211_channel *channels = NULL; 399 struct ieee80211_channel *channels = NULL;
400 const struct ieee80211_supported_band *supp_band = NULL; 400 const struct ieee80211_supported_band *supp_band = NULL;
401 int pos = 0, i, bufsz = PAGE_SIZE; 401 int pos = 0, i, bufsz = PAGE_SIZE;
402 char *buf; 402 char *buf;
403 ssize_t ret; 403 ssize_t ret;
404 404
405 if (!test_bit(STATUS_GEO_CONFIGURED, &priv->status)) 405 if (!test_bit(STATUS_GEO_CONFIGURED, &il->status))
406 return -EAGAIN; 406 return -EAGAIN;
407 407
408 buf = kzalloc(bufsz, GFP_KERNEL); 408 buf = kzalloc(bufsz, GFP_KERNEL);
409 if (!buf) { 409 if (!buf) {
410 IL_ERR(priv, "Can not allocate Buffer\n"); 410 IL_ERR(il, "Can not allocate Buffer\n");
411 return -ENOMEM; 411 return -ENOMEM;
412 } 412 }
413 413
414 supp_band = il_get_hw_mode(priv, IEEE80211_BAND_2GHZ); 414 supp_band = il_get_hw_mode(il, IEEE80211_BAND_2GHZ);
415 if (supp_band) { 415 if (supp_band) {
416 channels = supp_band->channels; 416 channels = supp_band->channels;
417 417
@@ -434,7 +434,7 @@ il_dbgfs_channels_read(struct file *file, char __user *user_buf,
434 IEEE80211_CHAN_PASSIVE_SCAN ? 434 IEEE80211_CHAN_PASSIVE_SCAN ?
435 "passive only" : "active/passive"); 435 "passive only" : "active/passive");
436 } 436 }
437 supp_band = il_get_hw_mode(priv, IEEE80211_BAND_5GHZ); 437 supp_band = il_get_hw_mode(il, IEEE80211_BAND_5GHZ);
438 if (supp_band) { 438 if (supp_band) {
439 channels = supp_band->channels; 439 channels = supp_band->channels;
440 440
@@ -466,43 +466,43 @@ static ssize_t il_dbgfs_status_read(struct file *file,
466 char __user *user_buf, 466 char __user *user_buf,
467 size_t count, loff_t *ppos) { 467 size_t count, loff_t *ppos) {
468 468
469 struct il_priv *priv = file->private_data; 469 struct il_priv *il = file->private_data;
470 char buf[512]; 470 char buf[512];
471 int pos = 0; 471 int pos = 0;
472 const size_t bufsz = sizeof(buf); 472 const size_t bufsz = sizeof(buf);
473 473
474 pos += scnprintf(buf + pos, bufsz - pos, "STATUS_HCMD_ACTIVE:\t %d\n", 474 pos += scnprintf(buf + pos, bufsz - pos, "STATUS_HCMD_ACTIVE:\t %d\n",
475 test_bit(STATUS_HCMD_ACTIVE, &priv->status)); 475 test_bit(STATUS_HCMD_ACTIVE, &il->status));
476 pos += scnprintf(buf + pos, bufsz - pos, "STATUS_INT_ENABLED:\t %d\n", 476 pos += scnprintf(buf + pos, bufsz - pos, "STATUS_INT_ENABLED:\t %d\n",
477 test_bit(STATUS_INT_ENABLED, &priv->status)); 477 test_bit(STATUS_INT_ENABLED, &il->status));
478 pos += scnprintf(buf + pos, bufsz - pos, "STATUS_RF_KILL_HW:\t %d\n", 478 pos += scnprintf(buf + pos, bufsz - pos, "STATUS_RF_KILL_HW:\t %d\n",
479 test_bit(STATUS_RF_KILL_HW, &priv->status)); 479 test_bit(STATUS_RF_KILL_HW, &il->status));
480 pos += scnprintf(buf + pos, bufsz - pos, "STATUS_CT_KILL:\t\t %d\n", 480 pos += scnprintf(buf + pos, bufsz - pos, "STATUS_CT_KILL:\t\t %d\n",
481 test_bit(STATUS_CT_KILL, &priv->status)); 481 test_bit(STATUS_CT_KILL, &il->status));
482 pos += scnprintf(buf + pos, bufsz - pos, "STATUS_INIT:\t\t %d\n", 482 pos += scnprintf(buf + pos, bufsz - pos, "STATUS_INIT:\t\t %d\n",
483 test_bit(STATUS_INIT, &priv->status)); 483 test_bit(STATUS_INIT, &il->status));
484 pos += scnprintf(buf + pos, bufsz - pos, "STATUS_ALIVE:\t\t %d\n", 484 pos += scnprintf(buf + pos, bufsz - pos, "STATUS_ALIVE:\t\t %d\n",
485 test_bit(STATUS_ALIVE, &priv->status)); 485 test_bit(STATUS_ALIVE, &il->status));
486 pos += scnprintf(buf + pos, bufsz - pos, "STATUS_READY:\t\t %d\n", 486 pos += scnprintf(buf + pos, bufsz - pos, "STATUS_READY:\t\t %d\n",
487 test_bit(STATUS_READY, &priv->status)); 487 test_bit(STATUS_READY, &il->status));
488 pos += scnprintf(buf + pos, bufsz - pos, "STATUS_TEMPERATURE:\t %d\n", 488 pos += scnprintf(buf + pos, bufsz - pos, "STATUS_TEMPERATURE:\t %d\n",
489 test_bit(STATUS_TEMPERATURE, &priv->status)); 489 test_bit(STATUS_TEMPERATURE, &il->status));
490 pos += scnprintf(buf + pos, bufsz - pos, "STATUS_GEO_CONFIGURED:\t %d\n", 490 pos += scnprintf(buf + pos, bufsz - pos, "STATUS_GEO_CONFIGURED:\t %d\n",
491 test_bit(STATUS_GEO_CONFIGURED, &priv->status)); 491 test_bit(STATUS_GEO_CONFIGURED, &il->status));
492 pos += scnprintf(buf + pos, bufsz - pos, "STATUS_EXIT_PENDING:\t %d\n", 492 pos += scnprintf(buf + pos, bufsz - pos, "STATUS_EXIT_PENDING:\t %d\n",
493 test_bit(STATUS_EXIT_PENDING, &priv->status)); 493 test_bit(STATUS_EXIT_PENDING, &il->status));
494 pos += scnprintf(buf + pos, bufsz - pos, "STATUS_STATISTICS:\t %d\n", 494 pos += scnprintf(buf + pos, bufsz - pos, "STATUS_STATISTICS:\t %d\n",
495 test_bit(STATUS_STATISTICS, &priv->status)); 495 test_bit(STATUS_STATISTICS, &il->status));
496 pos += scnprintf(buf + pos, bufsz - pos, "STATUS_SCANNING:\t %d\n", 496 pos += scnprintf(buf + pos, bufsz - pos, "STATUS_SCANNING:\t %d\n",
497 test_bit(STATUS_SCANNING, &priv->status)); 497 test_bit(STATUS_SCANNING, &il->status));
498 pos += scnprintf(buf + pos, bufsz - pos, "STATUS_SCAN_ABORTING:\t %d\n", 498 pos += scnprintf(buf + pos, bufsz - pos, "STATUS_SCAN_ABORTING:\t %d\n",
499 test_bit(STATUS_SCAN_ABORTING, &priv->status)); 499 test_bit(STATUS_SCAN_ABORTING, &il->status));
500 pos += scnprintf(buf + pos, bufsz - pos, "STATUS_SCAN_HW:\t\t %d\n", 500 pos += scnprintf(buf + pos, bufsz - pos, "STATUS_SCAN_HW:\t\t %d\n",
501 test_bit(STATUS_SCAN_HW, &priv->status)); 501 test_bit(STATUS_SCAN_HW, &il->status));
502 pos += scnprintf(buf + pos, bufsz - pos, "STATUS_POWER_PMI:\t %d\n", 502 pos += scnprintf(buf + pos, bufsz - pos, "STATUS_POWER_PMI:\t %d\n",
503 test_bit(STATUS_POWER_PMI, &priv->status)); 503 test_bit(STATUS_POWER_PMI, &il->status));
504 pos += scnprintf(buf + pos, bufsz - pos, "STATUS_FW_ERROR:\t %d\n", 504 pos += scnprintf(buf + pos, bufsz - pos, "STATUS_FW_ERROR:\t %d\n",
505 test_bit(STATUS_FW_ERROR, &priv->status)); 505 test_bit(STATUS_FW_ERROR, &il->status));
506 return simple_read_from_buffer(user_buf, count, ppos, buf, pos); 506 return simple_read_from_buffer(user_buf, count, ppos, buf, pos);
507} 507}
508 508
@@ -510,7 +510,7 @@ static ssize_t il_dbgfs_interrupt_read(struct file *file,
510 char __user *user_buf, 510 char __user *user_buf,
511 size_t count, loff_t *ppos) { 511 size_t count, loff_t *ppos) {
512 512
513 struct il_priv *priv = file->private_data; 513 struct il_priv *il = file->private_data;
514 int pos = 0; 514 int pos = 0;
515 int cnt = 0; 515 int cnt = 0;
516 char *buf; 516 char *buf;
@@ -519,7 +519,7 @@ static ssize_t il_dbgfs_interrupt_read(struct file *file,
519 519
520 buf = kzalloc(bufsz, GFP_KERNEL); 520 buf = kzalloc(bufsz, GFP_KERNEL);
521 if (!buf) { 521 if (!buf) {
522 IL_ERR(priv, "Can not allocate Buffer\n"); 522 IL_ERR(il, "Can not allocate Buffer\n");
523 return -ENOMEM; 523 return -ENOMEM;
524 } 524 }
525 525
@@ -527,46 +527,46 @@ static ssize_t il_dbgfs_interrupt_read(struct file *file,
527 "Interrupt Statistics Report:\n"); 527 "Interrupt Statistics Report:\n");
528 528
529 pos += scnprintf(buf + pos, bufsz - pos, "HW Error:\t\t\t %u\n", 529 pos += scnprintf(buf + pos, bufsz - pos, "HW Error:\t\t\t %u\n",
530 priv->isr_stats.hw); 530 il->isr_stats.hw);
531 pos += scnprintf(buf + pos, bufsz - pos, "SW Error:\t\t\t %u\n", 531 pos += scnprintf(buf + pos, bufsz - pos, "SW Error:\t\t\t %u\n",
532 priv->isr_stats.sw); 532 il->isr_stats.sw);
533 if (priv->isr_stats.sw || priv->isr_stats.hw) { 533 if (il->isr_stats.sw || il->isr_stats.hw) {
534 pos += scnprintf(buf + pos, bufsz - pos, 534 pos += scnprintf(buf + pos, bufsz - pos,
535 "\tLast Restarting Code: 0x%X\n", 535 "\tLast Restarting Code: 0x%X\n",
536 priv->isr_stats.err_code); 536 il->isr_stats.err_code);
537 } 537 }
538#ifdef CONFIG_IWLWIFI_LEGACY_DEBUG 538#ifdef CONFIG_IWLWIFI_LEGACY_DEBUG
539 pos += scnprintf(buf + pos, bufsz - pos, "Frame transmitted:\t\t %u\n", 539 pos += scnprintf(buf + pos, bufsz - pos, "Frame transmitted:\t\t %u\n",
540 priv->isr_stats.sch); 540 il->isr_stats.sch);
541 pos += scnprintf(buf + pos, bufsz - pos, "Alive interrupt:\t\t %u\n", 541 pos += scnprintf(buf + pos, bufsz - pos, "Alive interrupt:\t\t %u\n",
542 priv->isr_stats.alive); 542 il->isr_stats.alive);
543#endif 543#endif
544 pos += scnprintf(buf + pos, bufsz - pos, 544 pos += scnprintf(buf + pos, bufsz - pos,
545 "HW RF KILL switch toggled:\t %u\n", 545 "HW RF KILL switch toggled:\t %u\n",
546 priv->isr_stats.rfkill); 546 il->isr_stats.rfkill);
547 547
548 pos += scnprintf(buf + pos, bufsz - pos, "CT KILL:\t\t\t %u\n", 548 pos += scnprintf(buf + pos, bufsz - pos, "CT KILL:\t\t\t %u\n",
549 priv->isr_stats.ctkill); 549 il->isr_stats.ctkill);
550 550
551 pos += scnprintf(buf + pos, bufsz - pos, "Wakeup Interrupt:\t\t %u\n", 551 pos += scnprintf(buf + pos, bufsz - pos, "Wakeup Interrupt:\t\t %u\n",
552 priv->isr_stats.wakeup); 552 il->isr_stats.wakeup);
553 553
554 pos += scnprintf(buf + pos, bufsz - pos, 554 pos += scnprintf(buf + pos, bufsz - pos,
555 "Rx command responses:\t\t %u\n", 555 "Rx command responses:\t\t %u\n",
556 priv->isr_stats.rx); 556 il->isr_stats.rx);
557 for (cnt = 0; cnt < REPLY_MAX; cnt++) { 557 for (cnt = 0; cnt < REPLY_MAX; cnt++) {
558 if (priv->isr_stats.rx_handlers[cnt] > 0) 558 if (il->isr_stats.rx_handlers[cnt] > 0)
559 pos += scnprintf(buf + pos, bufsz - pos, 559 pos += scnprintf(buf + pos, bufsz - pos,
560 "\tRx handler[%36s]:\t\t %u\n", 560 "\tRx handler[%36s]:\t\t %u\n",
561 il_get_cmd_string(cnt), 561 il_get_cmd_string(cnt),
562 priv->isr_stats.rx_handlers[cnt]); 562 il->isr_stats.rx_handlers[cnt]);
563 } 563 }
564 564
565 pos += scnprintf(buf + pos, bufsz - pos, "Tx/FH interrupt:\t\t %u\n", 565 pos += scnprintf(buf + pos, bufsz - pos, "Tx/FH interrupt:\t\t %u\n",
566 priv->isr_stats.tx); 566 il->isr_stats.tx);
567 567
568 pos += scnprintf(buf + pos, bufsz - pos, "Unexpected INTA:\t\t %u\n", 568 pos += scnprintf(buf + pos, bufsz - pos, "Unexpected INTA:\t\t %u\n",
569 priv->isr_stats.unhandled); 569 il->isr_stats.unhandled);
570 570
571 ret = simple_read_from_buffer(user_buf, count, ppos, buf, pos); 571 ret = simple_read_from_buffer(user_buf, count, ppos, buf, pos);
572 kfree(buf); 572 kfree(buf);
@@ -577,7 +577,7 @@ static ssize_t il_dbgfs_interrupt_write(struct file *file,
577 const char __user *user_buf, 577 const char __user *user_buf,
578 size_t count, loff_t *ppos) 578 size_t count, loff_t *ppos)
579{ 579{
580 struct il_priv *priv = file->private_data; 580 struct il_priv *il = file->private_data;
581 char buf[8]; 581 char buf[8];
582 int buf_size; 582 int buf_size;
583 u32 reset_flag; 583 u32 reset_flag;
@@ -589,7 +589,7 @@ static ssize_t il_dbgfs_interrupt_write(struct file *file,
589 if (sscanf(buf, "%x", &reset_flag) != 1) 589 if (sscanf(buf, "%x", &reset_flag) != 1)
590 return -EFAULT; 590 return -EFAULT;
591 if (reset_flag == 0) 591 if (reset_flag == 0)
592 il_clear_isr_stats(priv); 592 il_clear_isr_stats(il);
593 593
594 return count; 594 return count;
595} 595}
@@ -598,13 +598,13 @@ static ssize_t
598il_dbgfs_qos_read(struct file *file, char __user *user_buf, 598il_dbgfs_qos_read(struct file *file, char __user *user_buf,
599 size_t count, loff_t *ppos) 599 size_t count, loff_t *ppos)
600{ 600{
601 struct il_priv *priv = file->private_data; 601 struct il_priv *il = file->private_data;
602 struct il_rxon_context *ctx; 602 struct il_rxon_context *ctx;
603 int pos = 0, i; 603 int pos = 0, i;
604 char buf[256 * NUM_IL_RXON_CTX]; 604 char buf[256 * NUM_IL_RXON_CTX];
605 const size_t bufsz = sizeof(buf); 605 const size_t bufsz = sizeof(buf);
606 606
607 for_each_context(priv, ctx) { 607 for_each_context(il, ctx) {
608 pos += scnprintf(buf + pos, bufsz - pos, "context %d:\n", 608 pos += scnprintf(buf + pos, bufsz - pos, "context %d:\n",
609 ctx->ctxid); 609 ctx->ctxid);
610 for (i = 0; i < AC_NUM; i++) { 610 for (i = 0; i < AC_NUM; i++) {
@@ -626,7 +626,7 @@ static ssize_t il_dbgfs_disable_ht40_write(struct file *file,
626 const char __user *user_buf, 626 const char __user *user_buf,
627 size_t count, loff_t *ppos) 627 size_t count, loff_t *ppos)
628{ 628{
629 struct il_priv *priv = file->private_data; 629 struct il_priv *il = file->private_data;
630 char buf[8]; 630 char buf[8];
631 int buf_size; 631 int buf_size;
632 int ht40; 632 int ht40;
@@ -637,10 +637,10 @@ static ssize_t il_dbgfs_disable_ht40_write(struct file *file,
637 return -EFAULT; 637 return -EFAULT;
638 if (sscanf(buf, "%d", &ht40) != 1) 638 if (sscanf(buf, "%d", &ht40) != 1)
639 return -EFAULT; 639 return -EFAULT;
640 if (!il_is_any_associated(priv)) 640 if (!il_is_any_associated(il))
641 priv->disable_ht40 = ht40 ? true : false; 641 il->disable_ht40 = ht40 ? true : false;
642 else { 642 else {
643 IL_ERR(priv, "Sta associated with AP - " 643 IL_ERR(il, "Sta associated with AP - "
644 "Change to 40MHz channel support is not allowed\n"); 644 "Change to 40MHz channel support is not allowed\n");
645 return -EINVAL; 645 return -EINVAL;
646 } 646 }
@@ -652,14 +652,14 @@ static ssize_t il_dbgfs_disable_ht40_read(struct file *file,
652 char __user *user_buf, 652 char __user *user_buf,
653 size_t count, loff_t *ppos) 653 size_t count, loff_t *ppos)
654{ 654{
655 struct il_priv *priv = file->private_data; 655 struct il_priv *il = file->private_data;
656 char buf[100]; 656 char buf[100];
657 int pos = 0; 657 int pos = 0;
658 const size_t bufsz = sizeof(buf); 658 const size_t bufsz = sizeof(buf);
659 659
660 pos += scnprintf(buf + pos, bufsz - pos, 660 pos += scnprintf(buf + pos, bufsz - pos,
661 "11n 40MHz Mode: %s\n", 661 "11n 40MHz Mode: %s\n",
662 priv->disable_ht40 ? "Disabled" : "Enabled"); 662 il->disable_ht40 ? "Disabled" : "Enabled");
663 return simple_read_from_buffer(user_buf, count, ppos, buf, pos); 663 return simple_read_from_buffer(user_buf, count, ppos, buf, pos);
664} 664}
665 665
@@ -676,39 +676,39 @@ static ssize_t il_dbgfs_traffic_log_read(struct file *file,
676 char __user *user_buf, 676 char __user *user_buf,
677 size_t count, loff_t *ppos) 677 size_t count, loff_t *ppos)
678{ 678{
679 struct il_priv *priv = file->private_data; 679 struct il_priv *il = file->private_data;
680 int pos = 0, ofs = 0; 680 int pos = 0, ofs = 0;
681 int cnt = 0, entry; 681 int cnt = 0, entry;
682 struct il_tx_queue *txq; 682 struct il_tx_queue *txq;
683 struct il_queue *q; 683 struct il_queue *q;
684 struct il_rx_queue *rxq = &priv->rxq; 684 struct il_rx_queue *rxq = &il->rxq;
685 char *buf; 685 char *buf;
686 int bufsz = ((IL_TRAFFIC_ENTRIES * IL_TRAFFIC_ENTRY_SIZE * 64) * 2) + 686 int bufsz = ((IL_TRAFFIC_ENTRIES * IL_TRAFFIC_ENTRY_SIZE * 64) * 2) +
687 (priv->cfg->base_params->num_of_queues * 32 * 8) + 400; 687 (il->cfg->base_params->num_of_queues * 32 * 8) + 400;
688 const u8 *ptr; 688 const u8 *ptr;
689 ssize_t ret; 689 ssize_t ret;
690 690
691 if (!priv->txq) { 691 if (!il->txq) {
692 IL_ERR(priv, "txq not ready\n"); 692 IL_ERR(il, "txq not ready\n");
693 return -EAGAIN; 693 return -EAGAIN;
694 } 694 }
695 buf = kzalloc(bufsz, GFP_KERNEL); 695 buf = kzalloc(bufsz, GFP_KERNEL);
696 if (!buf) { 696 if (!buf) {
697 IL_ERR(priv, "Can not allocate buffer\n"); 697 IL_ERR(il, "Can not allocate buffer\n");
698 return -ENOMEM; 698 return -ENOMEM;
699 } 699 }
700 pos += scnprintf(buf + pos, bufsz - pos, "Tx Queue\n"); 700 pos += scnprintf(buf + pos, bufsz - pos, "Tx Queue\n");
701 for (cnt = 0; cnt < priv->hw_params.max_txq_num; cnt++) { 701 for (cnt = 0; cnt < il->hw_params.max_txq_num; cnt++) {
702 txq = &priv->txq[cnt]; 702 txq = &il->txq[cnt];
703 q = &txq->q; 703 q = &txq->q;
704 pos += scnprintf(buf + pos, bufsz - pos, 704 pos += scnprintf(buf + pos, bufsz - pos,
705 "q[%d]: read_ptr: %u, write_ptr: %u\n", 705 "q[%d]: read_ptr: %u, write_ptr: %u\n",
706 cnt, q->read_ptr, q->write_ptr); 706 cnt, q->read_ptr, q->write_ptr);
707 } 707 }
708 if (priv->tx_traffic && (iwlegacy_debug_level & IL_DL_TX)) { 708 if (il->tx_traffic && (iwlegacy_debug_level & IL_DL_TX)) {
709 ptr = priv->tx_traffic; 709 ptr = il->tx_traffic;
710 pos += scnprintf(buf + pos, bufsz - pos, 710 pos += scnprintf(buf + pos, bufsz - pos,
711 "Tx Traffic idx: %u\n", priv->tx_traffic_idx); 711 "Tx Traffic idx: %u\n", il->tx_traffic_idx);
712 for (cnt = 0, ofs = 0; cnt < IL_TRAFFIC_ENTRIES; cnt++) { 712 for (cnt = 0, ofs = 0; cnt < IL_TRAFFIC_ENTRIES; cnt++) {
713 for (entry = 0; entry < IL_TRAFFIC_ENTRY_SIZE / 16; 713 for (entry = 0; entry < IL_TRAFFIC_ENTRY_SIZE / 16;
714 entry++, ofs += 16) { 714 entry++, ofs += 16) {
@@ -728,10 +728,10 @@ static ssize_t il_dbgfs_traffic_log_read(struct file *file,
728 "read: %u, write: %u\n", 728 "read: %u, write: %u\n",
729 rxq->read, rxq->write); 729 rxq->read, rxq->write);
730 730
731 if (priv->rx_traffic && (iwlegacy_debug_level & IL_DL_RX)) { 731 if (il->rx_traffic && (iwlegacy_debug_level & IL_DL_RX)) {
732 ptr = priv->rx_traffic; 732 ptr = il->rx_traffic;
733 pos += scnprintf(buf + pos, bufsz - pos, 733 pos += scnprintf(buf + pos, bufsz - pos,
734 "Rx Traffic idx: %u\n", priv->rx_traffic_idx); 734 "Rx Traffic idx: %u\n", il->rx_traffic_idx);
735 for (cnt = 0, ofs = 0; cnt < IL_TRAFFIC_ENTRIES; cnt++) { 735 for (cnt = 0, ofs = 0; cnt < IL_TRAFFIC_ENTRIES; cnt++) {
736 for (entry = 0; entry < IL_TRAFFIC_ENTRY_SIZE / 16; 736 for (entry = 0; entry < IL_TRAFFIC_ENTRY_SIZE / 16;
737 entry++, ofs += 16) { 737 entry++, ofs += 16) {
@@ -755,7 +755,7 @@ static ssize_t il_dbgfs_traffic_log_write(struct file *file,
755 const char __user *user_buf, 755 const char __user *user_buf,
756 size_t count, loff_t *ppos) 756 size_t count, loff_t *ppos)
757{ 757{
758 struct il_priv *priv = file->private_data; 758 struct il_priv *il = file->private_data;
759 char buf[8]; 759 char buf[8];
760 int buf_size; 760 int buf_size;
761 int traffic_log; 761 int traffic_log;
@@ -767,7 +767,7 @@ static ssize_t il_dbgfs_traffic_log_write(struct file *file,
767 if (sscanf(buf, "%d", &traffic_log) != 1) 767 if (sscanf(buf, "%d", &traffic_log) != 1)
768 return -EFAULT; 768 return -EFAULT;
769 if (traffic_log == 0) 769 if (traffic_log == 0)
770 il_reset_traffic_log(priv); 770 il_reset_traffic_log(il);
771 771
772 return count; 772 return count;
773} 773}
@@ -776,7 +776,7 @@ static ssize_t il_dbgfs_tx_queue_read(struct file *file,
776 char __user *user_buf, 776 char __user *user_buf,
777 size_t count, loff_t *ppos) { 777 size_t count, loff_t *ppos) {
778 778
779 struct il_priv *priv = file->private_data; 779 struct il_priv *il = file->private_data;
780 struct il_tx_queue *txq; 780 struct il_tx_queue *txq;
781 struct il_queue *q; 781 struct il_queue *q;
782 char *buf; 782 char *buf;
@@ -784,24 +784,24 @@ static ssize_t il_dbgfs_tx_queue_read(struct file *file,
784 int cnt; 784 int cnt;
785 int ret; 785 int ret;
786 const size_t bufsz = sizeof(char) * 64 * 786 const size_t bufsz = sizeof(char) * 64 *
787 priv->cfg->base_params->num_of_queues; 787 il->cfg->base_params->num_of_queues;
788 788
789 if (!priv->txq) { 789 if (!il->txq) {
790 IL_ERR(priv, "txq not ready\n"); 790 IL_ERR(il, "txq not ready\n");
791 return -EAGAIN; 791 return -EAGAIN;
792 } 792 }
793 buf = kzalloc(bufsz, GFP_KERNEL); 793 buf = kzalloc(bufsz, GFP_KERNEL);
794 if (!buf) 794 if (!buf)
795 return -ENOMEM; 795 return -ENOMEM;
796 796
797 for (cnt = 0; cnt < priv->hw_params.max_txq_num; cnt++) { 797 for (cnt = 0; cnt < il->hw_params.max_txq_num; cnt++) {
798 txq = &priv->txq[cnt]; 798 txq = &il->txq[cnt];
799 q = &txq->q; 799 q = &txq->q;
800 pos += scnprintf(buf + pos, bufsz - pos, 800 pos += scnprintf(buf + pos, bufsz - pos,
801 "hwq %.2d: read=%u write=%u stop=%d" 801 "hwq %.2d: read=%u write=%u stop=%d"
802 " swq_id=%#.2x (ac %d/hwq %d)\n", 802 " swq_id=%#.2x (ac %d/hwq %d)\n",
803 cnt, q->read_ptr, q->write_ptr, 803 cnt, q->read_ptr, q->write_ptr,
804 !!test_bit(cnt, priv->queue_stopped), 804 !!test_bit(cnt, il->queue_stopped),
805 txq->swq_id, txq->swq_id & 3, 805 txq->swq_id, txq->swq_id & 3,
806 (txq->swq_id >> 2) & 0x1f); 806 (txq->swq_id >> 2) & 0x1f);
807 if (cnt >= 4) 807 if (cnt >= 4)
@@ -809,7 +809,7 @@ static ssize_t il_dbgfs_tx_queue_read(struct file *file,
809 /* for the ACs, display the stop count too */ 809 /* for the ACs, display the stop count too */
810 pos += scnprintf(buf + pos, bufsz - pos, 810 pos += scnprintf(buf + pos, bufsz - pos,
811 " stop-count: %d\n", 811 " stop-count: %d\n",
812 atomic_read(&priv->queue_stop_count[cnt])); 812 atomic_read(&il->queue_stop_count[cnt]));
813 } 813 }
814 ret = simple_read_from_buffer(user_buf, count, ppos, buf, pos); 814 ret = simple_read_from_buffer(user_buf, count, ppos, buf, pos);
815 kfree(buf); 815 kfree(buf);
@@ -820,8 +820,8 @@ static ssize_t il_dbgfs_rx_queue_read(struct file *file,
820 char __user *user_buf, 820 char __user *user_buf,
821 size_t count, loff_t *ppos) { 821 size_t count, loff_t *ppos) {
822 822
823 struct il_priv *priv = file->private_data; 823 struct il_priv *il = file->private_data;
824 struct il_rx_queue *rxq = &priv->rxq; 824 struct il_rx_queue *rxq = &il->rxq;
825 char buf[256]; 825 char buf[256];
826 int pos = 0; 826 int pos = 0;
827 const size_t bufsz = sizeof(buf); 827 const size_t bufsz = sizeof(buf);
@@ -846,8 +846,8 @@ static ssize_t il_dbgfs_ucode_rx_stats_read(struct file *file,
846 char __user *user_buf, 846 char __user *user_buf,
847 size_t count, loff_t *ppos) 847 size_t count, loff_t *ppos)
848{ 848{
849 struct il_priv *priv = file->private_data; 849 struct il_priv *il = file->private_data;
850 return priv->cfg->ops->lib->debugfs_ops.rx_stats_read(file, 850 return il->cfg->ops->lib->debugfs_ops.rx_stats_read(file,
851 user_buf, count, ppos); 851 user_buf, count, ppos);
852} 852}
853 853
@@ -855,8 +855,8 @@ static ssize_t il_dbgfs_ucode_tx_stats_read(struct file *file,
855 char __user *user_buf, 855 char __user *user_buf,
856 size_t count, loff_t *ppos) 856 size_t count, loff_t *ppos)
857{ 857{
858 struct il_priv *priv = file->private_data; 858 struct il_priv *il = file->private_data;
859 return priv->cfg->ops->lib->debugfs_ops.tx_stats_read(file, 859 return il->cfg->ops->lib->debugfs_ops.tx_stats_read(file,
860 user_buf, count, ppos); 860 user_buf, count, ppos);
861} 861}
862 862
@@ -864,8 +864,8 @@ static ssize_t il_dbgfs_ucode_general_stats_read(struct file *file,
864 char __user *user_buf, 864 char __user *user_buf,
865 size_t count, loff_t *ppos) 865 size_t count, loff_t *ppos)
866{ 866{
867 struct il_priv *priv = file->private_data; 867 struct il_priv *il = file->private_data;
868 return priv->cfg->ops->lib->debugfs_ops.general_stats_read(file, 868 return il->cfg->ops->lib->debugfs_ops.general_stats_read(file,
869 user_buf, count, ppos); 869 user_buf, count, ppos);
870} 870}
871 871
@@ -873,7 +873,7 @@ static ssize_t il_dbgfs_sensitivity_read(struct file *file,
873 char __user *user_buf, 873 char __user *user_buf,
874 size_t count, loff_t *ppos) { 874 size_t count, loff_t *ppos) {
875 875
876 struct il_priv *priv = file->private_data; 876 struct il_priv *il = file->private_data;
877 int pos = 0; 877 int pos = 0;
878 int cnt = 0; 878 int cnt = 0;
879 char *buf; 879 char *buf;
@@ -881,10 +881,10 @@ static ssize_t il_dbgfs_sensitivity_read(struct file *file,
881 ssize_t ret; 881 ssize_t ret;
882 struct il_sensitivity_data *data; 882 struct il_sensitivity_data *data;
883 883
884 data = &priv->sensitivity_data; 884 data = &il->sensitivity_data;
885 buf = kzalloc(bufsz, GFP_KERNEL); 885 buf = kzalloc(bufsz, GFP_KERNEL);
886 if (!buf) { 886 if (!buf) {
887 IL_ERR(priv, "Can not allocate Buffer\n"); 887 IL_ERR(il, "Can not allocate Buffer\n");
888 return -ENOMEM; 888 return -ENOMEM;
889 } 889 }
890 890
@@ -954,7 +954,7 @@ static ssize_t il_dbgfs_chain_noise_read(struct file *file,
954 char __user *user_buf, 954 char __user *user_buf,
955 size_t count, loff_t *ppos) { 955 size_t count, loff_t *ppos) {
956 956
957 struct il_priv *priv = file->private_data; 957 struct il_priv *il = file->private_data;
958 int pos = 0; 958 int pos = 0;
959 int cnt = 0; 959 int cnt = 0;
960 char *buf; 960 char *buf;
@@ -962,10 +962,10 @@ static ssize_t il_dbgfs_chain_noise_read(struct file *file,
962 ssize_t ret; 962 ssize_t ret;
963 struct il_chain_noise_data *data; 963 struct il_chain_noise_data *data;
964 964
965 data = &priv->chain_noise_data; 965 data = &il->chain_noise_data;
966 buf = kzalloc(bufsz, GFP_KERNEL); 966 buf = kzalloc(bufsz, GFP_KERNEL);
967 if (!buf) { 967 if (!buf) {
968 IL_ERR(priv, "Can not allocate Buffer\n"); 968 IL_ERR(il, "Can not allocate Buffer\n");
969 return -ENOMEM; 969 return -ENOMEM;
970 } 970 }
971 971
@@ -1012,13 +1012,13 @@ static ssize_t il_dbgfs_power_save_status_read(struct file *file,
1012 char __user *user_buf, 1012 char __user *user_buf,
1013 size_t count, loff_t *ppos) 1013 size_t count, loff_t *ppos)
1014{ 1014{
1015 struct il_priv *priv = file->private_data; 1015 struct il_priv *il = file->private_data;
1016 char buf[60]; 1016 char buf[60];
1017 int pos = 0; 1017 int pos = 0;
1018 const size_t bufsz = sizeof(buf); 1018 const size_t bufsz = sizeof(buf);
1019 u32 pwrsave_status; 1019 u32 pwrsave_status;
1020 1020
1021 pwrsave_status = il_read32(priv, CSR_GP_CNTRL) & 1021 pwrsave_status = il_read32(il, CSR_GP_CNTRL) &
1022 CSR_GP_REG_POWER_SAVE_STATUS_MSK; 1022 CSR_GP_REG_POWER_SAVE_STATUS_MSK;
1023 1023
1024 pos += scnprintf(buf + pos, bufsz - pos, "Power Save Status: "); 1024 pos += scnprintf(buf + pos, bufsz - pos, "Power Save Status: ");
@@ -1035,7 +1035,7 @@ static ssize_t il_dbgfs_clear_ucode_statistics_write(struct file *file,
1035 const char __user *user_buf, 1035 const char __user *user_buf,
1036 size_t count, loff_t *ppos) 1036 size_t count, loff_t *ppos)
1037{ 1037{
1038 struct il_priv *priv = file->private_data; 1038 struct il_priv *il = file->private_data;
1039 char buf[8]; 1039 char buf[8];
1040 int buf_size; 1040 int buf_size;
1041 int clear; 1041 int clear;
@@ -1048,9 +1048,9 @@ static ssize_t il_dbgfs_clear_ucode_statistics_write(struct file *file,
1048 return -EFAULT; 1048 return -EFAULT;
1049 1049
1050 /* make request to uCode to retrieve statistics information */ 1050 /* make request to uCode to retrieve statistics information */
1051 mutex_lock(&priv->mutex); 1051 mutex_lock(&il->mutex);
1052 il_send_statistics_request(priv, CMD_SYNC, true); 1052 il_send_statistics_request(il, CMD_SYNC, true);
1053 mutex_unlock(&priv->mutex); 1053 mutex_unlock(&il->mutex);
1054 1054
1055 return count; 1055 return count;
1056} 1056}
@@ -1059,12 +1059,12 @@ static ssize_t il_dbgfs_rxon_flags_read(struct file *file,
1059 char __user *user_buf, 1059 char __user *user_buf,
1060 size_t count, loff_t *ppos) { 1060 size_t count, loff_t *ppos) {
1061 1061
1062 struct il_priv *priv = file->private_data; 1062 struct il_priv *il = file->private_data;
1063 int len = 0; 1063 int len = 0;
1064 char buf[20]; 1064 char buf[20];
1065 1065
1066 len = sprintf(buf, "0x%04X\n", 1066 len = sprintf(buf, "0x%04X\n",
1067 le32_to_cpu(priv->contexts[IL_RXON_CTX_BSS].active.flags)); 1067 le32_to_cpu(il->contexts[IL_RXON_CTX_BSS].active.flags));
1068 return simple_read_from_buffer(user_buf, count, ppos, buf, len); 1068 return simple_read_from_buffer(user_buf, count, ppos, buf, len);
1069} 1069}
1070 1070
@@ -1072,12 +1072,12 @@ static ssize_t il_dbgfs_rxon_filter_flags_read(struct file *file,
1072 char __user *user_buf, 1072 char __user *user_buf,
1073 size_t count, loff_t *ppos) { 1073 size_t count, loff_t *ppos) {
1074 1074
1075 struct il_priv *priv = file->private_data; 1075 struct il_priv *il = file->private_data;
1076 int len = 0; 1076 int len = 0;
1077 char buf[20]; 1077 char buf[20];
1078 1078
1079 len = sprintf(buf, "0x%04X\n", 1079 len = sprintf(buf, "0x%04X\n",
1080 le32_to_cpu(priv->contexts[IL_RXON_CTX_BSS].active.filter_flags)); 1080 le32_to_cpu(il->contexts[IL_RXON_CTX_BSS].active.filter_flags));
1081 return simple_read_from_buffer(user_buf, count, ppos, buf, len); 1081 return simple_read_from_buffer(user_buf, count, ppos, buf, len);
1082} 1082}
1083 1083
@@ -1085,13 +1085,13 @@ static ssize_t il_dbgfs_fh_reg_read(struct file *file,
1085 char __user *user_buf, 1085 char __user *user_buf,
1086 size_t count, loff_t *ppos) 1086 size_t count, loff_t *ppos)
1087{ 1087{
1088 struct il_priv *priv = file->private_data; 1088 struct il_priv *il = file->private_data;
1089 char *buf; 1089 char *buf;
1090 int pos = 0; 1090 int pos = 0;
1091 ssize_t ret = -EFAULT; 1091 ssize_t ret = -EFAULT;
1092 1092
1093 if (priv->cfg->ops->lib->dump_fh) { 1093 if (il->cfg->ops->lib->dump_fh) {
1094 ret = pos = priv->cfg->ops->lib->dump_fh(priv, &buf, true); 1094 ret = pos = il->cfg->ops->lib->dump_fh(il, &buf, true);
1095 if (buf) { 1095 if (buf) {
1096 ret = simple_read_from_buffer(user_buf, 1096 ret = simple_read_from_buffer(user_buf,
1097 count, ppos, buf, pos); 1097 count, ppos, buf, pos);
@@ -1106,13 +1106,13 @@ static ssize_t il_dbgfs_missed_beacon_read(struct file *file,
1106 char __user *user_buf, 1106 char __user *user_buf,
1107 size_t count, loff_t *ppos) { 1107 size_t count, loff_t *ppos) {
1108 1108
1109 struct il_priv *priv = file->private_data; 1109 struct il_priv *il = file->private_data;
1110 int pos = 0; 1110 int pos = 0;
1111 char buf[12]; 1111 char buf[12];
1112 const size_t bufsz = sizeof(buf); 1112 const size_t bufsz = sizeof(buf);
1113 1113
1114 pos += scnprintf(buf + pos, bufsz - pos, "%d\n", 1114 pos += scnprintf(buf + pos, bufsz - pos, "%d\n",
1115 priv->missed_beacon_threshold); 1115 il->missed_beacon_threshold);
1116 1116
1117 return simple_read_from_buffer(user_buf, count, ppos, buf, pos); 1117 return simple_read_from_buffer(user_buf, count, ppos, buf, pos);
1118} 1118}
@@ -1121,7 +1121,7 @@ static ssize_t il_dbgfs_missed_beacon_write(struct file *file,
1121 const char __user *user_buf, 1121 const char __user *user_buf,
1122 size_t count, loff_t *ppos) 1122 size_t count, loff_t *ppos)
1123{ 1123{
1124 struct il_priv *priv = file->private_data; 1124 struct il_priv *il = file->private_data;
1125 char buf[8]; 1125 char buf[8];
1126 int buf_size; 1126 int buf_size;
1127 int missed; 1127 int missed;
@@ -1135,10 +1135,10 @@ static ssize_t il_dbgfs_missed_beacon_write(struct file *file,
1135 1135
1136 if (missed < IL_MISSED_BEACON_THRESHOLD_MIN || 1136 if (missed < IL_MISSED_BEACON_THRESHOLD_MIN ||
1137 missed > IL_MISSED_BEACON_THRESHOLD_MAX) 1137 missed > IL_MISSED_BEACON_THRESHOLD_MAX)
1138 priv->missed_beacon_threshold = 1138 il->missed_beacon_threshold =
1139 IL_MISSED_BEACON_THRESHOLD_DEF; 1139 IL_MISSED_BEACON_THRESHOLD_DEF;
1140 else 1140 else
1141 priv->missed_beacon_threshold = missed; 1141 il->missed_beacon_threshold = missed;
1142 1142
1143 return count; 1143 return count;
1144} 1144}
@@ -1147,13 +1147,13 @@ static ssize_t il_dbgfs_force_reset_read(struct file *file,
1147 char __user *user_buf, 1147 char __user *user_buf,
1148 size_t count, loff_t *ppos) { 1148 size_t count, loff_t *ppos) {
1149 1149
1150 struct il_priv *priv = file->private_data; 1150 struct il_priv *il = file->private_data;
1151 int pos = 0; 1151 int pos = 0;
1152 char buf[300]; 1152 char buf[300];
1153 const size_t bufsz = sizeof(buf); 1153 const size_t bufsz = sizeof(buf);
1154 struct il_force_reset *force_reset; 1154 struct il_force_reset *force_reset;
1155 1155
1156 force_reset = &priv->force_reset; 1156 force_reset = &il->force_reset;
1157 1157
1158 pos += scnprintf(buf + pos, bufsz - pos, 1158 pos += scnprintf(buf + pos, bufsz - pos,
1159 "\tnumber of reset request: %d\n", 1159 "\tnumber of reset request: %d\n",
@@ -1176,9 +1176,9 @@ static ssize_t il_dbgfs_force_reset_write(struct file *file,
1176 size_t count, loff_t *ppos) { 1176 size_t count, loff_t *ppos) {
1177 1177
1178 int ret; 1178 int ret;
1179 struct il_priv *priv = file->private_data; 1179 struct il_priv *il = file->private_data;
1180 1180
1181 ret = il_force_reset(priv, true); 1181 ret = il_force_reset(il, true);
1182 1182
1183 return ret ? ret : count; 1183 return ret ? ret : count;
1184} 1184}
@@ -1187,7 +1187,7 @@ static ssize_t il_dbgfs_wd_timeout_write(struct file *file,
1187 const char __user *user_buf, 1187 const char __user *user_buf,
1188 size_t count, loff_t *ppos) { 1188 size_t count, loff_t *ppos) {
1189 1189
1190 struct il_priv *priv = file->private_data; 1190 struct il_priv *il = file->private_data;
1191 char buf[8]; 1191 char buf[8];
1192 int buf_size; 1192 int buf_size;
1193 int timeout; 1193 int timeout;
@@ -1201,8 +1201,8 @@ static ssize_t il_dbgfs_wd_timeout_write(struct file *file,
1201 if (timeout < 0 || timeout > IL_MAX_WD_TIMEOUT) 1201 if (timeout < 0 || timeout > IL_MAX_WD_TIMEOUT)
1202 timeout = IL_DEF_WD_TIMEOUT; 1202 timeout = IL_DEF_WD_TIMEOUT;
1203 1203
1204 priv->cfg->base_params->wd_timeout = timeout; 1204 il->cfg->base_params->wd_timeout = timeout;
1205 il_setup_watchdog(priv); 1205 il_setup_watchdog(il);
1206 return count; 1206 return count;
1207} 1207}
1208 1208
@@ -1230,16 +1230,16 @@ DEBUGFS_WRITE_FILE_OPS(wd_timeout);
1230 * Create the debugfs files and directories 1230 * Create the debugfs files and directories
1231 * 1231 *
1232 */ 1232 */
1233int il_dbgfs_register(struct il_priv *priv, const char *name) 1233int il_dbgfs_register(struct il_priv *il, const char *name)
1234{ 1234{
1235 struct dentry *phyd = priv->hw->wiphy->debugfsdir; 1235 struct dentry *phyd = il->hw->wiphy->debugfsdir;
1236 struct dentry *dir_drv, *dir_data, *dir_rf, *dir_debug; 1236 struct dentry *dir_drv, *dir_data, *dir_rf, *dir_debug;
1237 1237
1238 dir_drv = debugfs_create_dir(name, phyd); 1238 dir_drv = debugfs_create_dir(name, phyd);
1239 if (!dir_drv) 1239 if (!dir_drv)
1240 return -ENOMEM; 1240 return -ENOMEM;
1241 1241
1242 priv->debugfs_dir = dir_drv; 1242 il->debugfs_dir = dir_drv;
1243 1243
1244 dir_data = debugfs_create_dir("data", dir_drv); 1244 dir_data = debugfs_create_dir("data", dir_drv);
1245 if (!dir_data) 1245 if (!dir_data)
@@ -1274,26 +1274,26 @@ int il_dbgfs_register(struct il_priv *priv, const char *name)
1274 DEBUGFS_ADD_FILE(ucode_tx_stats, dir_debug, S_IRUSR); 1274 DEBUGFS_ADD_FILE(ucode_tx_stats, dir_debug, S_IRUSR);
1275 DEBUGFS_ADD_FILE(ucode_general_stats, dir_debug, S_IRUSR); 1275 DEBUGFS_ADD_FILE(ucode_general_stats, dir_debug, S_IRUSR);
1276 1276
1277 if (priv->cfg->base_params->sensitivity_calib_by_driver) 1277 if (il->cfg->base_params->sensitivity_calib_by_driver)
1278 DEBUGFS_ADD_FILE(sensitivity, dir_debug, S_IRUSR); 1278 DEBUGFS_ADD_FILE(sensitivity, dir_debug, S_IRUSR);
1279 if (priv->cfg->base_params->chain_noise_calib_by_driver) 1279 if (il->cfg->base_params->chain_noise_calib_by_driver)
1280 DEBUGFS_ADD_FILE(chain_noise, dir_debug, S_IRUSR); 1280 DEBUGFS_ADD_FILE(chain_noise, dir_debug, S_IRUSR);
1281 DEBUGFS_ADD_FILE(rxon_flags, dir_debug, S_IWUSR); 1281 DEBUGFS_ADD_FILE(rxon_flags, dir_debug, S_IWUSR);
1282 DEBUGFS_ADD_FILE(rxon_filter_flags, dir_debug, S_IWUSR); 1282 DEBUGFS_ADD_FILE(rxon_filter_flags, dir_debug, S_IWUSR);
1283 DEBUGFS_ADD_FILE(wd_timeout, dir_debug, S_IWUSR); 1283 DEBUGFS_ADD_FILE(wd_timeout, dir_debug, S_IWUSR);
1284 if (priv->cfg->base_params->sensitivity_calib_by_driver) 1284 if (il->cfg->base_params->sensitivity_calib_by_driver)
1285 DEBUGFS_ADD_BOOL(disable_sensitivity, dir_rf, 1285 DEBUGFS_ADD_BOOL(disable_sensitivity, dir_rf,
1286 &priv->disable_sens_cal); 1286 &il->disable_sens_cal);
1287 if (priv->cfg->base_params->chain_noise_calib_by_driver) 1287 if (il->cfg->base_params->chain_noise_calib_by_driver)
1288 DEBUGFS_ADD_BOOL(disable_chain_noise, dir_rf, 1288 DEBUGFS_ADD_BOOL(disable_chain_noise, dir_rf,
1289 &priv->disable_chain_noise_cal); 1289 &il->disable_chain_noise_cal);
1290 DEBUGFS_ADD_BOOL(disable_tx_power, dir_rf, 1290 DEBUGFS_ADD_BOOL(disable_tx_power, dir_rf,
1291 &priv->disable_tx_power_cal); 1291 &il->disable_tx_power_cal);
1292 return 0; 1292 return 0;
1293 1293
1294err: 1294err:
1295 IL_ERR(priv, "Can't create the debugfs directory\n"); 1295 IL_ERR(il, "Can't create the debugfs directory\n");
1296 il_dbgfs_unregister(priv); 1296 il_dbgfs_unregister(il);
1297 return -ENOMEM; 1297 return -ENOMEM;
1298} 1298}
1299EXPORT_SYMBOL(il_dbgfs_register); 1299EXPORT_SYMBOL(il_dbgfs_register);
@@ -1302,12 +1302,12 @@ EXPORT_SYMBOL(il_dbgfs_register);
1302 * Remove the debugfs files and directories 1302 * Remove the debugfs files and directories
1303 * 1303 *
1304 */ 1304 */
1305void il_dbgfs_unregister(struct il_priv *priv) 1305void il_dbgfs_unregister(struct il_priv *il)
1306{ 1306{
1307 if (!priv->debugfs_dir) 1307 if (!il->debugfs_dir)
1308 return; 1308 return;
1309 1309
1310 debugfs_remove_recursive(priv->debugfs_dir); 1310 debugfs_remove_recursive(il->debugfs_dir);
1311 priv->debugfs_dir = NULL; 1311 il->debugfs_dir = NULL;
1312} 1312}
1313EXPORT_SYMBOL(il_dbgfs_unregister); 1313EXPORT_SYMBOL(il_dbgfs_unregister);
diff --git a/drivers/net/wireless/iwlegacy/iwl-dev.h b/drivers/net/wireless/iwlegacy/iwl-dev.h
index 20c44f36ba77..824d1934a7a1 100644
--- a/drivers/net/wireless/iwlegacy/iwl-dev.h
+++ b/drivers/net/wireless/iwlegacy/iwl-dev.h
@@ -106,7 +106,7 @@ struct il_cmd_meta {
106 * invoked for SYNC commands, if it were and its result passed 106 * invoked for SYNC commands, if it were and its result passed
107 * through it would be simpler...) 107 * through it would be simpler...)
108 */ 108 */
109 void (*callback)(struct il_priv *priv, 109 void (*callback)(struct il_priv *il,
110 struct il_device_cmd *cmd, 110 struct il_device_cmd *cmd,
111 struct il_rx_packet *pkt); 111 struct il_rx_packet *pkt);
112 112
@@ -321,7 +321,7 @@ struct il_device_cmd {
321struct il_host_cmd { 321struct il_host_cmd {
322 const void *data; 322 const void *data;
323 unsigned long reply_page; 323 unsigned long reply_page;
324 void (*callback)(struct il_priv *priv, 324 void (*callback)(struct il_priv *il,
325 struct il_device_cmd *cmd, 325 struct il_device_cmd *cmd,
326 struct il_rx_packet *pkt); 326 struct il_rx_packet *pkt);
327 u32 flags; 327 u32 flags;
@@ -476,7 +476,7 @@ struct il_station_priv_common {
476}; 476};
477 477
478/* 478/*
479 * il_station_priv: Driver's private station information 479 * il_station_priv: Driver's ilate station information
480 * 480 *
481 * When mac80211 creates a station it reserves some space (hw->sta_data_size) 481 * When mac80211 creates a station it reserves some space (hw->sta_data_size)
482 * in the structure for use by driver. This structure is places in that 482 * in the structure for use by driver. This structure is places in that
@@ -494,7 +494,7 @@ struct il_station_priv {
494}; 494};
495 495
496/** 496/**
497 * struct il_vif_priv - driver's private per-interface information 497 * struct il_vif_priv - driver's ilate per-interface information
498 * 498 *
499 * When mac80211 allocates a virtual interface, it can allocate 499 * When mac80211 allocates a virtual interface, it can allocate
500 * space for us to put data into. 500 * space for us to put data into.
@@ -625,7 +625,7 @@ struct il_hw_params {
625 * il4965_mac_ <-- mac80211 callback 625 * il4965_mac_ <-- mac80211 callback
626 * 626 *
627 ****************************************************************************/ 627 ****************************************************************************/
628extern void il4965_update_chain_flags(struct il_priv *priv); 628extern void il4965_update_chain_flags(struct il_priv *il);
629extern const u8 iwlegacy_bcast_addr[ETH_ALEN]; 629extern const u8 iwlegacy_bcast_addr[ETH_ALEN];
630extern int il_queue_space(const struct il_queue *q); 630extern int il_queue_space(const struct il_queue *q);
631static inline int il_queue_used(const struct il_queue *q, int i) 631static inline int il_queue_used(const struct il_queue *q, int i)
@@ -973,7 +973,7 @@ struct il_priv {
973 enum ieee80211_band band; 973 enum ieee80211_band band;
974 int alloc_rxb_page; 974 int alloc_rxb_page;
975 975
976 void (*rx_handlers[REPLY_MAX])(struct il_priv *priv, 976 void (*rx_handlers[REPLY_MAX])(struct il_priv *il,
977 struct il_rx_mem_buffer *rxb); 977 struct il_rx_mem_buffer *rxb);
978 978
979 struct ieee80211_supported_band bands[IEEE80211_NUM_BANDS]; 979 struct ieee80211_supported_band bands[IEEE80211_NUM_BANDS];
@@ -1247,14 +1247,14 @@ struct il_priv {
1247 bool led_registered; 1247 bool led_registered;
1248}; /*il_priv */ 1248}; /*il_priv */
1249 1249
1250static inline void il_txq_ctx_activate(struct il_priv *priv, int txq_id) 1250static inline void il_txq_ctx_activate(struct il_priv *il, int txq_id)
1251{ 1251{
1252 set_bit(txq_id, &priv->txq_ctx_active_msk); 1252 set_bit(txq_id, &il->txq_ctx_active_msk);
1253} 1253}
1254 1254
1255static inline void il_txq_ctx_deactivate(struct il_priv *priv, int txq_id) 1255static inline void il_txq_ctx_deactivate(struct il_priv *il, int txq_id)
1256{ 1256{
1257 clear_bit(txq_id, &priv->txq_ctx_active_msk); 1257 clear_bit(txq_id, &il->txq_ctx_active_msk);
1258} 1258}
1259 1259
1260#ifdef CONFIG_IWLWIFI_LEGACY_DEBUG 1260#ifdef CONFIG_IWLWIFI_LEGACY_DEBUG
@@ -1265,15 +1265,15 @@ static inline void il_txq_ctx_deactivate(struct il_priv *priv, int txq_id)
1265 * level will be used if set, otherwise the global debug level which can be 1265 * level will be used if set, otherwise the global debug level which can be
1266 * set via module parameter is used. 1266 * set via module parameter is used.
1267 */ 1267 */
1268static inline u32 il_get_debug_level(struct il_priv *priv) 1268static inline u32 il_get_debug_level(struct il_priv *il)
1269{ 1269{
1270 if (priv->debug_level) 1270 if (il->debug_level)
1271 return priv->debug_level; 1271 return il->debug_level;
1272 else 1272 else
1273 return iwlegacy_debug_level; 1273 return iwlegacy_debug_level;
1274} 1274}
1275#else 1275#else
1276static inline u32 il_get_debug_level(struct il_priv *priv) 1276static inline u32 il_get_debug_level(struct il_priv *il)
1277{ 1277{
1278 return iwlegacy_debug_level; 1278 return iwlegacy_debug_level;
1279} 1279}
@@ -1281,11 +1281,11 @@ static inline u32 il_get_debug_level(struct il_priv *priv)
1281 1281
1282 1282
1283static inline struct ieee80211_hdr * 1283static inline struct ieee80211_hdr *
1284il_tx_queue_get_hdr(struct il_priv *priv, 1284il_tx_queue_get_hdr(struct il_priv *il,
1285 int txq_id, int idx) 1285 int txq_id, int idx)
1286{ 1286{
1287 if (priv->txq[txq_id].txb[idx].skb) 1287 if (il->txq[txq_id].txb[idx].skb)
1288 return (struct ieee80211_hdr *)priv->txq[txq_id]. 1288 return (struct ieee80211_hdr *)il->txq[txq_id].
1289 txb[idx].skb->data; 1289 txb[idx].skb->data;
1290 return NULL; 1290 return NULL;
1291} 1291}
@@ -1298,21 +1298,21 @@ il_rxon_ctx_from_vif(struct ieee80211_vif *vif)
1298 return vif_priv->ctx; 1298 return vif_priv->ctx;
1299} 1299}
1300 1300
1301#define for_each_context(priv, ctx) \ 1301#define for_each_context(il, ctx) \
1302 for (ctx = &priv->contexts[IL_RXON_CTX_BSS]; \ 1302 for (ctx = &il->contexts[IL_RXON_CTX_BSS]; \
1303 ctx < &priv->contexts[NUM_IL_RXON_CTX]; ctx++) \ 1303 ctx < &il->contexts[NUM_IL_RXON_CTX]; ctx++) \
1304 if (priv->valid_contexts & BIT(ctx->ctxid)) 1304 if (il->valid_contexts & BIT(ctx->ctxid))
1305 1305
1306static inline int il_is_associated(struct il_priv *priv, 1306static inline int il_is_associated(struct il_priv *il,
1307 enum il_rxon_context_id ctxid) 1307 enum il_rxon_context_id ctxid)
1308{ 1308{
1309 return (priv->contexts[ctxid].active.filter_flags & 1309 return (il->contexts[ctxid].active.filter_flags &
1310 RXON_FILTER_ASSOC_MSK) ? 1 : 0; 1310 RXON_FILTER_ASSOC_MSK) ? 1 : 0;
1311} 1311}
1312 1312
1313static inline int il_is_any_associated(struct il_priv *priv) 1313static inline int il_is_any_associated(struct il_priv *il)
1314{ 1314{
1315 return il_is_associated(priv, IL_RXON_CTX_BSS); 1315 return il_is_associated(il, IL_RXON_CTX_BSS);
1316} 1316}
1317 1317
1318static inline int il_is_associated_ctx(struct il_rxon_context *ctx) 1318static inline int il_is_associated_ctx(struct il_rxon_context *ctx)
@@ -1350,15 +1350,15 @@ il_is_channel_ibss(const struct il_channel_info *ch)
1350} 1350}
1351 1351
1352static inline void 1352static inline void
1353__il_free_pages(struct il_priv *priv, struct page *page) 1353__il_free_pages(struct il_priv *il, struct page *page)
1354{ 1354{
1355 __free_pages(page, priv->hw_params.rx_page_order); 1355 __free_pages(page, il->hw_params.rx_page_order);
1356 priv->alloc_rxb_page--; 1356 il->alloc_rxb_page--;
1357} 1357}
1358 1358
1359static inline void il_free_pages(struct il_priv *priv, unsigned long page) 1359static inline void il_free_pages(struct il_priv *il, unsigned long page)
1360{ 1360{
1361 free_pages(page, priv->hw_params.rx_page_order); 1361 free_pages(page, il->hw_params.rx_page_order);
1362 priv->alloc_rxb_page--; 1362 il->alloc_rxb_page--;
1363} 1363}
1364#endif /* __il_dev_h__ */ 1364#endif /* __il_dev_h__ */
diff --git a/drivers/net/wireless/iwlegacy/iwl-eeprom.c b/drivers/net/wireless/iwlegacy/iwl-eeprom.c
index 1075f1d7f016..5edec73a505e 100644
--- a/drivers/net/wireless/iwlegacy/iwl-eeprom.c
+++ b/drivers/net/wireless/iwlegacy/iwl-eeprom.c
@@ -87,7 +87,7 @@
87 * is contained in the eeprom map itself. 87 * is contained in the eeprom map itself.
88 * 88 *
89 * During init, we copy the eeprom information and channel map 89 * During init, we copy the eeprom information and channel map
90 * information into priv->channel_info_24/52 and priv->channel_map_24/52 90 * information into il->channel_info_24/52 and il->channel_map_24/52
91 * 91 *
92 * channel_map_24/52 provides the index in the channel_info array for a 92 * channel_map_24/52 provides the index in the channel_info array for a
93 * given channel. We have to have two separate maps as there is channel 93 * given channel. We have to have two separate maps as there is channel
@@ -142,18 +142,18 @@ static const u8 iwlegacy_eeprom_band_7[] = { /* 5.2 ht40 channel */
142 * 142 *
143******************************************************************************/ 143******************************************************************************/
144 144
145static int il_eeprom_verify_signature(struct il_priv *priv) 145static int il_eeprom_verify_signature(struct il_priv *il)
146{ 146{
147 u32 gp = il_read32(priv, CSR_EEPROM_GP) & CSR_EEPROM_GP_VALID_MSK; 147 u32 gp = il_read32(il, CSR_EEPROM_GP) & CSR_EEPROM_GP_VALID_MSK;
148 int ret = 0; 148 int ret = 0;
149 149
150 IL_DEBUG_EEPROM(priv, "EEPROM signature=0x%08x\n", gp); 150 IL_DEBUG_EEPROM(il, "EEPROM signature=0x%08x\n", gp);
151 switch (gp) { 151 switch (gp) {
152 case CSR_EEPROM_GP_GOOD_SIG_EEP_LESS_THAN_4K: 152 case CSR_EEPROM_GP_GOOD_SIG_EEP_LESS_THAN_4K:
153 case CSR_EEPROM_GP_GOOD_SIG_EEP_MORE_THAN_4K: 153 case CSR_EEPROM_GP_GOOD_SIG_EEP_MORE_THAN_4K:
154 break; 154 break;
155 default: 155 default:
156 IL_ERR(priv, "bad EEPROM signature," 156 IL_ERR(il, "bad EEPROM signature,"
157 "EEPROM_GP=0x%08x\n", gp); 157 "EEPROM_GP=0x%08x\n", gp);
158 ret = -ENOENT; 158 ret = -ENOENT;
159 break; 159 break;
@@ -162,59 +162,59 @@ static int il_eeprom_verify_signature(struct il_priv *priv)
162} 162}
163 163
164const u8 164const u8
165*il_eeprom_query_addr(const struct il_priv *priv, size_t offset) 165*il_eeprom_query_addr(const struct il_priv *il, size_t offset)
166{ 166{
167 BUG_ON(offset >= priv->cfg->base_params->eeprom_size); 167 BUG_ON(offset >= il->cfg->base_params->eeprom_size);
168 return &priv->eeprom[offset]; 168 return &il->eeprom[offset];
169} 169}
170EXPORT_SYMBOL(il_eeprom_query_addr); 170EXPORT_SYMBOL(il_eeprom_query_addr);
171 171
172u16 il_eeprom_query16(const struct il_priv *priv, size_t offset) 172u16 il_eeprom_query16(const struct il_priv *il, size_t offset)
173{ 173{
174 if (!priv->eeprom) 174 if (!il->eeprom)
175 return 0; 175 return 0;
176 return (u16)priv->eeprom[offset] | ((u16)priv->eeprom[offset + 1] << 8); 176 return (u16)il->eeprom[offset] | ((u16)il->eeprom[offset + 1] << 8);
177} 177}
178EXPORT_SYMBOL(il_eeprom_query16); 178EXPORT_SYMBOL(il_eeprom_query16);
179 179
180/** 180/**
181 * il_eeprom_init - read EEPROM contents 181 * il_eeprom_init - read EEPROM contents
182 * 182 *
183 * Load the EEPROM contents from adapter into priv->eeprom 183 * Load the EEPROM contents from adapter into il->eeprom
184 * 184 *
185 * NOTE: This routine uses the non-debug IO access functions. 185 * NOTE: This routine uses the non-debug IO access functions.
186 */ 186 */
187int il_eeprom_init(struct il_priv *priv) 187int il_eeprom_init(struct il_priv *il)
188{ 188{
189 __le16 *e; 189 __le16 *e;
190 u32 gp = il_read32(priv, CSR_EEPROM_GP); 190 u32 gp = il_read32(il, CSR_EEPROM_GP);
191 int sz; 191 int sz;
192 int ret; 192 int ret;
193 u16 addr; 193 u16 addr;
194 194
195 /* allocate eeprom */ 195 /* allocate eeprom */
196 sz = priv->cfg->base_params->eeprom_size; 196 sz = il->cfg->base_params->eeprom_size;
197 IL_DEBUG_EEPROM(priv, "NVM size = %d\n", sz); 197 IL_DEBUG_EEPROM(il, "NVM size = %d\n", sz);
198 priv->eeprom = kzalloc(sz, GFP_KERNEL); 198 il->eeprom = kzalloc(sz, GFP_KERNEL);
199 if (!priv->eeprom) { 199 if (!il->eeprom) {
200 ret = -ENOMEM; 200 ret = -ENOMEM;
201 goto alloc_err; 201 goto alloc_err;
202 } 202 }
203 e = (__le16 *)priv->eeprom; 203 e = (__le16 *)il->eeprom;
204 204
205 priv->cfg->ops->lib->apm_ops.init(priv); 205 il->cfg->ops->lib->apm_ops.init(il);
206 206
207 ret = il_eeprom_verify_signature(priv); 207 ret = il_eeprom_verify_signature(il);
208 if (ret < 0) { 208 if (ret < 0) {
209 IL_ERR(priv, "EEPROM not found, EEPROM_GP=0x%08x\n", gp); 209 IL_ERR(il, "EEPROM not found, EEPROM_GP=0x%08x\n", gp);
210 ret = -ENOENT; 210 ret = -ENOENT;
211 goto err; 211 goto err;
212 } 212 }
213 213
214 /* Make sure driver (instead of uCode) is allowed to read EEPROM */ 214 /* Make sure driver (instead of uCode) is allowed to read EEPROM */
215 ret = priv->cfg->ops->lib->eeprom_ops.acquire_semaphore(priv); 215 ret = il->cfg->ops->lib->eeprom_ops.acquire_semaphore(il);
216 if (ret < 0) { 216 if (ret < 0) {
217 IL_ERR(priv, "Failed to acquire EEPROM semaphore.\n"); 217 IL_ERR(il, "Failed to acquire EEPROM semaphore.\n");
218 ret = -ENOENT; 218 ret = -ENOENT;
219 goto err; 219 goto err;
220 } 220 }
@@ -223,95 +223,95 @@ int il_eeprom_init(struct il_priv *priv)
223 for (addr = 0; addr < sz; addr += sizeof(u16)) { 223 for (addr = 0; addr < sz; addr += sizeof(u16)) {
224 u32 r; 224 u32 r;
225 225
226 _il_write32(priv, CSR_EEPROM_REG, 226 _il_write32(il, CSR_EEPROM_REG,
227 CSR_EEPROM_REG_MSK_ADDR & (addr << 1)); 227 CSR_EEPROM_REG_MSK_ADDR & (addr << 1));
228 228
229 ret = il_poll_bit(priv, CSR_EEPROM_REG, 229 ret = il_poll_bit(il, CSR_EEPROM_REG,
230 CSR_EEPROM_REG_READ_VALID_MSK, 230 CSR_EEPROM_REG_READ_VALID_MSK,
231 CSR_EEPROM_REG_READ_VALID_MSK, 231 CSR_EEPROM_REG_READ_VALID_MSK,
232 IL_EEPROM_ACCESS_TIMEOUT); 232 IL_EEPROM_ACCESS_TIMEOUT);
233 if (ret < 0) { 233 if (ret < 0) {
234 IL_ERR(priv, "Time out reading EEPROM[%d]\n", 234 IL_ERR(il, "Time out reading EEPROM[%d]\n",
235 addr); 235 addr);
236 goto done; 236 goto done;
237 } 237 }
238 r = _il_read_direct32(priv, CSR_EEPROM_REG); 238 r = _il_read_direct32(il, CSR_EEPROM_REG);
239 e[addr / 2] = cpu_to_le16(r >> 16); 239 e[addr / 2] = cpu_to_le16(r >> 16);
240 } 240 }
241 241
242 IL_DEBUG_EEPROM(priv, "NVM Type: %s, version: 0x%x\n", 242 IL_DEBUG_EEPROM(il, "NVM Type: %s, version: 0x%x\n",
243 "EEPROM", 243 "EEPROM",
244 il_eeprom_query16(priv, EEPROM_VERSION)); 244 il_eeprom_query16(il, EEPROM_VERSION));
245 245
246 ret = 0; 246 ret = 0;
247done: 247done:
248 priv->cfg->ops->lib->eeprom_ops.release_semaphore(priv); 248 il->cfg->ops->lib->eeprom_ops.release_semaphore(il);
249 249
250err: 250err:
251 if (ret) 251 if (ret)
252 il_eeprom_free(priv); 252 il_eeprom_free(il);
253 /* Reset chip to save power until we load uCode during "up". */ 253 /* Reset chip to save power until we load uCode during "up". */
254 il_apm_stop(priv); 254 il_apm_stop(il);
255alloc_err: 255alloc_err:
256 return ret; 256 return ret;
257} 257}
258EXPORT_SYMBOL(il_eeprom_init); 258EXPORT_SYMBOL(il_eeprom_init);
259 259
260void il_eeprom_free(struct il_priv *priv) 260void il_eeprom_free(struct il_priv *il)
261{ 261{
262 kfree(priv->eeprom); 262 kfree(il->eeprom);
263 priv->eeprom = NULL; 263 il->eeprom = NULL;
264} 264}
265EXPORT_SYMBOL(il_eeprom_free); 265EXPORT_SYMBOL(il_eeprom_free);
266 266
267static void il_init_band_reference(const struct il_priv *priv, 267static void il_init_band_reference(const struct il_priv *il,
268 int eep_band, int *eeprom_ch_count, 268 int eep_band, int *eeprom_ch_count,
269 const struct il_eeprom_channel **eeprom_ch_info, 269 const struct il_eeprom_channel **eeprom_ch_info,
270 const u8 **eeprom_ch_index) 270 const u8 **eeprom_ch_index)
271{ 271{
272 u32 offset = priv->cfg->ops->lib-> 272 u32 offset = il->cfg->ops->lib->
273 eeprom_ops.regulatory_bands[eep_band - 1]; 273 eeprom_ops.regulatory_bands[eep_band - 1];
274 switch (eep_band) { 274 switch (eep_band) {
275 case 1: /* 2.4GHz band */ 275 case 1: /* 2.4GHz band */
276 *eeprom_ch_count = ARRAY_SIZE(iwlegacy_eeprom_band_1); 276 *eeprom_ch_count = ARRAY_SIZE(iwlegacy_eeprom_band_1);
277 *eeprom_ch_info = (struct il_eeprom_channel *) 277 *eeprom_ch_info = (struct il_eeprom_channel *)
278 il_eeprom_query_addr(priv, offset); 278 il_eeprom_query_addr(il, offset);
279 *eeprom_ch_index = iwlegacy_eeprom_band_1; 279 *eeprom_ch_index = iwlegacy_eeprom_band_1;
280 break; 280 break;
281 case 2: /* 4.9GHz band */ 281 case 2: /* 4.9GHz band */
282 *eeprom_ch_count = ARRAY_SIZE(iwlegacy_eeprom_band_2); 282 *eeprom_ch_count = ARRAY_SIZE(iwlegacy_eeprom_band_2);
283 *eeprom_ch_info = (struct il_eeprom_channel *) 283 *eeprom_ch_info = (struct il_eeprom_channel *)
284 il_eeprom_query_addr(priv, offset); 284 il_eeprom_query_addr(il, offset);
285 *eeprom_ch_index = iwlegacy_eeprom_band_2; 285 *eeprom_ch_index = iwlegacy_eeprom_band_2;
286 break; 286 break;
287 case 3: /* 5.2GHz band */ 287 case 3: /* 5.2GHz band */
288 *eeprom_ch_count = ARRAY_SIZE(iwlegacy_eeprom_band_3); 288 *eeprom_ch_count = ARRAY_SIZE(iwlegacy_eeprom_band_3);
289 *eeprom_ch_info = (struct il_eeprom_channel *) 289 *eeprom_ch_info = (struct il_eeprom_channel *)
290 il_eeprom_query_addr(priv, offset); 290 il_eeprom_query_addr(il, offset);
291 *eeprom_ch_index = iwlegacy_eeprom_band_3; 291 *eeprom_ch_index = iwlegacy_eeprom_band_3;
292 break; 292 break;
293 case 4: /* 5.5GHz band */ 293 case 4: /* 5.5GHz band */
294 *eeprom_ch_count = ARRAY_SIZE(iwlegacy_eeprom_band_4); 294 *eeprom_ch_count = ARRAY_SIZE(iwlegacy_eeprom_band_4);
295 *eeprom_ch_info = (struct il_eeprom_channel *) 295 *eeprom_ch_info = (struct il_eeprom_channel *)
296 il_eeprom_query_addr(priv, offset); 296 il_eeprom_query_addr(il, offset);
297 *eeprom_ch_index = iwlegacy_eeprom_band_4; 297 *eeprom_ch_index = iwlegacy_eeprom_band_4;
298 break; 298 break;
299 case 5: /* 5.7GHz band */ 299 case 5: /* 5.7GHz band */
300 *eeprom_ch_count = ARRAY_SIZE(iwlegacy_eeprom_band_5); 300 *eeprom_ch_count = ARRAY_SIZE(iwlegacy_eeprom_band_5);
301 *eeprom_ch_info = (struct il_eeprom_channel *) 301 *eeprom_ch_info = (struct il_eeprom_channel *)
302 il_eeprom_query_addr(priv, offset); 302 il_eeprom_query_addr(il, offset);
303 *eeprom_ch_index = iwlegacy_eeprom_band_5; 303 *eeprom_ch_index = iwlegacy_eeprom_band_5;
304 break; 304 break;
305 case 6: /* 2.4GHz ht40 channels */ 305 case 6: /* 2.4GHz ht40 channels */
306 *eeprom_ch_count = ARRAY_SIZE(iwlegacy_eeprom_band_6); 306 *eeprom_ch_count = ARRAY_SIZE(iwlegacy_eeprom_band_6);
307 *eeprom_ch_info = (struct il_eeprom_channel *) 307 *eeprom_ch_info = (struct il_eeprom_channel *)
308 il_eeprom_query_addr(priv, offset); 308 il_eeprom_query_addr(il, offset);
309 *eeprom_ch_index = iwlegacy_eeprom_band_6; 309 *eeprom_ch_index = iwlegacy_eeprom_band_6;
310 break; 310 break;
311 case 7: /* 5 GHz ht40 channels */ 311 case 7: /* 5 GHz ht40 channels */
312 *eeprom_ch_count = ARRAY_SIZE(iwlegacy_eeprom_band_7); 312 *eeprom_ch_count = ARRAY_SIZE(iwlegacy_eeprom_band_7);
313 *eeprom_ch_info = (struct il_eeprom_channel *) 313 *eeprom_ch_info = (struct il_eeprom_channel *)
314 il_eeprom_query_addr(priv, offset); 314 il_eeprom_query_addr(il, offset);
315 *eeprom_ch_index = iwlegacy_eeprom_band_7; 315 *eeprom_ch_index = iwlegacy_eeprom_band_7;
316 break; 316 break;
317 default: 317 default:
@@ -322,11 +322,11 @@ static void il_init_band_reference(const struct il_priv *priv,
322#define CHECK_AND_PRINT(x) ((eeprom_ch->flags & EEPROM_CHANNEL_##x) \ 322#define CHECK_AND_PRINT(x) ((eeprom_ch->flags & EEPROM_CHANNEL_##x) \
323 ? # x " " : "") 323 ? # x " " : "")
324/** 324/**
325 * il_mod_ht40_chan_info - Copy ht40 channel info into driver's priv. 325 * il_mod_ht40_chan_info - Copy ht40 channel info into driver's il.
326 * 326 *
327 * Does not set up a command, or touch hardware. 327 * Does not set up a command, or touch hardware.
328 */ 328 */
329static int il_mod_ht40_chan_info(struct il_priv *priv, 329static int il_mod_ht40_chan_info(struct il_priv *il,
330 enum ieee80211_band band, u16 channel, 330 enum ieee80211_band band, u16 channel,
331 const struct il_eeprom_channel *eeprom_ch, 331 const struct il_eeprom_channel *eeprom_ch,
332 u8 clear_ht40_extension_channel) 332 u8 clear_ht40_extension_channel)
@@ -334,12 +334,12 @@ static int il_mod_ht40_chan_info(struct il_priv *priv,
334 struct il_channel_info *ch_info; 334 struct il_channel_info *ch_info;
335 335
336 ch_info = (struct il_channel_info *) 336 ch_info = (struct il_channel_info *)
337 il_get_channel_info(priv, band, channel); 337 il_get_channel_info(il, band, channel);
338 338
339 if (!il_is_channel_valid(ch_info)) 339 if (!il_is_channel_valid(ch_info))
340 return -1; 340 return -1;
341 341
342 IL_DEBUG_EEPROM(priv, "HT40 Ch. %d [%sGHz] %s%s%s%s%s(0x%02x %ddBm):" 342 IL_DEBUG_EEPROM(il, "HT40 Ch. %d [%sGHz] %s%s%s%s%s(0x%02x %ddBm):"
343 " Ad-Hoc %ssupported\n", 343 " Ad-Hoc %ssupported\n",
344 ch_info->channel, 344 ch_info->channel,
345 il_is_channel_a_band(ch_info) ? 345 il_is_channel_a_band(ch_info) ?
@@ -371,7 +371,7 @@ static int il_mod_ht40_chan_info(struct il_priv *priv,
371/** 371/**
372 * il_init_channel_map - Set up driver's info for all possible channels 372 * il_init_channel_map - Set up driver's info for all possible channels
373 */ 373 */
374int il_init_channel_map(struct il_priv *priv) 374int il_init_channel_map(struct il_priv *il)
375{ 375{
376 int eeprom_ch_count = 0; 376 int eeprom_ch_count = 0;
377 const u8 *eeprom_ch_index = NULL; 377 const u8 *eeprom_ch_index = NULL;
@@ -379,39 +379,39 @@ int il_init_channel_map(struct il_priv *priv)
379 int band, ch; 379 int band, ch;
380 struct il_channel_info *ch_info; 380 struct il_channel_info *ch_info;
381 381
382 if (priv->channel_count) { 382 if (il->channel_count) {
383 IL_DEBUG_EEPROM(priv, "Channel map already initialized.\n"); 383 IL_DEBUG_EEPROM(il, "Channel map already initialized.\n");
384 return 0; 384 return 0;
385 } 385 }
386 386
387 IL_DEBUG_EEPROM(priv, "Initializing regulatory info from EEPROM\n"); 387 IL_DEBUG_EEPROM(il, "Initializing regulatory info from EEPROM\n");
388 388
389 priv->channel_count = 389 il->channel_count =
390 ARRAY_SIZE(iwlegacy_eeprom_band_1) + 390 ARRAY_SIZE(iwlegacy_eeprom_band_1) +
391 ARRAY_SIZE(iwlegacy_eeprom_band_2) + 391 ARRAY_SIZE(iwlegacy_eeprom_band_2) +
392 ARRAY_SIZE(iwlegacy_eeprom_band_3) + 392 ARRAY_SIZE(iwlegacy_eeprom_band_3) +
393 ARRAY_SIZE(iwlegacy_eeprom_band_4) + 393 ARRAY_SIZE(iwlegacy_eeprom_band_4) +
394 ARRAY_SIZE(iwlegacy_eeprom_band_5); 394 ARRAY_SIZE(iwlegacy_eeprom_band_5);
395 395
396 IL_DEBUG_EEPROM(priv, "Parsing data for %d channels.\n", 396 IL_DEBUG_EEPROM(il, "Parsing data for %d channels.\n",
397 priv->channel_count); 397 il->channel_count);
398 398
399 priv->channel_info = kzalloc(sizeof(struct il_channel_info) * 399 il->channel_info = kzalloc(sizeof(struct il_channel_info) *
400 priv->channel_count, GFP_KERNEL); 400 il->channel_count, GFP_KERNEL);
401 if (!priv->channel_info) { 401 if (!il->channel_info) {
402 IL_ERR(priv, "Could not allocate channel_info\n"); 402 IL_ERR(il, "Could not allocate channel_info\n");
403 priv->channel_count = 0; 403 il->channel_count = 0;
404 return -ENOMEM; 404 return -ENOMEM;
405 } 405 }
406 406
407 ch_info = priv->channel_info; 407 ch_info = il->channel_info;
408 408
409 /* Loop through the 5 EEPROM bands adding them in order to the 409 /* Loop through the 5 EEPROM bands adding them in order to the
410 * channel map we maintain (that contains additional information than 410 * channel map we maintain (that contains additional information than
411 * what just in the EEPROM) */ 411 * what just in the EEPROM) */
412 for (band = 1; band <= 5; band++) { 412 for (band = 1; band <= 5; band++) {
413 413
414 il_init_band_reference(priv, band, &eeprom_ch_count, 414 il_init_band_reference(il, band, &eeprom_ch_count,
415 &eeprom_ch_info, &eeprom_ch_index); 415 &eeprom_ch_info, &eeprom_ch_index);
416 416
417 /* Loop through each band adding each of the channels */ 417 /* Loop through each band adding each of the channels */
@@ -433,7 +433,7 @@ int il_init_channel_map(struct il_priv *priv)
433 IEEE80211_CHAN_NO_HT40; 433 IEEE80211_CHAN_NO_HT40;
434 434
435 if (!(il_is_channel_valid(ch_info))) { 435 if (!(il_is_channel_valid(ch_info))) {
436 IL_DEBUG_EEPROM(priv, 436 IL_DEBUG_EEPROM(il,
437 "Ch. %d Flags %x [%sGHz] - " 437 "Ch. %d Flags %x [%sGHz] - "
438 "No traffic\n", 438 "No traffic\n",
439 ch_info->channel, 439 ch_info->channel,
@@ -450,7 +450,7 @@ int il_init_channel_map(struct il_priv *priv)
450 ch_info->scan_power = eeprom_ch_info[ch].max_power_avg; 450 ch_info->scan_power = eeprom_ch_info[ch].max_power_avg;
451 ch_info->min_power = 0; 451 ch_info->min_power = 0;
452 452
453 IL_DEBUG_EEPROM(priv, "Ch. %d [%sGHz] " 453 IL_DEBUG_EEPROM(il, "Ch. %d [%sGHz] "
454 "%s%s%s%s%s%s(0x%02x %ddBm):" 454 "%s%s%s%s%s%s(0x%02x %ddBm):"
455 " Ad-Hoc %ssupported\n", 455 " Ad-Hoc %ssupported\n",
456 ch_info->channel, 456 ch_info->channel,
@@ -475,9 +475,9 @@ int il_init_channel_map(struct il_priv *priv)
475 } 475 }
476 476
477 /* Check if we do have HT40 channels */ 477 /* Check if we do have HT40 channels */
478 if (priv->cfg->ops->lib->eeprom_ops.regulatory_bands[5] == 478 if (il->cfg->ops->lib->eeprom_ops.regulatory_bands[5] ==
479 EEPROM_REGULATORY_BAND_NO_HT40 && 479 EEPROM_REGULATORY_BAND_NO_HT40 &&
480 priv->cfg->ops->lib->eeprom_ops.regulatory_bands[6] == 480 il->cfg->ops->lib->eeprom_ops.regulatory_bands[6] ==
481 EEPROM_REGULATORY_BAND_NO_HT40) 481 EEPROM_REGULATORY_BAND_NO_HT40)
482 return 0; 482 return 0;
483 483
@@ -485,7 +485,7 @@ int il_init_channel_map(struct il_priv *priv)
485 for (band = 6; band <= 7; band++) { 485 for (band = 6; band <= 7; band++) {
486 enum ieee80211_band ieeeband; 486 enum ieee80211_band ieeeband;
487 487
488 il_init_band_reference(priv, band, &eeprom_ch_count, 488 il_init_band_reference(il, band, &eeprom_ch_count,
489 &eeprom_ch_info, &eeprom_ch_index); 489 &eeprom_ch_info, &eeprom_ch_index);
490 490
491 /* EEPROM band 6 is 2.4, band 7 is 5 GHz */ 491 /* EEPROM band 6 is 2.4, band 7 is 5 GHz */
@@ -495,13 +495,13 @@ int il_init_channel_map(struct il_priv *priv)
495 /* Loop through each band adding each of the channels */ 495 /* Loop through each band adding each of the channels */
496 for (ch = 0; ch < eeprom_ch_count; ch++) { 496 for (ch = 0; ch < eeprom_ch_count; ch++) {
497 /* Set up driver's info for lower half */ 497 /* Set up driver's info for lower half */
498 il_mod_ht40_chan_info(priv, ieeeband, 498 il_mod_ht40_chan_info(il, ieeeband,
499 eeprom_ch_index[ch], 499 eeprom_ch_index[ch],
500 &eeprom_ch_info[ch], 500 &eeprom_ch_info[ch],
501 IEEE80211_CHAN_NO_HT40PLUS); 501 IEEE80211_CHAN_NO_HT40PLUS);
502 502
503 /* Set up driver's info for upper half */ 503 /* Set up driver's info for upper half */
504 il_mod_ht40_chan_info(priv, ieeeband, 504 il_mod_ht40_chan_info(il, ieeeband,
505 eeprom_ch_index[ch] + 4, 505 eeprom_ch_index[ch] + 4,
506 &eeprom_ch_info[ch], 506 &eeprom_ch_info[ch],
507 IEEE80211_CHAN_NO_HT40MINUS); 507 IEEE80211_CHAN_NO_HT40MINUS);
@@ -515,34 +515,34 @@ EXPORT_SYMBOL(il_init_channel_map);
515/* 515/*
516 * il_free_channel_map - undo allocations in il_init_channel_map 516 * il_free_channel_map - undo allocations in il_init_channel_map
517 */ 517 */
518void il_free_channel_map(struct il_priv *priv) 518void il_free_channel_map(struct il_priv *il)
519{ 519{
520 kfree(priv->channel_info); 520 kfree(il->channel_info);
521 priv->channel_count = 0; 521 il->channel_count = 0;
522} 522}
523EXPORT_SYMBOL(il_free_channel_map); 523EXPORT_SYMBOL(il_free_channel_map);
524 524
525/** 525/**
526 * il_get_channel_info - Find driver's private channel info 526 * il_get_channel_info - Find driver's ilate channel info
527 * 527 *
528 * Based on band and channel number. 528 * Based on band and channel number.
529 */ 529 */
530const struct 530const struct
531il_channel_info *il_get_channel_info(const struct il_priv *priv, 531il_channel_info *il_get_channel_info(const struct il_priv *il,
532 enum ieee80211_band band, u16 channel) 532 enum ieee80211_band band, u16 channel)
533{ 533{
534 int i; 534 int i;
535 535
536 switch (band) { 536 switch (band) {
537 case IEEE80211_BAND_5GHZ: 537 case IEEE80211_BAND_5GHZ:
538 for (i = 14; i < priv->channel_count; i++) { 538 for (i = 14; i < il->channel_count; i++) {
539 if (priv->channel_info[i].channel == channel) 539 if (il->channel_info[i].channel == channel)
540 return &priv->channel_info[i]; 540 return &il->channel_info[i];
541 } 541 }
542 break; 542 break;
543 case IEEE80211_BAND_2GHZ: 543 case IEEE80211_BAND_2GHZ:
544 if (channel >= 1 && channel <= 14) 544 if (channel >= 1 && channel <= 14)
545 return &priv->channel_info[channel - 1]; 545 return &il->channel_info[channel - 1];
546 break; 546 break;
547 default: 547 default:
548 BUG(); 548 BUG();
diff --git a/drivers/net/wireless/iwlegacy/iwl-eeprom.h b/drivers/net/wireless/iwlegacy/iwl-eeprom.h
index 9ad687161623..acb5ec17d70d 100644
--- a/drivers/net/wireless/iwlegacy/iwl-eeprom.h
+++ b/drivers/net/wireless/iwlegacy/iwl-eeprom.h
@@ -325,20 +325,20 @@ struct il_eeprom_calib_info {
325 325
326struct il_eeprom_ops { 326struct il_eeprom_ops {
327 const u32 regulatory_bands[7]; 327 const u32 regulatory_bands[7];
328 int (*acquire_semaphore) (struct il_priv *priv); 328 int (*acquire_semaphore) (struct il_priv *il);
329 void (*release_semaphore) (struct il_priv *priv); 329 void (*release_semaphore) (struct il_priv *il);
330}; 330};
331 331
332 332
333int il_eeprom_init(struct il_priv *priv); 333int il_eeprom_init(struct il_priv *il);
334void il_eeprom_free(struct il_priv *priv); 334void il_eeprom_free(struct il_priv *il);
335const u8 *il_eeprom_query_addr(const struct il_priv *priv, 335const u8 *il_eeprom_query_addr(const struct il_priv *il,
336 size_t offset); 336 size_t offset);
337u16 il_eeprom_query16(const struct il_priv *priv, size_t offset); 337u16 il_eeprom_query16(const struct il_priv *il, size_t offset);
338int il_init_channel_map(struct il_priv *priv); 338int il_init_channel_map(struct il_priv *il);
339void il_free_channel_map(struct il_priv *priv); 339void il_free_channel_map(struct il_priv *il);
340const struct il_channel_info *il_get_channel_info( 340const struct il_channel_info *il_get_channel_info(
341 const struct il_priv *priv, 341 const struct il_priv *il,
342 enum ieee80211_band band, u16 channel); 342 enum ieee80211_band band, u16 channel);
343 343
344#endif /* __il_eeprom_h__ */ 344#endif /* __il_eeprom_h__ */
diff --git a/drivers/net/wireless/iwlegacy/iwl-hcmd.c b/drivers/net/wireless/iwlegacy/iwl-hcmd.c
index 515befc28001..f16e31109e06 100644
--- a/drivers/net/wireless/iwlegacy/iwl-hcmd.c
+++ b/drivers/net/wireless/iwlegacy/iwl-hcmd.c
@@ -90,12 +90,12 @@ EXPORT_SYMBOL(il_get_cmd_string);
90 90
91#define HOST_COMPLETE_TIMEOUT (HZ / 2) 91#define HOST_COMPLETE_TIMEOUT (HZ / 2)
92 92
93static void il_generic_cmd_callback(struct il_priv *priv, 93static void il_generic_cmd_callback(struct il_priv *il,
94 struct il_device_cmd *cmd, 94 struct il_device_cmd *cmd,
95 struct il_rx_packet *pkt) 95 struct il_rx_packet *pkt)
96{ 96{
97 if (pkt->hdr.flags & IL_CMD_FAILED_MSK) { 97 if (pkt->hdr.flags & IL_CMD_FAILED_MSK) {
98 IL_ERR(priv, "Bad return from %s (0x%08X)\n", 98 IL_ERR(il, "Bad return from %s (0x%08X)\n",
99 il_get_cmd_string(cmd->hdr.cmd), pkt->hdr.flags); 99 il_get_cmd_string(cmd->hdr.cmd), pkt->hdr.flags);
100 return; 100 return;
101 } 101 }
@@ -104,18 +104,18 @@ static void il_generic_cmd_callback(struct il_priv *priv,
104 switch (cmd->hdr.cmd) { 104 switch (cmd->hdr.cmd) {
105 case REPLY_TX_LINK_QUALITY_CMD: 105 case REPLY_TX_LINK_QUALITY_CMD:
106 case SENSITIVITY_CMD: 106 case SENSITIVITY_CMD:
107 IL_DEBUG_HC_DUMP(priv, "back from %s (0x%08X)\n", 107 IL_DEBUG_HC_DUMP(il, "back from %s (0x%08X)\n",
108 il_get_cmd_string(cmd->hdr.cmd), pkt->hdr.flags); 108 il_get_cmd_string(cmd->hdr.cmd), pkt->hdr.flags);
109 break; 109 break;
110 default: 110 default:
111 IL_DEBUG_HC(priv, "back from %s (0x%08X)\n", 111 IL_DEBUG_HC(il, "back from %s (0x%08X)\n",
112 il_get_cmd_string(cmd->hdr.cmd), pkt->hdr.flags); 112 il_get_cmd_string(cmd->hdr.cmd), pkt->hdr.flags);
113 } 113 }
114#endif 114#endif
115} 115}
116 116
117static int 117static int
118il_send_cmd_async(struct il_priv *priv, struct il_host_cmd *cmd) 118il_send_cmd_async(struct il_priv *il, struct il_host_cmd *cmd)
119{ 119{
120 int ret; 120 int ret;
121 121
@@ -128,57 +128,57 @@ il_send_cmd_async(struct il_priv *priv, struct il_host_cmd *cmd)
128 if (!cmd->callback) 128 if (!cmd->callback)
129 cmd->callback = il_generic_cmd_callback; 129 cmd->callback = il_generic_cmd_callback;
130 130
131 if (test_bit(STATUS_EXIT_PENDING, &priv->status)) 131 if (test_bit(STATUS_EXIT_PENDING, &il->status))
132 return -EBUSY; 132 return -EBUSY;
133 133
134 ret = il_enqueue_hcmd(priv, cmd); 134 ret = il_enqueue_hcmd(il, cmd);
135 if (ret < 0) { 135 if (ret < 0) {
136 IL_ERR(priv, "Error sending %s: enqueue_hcmd failed: %d\n", 136 IL_ERR(il, "Error sending %s: enqueue_hcmd failed: %d\n",
137 il_get_cmd_string(cmd->id), ret); 137 il_get_cmd_string(cmd->id), ret);
138 return ret; 138 return ret;
139 } 139 }
140 return 0; 140 return 0;
141} 141}
142 142
143int il_send_cmd_sync(struct il_priv *priv, struct il_host_cmd *cmd) 143int il_send_cmd_sync(struct il_priv *il, struct il_host_cmd *cmd)
144{ 144{
145 int cmd_idx; 145 int cmd_idx;
146 int ret; 146 int ret;
147 147
148 lockdep_assert_held(&priv->mutex); 148 lockdep_assert_held(&il->mutex);
149 149
150 BUG_ON(cmd->flags & CMD_ASYNC); 150 BUG_ON(cmd->flags & CMD_ASYNC);
151 151
152 /* A synchronous command can not have a callback set. */ 152 /* A synchronous command can not have a callback set. */
153 BUG_ON(cmd->callback); 153 BUG_ON(cmd->callback);
154 154
155 IL_DEBUG_INFO(priv, "Attempting to send sync command %s\n", 155 IL_DEBUG_INFO(il, "Attempting to send sync command %s\n",
156 il_get_cmd_string(cmd->id)); 156 il_get_cmd_string(cmd->id));
157 157
158 set_bit(STATUS_HCMD_ACTIVE, &priv->status); 158 set_bit(STATUS_HCMD_ACTIVE, &il->status);
159 IL_DEBUG_INFO(priv, "Setting HCMD_ACTIVE for command %s\n", 159 IL_DEBUG_INFO(il, "Setting HCMD_ACTIVE for command %s\n",
160 il_get_cmd_string(cmd->id)); 160 il_get_cmd_string(cmd->id));
161 161
162 cmd_idx = il_enqueue_hcmd(priv, cmd); 162 cmd_idx = il_enqueue_hcmd(il, cmd);
163 if (cmd_idx < 0) { 163 if (cmd_idx < 0) {
164 ret = cmd_idx; 164 ret = cmd_idx;
165 IL_ERR(priv, "Error sending %s: enqueue_hcmd failed: %d\n", 165 IL_ERR(il, "Error sending %s: enqueue_hcmd failed: %d\n",
166 il_get_cmd_string(cmd->id), ret); 166 il_get_cmd_string(cmd->id), ret);
167 goto out; 167 goto out;
168 } 168 }
169 169
170 ret = wait_event_timeout(priv->wait_command_queue, 170 ret = wait_event_timeout(il->wait_command_queue,
171 !test_bit(STATUS_HCMD_ACTIVE, &priv->status), 171 !test_bit(STATUS_HCMD_ACTIVE, &il->status),
172 HOST_COMPLETE_TIMEOUT); 172 HOST_COMPLETE_TIMEOUT);
173 if (!ret) { 173 if (!ret) {
174 if (test_bit(STATUS_HCMD_ACTIVE, &priv->status)) { 174 if (test_bit(STATUS_HCMD_ACTIVE, &il->status)) {
175 IL_ERR(priv, 175 IL_ERR(il,
176 "Error sending %s: time out after %dms.\n", 176 "Error sending %s: time out after %dms.\n",
177 il_get_cmd_string(cmd->id), 177 il_get_cmd_string(cmd->id),
178 jiffies_to_msecs(HOST_COMPLETE_TIMEOUT)); 178 jiffies_to_msecs(HOST_COMPLETE_TIMEOUT));
179 179
180 clear_bit(STATUS_HCMD_ACTIVE, &priv->status); 180 clear_bit(STATUS_HCMD_ACTIVE, &il->status);
181 IL_DEBUG_INFO(priv, 181 IL_DEBUG_INFO(il,
182 "Clearing HCMD_ACTIVE for command %s\n", 182 "Clearing HCMD_ACTIVE for command %s\n",
183 il_get_cmd_string(cmd->id)); 183 il_get_cmd_string(cmd->id));
184 ret = -ETIMEDOUT; 184 ret = -ETIMEDOUT;
@@ -186,20 +186,20 @@ int il_send_cmd_sync(struct il_priv *priv, struct il_host_cmd *cmd)
186 } 186 }
187 } 187 }
188 188
189 if (test_bit(STATUS_RF_KILL_HW, &priv->status)) { 189 if (test_bit(STATUS_RF_KILL_HW, &il->status)) {
190 IL_ERR(priv, "Command %s aborted: RF KILL Switch\n", 190 IL_ERR(il, "Command %s aborted: RF KILL Switch\n",
191 il_get_cmd_string(cmd->id)); 191 il_get_cmd_string(cmd->id));
192 ret = -ECANCELED; 192 ret = -ECANCELED;
193 goto fail; 193 goto fail;
194 } 194 }
195 if (test_bit(STATUS_FW_ERROR, &priv->status)) { 195 if (test_bit(STATUS_FW_ERROR, &il->status)) {
196 IL_ERR(priv, "Command %s failed: FW Error\n", 196 IL_ERR(il, "Command %s failed: FW Error\n",
197 il_get_cmd_string(cmd->id)); 197 il_get_cmd_string(cmd->id));
198 ret = -EIO; 198 ret = -EIO;
199 goto fail; 199 goto fail;
200 } 200 }
201 if ((cmd->flags & CMD_WANT_SKB) && !cmd->reply_page) { 201 if ((cmd->flags & CMD_WANT_SKB) && !cmd->reply_page) {
202 IL_ERR(priv, "Error: Response NULL in '%s'\n", 202 IL_ERR(il, "Error: Response NULL in '%s'\n",
203 il_get_cmd_string(cmd->id)); 203 il_get_cmd_string(cmd->id));
204 ret = -EIO; 204 ret = -EIO;
205 goto cancel; 205 goto cancel;
@@ -216,12 +216,12 @@ cancel:
216 * in later, it will possibly set an invalid 216 * in later, it will possibly set an invalid
217 * address (cmd->meta.source). 217 * address (cmd->meta.source).
218 */ 218 */
219 priv->txq[priv->cmd_queue].meta[cmd_idx].flags &= 219 il->txq[il->cmd_queue].meta[cmd_idx].flags &=
220 ~CMD_WANT_SKB; 220 ~CMD_WANT_SKB;
221 } 221 }
222fail: 222fail:
223 if (cmd->reply_page) { 223 if (cmd->reply_page) {
224 il_free_pages(priv, cmd->reply_page); 224 il_free_pages(il, cmd->reply_page);
225 cmd->reply_page = 0; 225 cmd->reply_page = 0;
226 } 226 }
227out: 227out:
@@ -229,17 +229,17 @@ out:
229} 229}
230EXPORT_SYMBOL(il_send_cmd_sync); 230EXPORT_SYMBOL(il_send_cmd_sync);
231 231
232int il_send_cmd(struct il_priv *priv, struct il_host_cmd *cmd) 232int il_send_cmd(struct il_priv *il, struct il_host_cmd *cmd)
233{ 233{
234 if (cmd->flags & CMD_ASYNC) 234 if (cmd->flags & CMD_ASYNC)
235 return il_send_cmd_async(priv, cmd); 235 return il_send_cmd_async(il, cmd);
236 236
237 return il_send_cmd_sync(priv, cmd); 237 return il_send_cmd_sync(il, cmd);
238} 238}
239EXPORT_SYMBOL(il_send_cmd); 239EXPORT_SYMBOL(il_send_cmd);
240 240
241int 241int
242il_send_cmd_pdu(struct il_priv *priv, u8 id, u16 len, const void *data) 242il_send_cmd_pdu(struct il_priv *il, u8 id, u16 len, const void *data)
243{ 243{
244 struct il_host_cmd cmd = { 244 struct il_host_cmd cmd = {
245 .id = id, 245 .id = id,
@@ -247,13 +247,13 @@ il_send_cmd_pdu(struct il_priv *priv, u8 id, u16 len, const void *data)
247 .data = data, 247 .data = data,
248 }; 248 };
249 249
250 return il_send_cmd_sync(priv, &cmd); 250 return il_send_cmd_sync(il, &cmd);
251} 251}
252EXPORT_SYMBOL(il_send_cmd_pdu); 252EXPORT_SYMBOL(il_send_cmd_pdu);
253 253
254int il_send_cmd_pdu_async(struct il_priv *priv, 254int il_send_cmd_pdu_async(struct il_priv *il,
255 u8 id, u16 len, const void *data, 255 u8 id, u16 len, const void *data,
256 void (*callback)(struct il_priv *priv, 256 void (*callback)(struct il_priv *il,
257 struct il_device_cmd *cmd, 257 struct il_device_cmd *cmd,
258 struct il_rx_packet *pkt)) 258 struct il_rx_packet *pkt))
259{ 259{
@@ -266,6 +266,6 @@ int il_send_cmd_pdu_async(struct il_priv *priv,
266 cmd.flags |= CMD_ASYNC; 266 cmd.flags |= CMD_ASYNC;
267 cmd.callback = callback; 267 cmd.callback = callback;
268 268
269 return il_send_cmd_async(priv, &cmd); 269 return il_send_cmd_async(il, &cmd);
270} 270}
271EXPORT_SYMBOL(il_send_cmd_pdu_async); 271EXPORT_SYMBOL(il_send_cmd_pdu_async);
diff --git a/drivers/net/wireless/iwlegacy/iwl-helpers.h b/drivers/net/wireless/iwlegacy/iwl-helpers.h
index e4e63b570f57..e55f2ef1c57b 100644
--- a/drivers/net/wireless/iwlegacy/iwl-helpers.h
+++ b/drivers/net/wireless/iwlegacy/iwl-helpers.h
@@ -108,28 +108,28 @@ il_set_swq_id(struct il_tx_queue *txq, u8 ac, u8 hwq)
108 txq->swq_id = (hwq << 2) | ac; 108 txq->swq_id = (hwq << 2) | ac;
109} 109}
110 110
111static inline void il_wake_queue(struct il_priv *priv, 111static inline void il_wake_queue(struct il_priv *il,
112 struct il_tx_queue *txq) 112 struct il_tx_queue *txq)
113{ 113{
114 u8 queue = txq->swq_id; 114 u8 queue = txq->swq_id;
115 u8 ac = queue & 3; 115 u8 ac = queue & 3;
116 u8 hwq = (queue >> 2) & 0x1f; 116 u8 hwq = (queue >> 2) & 0x1f;
117 117
118 if (test_and_clear_bit(hwq, priv->queue_stopped)) 118 if (test_and_clear_bit(hwq, il->queue_stopped))
119 if (atomic_dec_return(&priv->queue_stop_count[ac]) <= 0) 119 if (atomic_dec_return(&il->queue_stop_count[ac]) <= 0)
120 ieee80211_wake_queue(priv->hw, ac); 120 ieee80211_wake_queue(il->hw, ac);
121} 121}
122 122
123static inline void il_stop_queue(struct il_priv *priv, 123static inline void il_stop_queue(struct il_priv *il,
124 struct il_tx_queue *txq) 124 struct il_tx_queue *txq)
125{ 125{
126 u8 queue = txq->swq_id; 126 u8 queue = txq->swq_id;
127 u8 ac = queue & 3; 127 u8 ac = queue & 3;
128 u8 hwq = (queue >> 2) & 0x1f; 128 u8 hwq = (queue >> 2) & 0x1f;
129 129
130 if (!test_and_set_bit(hwq, priv->queue_stopped)) 130 if (!test_and_set_bit(hwq, il->queue_stopped))
131 if (atomic_inc_return(&priv->queue_stop_count[ac]) > 0) 131 if (atomic_inc_return(&il->queue_stop_count[ac]) > 0)
132 ieee80211_stop_queue(priv->hw, ac); 132 ieee80211_stop_queue(il->hw, ac);
133} 133}
134 134
135#ifdef ieee80211_stop_queue 135#ifdef ieee80211_stop_queue
@@ -144,39 +144,39 @@ static inline void il_stop_queue(struct il_priv *priv,
144 144
145#define ieee80211_wake_queue DO_NOT_USE_ieee80211_wake_queue 145#define ieee80211_wake_queue DO_NOT_USE_ieee80211_wake_queue
146 146
147static inline void il_disable_interrupts(struct il_priv *priv) 147static inline void il_disable_interrupts(struct il_priv *il)
148{ 148{
149 clear_bit(STATUS_INT_ENABLED, &priv->status); 149 clear_bit(STATUS_INT_ENABLED, &il->status);
150 150
151 /* disable interrupts from uCode/NIC to host */ 151 /* disable interrupts from uCode/NIC to host */
152 il_write32(priv, CSR_INT_MASK, 0x00000000); 152 il_write32(il, CSR_INT_MASK, 0x00000000);
153 153
154 /* acknowledge/clear/reset any interrupts still pending 154 /* acknowledge/clear/reset any interrupts still pending
155 * from uCode or flow handler (Rx/Tx DMA) */ 155 * from uCode or flow handler (Rx/Tx DMA) */
156 il_write32(priv, CSR_INT, 0xffffffff); 156 il_write32(il, CSR_INT, 0xffffffff);
157 il_write32(priv, CSR_FH_INT_STATUS, 0xffffffff); 157 il_write32(il, CSR_FH_INT_STATUS, 0xffffffff);
158 IL_DEBUG_ISR(priv, "Disabled interrupts\n"); 158 IL_DEBUG_ISR(il, "Disabled interrupts\n");
159} 159}
160 160
161static inline void il_enable_rfkill_int(struct il_priv *priv) 161static inline void il_enable_rfkill_int(struct il_priv *il)
162{ 162{
163 IL_DEBUG_ISR(priv, "Enabling rfkill interrupt\n"); 163 IL_DEBUG_ISR(il, "Enabling rfkill interrupt\n");
164 il_write32(priv, CSR_INT_MASK, CSR_INT_BIT_RF_KILL); 164 il_write32(il, CSR_INT_MASK, CSR_INT_BIT_RF_KILL);
165} 165}
166 166
167static inline void il_enable_interrupts(struct il_priv *priv) 167static inline void il_enable_interrupts(struct il_priv *il)
168{ 168{
169 IL_DEBUG_ISR(priv, "Enabling interrupts\n"); 169 IL_DEBUG_ISR(il, "Enabling interrupts\n");
170 set_bit(STATUS_INT_ENABLED, &priv->status); 170 set_bit(STATUS_INT_ENABLED, &il->status);
171 il_write32(priv, CSR_INT_MASK, priv->inta_mask); 171 il_write32(il, CSR_INT_MASK, il->inta_mask);
172} 172}
173 173
174/** 174/**
175 * il_beacon_time_mask_low - mask of lower 32 bit of beacon time 175 * il_beacon_time_mask_low - mask of lower 32 bit of beacon time
176 * @priv -- pointer to il_priv data structure 176 * @il -- pointer to il_priv data structure
177 * @tsf_bits -- number of bits need to shift for masking) 177 * @tsf_bits -- number of bits need to shift for masking)
178 */ 178 */
179static inline u32 il_beacon_time_mask_low(struct il_priv *priv, 179static inline u32 il_beacon_time_mask_low(struct il_priv *il,
180 u16 tsf_bits) 180 u16 tsf_bits)
181{ 181{
182 return (1 << tsf_bits) - 1; 182 return (1 << tsf_bits) - 1;
@@ -184,10 +184,10 @@ static inline u32 il_beacon_time_mask_low(struct il_priv *priv,
184 184
185/** 185/**
186 * il_beacon_time_mask_high - mask of higher 32 bit of beacon time 186 * il_beacon_time_mask_high - mask of higher 32 bit of beacon time
187 * @priv -- pointer to il_priv data structure 187 * @il -- pointer to il_priv data structure
188 * @tsf_bits -- number of bits need to shift for masking) 188 * @tsf_bits -- number of bits need to shift for masking)
189 */ 189 */
190static inline u32 il_beacon_time_mask_high(struct il_priv *priv, 190static inline u32 il_beacon_time_mask_high(struct il_priv *il,
191 u16 tsf_bits) 191 u16 tsf_bits)
192{ 192{
193 return ((1 << (32 - tsf_bits)) - 1) << tsf_bits; 193 return ((1 << (32 - tsf_bits)) - 1) << tsf_bits;
diff --git a/drivers/net/wireless/iwlegacy/iwl-io.h b/drivers/net/wireless/iwlegacy/iwl-io.h
index ebeb6e2aa6e7..42d241fd6ac9 100644
--- a/drivers/net/wireless/iwlegacy/iwl-io.h
+++ b/drivers/net/wireless/iwlegacy/iwl-io.h
@@ -62,72 +62,72 @@
62 * 62 *
63 */ 63 */
64 64
65static inline void _il_write8(struct il_priv *priv, u32 ofs, u8 val) 65static inline void _il_write8(struct il_priv *il, u32 ofs, u8 val)
66{ 66{
67 iowrite8(val, priv->hw_base + ofs); 67 iowrite8(val, il->hw_base + ofs);
68} 68}
69 69
70#ifdef CONFIG_IWLWIFI_LEGACY_DEBUG 70#ifdef CONFIG_IWLWIFI_LEGACY_DEBUG
71static inline void 71static inline void
72__il_write8(const char *f, u32 l, struct il_priv *priv, 72__il_write8(const char *f, u32 l, struct il_priv *il,
73 u32 ofs, u8 val) 73 u32 ofs, u8 val)
74{ 74{
75 IL_DEBUG_IO(priv, "write8(0x%08X, 0x%02X) - %s %d\n", ofs, val, f, l); 75 IL_DEBUG_IO(il, "write8(0x%08X, 0x%02X) - %s %d\n", ofs, val, f, l);
76 _il_write8(priv, ofs, val); 76 _il_write8(il, ofs, val);
77} 77}
78#define il_write8(priv, ofs, val) \ 78#define il_write8(il, ofs, val) \
79 __il_write8(__FILE__, __LINE__, priv, ofs, val) 79 __il_write8(__FILE__, __LINE__, il, ofs, val)
80#else 80#else
81#define il_write8(priv, ofs, val) _il_write8(priv, ofs, val) 81#define il_write8(il, ofs, val) _il_write8(il, ofs, val)
82#endif 82#endif
83 83
84 84
85static inline void _il_write32(struct il_priv *priv, u32 ofs, u32 val) 85static inline void _il_write32(struct il_priv *il, u32 ofs, u32 val)
86{ 86{
87 iowrite32(val, priv->hw_base + ofs); 87 iowrite32(val, il->hw_base + ofs);
88} 88}
89 89
90#ifdef CONFIG_IWLWIFI_LEGACY_DEBUG 90#ifdef CONFIG_IWLWIFI_LEGACY_DEBUG
91static inline void 91static inline void
92__il_write32(const char *f, u32 l, struct il_priv *priv, 92__il_write32(const char *f, u32 l, struct il_priv *il,
93 u32 ofs, u32 val) 93 u32 ofs, u32 val)
94{ 94{
95 IL_DEBUG_IO(priv, "write32(0x%08X, 0x%08X) - %s %d\n", ofs, val, f, l); 95 IL_DEBUG_IO(il, "write32(0x%08X, 0x%08X) - %s %d\n", ofs, val, f, l);
96 _il_write32(priv, ofs, val); 96 _il_write32(il, ofs, val);
97} 97}
98#define il_write32(priv, ofs, val) \ 98#define il_write32(il, ofs, val) \
99 __il_write32(__FILE__, __LINE__, priv, ofs, val) 99 __il_write32(__FILE__, __LINE__, il, ofs, val)
100#else 100#else
101#define il_write32(priv, ofs, val) _il_write32(priv, ofs, val) 101#define il_write32(il, ofs, val) _il_write32(il, ofs, val)
102#endif 102#endif
103 103
104static inline u32 _il_read32(struct il_priv *priv, u32 ofs) 104static inline u32 _il_read32(struct il_priv *il, u32 ofs)
105{ 105{
106 u32 val = ioread32(priv->hw_base + ofs); 106 u32 val = ioread32(il->hw_base + ofs);
107 return val; 107 return val;
108} 108}
109 109
110#ifdef CONFIG_IWLWIFI_LEGACY_DEBUG 110#ifdef CONFIG_IWLWIFI_LEGACY_DEBUG
111static inline u32 111static inline u32
112__il_read32(char *f, u32 l, struct il_priv *priv, u32 ofs) 112__il_read32(char *f, u32 l, struct il_priv *il, u32 ofs)
113{ 113{
114 IL_DEBUG_IO(priv, "read_direct32(0x%08X) - %s %d\n", ofs, f, l); 114 IL_DEBUG_IO(il, "read_direct32(0x%08X) - %s %d\n", ofs, f, l);
115 return _il_read32(priv, ofs); 115 return _il_read32(il, ofs);
116} 116}
117#define il_read32(priv, ofs) __il_read32(__FILE__, __LINE__, priv, ofs) 117#define il_read32(il, ofs) __il_read32(__FILE__, __LINE__, il, ofs)
118#else 118#else
119#define il_read32(p, o) _il_read32(p, o) 119#define il_read32(p, o) _il_read32(p, o)
120#endif 120#endif
121 121
122#define IL_POLL_INTERVAL 10 /* microseconds */ 122#define IL_POLL_INTERVAL 10 /* microseconds */
123static inline int 123static inline int
124_il_poll_bit(struct il_priv *priv, u32 addr, 124_il_poll_bit(struct il_priv *il, u32 addr,
125 u32 bits, u32 mask, int timeout) 125 u32 bits, u32 mask, int timeout)
126{ 126{
127 int t = 0; 127 int t = 0;
128 128
129 do { 129 do {
130 if ((_il_read32(priv, addr) & mask) == (bits & mask)) 130 if ((_il_read32(il, addr) & mask) == (bits & mask))
131 return t; 131 return t;
132 udelay(IL_POLL_INTERVAL); 132 udelay(IL_POLL_INTERVAL);
133 t += IL_POLL_INTERVAL; 133 t += IL_POLL_INTERVAL;
@@ -137,34 +137,34 @@ _il_poll_bit(struct il_priv *priv, u32 addr,
137} 137}
138#ifdef CONFIG_IWLWIFI_LEGACY_DEBUG 138#ifdef CONFIG_IWLWIFI_LEGACY_DEBUG
139static inline int __il_poll_bit(const char *f, u32 l, 139static inline int __il_poll_bit(const char *f, u32 l,
140 struct il_priv *priv, u32 addr, 140 struct il_priv *il, u32 addr,
141 u32 bits, u32 mask, int timeout) 141 u32 bits, u32 mask, int timeout)
142{ 142{
143 int ret = _il_poll_bit(priv, addr, bits, mask, timeout); 143 int ret = _il_poll_bit(il, addr, bits, mask, timeout);
144 IL_DEBUG_IO(priv, "poll_bit(0x%08X, 0x%08X, 0x%08X) - %s- %s %d\n", 144 IL_DEBUG_IO(il, "poll_bit(0x%08X, 0x%08X, 0x%08X) - %s- %s %d\n",
145 addr, bits, mask, 145 addr, bits, mask,
146 unlikely(ret == -ETIMEDOUT) ? "timeout" : "", f, l); 146 unlikely(ret == -ETIMEDOUT) ? "timeout" : "", f, l);
147 return ret; 147 return ret;
148} 148}
149#define il_poll_bit(priv, addr, bits, mask, timeout) \ 149#define il_poll_bit(il, addr, bits, mask, timeout) \
150 __il_poll_bit(__FILE__, __LINE__, priv, addr, \ 150 __il_poll_bit(__FILE__, __LINE__, il, addr, \
151 bits, mask, timeout) 151 bits, mask, timeout)
152#else 152#else
153#define il_poll_bit(p, a, b, m, t) _il_poll_bit(p, a, b, m, t) 153#define il_poll_bit(p, a, b, m, t) _il_poll_bit(p, a, b, m, t)
154#endif 154#endif
155 155
156static inline void _il_set_bit(struct il_priv *priv, u32 reg, u32 mask) 156static inline void _il_set_bit(struct il_priv *il, u32 reg, u32 mask)
157{ 157{
158 _il_write32(priv, reg, _il_read32(priv, reg) | mask); 158 _il_write32(il, reg, _il_read32(il, reg) | mask);
159} 159}
160#ifdef CONFIG_IWLWIFI_LEGACY_DEBUG 160#ifdef CONFIG_IWLWIFI_LEGACY_DEBUG
161static inline void __il_set_bit(const char *f, u32 l, 161static inline void __il_set_bit(const char *f, u32 l,
162 struct il_priv *priv, u32 reg, u32 mask) 162 struct il_priv *il, u32 reg, u32 mask)
163{ 163{
164 u32 val = _il_read32(priv, reg) | mask; 164 u32 val = _il_read32(il, reg) | mask;
165 IL_DEBUG_IO(priv, "set_bit(0x%08X, 0x%08X) = 0x%08X\n", reg, 165 IL_DEBUG_IO(il, "set_bit(0x%08X, 0x%08X) = 0x%08X\n", reg,
166 mask, val); 166 mask, val);
167 _il_write32(priv, reg, val); 167 _il_write32(il, reg, val);
168} 168}
169static inline void il_set_bit(struct il_priv *p, u32 r, u32 m) 169static inline void il_set_bit(struct il_priv *p, u32 r, u32 m)
170{ 170{
@@ -186,18 +186,18 @@ static inline void il_set_bit(struct il_priv *p, u32 r, u32 m)
186#endif 186#endif
187 187
188static inline void 188static inline void
189_il_clear_bit(struct il_priv *priv, u32 reg, u32 mask) 189_il_clear_bit(struct il_priv *il, u32 reg, u32 mask)
190{ 190{
191 _il_write32(priv, reg, _il_read32(priv, reg) & ~mask); 191 _il_write32(il, reg, _il_read32(il, reg) & ~mask);
192} 192}
193#ifdef CONFIG_IWLWIFI_LEGACY_DEBUG 193#ifdef CONFIG_IWLWIFI_LEGACY_DEBUG
194static inline void 194static inline void
195__il_clear_bit(const char *f, u32 l, 195__il_clear_bit(const char *f, u32 l,
196 struct il_priv *priv, u32 reg, u32 mask) 196 struct il_priv *il, u32 reg, u32 mask)
197{ 197{
198 u32 val = _il_read32(priv, reg) & ~mask; 198 u32 val = _il_read32(il, reg) & ~mask;
199 IL_DEBUG_IO(priv, "clear_bit(0x%08X, 0x%08X) = 0x%08X\n", reg, mask, val); 199 IL_DEBUG_IO(il, "clear_bit(0x%08X, 0x%08X) = 0x%08X\n", reg, mask, val);
200 _il_write32(priv, reg, val); 200 _il_write32(il, reg, val);
201} 201}
202static inline void il_clear_bit(struct il_priv *p, u32 r, u32 m) 202static inline void il_clear_bit(struct il_priv *p, u32 r, u32 m)
203{ 203{
@@ -218,13 +218,13 @@ static inline void il_clear_bit(struct il_priv *p, u32 r, u32 m)
218} 218}
219#endif 219#endif
220 220
221static inline int _il_grab_nic_access(struct il_priv *priv) 221static inline int _il_grab_nic_access(struct il_priv *il)
222{ 222{
223 int ret; 223 int ret;
224 u32 val; 224 u32 val;
225 225
226 /* this bit wakes up the NIC */ 226 /* this bit wakes up the NIC */
227 _il_set_bit(priv, CSR_GP_CNTRL, 227 _il_set_bit(il, CSR_GP_CNTRL,
228 CSR_GP_CNTRL_REG_FLAG_MAC_ACCESS_REQ); 228 CSR_GP_CNTRL_REG_FLAG_MAC_ACCESS_REQ);
229 229
230 /* 230 /*
@@ -244,15 +244,15 @@ static inline int _il_grab_nic_access(struct il_priv *priv)
244 * good idea before accessing 3945/4965 SRAM (e.g. reading Event Log). 244 * good idea before accessing 3945/4965 SRAM (e.g. reading Event Log).
245 * 245 *
246 */ 246 */
247 ret = _il_poll_bit(priv, CSR_GP_CNTRL, 247 ret = _il_poll_bit(il, CSR_GP_CNTRL,
248 CSR_GP_CNTRL_REG_VAL_MAC_ACCESS_EN, 248 CSR_GP_CNTRL_REG_VAL_MAC_ACCESS_EN,
249 (CSR_GP_CNTRL_REG_FLAG_MAC_CLOCK_READY | 249 (CSR_GP_CNTRL_REG_FLAG_MAC_CLOCK_READY |
250 CSR_GP_CNTRL_REG_FLAG_GOING_TO_SLEEP), 15000); 250 CSR_GP_CNTRL_REG_FLAG_GOING_TO_SLEEP), 15000);
251 if (ret < 0) { 251 if (ret < 0) {
252 val = _il_read32(priv, CSR_GP_CNTRL); 252 val = _il_read32(il, CSR_GP_CNTRL);
253 IL_ERR(priv, 253 IL_ERR(il,
254 "MAC is in deep sleep!. CSR_GP_CNTRL = 0x%08X\n", val); 254 "MAC is in deep sleep!. CSR_GP_CNTRL = 0x%08X\n", val);
255 _il_write32(priv, CSR_RESET, 255 _il_write32(il, CSR_RESET,
256 CSR_RESET_REG_FLAG_FORCE_NMI); 256 CSR_RESET_REG_FLAG_FORCE_NMI);
257 return -EIO; 257 return -EIO;
258 } 258 }
@@ -262,117 +262,117 @@ static inline int _il_grab_nic_access(struct il_priv *priv)
262 262
263#ifdef CONFIG_IWLWIFI_LEGACY_DEBUG 263#ifdef CONFIG_IWLWIFI_LEGACY_DEBUG
264static inline int __il_grab_nic_access(const char *f, u32 l, 264static inline int __il_grab_nic_access(const char *f, u32 l,
265 struct il_priv *priv) 265 struct il_priv *il)
266{ 266{
267 IL_DEBUG_IO(priv, "grabbing nic access - %s %d\n", f, l); 267 IL_DEBUG_IO(il, "grabbing nic access - %s %d\n", f, l);
268 return _il_grab_nic_access(priv); 268 return _il_grab_nic_access(il);
269} 269}
270#define il_grab_nic_access(priv) \ 270#define il_grab_nic_access(il) \
271 __il_grab_nic_access(__FILE__, __LINE__, priv) 271 __il_grab_nic_access(__FILE__, __LINE__, il)
272#else 272#else
273#define il_grab_nic_access(priv) \ 273#define il_grab_nic_access(il) \
274 _il_grab_nic_access(priv) 274 _il_grab_nic_access(il)
275#endif 275#endif
276 276
277static inline void _il_release_nic_access(struct il_priv *priv) 277static inline void _il_release_nic_access(struct il_priv *il)
278{ 278{
279 _il_clear_bit(priv, CSR_GP_CNTRL, 279 _il_clear_bit(il, CSR_GP_CNTRL,
280 CSR_GP_CNTRL_REG_FLAG_MAC_ACCESS_REQ); 280 CSR_GP_CNTRL_REG_FLAG_MAC_ACCESS_REQ);
281} 281}
282#ifdef CONFIG_IWLWIFI_LEGACY_DEBUG 282#ifdef CONFIG_IWLWIFI_LEGACY_DEBUG
283static inline void __il_release_nic_access(const char *f, u32 l, 283static inline void __il_release_nic_access(const char *f, u32 l,
284 struct il_priv *priv) 284 struct il_priv *il)
285{ 285{
286 286
287 IL_DEBUG_IO(priv, "releasing nic access - %s %d\n", f, l); 287 IL_DEBUG_IO(il, "releasing nic access - %s %d\n", f, l);
288 _il_release_nic_access(priv); 288 _il_release_nic_access(il);
289} 289}
290#define il_release_nic_access(priv) \ 290#define il_release_nic_access(il) \
291 __il_release_nic_access(__FILE__, __LINE__, priv) 291 __il_release_nic_access(__FILE__, __LINE__, il)
292#else 292#else
293#define il_release_nic_access(priv) \ 293#define il_release_nic_access(il) \
294 _il_release_nic_access(priv) 294 _il_release_nic_access(il)
295#endif 295#endif
296 296
297static inline u32 _il_read_direct32(struct il_priv *priv, u32 reg) 297static inline u32 _il_read_direct32(struct il_priv *il, u32 reg)
298{ 298{
299 return _il_read32(priv, reg); 299 return _il_read32(il, reg);
300} 300}
301#ifdef CONFIG_IWLWIFI_LEGACY_DEBUG 301#ifdef CONFIG_IWLWIFI_LEGACY_DEBUG
302static inline u32 __il_read_direct32(const char *f, u32 l, 302static inline u32 __il_read_direct32(const char *f, u32 l,
303 struct il_priv *priv, u32 reg) 303 struct il_priv *il, u32 reg)
304{ 304{
305 u32 value = _il_read_direct32(priv, reg); 305 u32 value = _il_read_direct32(il, reg);
306 IL_DEBUG_IO(priv, 306 IL_DEBUG_IO(il,
307 "read_direct32(0x%4X) = 0x%08x - %s %d\n", reg, value, 307 "read_direct32(0x%4X) = 0x%08x - %s %d\n", reg, value,
308 f, l); 308 f, l);
309 return value; 309 return value;
310} 310}
311static inline u32 il_read_direct32(struct il_priv *priv, u32 reg) 311static inline u32 il_read_direct32(struct il_priv *il, u32 reg)
312{ 312{
313 u32 value; 313 u32 value;
314 unsigned long reg_flags; 314 unsigned long reg_flags;
315 315
316 spin_lock_irqsave(&priv->reg_lock, reg_flags); 316 spin_lock_irqsave(&il->reg_lock, reg_flags);
317 il_grab_nic_access(priv); 317 il_grab_nic_access(il);
318 value = __il_read_direct32(__FILE__, __LINE__, priv, reg); 318 value = __il_read_direct32(__FILE__, __LINE__, il, reg);
319 il_release_nic_access(priv); 319 il_release_nic_access(il);
320 spin_unlock_irqrestore(&priv->reg_lock, reg_flags); 320 spin_unlock_irqrestore(&il->reg_lock, reg_flags);
321 return value; 321 return value;
322} 322}
323 323
324#else 324#else
325static inline u32 il_read_direct32(struct il_priv *priv, u32 reg) 325static inline u32 il_read_direct32(struct il_priv *il, u32 reg)
326{ 326{
327 u32 value; 327 u32 value;
328 unsigned long reg_flags; 328 unsigned long reg_flags;
329 329
330 spin_lock_irqsave(&priv->reg_lock, reg_flags); 330 spin_lock_irqsave(&il->reg_lock, reg_flags);
331 il_grab_nic_access(priv); 331 il_grab_nic_access(il);
332 value = _il_read_direct32(priv, reg); 332 value = _il_read_direct32(il, reg);
333 il_release_nic_access(priv); 333 il_release_nic_access(il);
334 spin_unlock_irqrestore(&priv->reg_lock, reg_flags); 334 spin_unlock_irqrestore(&il->reg_lock, reg_flags);
335 return value; 335 return value;
336 336
337} 337}
338#endif 338#endif
339 339
340static inline void _il_write_direct32(struct il_priv *priv, 340static inline void _il_write_direct32(struct il_priv *il,
341 u32 reg, u32 value) 341 u32 reg, u32 value)
342{ 342{
343 _il_write32(priv, reg, value); 343 _il_write32(il, reg, value);
344} 344}
345static inline void 345static inline void
346il_write_direct32(struct il_priv *priv, u32 reg, u32 value) 346il_write_direct32(struct il_priv *il, u32 reg, u32 value)
347{ 347{
348 unsigned long reg_flags; 348 unsigned long reg_flags;
349 349
350 spin_lock_irqsave(&priv->reg_lock, reg_flags); 350 spin_lock_irqsave(&il->reg_lock, reg_flags);
351 if (!il_grab_nic_access(priv)) { 351 if (!il_grab_nic_access(il)) {
352 _il_write_direct32(priv, reg, value); 352 _il_write_direct32(il, reg, value);
353 il_release_nic_access(priv); 353 il_release_nic_access(il);
354 } 354 }
355 spin_unlock_irqrestore(&priv->reg_lock, reg_flags); 355 spin_unlock_irqrestore(&il->reg_lock, reg_flags);
356} 356}
357 357
358static inline void il_write_reg_buf(struct il_priv *priv, 358static inline void il_write_reg_buf(struct il_priv *il,
359 u32 reg, u32 len, u32 *values) 359 u32 reg, u32 len, u32 *values)
360{ 360{
361 u32 count = sizeof(u32); 361 u32 count = sizeof(u32);
362 362
363 if ((priv != NULL) && (values != NULL)) { 363 if ((il != NULL) && (values != NULL)) {
364 for (; 0 < len; len -= count, reg += count, values++) 364 for (; 0 < len; len -= count, reg += count, values++)
365 il_write_direct32(priv, reg, *values); 365 il_write_direct32(il, reg, *values);
366 } 366 }
367} 367}
368 368
369static inline int _il_poll_direct_bit(struct il_priv *priv, u32 addr, 369static inline int _il_poll_direct_bit(struct il_priv *il, u32 addr,
370 u32 mask, int timeout) 370 u32 mask, int timeout)
371{ 371{
372 int t = 0; 372 int t = 0;
373 373
374 do { 374 do {
375 if ((il_read_direct32(priv, addr) & mask) == mask) 375 if ((il_read_direct32(il, addr) & mask) == mask)
376 return t; 376 return t;
377 udelay(IL_POLL_INTERVAL); 377 udelay(IL_POLL_INTERVAL);
378 t += IL_POLL_INTERVAL; 378 t += IL_POLL_INTERVAL;
@@ -383,159 +383,159 @@ static inline int _il_poll_direct_bit(struct il_priv *priv, u32 addr,
383 383
384#ifdef CONFIG_IWLWIFI_LEGACY_DEBUG 384#ifdef CONFIG_IWLWIFI_LEGACY_DEBUG
385static inline int __il_poll_direct_bit(const char *f, u32 l, 385static inline int __il_poll_direct_bit(const char *f, u32 l,
386 struct il_priv *priv, 386 struct il_priv *il,
387 u32 addr, u32 mask, int timeout) 387 u32 addr, u32 mask, int timeout)
388{ 388{
389 int ret = _il_poll_direct_bit(priv, addr, mask, timeout); 389 int ret = _il_poll_direct_bit(il, addr, mask, timeout);
390 390
391 if (unlikely(ret == -ETIMEDOUT)) 391 if (unlikely(ret == -ETIMEDOUT))
392 IL_DEBUG_IO(priv, "poll_direct_bit(0x%08X, 0x%08X) - " 392 IL_DEBUG_IO(il, "poll_direct_bit(0x%08X, 0x%08X) - "
393 "timedout - %s %d\n", addr, mask, f, l); 393 "timedout - %s %d\n", addr, mask, f, l);
394 else 394 else
395 IL_DEBUG_IO(priv, "poll_direct_bit(0x%08X, 0x%08X) = 0x%08X " 395 IL_DEBUG_IO(il, "poll_direct_bit(0x%08X, 0x%08X) = 0x%08X "
396 "- %s %d\n", addr, mask, ret, f, l); 396 "- %s %d\n", addr, mask, ret, f, l);
397 return ret; 397 return ret;
398} 398}
399#define il_poll_direct_bit(priv, addr, mask, timeout) \ 399#define il_poll_direct_bit(il, addr, mask, timeout) \
400__il_poll_direct_bit(__FILE__, __LINE__, priv, addr, mask, timeout) 400__il_poll_direct_bit(__FILE__, __LINE__, il, addr, mask, timeout)
401#else 401#else
402#define il_poll_direct_bit _il_poll_direct_bit 402#define il_poll_direct_bit _il_poll_direct_bit
403#endif 403#endif
404 404
405static inline u32 _il_read_prph(struct il_priv *priv, u32 reg) 405static inline u32 _il_read_prph(struct il_priv *il, u32 reg)
406{ 406{
407 _il_write_direct32(priv, HBUS_TARG_PRPH_RADDR, reg | (3 << 24)); 407 _il_write_direct32(il, HBUS_TARG_PRPH_RADDR, reg | (3 << 24));
408 rmb(); 408 rmb();
409 return _il_read_direct32(priv, HBUS_TARG_PRPH_RDAT); 409 return _il_read_direct32(il, HBUS_TARG_PRPH_RDAT);
410} 410}
411static inline u32 il_read_prph(struct il_priv *priv, u32 reg) 411static inline u32 il_read_prph(struct il_priv *il, u32 reg)
412{ 412{
413 unsigned long reg_flags; 413 unsigned long reg_flags;
414 u32 val; 414 u32 val;
415 415
416 spin_lock_irqsave(&priv->reg_lock, reg_flags); 416 spin_lock_irqsave(&il->reg_lock, reg_flags);
417 il_grab_nic_access(priv); 417 il_grab_nic_access(il);
418 val = _il_read_prph(priv, reg); 418 val = _il_read_prph(il, reg);
419 il_release_nic_access(priv); 419 il_release_nic_access(il);
420 spin_unlock_irqrestore(&priv->reg_lock, reg_flags); 420 spin_unlock_irqrestore(&il->reg_lock, reg_flags);
421 return val; 421 return val;
422} 422}
423 423
424static inline void _il_write_prph(struct il_priv *priv, 424static inline void _il_write_prph(struct il_priv *il,
425 u32 addr, u32 val) 425 u32 addr, u32 val)
426{ 426{
427 _il_write_direct32(priv, HBUS_TARG_PRPH_WADDR, 427 _il_write_direct32(il, HBUS_TARG_PRPH_WADDR,
428 ((addr & 0x0000FFFF) | (3 << 24))); 428 ((addr & 0x0000FFFF) | (3 << 24)));
429 wmb(); 429 wmb();
430 _il_write_direct32(priv, HBUS_TARG_PRPH_WDAT, val); 430 _il_write_direct32(il, HBUS_TARG_PRPH_WDAT, val);
431} 431}
432 432
433static inline void 433static inline void
434il_write_prph(struct il_priv *priv, u32 addr, u32 val) 434il_write_prph(struct il_priv *il, u32 addr, u32 val)
435{ 435{
436 unsigned long reg_flags; 436 unsigned long reg_flags;
437 437
438 spin_lock_irqsave(&priv->reg_lock, reg_flags); 438 spin_lock_irqsave(&il->reg_lock, reg_flags);
439 if (!il_grab_nic_access(priv)) { 439 if (!il_grab_nic_access(il)) {
440 _il_write_prph(priv, addr, val); 440 _il_write_prph(il, addr, val);
441 il_release_nic_access(priv); 441 il_release_nic_access(il);
442 } 442 }
443 spin_unlock_irqrestore(&priv->reg_lock, reg_flags); 443 spin_unlock_irqrestore(&il->reg_lock, reg_flags);
444} 444}
445 445
446#define _il_set_bits_prph(priv, reg, mask) \ 446#define _il_set_bits_prph(il, reg, mask) \
447_il_write_prph(priv, reg, (_il_read_prph(priv, reg) | mask)) 447_il_write_prph(il, reg, (_il_read_prph(il, reg) | mask))
448 448
449static inline void 449static inline void
450il_set_bits_prph(struct il_priv *priv, u32 reg, u32 mask) 450il_set_bits_prph(struct il_priv *il, u32 reg, u32 mask)
451{ 451{
452 unsigned long reg_flags; 452 unsigned long reg_flags;
453 453
454 spin_lock_irqsave(&priv->reg_lock, reg_flags); 454 spin_lock_irqsave(&il->reg_lock, reg_flags);
455 il_grab_nic_access(priv); 455 il_grab_nic_access(il);
456 _il_set_bits_prph(priv, reg, mask); 456 _il_set_bits_prph(il, reg, mask);
457 il_release_nic_access(priv); 457 il_release_nic_access(il);
458 spin_unlock_irqrestore(&priv->reg_lock, reg_flags); 458 spin_unlock_irqrestore(&il->reg_lock, reg_flags);
459} 459}
460 460
461#define _il_set_bits_mask_prph(priv, reg, bits, mask) \ 461#define _il_set_bits_mask_prph(il, reg, bits, mask) \
462_il_write_prph(priv, reg, \ 462_il_write_prph(il, reg, \
463 ((_il_read_prph(priv, reg) & mask) | bits)) 463 ((_il_read_prph(il, reg) & mask) | bits))
464 464
465static inline void il_set_bits_mask_prph(struct il_priv *priv, u32 reg, 465static inline void il_set_bits_mask_prph(struct il_priv *il, u32 reg,
466 u32 bits, u32 mask) 466 u32 bits, u32 mask)
467{ 467{
468 unsigned long reg_flags; 468 unsigned long reg_flags;
469 469
470 spin_lock_irqsave(&priv->reg_lock, reg_flags); 470 spin_lock_irqsave(&il->reg_lock, reg_flags);
471 il_grab_nic_access(priv); 471 il_grab_nic_access(il);
472 _il_set_bits_mask_prph(priv, reg, bits, mask); 472 _il_set_bits_mask_prph(il, reg, bits, mask);
473 il_release_nic_access(priv); 473 il_release_nic_access(il);
474 spin_unlock_irqrestore(&priv->reg_lock, reg_flags); 474 spin_unlock_irqrestore(&il->reg_lock, reg_flags);
475} 475}
476 476
477static inline void il_clear_bits_prph(struct il_priv 477static inline void il_clear_bits_prph(struct il_priv
478 *priv, u32 reg, u32 mask) 478 *il, u32 reg, u32 mask)
479{ 479{
480 unsigned long reg_flags; 480 unsigned long reg_flags;
481 u32 val; 481 u32 val;
482 482
483 spin_lock_irqsave(&priv->reg_lock, reg_flags); 483 spin_lock_irqsave(&il->reg_lock, reg_flags);
484 il_grab_nic_access(priv); 484 il_grab_nic_access(il);
485 val = _il_read_prph(priv, reg); 485 val = _il_read_prph(il, reg);
486 _il_write_prph(priv, reg, (val & ~mask)); 486 _il_write_prph(il, reg, (val & ~mask));
487 il_release_nic_access(priv); 487 il_release_nic_access(il);
488 spin_unlock_irqrestore(&priv->reg_lock, reg_flags); 488 spin_unlock_irqrestore(&il->reg_lock, reg_flags);
489} 489}
490 490
491static inline u32 il_read_targ_mem(struct il_priv *priv, u32 addr) 491static inline u32 il_read_targ_mem(struct il_priv *il, u32 addr)
492{ 492{
493 unsigned long reg_flags; 493 unsigned long reg_flags;
494 u32 value; 494 u32 value;
495 495
496 spin_lock_irqsave(&priv->reg_lock, reg_flags); 496 spin_lock_irqsave(&il->reg_lock, reg_flags);
497 il_grab_nic_access(priv); 497 il_grab_nic_access(il);
498 498
499 _il_write_direct32(priv, HBUS_TARG_MEM_RADDR, addr); 499 _il_write_direct32(il, HBUS_TARG_MEM_RADDR, addr);
500 rmb(); 500 rmb();
501 value = _il_read_direct32(priv, HBUS_TARG_MEM_RDAT); 501 value = _il_read_direct32(il, HBUS_TARG_MEM_RDAT);
502 502
503 il_release_nic_access(priv); 503 il_release_nic_access(il);
504 spin_unlock_irqrestore(&priv->reg_lock, reg_flags); 504 spin_unlock_irqrestore(&il->reg_lock, reg_flags);
505 return value; 505 return value;
506} 506}
507 507
508static inline void 508static inline void
509il_write_targ_mem(struct il_priv *priv, u32 addr, u32 val) 509il_write_targ_mem(struct il_priv *il, u32 addr, u32 val)
510{ 510{
511 unsigned long reg_flags; 511 unsigned long reg_flags;
512 512
513 spin_lock_irqsave(&priv->reg_lock, reg_flags); 513 spin_lock_irqsave(&il->reg_lock, reg_flags);
514 if (!il_grab_nic_access(priv)) { 514 if (!il_grab_nic_access(il)) {
515 _il_write_direct32(priv, HBUS_TARG_MEM_WADDR, addr); 515 _il_write_direct32(il, HBUS_TARG_MEM_WADDR, addr);
516 wmb(); 516 wmb();
517 _il_write_direct32(priv, HBUS_TARG_MEM_WDAT, val); 517 _il_write_direct32(il, HBUS_TARG_MEM_WDAT, val);
518 il_release_nic_access(priv); 518 il_release_nic_access(il);
519 } 519 }
520 spin_unlock_irqrestore(&priv->reg_lock, reg_flags); 520 spin_unlock_irqrestore(&il->reg_lock, reg_flags);
521} 521}
522 522
523static inline void 523static inline void
524il_write_targ_mem_buf(struct il_priv *priv, u32 addr, 524il_write_targ_mem_buf(struct il_priv *il, u32 addr,
525 u32 len, u32 *values) 525 u32 len, u32 *values)
526{ 526{
527 unsigned long reg_flags; 527 unsigned long reg_flags;
528 528
529 spin_lock_irqsave(&priv->reg_lock, reg_flags); 529 spin_lock_irqsave(&il->reg_lock, reg_flags);
530 if (!il_grab_nic_access(priv)) { 530 if (!il_grab_nic_access(il)) {
531 _il_write_direct32(priv, HBUS_TARG_MEM_WADDR, addr); 531 _il_write_direct32(il, HBUS_TARG_MEM_WADDR, addr);
532 wmb(); 532 wmb();
533 for (; 0 < len; len -= sizeof(u32), values++) 533 for (; 0 < len; len -= sizeof(u32), values++)
534 _il_write_direct32(priv, 534 _il_write_direct32(il,
535 HBUS_TARG_MEM_WDAT, *values); 535 HBUS_TARG_MEM_WDAT, *values);
536 536
537 il_release_nic_access(priv); 537 il_release_nic_access(il);
538 } 538 }
539 spin_unlock_irqrestore(&priv->reg_lock, reg_flags); 539 spin_unlock_irqrestore(&il->reg_lock, reg_flags);
540} 540}
541#endif 541#endif
diff --git a/drivers/net/wireless/iwlegacy/iwl-led.c b/drivers/net/wireless/iwlegacy/iwl-led.c
index 490b183b1347..13add43987b6 100644
--- a/drivers/net/wireless/iwlegacy/iwl-led.c
+++ b/drivers/net/wireless/iwlegacy/iwl-led.c
@@ -84,11 +84,11 @@ static const struct ieee80211_tpt_blink il_blink[] = {
84 * compensation = (100 - averageDeviation) * 64 / 100 84 * compensation = (100 - averageDeviation) * 64 / 100
85 * NewBlinkTime = (compensation * BlinkTime) / 64 85 * NewBlinkTime = (compensation * BlinkTime) / 64
86 */ 86 */
87static inline u8 il_blink_compensation(struct il_priv *priv, 87static inline u8 il_blink_compensation(struct il_priv *il,
88 u8 time, u16 compensation) 88 u8 time, u16 compensation)
89{ 89{
90 if (!compensation) { 90 if (!compensation) {
91 IL_ERR(priv, "undefined blink compensation: " 91 IL_ERR(il, "undefined blink compensation: "
92 "use pre-defined blinking time\n"); 92 "use pre-defined blinking time\n");
93 return time; 93 return time;
94 } 94 }
@@ -97,7 +97,7 @@ static inline u8 il_blink_compensation(struct il_priv *priv,
97} 97}
98 98
99/* Set led pattern command */ 99/* Set led pattern command */
100static int il_led_cmd(struct il_priv *priv, 100static int il_led_cmd(struct il_priv *il,
101 unsigned long on, 101 unsigned long on,
102 unsigned long off) 102 unsigned long off)
103{ 103{
@@ -107,10 +107,10 @@ static int il_led_cmd(struct il_priv *priv,
107 }; 107 };
108 int ret; 108 int ret;
109 109
110 if (!test_bit(STATUS_READY, &priv->status)) 110 if (!test_bit(STATUS_READY, &il->status))
111 return -EBUSY; 111 return -EBUSY;
112 112
113 if (priv->blink_on == on && priv->blink_off == off) 113 if (il->blink_on == on && il->blink_off == off)
114 return 0; 114 return 0;
115 115
116 if (off == 0) { 116 if (off == 0) {
@@ -118,17 +118,17 @@ static int il_led_cmd(struct il_priv *priv,
118 on = IL_LED_SOLID; 118 on = IL_LED_SOLID;
119 } 119 }
120 120
121 IL_DEBUG_LED(priv, "Led blink time compensation=%u\n", 121 IL_DEBUG_LED(il, "Led blink time compensation=%u\n",
122 priv->cfg->base_params->led_compensation); 122 il->cfg->base_params->led_compensation);
123 led_cmd.on = il_blink_compensation(priv, on, 123 led_cmd.on = il_blink_compensation(il, on,
124 priv->cfg->base_params->led_compensation); 124 il->cfg->base_params->led_compensation);
125 led_cmd.off = il_blink_compensation(priv, off, 125 led_cmd.off = il_blink_compensation(il, off,
126 priv->cfg->base_params->led_compensation); 126 il->cfg->base_params->led_compensation);
127 127
128 ret = priv->cfg->ops->led->cmd(priv, &led_cmd); 128 ret = il->cfg->ops->led->cmd(il, &led_cmd);
129 if (!ret) { 129 if (!ret) {
130 priv->blink_on = on; 130 il->blink_on = on;
131 priv->blink_off = off; 131 il->blink_off = off;
132 } 132 }
133 return ret; 133 return ret;
134} 134}
@@ -136,70 +136,70 @@ static int il_led_cmd(struct il_priv *priv,
136static void il_led_brightness_set(struct led_classdev *led_cdev, 136static void il_led_brightness_set(struct led_classdev *led_cdev,
137 enum led_brightness brightness) 137 enum led_brightness brightness)
138{ 138{
139 struct il_priv *priv = container_of(led_cdev, struct il_priv, led); 139 struct il_priv *il = container_of(led_cdev, struct il_priv, led);
140 unsigned long on = 0; 140 unsigned long on = 0;
141 141
142 if (brightness > 0) 142 if (brightness > 0)
143 on = IL_LED_SOLID; 143 on = IL_LED_SOLID;
144 144
145 il_led_cmd(priv, on, 0); 145 il_led_cmd(il, on, 0);
146} 146}
147 147
148static int il_led_blink_set(struct led_classdev *led_cdev, 148static int il_led_blink_set(struct led_classdev *led_cdev,
149 unsigned long *delay_on, 149 unsigned long *delay_on,
150 unsigned long *delay_off) 150 unsigned long *delay_off)
151{ 151{
152 struct il_priv *priv = container_of(led_cdev, struct il_priv, led); 152 struct il_priv *il = container_of(led_cdev, struct il_priv, led);
153 153
154 return il_led_cmd(priv, *delay_on, *delay_off); 154 return il_led_cmd(il, *delay_on, *delay_off);
155} 155}
156 156
157void il_leds_init(struct il_priv *priv) 157void il_leds_init(struct il_priv *il)
158{ 158{
159 int mode = led_mode; 159 int mode = led_mode;
160 int ret; 160 int ret;
161 161
162 if (mode == IL_LED_DEFAULT) 162 if (mode == IL_LED_DEFAULT)
163 mode = priv->cfg->led_mode; 163 mode = il->cfg->led_mode;
164 164
165 priv->led.name = kasprintf(GFP_KERNEL, "%s-led", 165 il->led.name = kasprintf(GFP_KERNEL, "%s-led",
166 wiphy_name(priv->hw->wiphy)); 166 wiphy_name(il->hw->wiphy));
167 priv->led.brightness_set = il_led_brightness_set; 167 il->led.brightness_set = il_led_brightness_set;
168 priv->led.blink_set = il_led_blink_set; 168 il->led.blink_set = il_led_blink_set;
169 priv->led.max_brightness = 1; 169 il->led.max_brightness = 1;
170 170
171 switch (mode) { 171 switch (mode) {
172 case IL_LED_DEFAULT: 172 case IL_LED_DEFAULT:
173 WARN_ON(1); 173 WARN_ON(1);
174 break; 174 break;
175 case IL_LED_BLINK: 175 case IL_LED_BLINK:
176 priv->led.default_trigger = 176 il->led.default_trigger =
177 ieee80211_create_tpt_led_trigger(priv->hw, 177 ieee80211_create_tpt_led_trigger(il->hw,
178 IEEE80211_TPT_LEDTRIG_FL_CONNECTED, 178 IEEE80211_TPT_LEDTRIG_FL_CONNECTED,
179 il_blink, ARRAY_SIZE(il_blink)); 179 il_blink, ARRAY_SIZE(il_blink));
180 break; 180 break;
181 case IL_LED_RF_STATE: 181 case IL_LED_RF_STATE:
182 priv->led.default_trigger = 182 il->led.default_trigger =
183 ieee80211_get_radio_led_name(priv->hw); 183 ieee80211_get_radio_led_name(il->hw);
184 break; 184 break;
185 } 185 }
186 186
187 ret = led_classdev_register(&priv->pci_dev->dev, &priv->led); 187 ret = led_classdev_register(&il->pci_dev->dev, &il->led);
188 if (ret) { 188 if (ret) {
189 kfree(priv->led.name); 189 kfree(il->led.name);
190 return; 190 return;
191 } 191 }
192 192
193 priv->led_registered = true; 193 il->led_registered = true;
194} 194}
195EXPORT_SYMBOL(il_leds_init); 195EXPORT_SYMBOL(il_leds_init);
196 196
197void il_leds_exit(struct il_priv *priv) 197void il_leds_exit(struct il_priv *il)
198{ 198{
199 if (!priv->led_registered) 199 if (!il->led_registered)
200 return; 200 return;
201 201
202 led_classdev_unregister(&priv->led); 202 led_classdev_unregister(&il->led);
203 kfree(priv->led.name); 203 kfree(il->led.name);
204} 204}
205EXPORT_SYMBOL(il_leds_exit); 205EXPORT_SYMBOL(il_leds_exit);
diff --git a/drivers/net/wireless/iwlegacy/iwl-led.h b/drivers/net/wireless/iwlegacy/iwl-led.h
index ea7a8ea23a15..d3aba57feba7 100644
--- a/drivers/net/wireless/iwlegacy/iwl-led.h
+++ b/drivers/net/wireless/iwlegacy/iwl-led.h
@@ -50,7 +50,7 @@ enum il_led_mode {
50 IL_LED_BLINK, 50 IL_LED_BLINK,
51}; 51};
52 52
53void il_leds_init(struct il_priv *priv); 53void il_leds_init(struct il_priv *il);
54void il_leds_exit(struct il_priv *priv); 54void il_leds_exit(struct il_priv *il);
55 55
56#endif /* __il_leds_h__ */ 56#endif /* __il_leds_h__ */
diff --git a/drivers/net/wireless/iwlegacy/iwl-legacy-rs.h b/drivers/net/wireless/iwlegacy/iwl-legacy-rs.h
index 72ef91e9a799..4282ed553b92 100644
--- a/drivers/net/wireless/iwlegacy/iwl-legacy-rs.h
+++ b/drivers/net/wireless/iwlegacy/iwl-legacy-rs.h
@@ -346,7 +346,7 @@ struct il_traffic_load {
346}; 346};
347 347
348/** 348/**
349 * struct il_lq_sta -- driver's rate scaling private structure 349 * struct il_lq_sta -- driver's rate scaling ilate structure
350 * 350 *
351 * Pointer to this gets passed back and forth between driver and mac80211. 351 * Pointer to this gets passed back and forth between driver and mac80211.
352 */ 352 */
@@ -400,11 +400,9 @@ struct il_lq_sta {
400 u8 is_agg; 400 u8 is_agg;
401}; 401};
402 402
403static inline u8 il4965_num_of_ant(u8 mask) 403static inline u8 il4965_num_of_ant(u8 m)
404{ 404{
405 return !!((mask) & ANT_A) + 405 return !!(m & ANT_A) + !!(m & ANT_B) + !!(m & ANT_C);
406 !!((mask) & ANT_B) +
407 !!((mask) & ANT_C);
408} 406}
409 407
410static inline u8 il4965_first_antenna(u8 mask) 408static inline u8 il4965_first_antenna(u8 mask)
@@ -426,9 +424,9 @@ static inline u8 il4965_first_antenna(u8 mask)
426extern void il3945_rate_scale_init(struct ieee80211_hw *hw, s32 sta_id); 424extern void il3945_rate_scale_init(struct ieee80211_hw *hw, s32 sta_id);
427 425
428/* Initialize station's rate scaling information after adding station */ 426/* Initialize station's rate scaling information after adding station */
429extern void il4965_rs_rate_init(struct il_priv *priv, 427extern void il4965_rs_rate_init(struct il_priv *il,
430 struct ieee80211_sta *sta, u8 sta_id); 428 struct ieee80211_sta *sta, u8 sta_id);
431extern void il3945_rs_rate_init(struct il_priv *priv, 429extern void il3945_rs_rate_init(struct il_priv *il,
432 struct ieee80211_sta *sta, u8 sta_id); 430 struct ieee80211_sta *sta, u8 sta_id);
433 431
434/** 432/**
diff --git a/drivers/net/wireless/iwlegacy/iwl-power.c b/drivers/net/wireless/iwlegacy/iwl-power.c
index 7ccff257736e..63862464fcdb 100644
--- a/drivers/net/wireless/iwlegacy/iwl-power.c
+++ b/drivers/net/wireless/iwlegacy/iwl-power.c
@@ -60,27 +60,27 @@ struct il_power_vec_entry {
60 u8 no_dtim; /* number of skip dtim */ 60 u8 no_dtim; /* number of skip dtim */
61}; 61};
62 62
63static void il_power_sleep_cam_cmd(struct il_priv *priv, 63static void il_power_sleep_cam_cmd(struct il_priv *il,
64 struct il_powertable_cmd *cmd) 64 struct il_powertable_cmd *cmd)
65{ 65{
66 memset(cmd, 0, sizeof(*cmd)); 66 memset(cmd, 0, sizeof(*cmd));
67 67
68 if (priv->power_data.pci_pm) 68 if (il->power_data.pci_pm)
69 cmd->flags |= IL_POWER_PCI_PM_MSK; 69 cmd->flags |= IL_POWER_PCI_PM_MSK;
70 70
71 IL_DEBUG_POWER(priv, "Sleep command for CAM\n"); 71 IL_DEBUG_POWER(il, "Sleep command for CAM\n");
72} 72}
73 73
74static int 74static int
75il_set_power(struct il_priv *priv, struct il_powertable_cmd *cmd) 75il_set_power(struct il_priv *il, struct il_powertable_cmd *cmd)
76{ 76{
77 IL_DEBUG_POWER(priv, "Sending power/sleep command\n"); 77 IL_DEBUG_POWER(il, "Sending power/sleep command\n");
78 IL_DEBUG_POWER(priv, "Flags value = 0x%08X\n", cmd->flags); 78 IL_DEBUG_POWER(il, "Flags value = 0x%08X\n", cmd->flags);
79 IL_DEBUG_POWER(priv, "Tx timeout = %u\n", 79 IL_DEBUG_POWER(il, "Tx timeout = %u\n",
80 le32_to_cpu(cmd->tx_data_timeout)); 80 le32_to_cpu(cmd->tx_data_timeout));
81 IL_DEBUG_POWER(priv, "Rx timeout = %u\n", 81 IL_DEBUG_POWER(il, "Rx timeout = %u\n",
82 le32_to_cpu(cmd->rx_data_timeout)); 82 le32_to_cpu(cmd->rx_data_timeout));
83 IL_DEBUG_POWER(priv, 83 IL_DEBUG_POWER(il,
84 "Sleep interval vector = { %d , %d , %d , %d , %d }\n", 84 "Sleep interval vector = { %d , %d , %d , %d , %d }\n",
85 le32_to_cpu(cmd->sleep_interval[0]), 85 le32_to_cpu(cmd->sleep_interval[0]),
86 le32_to_cpu(cmd->sleep_interval[1]), 86 le32_to_cpu(cmd->sleep_interval[1]),
@@ -88,78 +88,78 @@ il_set_power(struct il_priv *priv, struct il_powertable_cmd *cmd)
88 le32_to_cpu(cmd->sleep_interval[3]), 88 le32_to_cpu(cmd->sleep_interval[3]),
89 le32_to_cpu(cmd->sleep_interval[4])); 89 le32_to_cpu(cmd->sleep_interval[4]));
90 90
91 return il_send_cmd_pdu(priv, POWER_TABLE_CMD, 91 return il_send_cmd_pdu(il, POWER_TABLE_CMD,
92 sizeof(struct il_powertable_cmd), cmd); 92 sizeof(struct il_powertable_cmd), cmd);
93} 93}
94 94
95int 95int
96il_power_set_mode(struct il_priv *priv, struct il_powertable_cmd *cmd, 96il_power_set_mode(struct il_priv *il, struct il_powertable_cmd *cmd,
97 bool force) 97 bool force)
98{ 98{
99 int ret; 99 int ret;
100 bool update_chains; 100 bool update_chains;
101 101
102 lockdep_assert_held(&priv->mutex); 102 lockdep_assert_held(&il->mutex);
103 103
104 /* Don't update the RX chain when chain noise calibration is running */ 104 /* Don't update the RX chain when chain noise calibration is running */
105 update_chains = priv->chain_noise_data.state == IL_CHAIN_NOISE_DONE || 105 update_chains = il->chain_noise_data.state == IL_CHAIN_NOISE_DONE ||
106 priv->chain_noise_data.state == IL_CHAIN_NOISE_ALIVE; 106 il->chain_noise_data.state == IL_CHAIN_NOISE_ALIVE;
107 107
108 if (!memcmp(&priv->power_data.sleep_cmd, cmd, sizeof(*cmd)) && !force) 108 if (!memcmp(&il->power_data.sleep_cmd, cmd, sizeof(*cmd)) && !force)
109 return 0; 109 return 0;
110 110
111 if (!il_is_ready_rf(priv)) 111 if (!il_is_ready_rf(il))
112 return -EIO; 112 return -EIO;
113 113
114 /* scan complete use sleep_power_next, need to be updated */ 114 /* scan complete use sleep_power_next, need to be updated */
115 memcpy(&priv->power_data.sleep_cmd_next, cmd, sizeof(*cmd)); 115 memcpy(&il->power_data.sleep_cmd_next, cmd, sizeof(*cmd));
116 if (test_bit(STATUS_SCANNING, &priv->status) && !force) { 116 if (test_bit(STATUS_SCANNING, &il->status) && !force) {
117 IL_DEBUG_INFO(priv, "Defer power set mode while scanning\n"); 117 IL_DEBUG_INFO(il, "Defer power set mode while scanning\n");
118 return 0; 118 return 0;
119 } 119 }
120 120
121 if (cmd->flags & IL_POWER_DRIVER_ALLOW_SLEEP_MSK) 121 if (cmd->flags & IL_POWER_DRIVER_ALLOW_SLEEP_MSK)
122 set_bit(STATUS_POWER_PMI, &priv->status); 122 set_bit(STATUS_POWER_PMI, &il->status);
123 123
124 ret = il_set_power(priv, cmd); 124 ret = il_set_power(il, cmd);
125 if (!ret) { 125 if (!ret) {
126 if (!(cmd->flags & IL_POWER_DRIVER_ALLOW_SLEEP_MSK)) 126 if (!(cmd->flags & IL_POWER_DRIVER_ALLOW_SLEEP_MSK))
127 clear_bit(STATUS_POWER_PMI, &priv->status); 127 clear_bit(STATUS_POWER_PMI, &il->status);
128 128
129 if (priv->cfg->ops->lib->update_chain_flags && update_chains) 129 if (il->cfg->ops->lib->update_chain_flags && update_chains)
130 priv->cfg->ops->lib->update_chain_flags(priv); 130 il->cfg->ops->lib->update_chain_flags(il);
131 else if (priv->cfg->ops->lib->update_chain_flags) 131 else if (il->cfg->ops->lib->update_chain_flags)
132 IL_DEBUG_POWER(priv, 132 IL_DEBUG_POWER(il,
133 "Cannot update the power, chain noise " 133 "Cannot update the power, chain noise "
134 "calibration running: %d\n", 134 "calibration running: %d\n",
135 priv->chain_noise_data.state); 135 il->chain_noise_data.state);
136 136
137 memcpy(&priv->power_data.sleep_cmd, cmd, sizeof(*cmd)); 137 memcpy(&il->power_data.sleep_cmd, cmd, sizeof(*cmd));
138 } else 138 } else
139 IL_ERR(priv, "set power fail, ret = %d", ret); 139 IL_ERR(il, "set power fail, ret = %d", ret);
140 140
141 return ret; 141 return ret;
142} 142}
143 143
144int il_power_update_mode(struct il_priv *priv, bool force) 144int il_power_update_mode(struct il_priv *il, bool force)
145{ 145{
146 struct il_powertable_cmd cmd; 146 struct il_powertable_cmd cmd;
147 147
148 il_power_sleep_cam_cmd(priv, &cmd); 148 il_power_sleep_cam_cmd(il, &cmd);
149 return il_power_set_mode(priv, &cmd, force); 149 return il_power_set_mode(il, &cmd, force);
150} 150}
151EXPORT_SYMBOL(il_power_update_mode); 151EXPORT_SYMBOL(il_power_update_mode);
152 152
153/* initialize to default */ 153/* initialize to default */
154void il_power_initialize(struct il_priv *priv) 154void il_power_initialize(struct il_priv *il)
155{ 155{
156 u16 lctl = il_pcie_link_ctl(priv); 156 u16 lctl = il_pcie_link_ctl(il);
157 157
158 priv->power_data.pci_pm = !(lctl & PCI_CFG_LINK_CTRL_VAL_L0S_EN); 158 il->power_data.pci_pm = !(lctl & PCI_CFG_LINK_CTRL_VAL_L0S_EN);
159 159
160 priv->power_data.debug_sleep_level_override = -1; 160 il->power_data.debug_sleep_level_override = -1;
161 161
162 memset(&priv->power_data.sleep_cmd, 0, 162 memset(&il->power_data.sleep_cmd, 0,
163 sizeof(priv->power_data.sleep_cmd)); 163 sizeof(il->power_data.sleep_cmd));
164} 164}
165EXPORT_SYMBOL(il_power_initialize); 165EXPORT_SYMBOL(il_power_initialize);
diff --git a/drivers/net/wireless/iwlegacy/iwl-power.h b/drivers/net/wireless/iwlegacy/iwl-power.h
index dba4ca9d30eb..e149f789063f 100644
--- a/drivers/net/wireless/iwlegacy/iwl-power.h
+++ b/drivers/net/wireless/iwlegacy/iwl-power.h
@@ -47,9 +47,9 @@ struct il_power_mgr {
47}; 47};
48 48
49int 49int
50il_power_set_mode(struct il_priv *priv, struct il_powertable_cmd *cmd, 50il_power_set_mode(struct il_priv *il, struct il_powertable_cmd *cmd,
51 bool force); 51 bool force);
52int il_power_update_mode(struct il_priv *priv, bool force); 52int il_power_update_mode(struct il_priv *il, bool force);
53void il_power_initialize(struct il_priv *priv); 53void il_power_initialize(struct il_priv *il);
54 54
55#endif /* __il_power_setting_h__ */ 55#endif /* __il_power_setting_h__ */
diff --git a/drivers/net/wireless/iwlegacy/iwl-rx.c b/drivers/net/wireless/iwlegacy/iwl-rx.c
index 9a2714c7f3e8..b6c5dd09bd8b 100644
--- a/drivers/net/wireless/iwlegacy/iwl-rx.c
+++ b/drivers/net/wireless/iwlegacy/iwl-rx.c
@@ -124,11 +124,11 @@ EXPORT_SYMBOL(il_rx_queue_space);
124 * il_rx_queue_update_write_ptr - Update the write pointer for the RX queue 124 * il_rx_queue_update_write_ptr - Update the write pointer for the RX queue
125 */ 125 */
126void 126void
127il_rx_queue_update_write_ptr(struct il_priv *priv, 127il_rx_queue_update_write_ptr(struct il_priv *il,
128 struct il_rx_queue *q) 128 struct il_rx_queue *q)
129{ 129{
130 unsigned long flags; 130 unsigned long flags;
131 u32 rx_wrt_ptr_reg = priv->hw_params.rx_wrt_ptr_reg; 131 u32 rx_wrt_ptr_reg = il->hw_params.rx_wrt_ptr_reg;
132 u32 reg; 132 u32 reg;
133 133
134 spin_lock_irqsave(&q->lock, flags); 134 spin_lock_irqsave(&q->lock, flags);
@@ -137,27 +137,27 @@ il_rx_queue_update_write_ptr(struct il_priv *priv,
137 goto exit_unlock; 137 goto exit_unlock;
138 138
139 /* If power-saving is in use, make sure device is awake */ 139 /* If power-saving is in use, make sure device is awake */
140 if (test_bit(STATUS_POWER_PMI, &priv->status)) { 140 if (test_bit(STATUS_POWER_PMI, &il->status)) {
141 reg = il_read32(priv, CSR_UCODE_DRV_GP1); 141 reg = il_read32(il, CSR_UCODE_DRV_GP1);
142 142
143 if (reg & CSR_UCODE_DRV_GP1_BIT_MAC_SLEEP) { 143 if (reg & CSR_UCODE_DRV_GP1_BIT_MAC_SLEEP) {
144 IL_DEBUG_INFO(priv, 144 IL_DEBUG_INFO(il,
145 "Rx queue requesting wakeup," 145 "Rx queue requesting wakeup,"
146 " GP1 = 0x%x\n", reg); 146 " GP1 = 0x%x\n", reg);
147 il_set_bit(priv, CSR_GP_CNTRL, 147 il_set_bit(il, CSR_GP_CNTRL,
148 CSR_GP_CNTRL_REG_FLAG_MAC_ACCESS_REQ); 148 CSR_GP_CNTRL_REG_FLAG_MAC_ACCESS_REQ);
149 goto exit_unlock; 149 goto exit_unlock;
150 } 150 }
151 151
152 q->write_actual = (q->write & ~0x7); 152 q->write_actual = (q->write & ~0x7);
153 il_write_direct32(priv, rx_wrt_ptr_reg, 153 il_write_direct32(il, rx_wrt_ptr_reg,
154 q->write_actual); 154 q->write_actual);
155 155
156 /* Else device is assumed to be awake */ 156 /* Else device is assumed to be awake */
157 } else { 157 } else {
158 /* Device expects a multiple of 8 */ 158 /* Device expects a multiple of 8 */
159 q->write_actual = (q->write & ~0x7); 159 q->write_actual = (q->write & ~0x7);
160 il_write_direct32(priv, rx_wrt_ptr_reg, 160 il_write_direct32(il, rx_wrt_ptr_reg,
161 q->write_actual); 161 q->write_actual);
162 } 162 }
163 163
@@ -168,10 +168,10 @@ il_rx_queue_update_write_ptr(struct il_priv *priv,
168} 168}
169EXPORT_SYMBOL(il_rx_queue_update_write_ptr); 169EXPORT_SYMBOL(il_rx_queue_update_write_ptr);
170 170
171int il_rx_queue_alloc(struct il_priv *priv) 171int il_rx_queue_alloc(struct il_priv *il)
172{ 172{
173 struct il_rx_queue *rxq = &priv->rxq; 173 struct il_rx_queue *rxq = &il->rxq;
174 struct device *dev = &priv->pci_dev->dev; 174 struct device *dev = &il->pci_dev->dev;
175 int i; 175 int i;
176 176
177 spin_lock_init(&rxq->lock); 177 spin_lock_init(&rxq->lock);
@@ -202,7 +202,7 @@ int il_rx_queue_alloc(struct il_priv *priv)
202 return 0; 202 return 0;
203 203
204err_rb: 204err_rb:
205 dma_free_coherent(&priv->pci_dev->dev, 4 * RX_QUEUE_SIZE, rxq->bd, 205 dma_free_coherent(&il->pci_dev->dev, 4 * RX_QUEUE_SIZE, rxq->bd,
206 rxq->bd_dma); 206 rxq->bd_dma);
207err_bd: 207err_bd:
208 return -ENOMEM; 208 return -ENOMEM;
@@ -210,27 +210,27 @@ err_bd:
210EXPORT_SYMBOL(il_rx_queue_alloc); 210EXPORT_SYMBOL(il_rx_queue_alloc);
211 211
212 212
213void il_rx_spectrum_measure_notif(struct il_priv *priv, 213void il_rx_spectrum_measure_notif(struct il_priv *il,
214 struct il_rx_mem_buffer *rxb) 214 struct il_rx_mem_buffer *rxb)
215{ 215{
216 struct il_rx_packet *pkt = rxb_addr(rxb); 216 struct il_rx_packet *pkt = rxb_addr(rxb);
217 struct il_spectrum_notification *report = &(pkt->u.spectrum_notif); 217 struct il_spectrum_notification *report = &(pkt->u.spectrum_notif);
218 218
219 if (!report->state) { 219 if (!report->state) {
220 IL_DEBUG_11H(priv, 220 IL_DEBUG_11H(il,
221 "Spectrum Measure Notification: Start\n"); 221 "Spectrum Measure Notification: Start\n");
222 return; 222 return;
223 } 223 }
224 224
225 memcpy(&priv->measure_report, report, sizeof(*report)); 225 memcpy(&il->measure_report, report, sizeof(*report));
226 priv->measurement_status |= MEASUREMENT_READY; 226 il->measurement_status |= MEASUREMENT_READY;
227} 227}
228EXPORT_SYMBOL(il_rx_spectrum_measure_notif); 228EXPORT_SYMBOL(il_rx_spectrum_measure_notif);
229 229
230/* 230/*
231 * returns non-zero if packet should be dropped 231 * returns non-zero if packet should be dropped
232 */ 232 */
233int il_set_decrypted_flag(struct il_priv *priv, 233int il_set_decrypted_flag(struct il_priv *il,
234 struct ieee80211_hdr *hdr, 234 struct ieee80211_hdr *hdr,
235 u32 decrypt_res, 235 u32 decrypt_res,
236 struct ieee80211_rx_status *stats) 236 struct ieee80211_rx_status *stats)
@@ -241,14 +241,14 @@ int il_set_decrypted_flag(struct il_priv *priv,
241 * All contexts have the same setting here due to it being 241 * All contexts have the same setting here due to it being
242 * a module parameter, so OK to check any context. 242 * a module parameter, so OK to check any context.
243 */ 243 */
244 if (priv->contexts[IL_RXON_CTX_BSS].active.filter_flags & 244 if (il->contexts[IL_RXON_CTX_BSS].active.filter_flags &
245 RXON_FILTER_DIS_DECRYPT_MSK) 245 RXON_FILTER_DIS_DECRYPT_MSK)
246 return 0; 246 return 0;
247 247
248 if (!(fc & IEEE80211_FCTL_PROTECTED)) 248 if (!(fc & IEEE80211_FCTL_PROTECTED))
249 return 0; 249 return 0;
250 250
251 IL_DEBUG_RX(priv, "decrypt_res:0x%x\n", decrypt_res); 251 IL_DEBUG_RX(il, "decrypt_res:0x%x\n", decrypt_res);
252 switch (decrypt_res & RX_RES_STATUS_SEC_TYPE_MSK) { 252 switch (decrypt_res & RX_RES_STATUS_SEC_TYPE_MSK) {
253 case RX_RES_STATUS_SEC_TYPE_TKIP: 253 case RX_RES_STATUS_SEC_TYPE_TKIP:
254 /* The uCode has got a bad phase 1 Key, pushes the packet. 254 /* The uCode has got a bad phase 1 Key, pushes the packet.
@@ -262,13 +262,13 @@ int il_set_decrypted_flag(struct il_priv *priv,
262 RX_RES_STATUS_BAD_ICV_MIC) { 262 RX_RES_STATUS_BAD_ICV_MIC) {
263 /* bad ICV, the packet is destroyed since the 263 /* bad ICV, the packet is destroyed since the
264 * decryption is inplace, drop it */ 264 * decryption is inplace, drop it */
265 IL_DEBUG_RX(priv, "Packet destroyed\n"); 265 IL_DEBUG_RX(il, "Packet destroyed\n");
266 return -1; 266 return -1;
267 } 267 }
268 case RX_RES_STATUS_SEC_TYPE_CCMP: 268 case RX_RES_STATUS_SEC_TYPE_CCMP:
269 if ((decrypt_res & RX_RES_STATUS_DECRYPT_TYPE_MSK) == 269 if ((decrypt_res & RX_RES_STATUS_DECRYPT_TYPE_MSK) ==
270 RX_RES_STATUS_DECRYPT_OK) { 270 RX_RES_STATUS_DECRYPT_OK) {
271 IL_DEBUG_RX(priv, "hw decrypt successfully!!!\n"); 271 IL_DEBUG_RX(il, "hw decrypt successfully!!!\n");
272 stats->flag |= RX_FLAG_DECRYPTED; 272 stats->flag |= RX_FLAG_DECRYPTED;
273 } 273 }
274 break; 274 break;
diff --git a/drivers/net/wireless/iwlegacy/iwl-scan.c b/drivers/net/wireless/iwlegacy/iwl-scan.c
index 93e939cc9bc6..0184d5bf04e2 100644
--- a/drivers/net/wireless/iwlegacy/iwl-scan.c
+++ b/drivers/net/wireless/iwlegacy/iwl-scan.c
@@ -54,7 +54,7 @@
54#define IL_PASSIVE_DWELL_BASE (100) 54#define IL_PASSIVE_DWELL_BASE (100)
55#define IL_CHANNEL_TUNE_TIME 5 55#define IL_CHANNEL_TUNE_TIME 5
56 56
57static int il_send_scan_abort(struct il_priv *priv) 57static int il_send_scan_abort(struct il_priv *il)
58{ 58{
59 int ret; 59 int ret;
60 struct il_rx_packet *pkt; 60 struct il_rx_packet *pkt;
@@ -66,14 +66,14 @@ static int il_send_scan_abort(struct il_priv *priv)
66 /* Exit instantly with error when device is not ready 66 /* Exit instantly with error when device is not ready
67 * to receive scan abort command or it does not perform 67 * to receive scan abort command or it does not perform
68 * hardware scan currently */ 68 * hardware scan currently */
69 if (!test_bit(STATUS_READY, &priv->status) || 69 if (!test_bit(STATUS_READY, &il->status) ||
70 !test_bit(STATUS_GEO_CONFIGURED, &priv->status) || 70 !test_bit(STATUS_GEO_CONFIGURED, &il->status) ||
71 !test_bit(STATUS_SCAN_HW, &priv->status) || 71 !test_bit(STATUS_SCAN_HW, &il->status) ||
72 test_bit(STATUS_FW_ERROR, &priv->status) || 72 test_bit(STATUS_FW_ERROR, &il->status) ||
73 test_bit(STATUS_EXIT_PENDING, &priv->status)) 73 test_bit(STATUS_EXIT_PENDING, &il->status))
74 return -EIO; 74 return -EIO;
75 75
76 ret = il_send_cmd_sync(priv, &cmd); 76 ret = il_send_cmd_sync(il, &cmd);
77 if (ret) 77 if (ret)
78 return ret; 78 return ret;
79 79
@@ -85,73 +85,73 @@ static int il_send_scan_abort(struct il_priv *priv)
85 * can occur if we send the scan abort before we 85 * can occur if we send the scan abort before we
86 * the microcode has notified us that a scan is 86 * the microcode has notified us that a scan is
87 * completed. */ 87 * completed. */
88 IL_DEBUG_SCAN(priv, "SCAN_ABORT ret %d.\n", pkt->u.status); 88 IL_DEBUG_SCAN(il, "SCAN_ABORT ret %d.\n", pkt->u.status);
89 ret = -EIO; 89 ret = -EIO;
90 } 90 }
91 91
92 il_free_pages(priv, cmd.reply_page); 92 il_free_pages(il, cmd.reply_page);
93 return ret; 93 return ret;
94} 94}
95 95
96static void il_complete_scan(struct il_priv *priv, bool aborted) 96static void il_complete_scan(struct il_priv *il, bool aborted)
97{ 97{
98 /* check if scan was requested from mac80211 */ 98 /* check if scan was requested from mac80211 */
99 if (priv->scan_request) { 99 if (il->scan_request) {
100 IL_DEBUG_SCAN(priv, "Complete scan in mac80211\n"); 100 IL_DEBUG_SCAN(il, "Complete scan in mac80211\n");
101 ieee80211_scan_completed(priv->hw, aborted); 101 ieee80211_scan_completed(il->hw, aborted);
102 } 102 }
103 103
104 priv->scan_vif = NULL; 104 il->scan_vif = NULL;
105 priv->scan_request = NULL; 105 il->scan_request = NULL;
106} 106}
107 107
108void il_force_scan_end(struct il_priv *priv) 108void il_force_scan_end(struct il_priv *il)
109{ 109{
110 lockdep_assert_held(&priv->mutex); 110 lockdep_assert_held(&il->mutex);
111 111
112 if (!test_bit(STATUS_SCANNING, &priv->status)) { 112 if (!test_bit(STATUS_SCANNING, &il->status)) {
113 IL_DEBUG_SCAN(priv, "Forcing scan end while not scanning\n"); 113 IL_DEBUG_SCAN(il, "Forcing scan end while not scanning\n");
114 return; 114 return;
115 } 115 }
116 116
117 IL_DEBUG_SCAN(priv, "Forcing scan end\n"); 117 IL_DEBUG_SCAN(il, "Forcing scan end\n");
118 clear_bit(STATUS_SCANNING, &priv->status); 118 clear_bit(STATUS_SCANNING, &il->status);
119 clear_bit(STATUS_SCAN_HW, &priv->status); 119 clear_bit(STATUS_SCAN_HW, &il->status);
120 clear_bit(STATUS_SCAN_ABORTING, &priv->status); 120 clear_bit(STATUS_SCAN_ABORTING, &il->status);
121 il_complete_scan(priv, true); 121 il_complete_scan(il, true);
122} 122}
123 123
124static void il_do_scan_abort(struct il_priv *priv) 124static void il_do_scan_abort(struct il_priv *il)
125{ 125{
126 int ret; 126 int ret;
127 127
128 lockdep_assert_held(&priv->mutex); 128 lockdep_assert_held(&il->mutex);
129 129
130 if (!test_bit(STATUS_SCANNING, &priv->status)) { 130 if (!test_bit(STATUS_SCANNING, &il->status)) {
131 IL_DEBUG_SCAN(priv, "Not performing scan to abort\n"); 131 IL_DEBUG_SCAN(il, "Not performing scan to abort\n");
132 return; 132 return;
133 } 133 }
134 134
135 if (test_and_set_bit(STATUS_SCAN_ABORTING, &priv->status)) { 135 if (test_and_set_bit(STATUS_SCAN_ABORTING, &il->status)) {
136 IL_DEBUG_SCAN(priv, "Scan abort in progress\n"); 136 IL_DEBUG_SCAN(il, "Scan abort in progress\n");
137 return; 137 return;
138 } 138 }
139 139
140 ret = il_send_scan_abort(priv); 140 ret = il_send_scan_abort(il);
141 if (ret) { 141 if (ret) {
142 IL_DEBUG_SCAN(priv, "Send scan abort failed %d\n", ret); 142 IL_DEBUG_SCAN(il, "Send scan abort failed %d\n", ret);
143 il_force_scan_end(priv); 143 il_force_scan_end(il);
144 } else 144 } else
145 IL_DEBUG_SCAN(priv, "Successfully send scan abort\n"); 145 IL_DEBUG_SCAN(il, "Successfully send scan abort\n");
146} 146}
147 147
148/** 148/**
149 * il_scan_cancel - Cancel any currently executing HW scan 149 * il_scan_cancel - Cancel any currently executing HW scan
150 */ 150 */
151int il_scan_cancel(struct il_priv *priv) 151int il_scan_cancel(struct il_priv *il)
152{ 152{
153 IL_DEBUG_SCAN(priv, "Queuing abort scan\n"); 153 IL_DEBUG_SCAN(il, "Queuing abort scan\n");
154 queue_work(priv->workqueue, &priv->abort_scan); 154 queue_work(il->workqueue, &il->abort_scan);
155 return 0; 155 return 0;
156} 156}
157EXPORT_SYMBOL(il_scan_cancel); 157EXPORT_SYMBOL(il_scan_cancel);
@@ -161,28 +161,28 @@ EXPORT_SYMBOL(il_scan_cancel);
161 * @ms: amount of time to wait (in milliseconds) for scan to abort 161 * @ms: amount of time to wait (in milliseconds) for scan to abort
162 * 162 *
163 */ 163 */
164int il_scan_cancel_timeout(struct il_priv *priv, unsigned long ms) 164int il_scan_cancel_timeout(struct il_priv *il, unsigned long ms)
165{ 165{
166 unsigned long timeout = jiffies + msecs_to_jiffies(ms); 166 unsigned long timeout = jiffies + msecs_to_jiffies(ms);
167 167
168 lockdep_assert_held(&priv->mutex); 168 lockdep_assert_held(&il->mutex);
169 169
170 IL_DEBUG_SCAN(priv, "Scan cancel timeout\n"); 170 IL_DEBUG_SCAN(il, "Scan cancel timeout\n");
171 171
172 il_do_scan_abort(priv); 172 il_do_scan_abort(il);
173 173
174 while (time_before_eq(jiffies, timeout)) { 174 while (time_before_eq(jiffies, timeout)) {
175 if (!test_bit(STATUS_SCAN_HW, &priv->status)) 175 if (!test_bit(STATUS_SCAN_HW, &il->status))
176 break; 176 break;
177 msleep(20); 177 msleep(20);
178 } 178 }
179 179
180 return test_bit(STATUS_SCAN_HW, &priv->status); 180 return test_bit(STATUS_SCAN_HW, &il->status);
181} 181}
182EXPORT_SYMBOL(il_scan_cancel_timeout); 182EXPORT_SYMBOL(il_scan_cancel_timeout);
183 183
184/* Service response to REPLY_SCAN_CMD (0x80) */ 184/* Service response to REPLY_SCAN_CMD (0x80) */
185static void il_rx_reply_scan(struct il_priv *priv, 185static void il_rx_reply_scan(struct il_priv *il,
186 struct il_rx_mem_buffer *rxb) 186 struct il_rx_mem_buffer *rxb)
187{ 187{
188#ifdef CONFIG_IWLWIFI_LEGACY_DEBUG 188#ifdef CONFIG_IWLWIFI_LEGACY_DEBUG
@@ -190,19 +190,19 @@ static void il_rx_reply_scan(struct il_priv *priv,
190 struct il_scanreq_notification *notif = 190 struct il_scanreq_notification *notif =
191 (struct il_scanreq_notification *)pkt->u.raw; 191 (struct il_scanreq_notification *)pkt->u.raw;
192 192
193 IL_DEBUG_SCAN(priv, "Scan request status = 0x%x\n", notif->status); 193 IL_DEBUG_SCAN(il, "Scan request status = 0x%x\n", notif->status);
194#endif 194#endif
195} 195}
196 196
197/* Service SCAN_START_NOTIFICATION (0x82) */ 197/* Service SCAN_START_NOTIFICATION (0x82) */
198static void il_rx_scan_start_notif(struct il_priv *priv, 198static void il_rx_scan_start_notif(struct il_priv *il,
199 struct il_rx_mem_buffer *rxb) 199 struct il_rx_mem_buffer *rxb)
200{ 200{
201 struct il_rx_packet *pkt = rxb_addr(rxb); 201 struct il_rx_packet *pkt = rxb_addr(rxb);
202 struct il_scanstart_notification *notif = 202 struct il_scanstart_notification *notif =
203 (struct il_scanstart_notification *)pkt->u.raw; 203 (struct il_scanstart_notification *)pkt->u.raw;
204 priv->scan_start_tsf = le32_to_cpu(notif->tsf_low); 204 il->scan_start_tsf = le32_to_cpu(notif->tsf_low);
205 IL_DEBUG_SCAN(priv, "Scan start: " 205 IL_DEBUG_SCAN(il, "Scan start: "
206 "%d [802.11%s] " 206 "%d [802.11%s] "
207 "(TSF: 0x%08X:%08X) - %d (beacon timer %u)\n", 207 "(TSF: 0x%08X:%08X) - %d (beacon timer %u)\n",
208 notif->channel, 208 notif->channel,
@@ -213,7 +213,7 @@ static void il_rx_scan_start_notif(struct il_priv *priv,
213} 213}
214 214
215/* Service SCAN_RESULTS_NOTIFICATION (0x83) */ 215/* Service SCAN_RESULTS_NOTIFICATION (0x83) */
216static void il_rx_scan_results_notif(struct il_priv *priv, 216static void il_rx_scan_results_notif(struct il_priv *il,
217 struct il_rx_mem_buffer *rxb) 217 struct il_rx_mem_buffer *rxb)
218{ 218{
219#ifdef CONFIG_IWLWIFI_LEGACY_DEBUG 219#ifdef CONFIG_IWLWIFI_LEGACY_DEBUG
@@ -221,7 +221,7 @@ static void il_rx_scan_results_notif(struct il_priv *priv,
221 struct il_scanresults_notification *notif = 221 struct il_scanresults_notification *notif =
222 (struct il_scanresults_notification *)pkt->u.raw; 222 (struct il_scanresults_notification *)pkt->u.raw;
223 223
224 IL_DEBUG_SCAN(priv, "Scan ch.res: " 224 IL_DEBUG_SCAN(il, "Scan ch.res: "
225 "%d [802.11%s] " 225 "%d [802.11%s] "
226 "(TSF: 0x%08X:%08X) - %d " 226 "(TSF: 0x%08X:%08X) - %d "
227 "elapsed=%lu usec\n", 227 "elapsed=%lu usec\n",
@@ -230,12 +230,12 @@ static void il_rx_scan_results_notif(struct il_priv *priv,
230 le32_to_cpu(notif->tsf_high), 230 le32_to_cpu(notif->tsf_high),
231 le32_to_cpu(notif->tsf_low), 231 le32_to_cpu(notif->tsf_low),
232 le32_to_cpu(notif->statistics[0]), 232 le32_to_cpu(notif->statistics[0]),
233 le32_to_cpu(notif->tsf_low) - priv->scan_start_tsf); 233 le32_to_cpu(notif->tsf_low) - il->scan_start_tsf);
234#endif 234#endif
235} 235}
236 236
237/* Service SCAN_COMPLETE_NOTIFICATION (0x84) */ 237/* Service SCAN_COMPLETE_NOTIFICATION (0x84) */
238static void il_rx_scan_complete_notif(struct il_priv *priv, 238static void il_rx_scan_complete_notif(struct il_priv *il,
239 struct il_rx_mem_buffer *rxb) 239 struct il_rx_mem_buffer *rxb)
240{ 240{
241 241
@@ -244,36 +244,36 @@ static void il_rx_scan_complete_notif(struct il_priv *priv,
244 struct il_scancomplete_notification *scan_notif = (void *)pkt->u.raw; 244 struct il_scancomplete_notification *scan_notif = (void *)pkt->u.raw;
245#endif 245#endif
246 246
247 IL_DEBUG_SCAN(priv, 247 IL_DEBUG_SCAN(il,
248 "Scan complete: %d channels (TSF 0x%08X:%08X) - %d\n", 248 "Scan complete: %d channels (TSF 0x%08X:%08X) - %d\n",
249 scan_notif->scanned_channels, 249 scan_notif->scanned_channels,
250 scan_notif->tsf_low, 250 scan_notif->tsf_low,
251 scan_notif->tsf_high, scan_notif->status); 251 scan_notif->tsf_high, scan_notif->status);
252 252
253 /* The HW is no longer scanning */ 253 /* The HW is no longer scanning */
254 clear_bit(STATUS_SCAN_HW, &priv->status); 254 clear_bit(STATUS_SCAN_HW, &il->status);
255 255
256 IL_DEBUG_SCAN(priv, "Scan on %sGHz took %dms\n", 256 IL_DEBUG_SCAN(il, "Scan on %sGHz took %dms\n",
257 (priv->scan_band == IEEE80211_BAND_2GHZ) ? "2.4" : "5.2", 257 (il->scan_band == IEEE80211_BAND_2GHZ) ? "2.4" : "5.2",
258 jiffies_to_msecs(jiffies - priv->scan_start)); 258 jiffies_to_msecs(jiffies - il->scan_start));
259 259
260 queue_work(priv->workqueue, &priv->scan_completed); 260 queue_work(il->workqueue, &il->scan_completed);
261} 261}
262 262
263void il_setup_rx_scan_handlers(struct il_priv *priv) 263void il_setup_rx_scan_handlers(struct il_priv *il)
264{ 264{
265 /* scan handlers */ 265 /* scan handlers */
266 priv->rx_handlers[REPLY_SCAN_CMD] = il_rx_reply_scan; 266 il->rx_handlers[REPLY_SCAN_CMD] = il_rx_reply_scan;
267 priv->rx_handlers[SCAN_START_NOTIFICATION] = 267 il->rx_handlers[SCAN_START_NOTIFICATION] =
268 il_rx_scan_start_notif; 268 il_rx_scan_start_notif;
269 priv->rx_handlers[SCAN_RESULTS_NOTIFICATION] = 269 il->rx_handlers[SCAN_RESULTS_NOTIFICATION] =
270 il_rx_scan_results_notif; 270 il_rx_scan_results_notif;
271 priv->rx_handlers[SCAN_COMPLETE_NOTIFICATION] = 271 il->rx_handlers[SCAN_COMPLETE_NOTIFICATION] =
272 il_rx_scan_complete_notif; 272 il_rx_scan_complete_notif;
273} 273}
274EXPORT_SYMBOL(il_setup_rx_scan_handlers); 274EXPORT_SYMBOL(il_setup_rx_scan_handlers);
275 275
276inline u16 il_get_active_dwell_time(struct il_priv *priv, 276inline u16 il_get_active_dwell_time(struct il_priv *il,
277 enum ieee80211_band band, 277 enum ieee80211_band band,
278 u8 n_probes) 278 u8 n_probes)
279{ 279{
@@ -286,7 +286,7 @@ inline u16 il_get_active_dwell_time(struct il_priv *priv,
286} 286}
287EXPORT_SYMBOL(il_get_active_dwell_time); 287EXPORT_SYMBOL(il_get_active_dwell_time);
288 288
289u16 il_get_passive_dwell_time(struct il_priv *priv, 289u16 il_get_passive_dwell_time(struct il_priv *il,
290 enum ieee80211_band band, 290 enum ieee80211_band band,
291 struct ieee80211_vif *vif) 291 struct ieee80211_vif *vif)
292{ 292{
@@ -295,13 +295,13 @@ u16 il_get_passive_dwell_time(struct il_priv *priv,
295 IL_PASSIVE_DWELL_BASE + IL_PASSIVE_DWELL_TIME_24 : 295 IL_PASSIVE_DWELL_BASE + IL_PASSIVE_DWELL_TIME_24 :
296 IL_PASSIVE_DWELL_BASE + IL_PASSIVE_DWELL_TIME_52; 296 IL_PASSIVE_DWELL_BASE + IL_PASSIVE_DWELL_TIME_52;
297 297
298 if (il_is_any_associated(priv)) { 298 if (il_is_any_associated(il)) {
299 /* 299 /*
300 * If we're associated, we clamp the maximum passive 300 * If we're associated, we clamp the maximum passive
301 * dwell time to be 98% of the smallest beacon interval 301 * dwell time to be 98% of the smallest beacon interval
302 * (minus 2 * channel tune time) 302 * (minus 2 * channel tune time)
303 */ 303 */
304 for_each_context(priv, ctx) { 304 for_each_context(il, ctx) {
305 u16 value; 305 u16 value;
306 306
307 if (!il_is_associated_ctx(ctx)) 307 if (!il_is_associated_ctx(ctx))
@@ -318,56 +318,56 @@ u16 il_get_passive_dwell_time(struct il_priv *priv,
318} 318}
319EXPORT_SYMBOL(il_get_passive_dwell_time); 319EXPORT_SYMBOL(il_get_passive_dwell_time);
320 320
321void il_init_scan_params(struct il_priv *priv) 321void il_init_scan_params(struct il_priv *il)
322{ 322{
323 u8 ant_idx = fls(priv->hw_params.valid_tx_ant) - 1; 323 u8 ant_idx = fls(il->hw_params.valid_tx_ant) - 1;
324 if (!priv->scan_tx_ant[IEEE80211_BAND_5GHZ]) 324 if (!il->scan_tx_ant[IEEE80211_BAND_5GHZ])
325 priv->scan_tx_ant[IEEE80211_BAND_5GHZ] = ant_idx; 325 il->scan_tx_ant[IEEE80211_BAND_5GHZ] = ant_idx;
326 if (!priv->scan_tx_ant[IEEE80211_BAND_2GHZ]) 326 if (!il->scan_tx_ant[IEEE80211_BAND_2GHZ])
327 priv->scan_tx_ant[IEEE80211_BAND_2GHZ] = ant_idx; 327 il->scan_tx_ant[IEEE80211_BAND_2GHZ] = ant_idx;
328} 328}
329EXPORT_SYMBOL(il_init_scan_params); 329EXPORT_SYMBOL(il_init_scan_params);
330 330
331static int il_scan_initiate(struct il_priv *priv, 331static int il_scan_initiate(struct il_priv *il,
332 struct ieee80211_vif *vif) 332 struct ieee80211_vif *vif)
333{ 333{
334 int ret; 334 int ret;
335 335
336 lockdep_assert_held(&priv->mutex); 336 lockdep_assert_held(&il->mutex);
337 337
338 if (WARN_ON(!priv->cfg->ops->utils->request_scan)) 338 if (WARN_ON(!il->cfg->ops->utils->request_scan))
339 return -EOPNOTSUPP; 339 return -EOPNOTSUPP;
340 340
341 cancel_delayed_work(&priv->scan_check); 341 cancel_delayed_work(&il->scan_check);
342 342
343 if (!il_is_ready_rf(priv)) { 343 if (!il_is_ready_rf(il)) {
344 IL_WARN(priv, "Request scan called when driver not ready.\n"); 344 IL_WARN(il, "Request scan called when driver not ready.\n");
345 return -EIO; 345 return -EIO;
346 } 346 }
347 347
348 if (test_bit(STATUS_SCAN_HW, &priv->status)) { 348 if (test_bit(STATUS_SCAN_HW, &il->status)) {
349 IL_DEBUG_SCAN(priv, 349 IL_DEBUG_SCAN(il,
350 "Multiple concurrent scan requests in parallel.\n"); 350 "Multiple concurrent scan requests in parallel.\n");
351 return -EBUSY; 351 return -EBUSY;
352 } 352 }
353 353
354 if (test_bit(STATUS_SCAN_ABORTING, &priv->status)) { 354 if (test_bit(STATUS_SCAN_ABORTING, &il->status)) {
355 IL_DEBUG_SCAN(priv, "Scan request while abort pending.\n"); 355 IL_DEBUG_SCAN(il, "Scan request while abort pending.\n");
356 return -EBUSY; 356 return -EBUSY;
357 } 357 }
358 358
359 IL_DEBUG_SCAN(priv, "Starting scan...\n"); 359 IL_DEBUG_SCAN(il, "Starting scan...\n");
360 360
361 set_bit(STATUS_SCANNING, &priv->status); 361 set_bit(STATUS_SCANNING, &il->status);
362 priv->scan_start = jiffies; 362 il->scan_start = jiffies;
363 363
364 ret = priv->cfg->ops->utils->request_scan(priv, vif); 364 ret = il->cfg->ops->utils->request_scan(il, vif);
365 if (ret) { 365 if (ret) {
366 clear_bit(STATUS_SCANNING, &priv->status); 366 clear_bit(STATUS_SCANNING, &il->status);
367 return ret; 367 return ret;
368 } 368 }
369 369
370 queue_delayed_work(priv->workqueue, &priv->scan_check, 370 queue_delayed_work(il->workqueue, &il->scan_check,
371 IL_SCAN_CHECK_WATCHDOG); 371 IL_SCAN_CHECK_WATCHDOG);
372 372
373 return 0; 373 return 0;
@@ -377,33 +377,33 @@ int il_mac_hw_scan(struct ieee80211_hw *hw,
377 struct ieee80211_vif *vif, 377 struct ieee80211_vif *vif,
378 struct cfg80211_scan_request *req) 378 struct cfg80211_scan_request *req)
379{ 379{
380 struct il_priv *priv = hw->priv; 380 struct il_priv *il = hw->priv;
381 int ret; 381 int ret;
382 382
383 IL_DEBUG_MAC80211(priv, "enter\n"); 383 IL_DEBUG_MAC80211(il, "enter\n");
384 384
385 if (req->n_channels == 0) 385 if (req->n_channels == 0)
386 return -EINVAL; 386 return -EINVAL;
387 387
388 mutex_lock(&priv->mutex); 388 mutex_lock(&il->mutex);
389 389
390 if (test_bit(STATUS_SCANNING, &priv->status)) { 390 if (test_bit(STATUS_SCANNING, &il->status)) {
391 IL_DEBUG_SCAN(priv, "Scan already in progress.\n"); 391 IL_DEBUG_SCAN(il, "Scan already in progress.\n");
392 ret = -EAGAIN; 392 ret = -EAGAIN;
393 goto out_unlock; 393 goto out_unlock;
394 } 394 }
395 395
396 /* mac80211 will only ask for one band at a time */ 396 /* mac80211 will only ask for one band at a time */
397 priv->scan_request = req; 397 il->scan_request = req;
398 priv->scan_vif = vif; 398 il->scan_vif = vif;
399 priv->scan_band = req->channels[0]->band; 399 il->scan_band = req->channels[0]->band;
400 400
401 ret = il_scan_initiate(priv, vif); 401 ret = il_scan_initiate(il, vif);
402 402
403 IL_DEBUG_MAC80211(priv, "leave\n"); 403 IL_DEBUG_MAC80211(il, "leave\n");
404 404
405out_unlock: 405out_unlock:
406 mutex_unlock(&priv->mutex); 406 mutex_unlock(&il->mutex);
407 407
408 return ret; 408 return ret;
409} 409}
@@ -411,17 +411,17 @@ EXPORT_SYMBOL(il_mac_hw_scan);
411 411
412static void il_bg_scan_check(struct work_struct *data) 412static void il_bg_scan_check(struct work_struct *data)
413{ 413{
414 struct il_priv *priv = 414 struct il_priv *il =
415 container_of(data, struct il_priv, scan_check.work); 415 container_of(data, struct il_priv, scan_check.work);
416 416
417 IL_DEBUG_SCAN(priv, "Scan check work\n"); 417 IL_DEBUG_SCAN(il, "Scan check work\n");
418 418
419 /* Since we are here firmware does not finish scan and 419 /* Since we are here firmware does not finish scan and
420 * most likely is in bad shape, so we don't bother to 420 * most likely is in bad shape, so we don't bother to
421 * send abort command, just force scan complete to mac80211 */ 421 * send abort command, just force scan complete to mac80211 */
422 mutex_lock(&priv->mutex); 422 mutex_lock(&il->mutex);
423 il_force_scan_end(priv); 423 il_force_scan_end(il);
424 mutex_unlock(&priv->mutex); 424 mutex_unlock(&il->mutex);
425} 425}
426 426
427/** 427/**
@@ -429,7 +429,7 @@ static void il_bg_scan_check(struct work_struct *data)
429 */ 429 */
430 430
431u16 431u16
432il_fill_probe_req(struct il_priv *priv, struct ieee80211_mgmt *frame, 432il_fill_probe_req(struct il_priv *il, struct ieee80211_mgmt *frame,
433 const u8 *ta, const u8 *ies, int ie_len, int left) 433 const u8 *ta, const u8 *ies, int ie_len, int left)
434{ 434{
435 int len = 0; 435 int len = 0;
@@ -475,75 +475,75 @@ EXPORT_SYMBOL(il_fill_probe_req);
475 475
476static void il_bg_abort_scan(struct work_struct *work) 476static void il_bg_abort_scan(struct work_struct *work)
477{ 477{
478 struct il_priv *priv = container_of(work, struct il_priv, abort_scan); 478 struct il_priv *il = container_of(work, struct il_priv, abort_scan);
479 479
480 IL_DEBUG_SCAN(priv, "Abort scan work\n"); 480 IL_DEBUG_SCAN(il, "Abort scan work\n");
481 481
482 /* We keep scan_check work queued in case when firmware will not 482 /* We keep scan_check work queued in case when firmware will not
483 * report back scan completed notification */ 483 * report back scan completed notification */
484 mutex_lock(&priv->mutex); 484 mutex_lock(&il->mutex);
485 il_scan_cancel_timeout(priv, 200); 485 il_scan_cancel_timeout(il, 200);
486 mutex_unlock(&priv->mutex); 486 mutex_unlock(&il->mutex);
487} 487}
488 488
489static void il_bg_scan_completed(struct work_struct *work) 489static void il_bg_scan_completed(struct work_struct *work)
490{ 490{
491 struct il_priv *priv = 491 struct il_priv *il =
492 container_of(work, struct il_priv, scan_completed); 492 container_of(work, struct il_priv, scan_completed);
493 bool aborted; 493 bool aborted;
494 494
495 IL_DEBUG_SCAN(priv, "Completed scan.\n"); 495 IL_DEBUG_SCAN(il, "Completed scan.\n");
496 496
497 cancel_delayed_work(&priv->scan_check); 497 cancel_delayed_work(&il->scan_check);
498 498
499 mutex_lock(&priv->mutex); 499 mutex_lock(&il->mutex);
500 500
501 aborted = test_and_clear_bit(STATUS_SCAN_ABORTING, &priv->status); 501 aborted = test_and_clear_bit(STATUS_SCAN_ABORTING, &il->status);
502 if (aborted) 502 if (aborted)
503 IL_DEBUG_SCAN(priv, "Aborted scan completed.\n"); 503 IL_DEBUG_SCAN(il, "Aborted scan completed.\n");
504 504
505 if (!test_and_clear_bit(STATUS_SCANNING, &priv->status)) { 505 if (!test_and_clear_bit(STATUS_SCANNING, &il->status)) {
506 IL_DEBUG_SCAN(priv, "Scan already completed.\n"); 506 IL_DEBUG_SCAN(il, "Scan already completed.\n");
507 goto out_settings; 507 goto out_settings;
508 } 508 }
509 509
510 il_complete_scan(priv, aborted); 510 il_complete_scan(il, aborted);
511 511
512out_settings: 512out_settings:
513 /* Can we still talk to firmware ? */ 513 /* Can we still talk to firmware ? */
514 if (!il_is_ready_rf(priv)) 514 if (!il_is_ready_rf(il))
515 goto out; 515 goto out;
516 516
517 /* 517 /*
518 * We do not commit power settings while scan is pending, 518 * We do not commit power settings while scan is pending,
519 * do it now if the settings changed. 519 * do it now if the settings changed.
520 */ 520 */
521 il_power_set_mode(priv, &priv->power_data.sleep_cmd_next, false); 521 il_power_set_mode(il, &il->power_data.sleep_cmd_next, false);
522 il_set_tx_power(priv, priv->tx_power_next, false); 522 il_set_tx_power(il, il->tx_power_next, false);
523 523
524 priv->cfg->ops->utils->post_scan(priv); 524 il->cfg->ops->utils->post_scan(il);
525 525
526out: 526out:
527 mutex_unlock(&priv->mutex); 527 mutex_unlock(&il->mutex);
528} 528}
529 529
530void il_setup_scan_deferred_work(struct il_priv *priv) 530void il_setup_scan_deferred_work(struct il_priv *il)
531{ 531{
532 INIT_WORK(&priv->scan_completed, il_bg_scan_completed); 532 INIT_WORK(&il->scan_completed, il_bg_scan_completed);
533 INIT_WORK(&priv->abort_scan, il_bg_abort_scan); 533 INIT_WORK(&il->abort_scan, il_bg_abort_scan);
534 INIT_DELAYED_WORK(&priv->scan_check, il_bg_scan_check); 534 INIT_DELAYED_WORK(&il->scan_check, il_bg_scan_check);
535} 535}
536EXPORT_SYMBOL(il_setup_scan_deferred_work); 536EXPORT_SYMBOL(il_setup_scan_deferred_work);
537 537
538void il_cancel_scan_deferred_work(struct il_priv *priv) 538void il_cancel_scan_deferred_work(struct il_priv *il)
539{ 539{
540 cancel_work_sync(&priv->abort_scan); 540 cancel_work_sync(&il->abort_scan);
541 cancel_work_sync(&priv->scan_completed); 541 cancel_work_sync(&il->scan_completed);
542 542
543 if (cancel_delayed_work_sync(&priv->scan_check)) { 543 if (cancel_delayed_work_sync(&il->scan_check)) {
544 mutex_lock(&priv->mutex); 544 mutex_lock(&il->mutex);
545 il_force_scan_end(priv); 545 il_force_scan_end(il);
546 mutex_unlock(&priv->mutex); 546 mutex_unlock(&il->mutex);
547 } 547 }
548} 548}
549EXPORT_SYMBOL(il_cancel_scan_deferred_work); 549EXPORT_SYMBOL(il_cancel_scan_deferred_work);
diff --git a/drivers/net/wireless/iwlegacy/iwl-sta.c b/drivers/net/wireless/iwlegacy/iwl-sta.c
index 3773f7d64d2a..7d66e79f5d3e 100644
--- a/drivers/net/wireless/iwlegacy/iwl-sta.c
+++ b/drivers/net/wireless/iwlegacy/iwl-sta.c
@@ -36,28 +36,28 @@
36#include "iwl-core.h" 36#include "iwl-core.h"
37#include "iwl-sta.h" 37#include "iwl-sta.h"
38 38
39/* priv->sta_lock must be held */ 39/* il->sta_lock must be held */
40static void il_sta_ucode_activate(struct il_priv *priv, u8 sta_id) 40static void il_sta_ucode_activate(struct il_priv *il, u8 sta_id)
41{ 41{
42 42
43 if (!(priv->stations[sta_id].used & IL_STA_DRIVER_ACTIVE)) 43 if (!(il->stations[sta_id].used & IL_STA_DRIVER_ACTIVE))
44 IL_ERR(priv, 44 IL_ERR(il,
45 "ACTIVATE a non DRIVER active station id %u addr %pM\n", 45 "ACTIVATE a non DRIVER active station id %u addr %pM\n",
46 sta_id, priv->stations[sta_id].sta.sta.addr); 46 sta_id, il->stations[sta_id].sta.sta.addr);
47 47
48 if (priv->stations[sta_id].used & IL_STA_UCODE_ACTIVE) { 48 if (il->stations[sta_id].used & IL_STA_UCODE_ACTIVE) {
49 IL_DEBUG_ASSOC(priv, 49 IL_DEBUG_ASSOC(il,
50 "STA id %u addr %pM already present" 50 "STA id %u addr %pM already present"
51 " in uCode (according to driver)\n", 51 " in uCode (according to driver)\n",
52 sta_id, priv->stations[sta_id].sta.sta.addr); 52 sta_id, il->stations[sta_id].sta.sta.addr);
53 } else { 53 } else {
54 priv->stations[sta_id].used |= IL_STA_UCODE_ACTIVE; 54 il->stations[sta_id].used |= IL_STA_UCODE_ACTIVE;
55 IL_DEBUG_ASSOC(priv, "Added STA id %u addr %pM to uCode\n", 55 IL_DEBUG_ASSOC(il, "Added STA id %u addr %pM to uCode\n",
56 sta_id, priv->stations[sta_id].sta.sta.addr); 56 sta_id, il->stations[sta_id].sta.sta.addr);
57 } 57 }
58} 58}
59 59
60static int il_process_add_sta_resp(struct il_priv *priv, 60static int il_process_add_sta_resp(struct il_priv *il,
61 struct il_addsta_cmd *addsta, 61 struct il_addsta_cmd *addsta,
62 struct il_rx_packet *pkt, 62 struct il_rx_packet *pkt,
63 bool sync) 63 bool sync)
@@ -67,45 +67,45 @@ static int il_process_add_sta_resp(struct il_priv *priv,
67 int ret = -EIO; 67 int ret = -EIO;
68 68
69 if (pkt->hdr.flags & IL_CMD_FAILED_MSK) { 69 if (pkt->hdr.flags & IL_CMD_FAILED_MSK) {
70 IL_ERR(priv, "Bad return from REPLY_ADD_STA (0x%08X)\n", 70 IL_ERR(il, "Bad return from REPLY_ADD_STA (0x%08X)\n",
71 pkt->hdr.flags); 71 pkt->hdr.flags);
72 return ret; 72 return ret;
73 } 73 }
74 74
75 IL_DEBUG_INFO(priv, "Processing response for adding station %u\n", 75 IL_DEBUG_INFO(il, "Processing response for adding station %u\n",
76 sta_id); 76 sta_id);
77 77
78 spin_lock_irqsave(&priv->sta_lock, flags); 78 spin_lock_irqsave(&il->sta_lock, flags);
79 79
80 switch (pkt->u.add_sta.status) { 80 switch (pkt->u.add_sta.status) {
81 case ADD_STA_SUCCESS_MSK: 81 case ADD_STA_SUCCESS_MSK:
82 IL_DEBUG_INFO(priv, "REPLY_ADD_STA PASSED\n"); 82 IL_DEBUG_INFO(il, "REPLY_ADD_STA PASSED\n");
83 il_sta_ucode_activate(priv, sta_id); 83 il_sta_ucode_activate(il, sta_id);
84 ret = 0; 84 ret = 0;
85 break; 85 break;
86 case ADD_STA_NO_ROOM_IN_TABLE: 86 case ADD_STA_NO_ROOM_IN_TABLE:
87 IL_ERR(priv, "Adding station %d failed, no room in table.\n", 87 IL_ERR(il, "Adding station %d failed, no room in table.\n",
88 sta_id); 88 sta_id);
89 break; 89 break;
90 case ADD_STA_NO_BLOCK_ACK_RESOURCE: 90 case ADD_STA_NO_BLOCK_ACK_RESOURCE:
91 IL_ERR(priv, 91 IL_ERR(il,
92 "Adding station %d failed, no block ack resource.\n", 92 "Adding station %d failed, no block ack resource.\n",
93 sta_id); 93 sta_id);
94 break; 94 break;
95 case ADD_STA_MODIFY_NON_EXIST_STA: 95 case ADD_STA_MODIFY_NON_EXIST_STA:
96 IL_ERR(priv, "Attempting to modify non-existing station %d\n", 96 IL_ERR(il, "Attempting to modify non-existing station %d\n",
97 sta_id); 97 sta_id);
98 break; 98 break;
99 default: 99 default:
100 IL_DEBUG_ASSOC(priv, "Received REPLY_ADD_STA:(0x%08X)\n", 100 IL_DEBUG_ASSOC(il, "Received REPLY_ADD_STA:(0x%08X)\n",
101 pkt->u.add_sta.status); 101 pkt->u.add_sta.status);
102 break; 102 break;
103 } 103 }
104 104
105 IL_DEBUG_INFO(priv, "%s station id %u addr %pM\n", 105 IL_DEBUG_INFO(il, "%s station id %u addr %pM\n",
106 priv->stations[sta_id].sta.mode == 106 il->stations[sta_id].sta.mode ==
107 STA_CONTROL_MODIFY_MSK ? "Modified" : "Added", 107 STA_CONTROL_MODIFY_MSK ? "Modified" : "Added",
108 sta_id, priv->stations[sta_id].sta.sta.addr); 108 sta_id, il->stations[sta_id].sta.sta.addr);
109 109
110 /* 110 /*
111 * XXX: The MAC address in the command buffer is often changed from 111 * XXX: The MAC address in the command buffer is often changed from
@@ -115,27 +115,27 @@ static int il_process_add_sta_resp(struct il_priv *priv,
115 * issue has not yet been resolved and this debugging is left to 115 * issue has not yet been resolved and this debugging is left to
116 * observe the problem. 116 * observe the problem.
117 */ 117 */
118 IL_DEBUG_INFO(priv, "%s station according to cmd buffer %pM\n", 118 IL_DEBUG_INFO(il, "%s station according to cmd buffer %pM\n",
119 priv->stations[sta_id].sta.mode == 119 il->stations[sta_id].sta.mode ==
120 STA_CONTROL_MODIFY_MSK ? "Modified" : "Added", 120 STA_CONTROL_MODIFY_MSK ? "Modified" : "Added",
121 addsta->sta.addr); 121 addsta->sta.addr);
122 spin_unlock_irqrestore(&priv->sta_lock, flags); 122 spin_unlock_irqrestore(&il->sta_lock, flags);
123 123
124 return ret; 124 return ret;
125} 125}
126 126
127static void il_add_sta_callback(struct il_priv *priv, 127static void il_add_sta_callback(struct il_priv *il,
128 struct il_device_cmd *cmd, 128 struct il_device_cmd *cmd,
129 struct il_rx_packet *pkt) 129 struct il_rx_packet *pkt)
130{ 130{
131 struct il_addsta_cmd *addsta = 131 struct il_addsta_cmd *addsta =
132 (struct il_addsta_cmd *)cmd->cmd.payload; 132 (struct il_addsta_cmd *)cmd->cmd.payload;
133 133
134 il_process_add_sta_resp(priv, addsta, pkt, false); 134 il_process_add_sta_resp(il, addsta, pkt, false);
135 135
136} 136}
137 137
138int il_send_add_sta(struct il_priv *priv, 138int il_send_add_sta(struct il_priv *il,
139 struct il_addsta_cmd *sta, u8 flags) 139 struct il_addsta_cmd *sta, u8 flags)
140{ 140{
141 struct il_rx_packet *pkt = NULL; 141 struct il_rx_packet *pkt = NULL;
@@ -148,7 +148,7 @@ int il_send_add_sta(struct il_priv *priv,
148 }; 148 };
149 u8 sta_id __maybe_unused = sta->sta.sta_id; 149 u8 sta_id __maybe_unused = sta->sta.sta_id;
150 150
151 IL_DEBUG_INFO(priv, "Adding sta %u (%pM) %ssynchronously\n", 151 IL_DEBUG_INFO(il, "Adding sta %u (%pM) %ssynchronously\n",
152 sta_id, sta->sta.addr, flags & CMD_ASYNC ? "a" : ""); 152 sta_id, sta->sta.addr, flags & CMD_ASYNC ? "a" : "");
153 153
154 if (flags & CMD_ASYNC) 154 if (flags & CMD_ASYNC)
@@ -158,23 +158,23 @@ int il_send_add_sta(struct il_priv *priv,
158 might_sleep(); 158 might_sleep();
159 } 159 }
160 160
161 cmd.len = priv->cfg->ops->utils->build_addsta_hcmd(sta, data); 161 cmd.len = il->cfg->ops->utils->build_addsta_hcmd(sta, data);
162 ret = il_send_cmd(priv, &cmd); 162 ret = il_send_cmd(il, &cmd);
163 163
164 if (ret || (flags & CMD_ASYNC)) 164 if (ret || (flags & CMD_ASYNC))
165 return ret; 165 return ret;
166 166
167 if (ret == 0) { 167 if (ret == 0) {
168 pkt = (struct il_rx_packet *)cmd.reply_page; 168 pkt = (struct il_rx_packet *)cmd.reply_page;
169 ret = il_process_add_sta_resp(priv, sta, pkt, true); 169 ret = il_process_add_sta_resp(il, sta, pkt, true);
170 } 170 }
171 il_free_pages(priv, cmd.reply_page); 171 il_free_pages(il, cmd.reply_page);
172 172
173 return ret; 173 return ret;
174} 174}
175EXPORT_SYMBOL(il_send_add_sta); 175EXPORT_SYMBOL(il_send_add_sta);
176 176
177static void il_set_ht_add_station(struct il_priv *priv, u8 index, 177static void il_set_ht_add_station(struct il_priv *il, u8 index,
178 struct ieee80211_sta *sta, 178 struct ieee80211_sta *sta,
179 struct il_rxon_context *ctx) 179 struct il_rxon_context *ctx)
180{ 180{
@@ -186,13 +186,13 @@ static void il_set_ht_add_station(struct il_priv *priv, u8 index,
186 goto done; 186 goto done;
187 187
188 mimo_ps_mode = (sta_ht_inf->cap & IEEE80211_HT_CAP_SM_PS) >> 2; 188 mimo_ps_mode = (sta_ht_inf->cap & IEEE80211_HT_CAP_SM_PS) >> 2;
189 IL_DEBUG_ASSOC(priv, "spatial multiplexing power save mode: %s\n", 189 IL_DEBUG_ASSOC(il, "spatial multiplexing power save mode: %s\n",
190 (mimo_ps_mode == WLAN_HT_CAP_SM_PS_STATIC) ? 190 (mimo_ps_mode == WLAN_HT_CAP_SM_PS_STATIC) ?
191 "static" : 191 "static" :
192 (mimo_ps_mode == WLAN_HT_CAP_SM_PS_DYNAMIC) ? 192 (mimo_ps_mode == WLAN_HT_CAP_SM_PS_DYNAMIC) ?
193 "dynamic" : "disabled"); 193 "dynamic" : "disabled");
194 194
195 sta_flags = priv->stations[index].sta.station_flags; 195 sta_flags = il->stations[index].sta.station_flags;
196 196
197 sta_flags &= ~(STA_FLG_RTS_MIMO_PROT_MSK | STA_FLG_MIMO_DIS_MSK); 197 sta_flags &= ~(STA_FLG_RTS_MIMO_PROT_MSK | STA_FLG_MIMO_DIS_MSK);
198 198
@@ -206,7 +206,7 @@ static void il_set_ht_add_station(struct il_priv *priv, u8 index,
206 case WLAN_HT_CAP_SM_PS_DISABLED: 206 case WLAN_HT_CAP_SM_PS_DISABLED:
207 break; 207 break;
208 default: 208 default:
209 IL_WARN(priv, "Invalid MIMO PS mode %d\n", mimo_ps_mode); 209 IL_WARN(il, "Invalid MIMO PS mode %d\n", mimo_ps_mode);
210 break; 210 break;
211 } 211 }
212 212
@@ -216,12 +216,12 @@ static void il_set_ht_add_station(struct il_priv *priv, u8 index,
216 sta_flags |= cpu_to_le32( 216 sta_flags |= cpu_to_le32(
217 (u32)sta_ht_inf->ampdu_density << STA_FLG_AGG_MPDU_DENSITY_POS); 217 (u32)sta_ht_inf->ampdu_density << STA_FLG_AGG_MPDU_DENSITY_POS);
218 218
219 if (il_is_ht40_tx_allowed(priv, ctx, &sta->ht_cap)) 219 if (il_is_ht40_tx_allowed(il, ctx, &sta->ht_cap))
220 sta_flags |= STA_FLG_HT40_EN_MSK; 220 sta_flags |= STA_FLG_HT40_EN_MSK;
221 else 221 else
222 sta_flags &= ~STA_FLG_HT40_EN_MSK; 222 sta_flags &= ~STA_FLG_HT40_EN_MSK;
223 223
224 priv->stations[index].sta.station_flags = sta_flags; 224 il->stations[index].sta.station_flags = sta_flags;
225 done: 225 done:
226 return; 226 return;
227} 227}
@@ -231,7 +231,7 @@ static void il_set_ht_add_station(struct il_priv *priv, u8 index,
231 * 231 *
232 * should be called with sta_lock held 232 * should be called with sta_lock held
233 */ 233 */
234u8 il_prep_station(struct il_priv *priv, struct il_rxon_context *ctx, 234u8 il_prep_station(struct il_priv *il, struct il_rxon_context *ctx,
235 const u8 *addr, bool is_ap, struct ieee80211_sta *sta) 235 const u8 *addr, bool is_ap, struct ieee80211_sta *sta)
236{ 236{
237 struct il_station_entry *station; 237 struct il_station_entry *station;
@@ -244,14 +244,14 @@ u8 il_prep_station(struct il_priv *priv, struct il_rxon_context *ctx,
244 else if (is_broadcast_ether_addr(addr)) 244 else if (is_broadcast_ether_addr(addr))
245 sta_id = ctx->bcast_sta_id; 245 sta_id = ctx->bcast_sta_id;
246 else 246 else
247 for (i = IL_STA_ID; i < priv->hw_params.max_stations; i++) { 247 for (i = IL_STA_ID; i < il->hw_params.max_stations; i++) {
248 if (!compare_ether_addr(priv->stations[i].sta.sta.addr, 248 if (!compare_ether_addr(il->stations[i].sta.sta.addr,
249 addr)) { 249 addr)) {
250 sta_id = i; 250 sta_id = i;
251 break; 251 break;
252 } 252 }
253 253
254 if (!priv->stations[i].used && 254 if (!il->stations[i].used &&
255 sta_id == IL_INVALID_STATION) 255 sta_id == IL_INVALID_STATION)
256 sta_id = i; 256 sta_id = i;
257 } 257 }
@@ -268,27 +268,27 @@ u8 il_prep_station(struct il_priv *priv, struct il_rxon_context *ctx,
268 * station. Keep track if one is in progress so that we do not send 268 * station. Keep track if one is in progress so that we do not send
269 * another. 269 * another.
270 */ 270 */
271 if (priv->stations[sta_id].used & IL_STA_UCODE_INPROGRESS) { 271 if (il->stations[sta_id].used & IL_STA_UCODE_INPROGRESS) {
272 IL_DEBUG_INFO(priv, 272 IL_DEBUG_INFO(il,
273 "STA %d already in process of being added.\n", 273 "STA %d already in process of being added.\n",
274 sta_id); 274 sta_id);
275 return sta_id; 275 return sta_id;
276 } 276 }
277 277
278 if ((priv->stations[sta_id].used & IL_STA_DRIVER_ACTIVE) && 278 if ((il->stations[sta_id].used & IL_STA_DRIVER_ACTIVE) &&
279 (priv->stations[sta_id].used & IL_STA_UCODE_ACTIVE) && 279 (il->stations[sta_id].used & IL_STA_UCODE_ACTIVE) &&
280 !compare_ether_addr(priv->stations[sta_id].sta.sta.addr, addr)) { 280 !compare_ether_addr(il->stations[sta_id].sta.sta.addr, addr)) {
281 IL_DEBUG_ASSOC(priv, 281 IL_DEBUG_ASSOC(il,
282 "STA %d (%pM) already added, not adding again.\n", 282 "STA %d (%pM) already added, not adding again.\n",
283 sta_id, addr); 283 sta_id, addr);
284 return sta_id; 284 return sta_id;
285 } 285 }
286 286
287 station = &priv->stations[sta_id]; 287 station = &il->stations[sta_id];
288 station->used = IL_STA_DRIVER_ACTIVE; 288 station->used = IL_STA_DRIVER_ACTIVE;
289 IL_DEBUG_ASSOC(priv, "Add STA to driver ID %d: %pM\n", 289 IL_DEBUG_ASSOC(il, "Add STA to driver ID %d: %pM\n",
290 sta_id, addr); 290 sta_id, addr);
291 priv->num_stations++; 291 il->num_stations++;
292 292
293 /* Set up the REPLY_ADD_STA command to send to device */ 293 /* Set up the REPLY_ADD_STA command to send to device */
294 memset(&station->sta, 0, sizeof(struct il_addsta_cmd)); 294 memset(&station->sta, 0, sizeof(struct il_addsta_cmd));
@@ -310,10 +310,10 @@ u8 il_prep_station(struct il_priv *priv, struct il_rxon_context *ctx,
310 * STA and broadcast STA) pass in a NULL sta, and mac80211 310 * STA and broadcast STA) pass in a NULL sta, and mac80211
311 * doesn't allow HT IBSS. 311 * doesn't allow HT IBSS.
312 */ 312 */
313 il_set_ht_add_station(priv, sta_id, sta, ctx); 313 il_set_ht_add_station(il, sta_id, sta, ctx);
314 314
315 /* 3945 only */ 315 /* 3945 only */
316 rate = (priv->band == IEEE80211_BAND_5GHZ) ? 316 rate = (il->band == IEEE80211_BAND_5GHZ) ?
317 IL_RATE_6M_PLCP : IL_RATE_1M_PLCP; 317 IL_RATE_6M_PLCP : IL_RATE_1M_PLCP;
318 /* Turn on both antennas for the station... */ 318 /* Turn on both antennas for the station... */
319 station->sta.rate_n_flags = cpu_to_le16(rate | RATE_MCS_ANT_AB_MSK); 319 station->sta.rate_n_flags = cpu_to_le16(rate | RATE_MCS_ANT_AB_MSK);
@@ -329,7 +329,7 @@ EXPORT_SYMBOL_GPL(il_prep_station);
329 * il_add_station_common - 329 * il_add_station_common -
330 */ 330 */
331int 331int
332il_add_station_common(struct il_priv *priv, 332il_add_station_common(struct il_priv *il,
333 struct il_rxon_context *ctx, 333 struct il_rxon_context *ctx,
334 const u8 *addr, bool is_ap, 334 const u8 *addr, bool is_ap,
335 struct ieee80211_sta *sta, u8 *sta_id_r) 335 struct ieee80211_sta *sta, u8 *sta_id_r)
@@ -340,12 +340,12 @@ il_add_station_common(struct il_priv *priv,
340 struct il_addsta_cmd sta_cmd; 340 struct il_addsta_cmd sta_cmd;
341 341
342 *sta_id_r = 0; 342 *sta_id_r = 0;
343 spin_lock_irqsave(&priv->sta_lock, flags_spin); 343 spin_lock_irqsave(&il->sta_lock, flags_spin);
344 sta_id = il_prep_station(priv, ctx, addr, is_ap, sta); 344 sta_id = il_prep_station(il, ctx, addr, is_ap, sta);
345 if (sta_id == IL_INVALID_STATION) { 345 if (sta_id == IL_INVALID_STATION) {
346 IL_ERR(priv, "Unable to prepare station %pM for addition\n", 346 IL_ERR(il, "Unable to prepare station %pM for addition\n",
347 addr); 347 addr);
348 spin_unlock_irqrestore(&priv->sta_lock, flags_spin); 348 spin_unlock_irqrestore(&il->sta_lock, flags_spin);
349 return -EINVAL; 349 return -EINVAL;
350 } 350 }
351 351
@@ -354,37 +354,37 @@ il_add_station_common(struct il_priv *priv,
354 * station. Keep track if one is in progress so that we do not send 354 * station. Keep track if one is in progress so that we do not send
355 * another. 355 * another.
356 */ 356 */
357 if (priv->stations[sta_id].used & IL_STA_UCODE_INPROGRESS) { 357 if (il->stations[sta_id].used & IL_STA_UCODE_INPROGRESS) {
358 IL_DEBUG_INFO(priv, 358 IL_DEBUG_INFO(il,
359 "STA %d already in process of being added.\n", 359 "STA %d already in process of being added.\n",
360 sta_id); 360 sta_id);
361 spin_unlock_irqrestore(&priv->sta_lock, flags_spin); 361 spin_unlock_irqrestore(&il->sta_lock, flags_spin);
362 return -EEXIST; 362 return -EEXIST;
363 } 363 }
364 364
365 if ((priv->stations[sta_id].used & IL_STA_DRIVER_ACTIVE) && 365 if ((il->stations[sta_id].used & IL_STA_DRIVER_ACTIVE) &&
366 (priv->stations[sta_id].used & IL_STA_UCODE_ACTIVE)) { 366 (il->stations[sta_id].used & IL_STA_UCODE_ACTIVE)) {
367 IL_DEBUG_ASSOC(priv, 367 IL_DEBUG_ASSOC(il,
368 "STA %d (%pM) already added, not adding again.\n", 368 "STA %d (%pM) already added, not adding again.\n",
369 sta_id, addr); 369 sta_id, addr);
370 spin_unlock_irqrestore(&priv->sta_lock, flags_spin); 370 spin_unlock_irqrestore(&il->sta_lock, flags_spin);
371 return -EEXIST; 371 return -EEXIST;
372 } 372 }
373 373
374 priv->stations[sta_id].used |= IL_STA_UCODE_INPROGRESS; 374 il->stations[sta_id].used |= IL_STA_UCODE_INPROGRESS;
375 memcpy(&sta_cmd, &priv->stations[sta_id].sta, 375 memcpy(&sta_cmd, &il->stations[sta_id].sta,
376 sizeof(struct il_addsta_cmd)); 376 sizeof(struct il_addsta_cmd));
377 spin_unlock_irqrestore(&priv->sta_lock, flags_spin); 377 spin_unlock_irqrestore(&il->sta_lock, flags_spin);
378 378
379 /* Add station to device's station table */ 379 /* Add station to device's station table */
380 ret = il_send_add_sta(priv, &sta_cmd, CMD_SYNC); 380 ret = il_send_add_sta(il, &sta_cmd, CMD_SYNC);
381 if (ret) { 381 if (ret) {
382 spin_lock_irqsave(&priv->sta_lock, flags_spin); 382 spin_lock_irqsave(&il->sta_lock, flags_spin);
383 IL_ERR(priv, "Adding station %pM failed.\n", 383 IL_ERR(il, "Adding station %pM failed.\n",
384 priv->stations[sta_id].sta.sta.addr); 384 il->stations[sta_id].sta.sta.addr);
385 priv->stations[sta_id].used &= ~IL_STA_DRIVER_ACTIVE; 385 il->stations[sta_id].used &= ~IL_STA_DRIVER_ACTIVE;
386 priv->stations[sta_id].used &= ~IL_STA_UCODE_INPROGRESS; 386 il->stations[sta_id].used &= ~IL_STA_UCODE_INPROGRESS;
387 spin_unlock_irqrestore(&priv->sta_lock, flags_spin); 387 spin_unlock_irqrestore(&il->sta_lock, flags_spin);
388 } 388 }
389 *sta_id_r = sta_id; 389 *sta_id_r = sta_id;
390 return ret; 390 return ret;
@@ -394,23 +394,23 @@ EXPORT_SYMBOL(il_add_station_common);
394/** 394/**
395 * il_sta_ucode_deactivate - deactivate ucode status for a station 395 * il_sta_ucode_deactivate - deactivate ucode status for a station
396 * 396 *
397 * priv->sta_lock must be held 397 * il->sta_lock must be held
398 */ 398 */
399static void il_sta_ucode_deactivate(struct il_priv *priv, u8 sta_id) 399static void il_sta_ucode_deactivate(struct il_priv *il, u8 sta_id)
400{ 400{
401 /* Ucode must be active and driver must be non active */ 401 /* Ucode must be active and driver must be non active */
402 if ((priv->stations[sta_id].used & 402 if ((il->stations[sta_id].used &
403 (IL_STA_UCODE_ACTIVE | IL_STA_DRIVER_ACTIVE)) != 403 (IL_STA_UCODE_ACTIVE | IL_STA_DRIVER_ACTIVE)) !=
404 IL_STA_UCODE_ACTIVE) 404 IL_STA_UCODE_ACTIVE)
405 IL_ERR(priv, "removed non active STA %u\n", sta_id); 405 IL_ERR(il, "removed non active STA %u\n", sta_id);
406 406
407 priv->stations[sta_id].used &= ~IL_STA_UCODE_ACTIVE; 407 il->stations[sta_id].used &= ~IL_STA_UCODE_ACTIVE;
408 408
409 memset(&priv->stations[sta_id], 0, sizeof(struct il_station_entry)); 409 memset(&il->stations[sta_id], 0, sizeof(struct il_station_entry));
410 IL_DEBUG_ASSOC(priv, "Removed STA %u\n", sta_id); 410 IL_DEBUG_ASSOC(il, "Removed STA %u\n", sta_id);
411} 411}
412 412
413static int il_send_remove_station(struct il_priv *priv, 413static int il_send_remove_station(struct il_priv *il,
414 const u8 *addr, int sta_id, 414 const u8 *addr, int sta_id,
415 bool temporary) 415 bool temporary)
416{ 416{
@@ -433,14 +433,14 @@ static int il_send_remove_station(struct il_priv *priv,
433 433
434 cmd.flags |= CMD_WANT_SKB; 434 cmd.flags |= CMD_WANT_SKB;
435 435
436 ret = il_send_cmd(priv, &cmd); 436 ret = il_send_cmd(il, &cmd);
437 437
438 if (ret) 438 if (ret)
439 return ret; 439 return ret;
440 440
441 pkt = (struct il_rx_packet *)cmd.reply_page; 441 pkt = (struct il_rx_packet *)cmd.reply_page;
442 if (pkt->hdr.flags & IL_CMD_FAILED_MSK) { 442 if (pkt->hdr.flags & IL_CMD_FAILED_MSK) {
443 IL_ERR(priv, "Bad return from REPLY_REMOVE_STA (0x%08X)\n", 443 IL_ERR(il, "Bad return from REPLY_REMOVE_STA (0x%08X)\n",
444 pkt->hdr.flags); 444 pkt->hdr.flags);
445 ret = -EIO; 445 ret = -EIO;
446 } 446 }
@@ -449,20 +449,20 @@ static int il_send_remove_station(struct il_priv *priv,
449 switch (pkt->u.rem_sta.status) { 449 switch (pkt->u.rem_sta.status) {
450 case REM_STA_SUCCESS_MSK: 450 case REM_STA_SUCCESS_MSK:
451 if (!temporary) { 451 if (!temporary) {
452 spin_lock_irqsave(&priv->sta_lock, flags_spin); 452 spin_lock_irqsave(&il->sta_lock, flags_spin);
453 il_sta_ucode_deactivate(priv, sta_id); 453 il_sta_ucode_deactivate(il, sta_id);
454 spin_unlock_irqrestore(&priv->sta_lock, 454 spin_unlock_irqrestore(&il->sta_lock,
455 flags_spin); 455 flags_spin);
456 } 456 }
457 IL_DEBUG_ASSOC(priv, "REPLY_REMOVE_STA PASSED\n"); 457 IL_DEBUG_ASSOC(il, "REPLY_REMOVE_STA PASSED\n");
458 break; 458 break;
459 default: 459 default:
460 ret = -EIO; 460 ret = -EIO;
461 IL_ERR(priv, "REPLY_REMOVE_STA failed\n"); 461 IL_ERR(il, "REPLY_REMOVE_STA failed\n");
462 break; 462 break;
463 } 463 }
464 } 464 }
465 il_free_pages(priv, cmd.reply_page); 465 il_free_pages(il, cmd.reply_page);
466 466
467 return ret; 467 return ret;
468} 468}
@@ -470,13 +470,13 @@ static int il_send_remove_station(struct il_priv *priv,
470/** 470/**
471 * il_remove_station - Remove driver's knowledge of station. 471 * il_remove_station - Remove driver's knowledge of station.
472 */ 472 */
473int il_remove_station(struct il_priv *priv, const u8 sta_id, 473int il_remove_station(struct il_priv *il, const u8 sta_id,
474 const u8 *addr) 474 const u8 *addr)
475{ 475{
476 unsigned long flags; 476 unsigned long flags;
477 477
478 if (!il_is_ready(priv)) { 478 if (!il_is_ready(il)) {
479 IL_DEBUG_INFO(priv, 479 IL_DEBUG_INFO(il,
480 "Unable to remove station %pM, device not ready.\n", 480 "Unable to remove station %pM, device not ready.\n",
481 addr); 481 addr);
482 /* 482 /*
@@ -487,42 +487,42 @@ int il_remove_station(struct il_priv *priv, const u8 sta_id,
487 return 0; 487 return 0;
488 } 488 }
489 489
490 IL_DEBUG_ASSOC(priv, "Removing STA from driver:%d %pM\n", 490 IL_DEBUG_ASSOC(il, "Removing STA from driver:%d %pM\n",
491 sta_id, addr); 491 sta_id, addr);
492 492
493 if (WARN_ON(sta_id == IL_INVALID_STATION)) 493 if (WARN_ON(sta_id == IL_INVALID_STATION))
494 return -EINVAL; 494 return -EINVAL;
495 495
496 spin_lock_irqsave(&priv->sta_lock, flags); 496 spin_lock_irqsave(&il->sta_lock, flags);
497 497
498 if (!(priv->stations[sta_id].used & IL_STA_DRIVER_ACTIVE)) { 498 if (!(il->stations[sta_id].used & IL_STA_DRIVER_ACTIVE)) {
499 IL_DEBUG_INFO(priv, "Removing %pM but non DRIVER active\n", 499 IL_DEBUG_INFO(il, "Removing %pM but non DRIVER active\n",
500 addr); 500 addr);
501 goto out_err; 501 goto out_err;
502 } 502 }
503 503
504 if (!(priv->stations[sta_id].used & IL_STA_UCODE_ACTIVE)) { 504 if (!(il->stations[sta_id].used & IL_STA_UCODE_ACTIVE)) {
505 IL_DEBUG_INFO(priv, "Removing %pM but non UCODE active\n", 505 IL_DEBUG_INFO(il, "Removing %pM but non UCODE active\n",
506 addr); 506 addr);
507 goto out_err; 507 goto out_err;
508 } 508 }
509 509
510 if (priv->stations[sta_id].used & IL_STA_LOCAL) { 510 if (il->stations[sta_id].used & IL_STA_LOCAL) {
511 kfree(priv->stations[sta_id].lq); 511 kfree(il->stations[sta_id].lq);
512 priv->stations[sta_id].lq = NULL; 512 il->stations[sta_id].lq = NULL;
513 } 513 }
514 514
515 priv->stations[sta_id].used &= ~IL_STA_DRIVER_ACTIVE; 515 il->stations[sta_id].used &= ~IL_STA_DRIVER_ACTIVE;
516 516
517 priv->num_stations--; 517 il->num_stations--;
518 518
519 BUG_ON(priv->num_stations < 0); 519 BUG_ON(il->num_stations < 0);
520 520
521 spin_unlock_irqrestore(&priv->sta_lock, flags); 521 spin_unlock_irqrestore(&il->sta_lock, flags);
522 522
523 return il_send_remove_station(priv, addr, sta_id, false); 523 return il_send_remove_station(il, addr, sta_id, false);
524out_err: 524out_err:
525 spin_unlock_irqrestore(&priv->sta_lock, flags); 525 spin_unlock_irqrestore(&il->sta_lock, flags);
526 return -EINVAL; 526 return -EINVAL;
527} 527}
528EXPORT_SYMBOL_GPL(il_remove_station); 528EXPORT_SYMBOL_GPL(il_remove_station);
@@ -535,31 +535,31 @@ EXPORT_SYMBOL_GPL(il_remove_station);
535 * other than explicit station management would cause this in 535 * other than explicit station management would cause this in
536 * the ucode, e.g. unassociated RXON. 536 * the ucode, e.g. unassociated RXON.
537 */ 537 */
538void il_clear_ucode_stations(struct il_priv *priv, 538void il_clear_ucode_stations(struct il_priv *il,
539 struct il_rxon_context *ctx) 539 struct il_rxon_context *ctx)
540{ 540{
541 int i; 541 int i;
542 unsigned long flags_spin; 542 unsigned long flags_spin;
543 bool cleared = false; 543 bool cleared = false;
544 544
545 IL_DEBUG_INFO(priv, "Clearing ucode stations in driver\n"); 545 IL_DEBUG_INFO(il, "Clearing ucode stations in driver\n");
546 546
547 spin_lock_irqsave(&priv->sta_lock, flags_spin); 547 spin_lock_irqsave(&il->sta_lock, flags_spin);
548 for (i = 0; i < priv->hw_params.max_stations; i++) { 548 for (i = 0; i < il->hw_params.max_stations; i++) {
549 if (ctx && ctx->ctxid != priv->stations[i].ctxid) 549 if (ctx && ctx->ctxid != il->stations[i].ctxid)
550 continue; 550 continue;
551 551
552 if (priv->stations[i].used & IL_STA_UCODE_ACTIVE) { 552 if (il->stations[i].used & IL_STA_UCODE_ACTIVE) {
553 IL_DEBUG_INFO(priv, 553 IL_DEBUG_INFO(il,
554 "Clearing ucode active for station %d\n", i); 554 "Clearing ucode active for station %d\n", i);
555 priv->stations[i].used &= ~IL_STA_UCODE_ACTIVE; 555 il->stations[i].used &= ~IL_STA_UCODE_ACTIVE;
556 cleared = true; 556 cleared = true;
557 } 557 }
558 } 558 }
559 spin_unlock_irqrestore(&priv->sta_lock, flags_spin); 559 spin_unlock_irqrestore(&il->sta_lock, flags_spin);
560 560
561 if (!cleared) 561 if (!cleared)
562 IL_DEBUG_INFO(priv, 562 IL_DEBUG_INFO(il,
563 "No active stations found to be cleared\n"); 563 "No active stations found to be cleared\n");
564} 564}
565EXPORT_SYMBOL(il_clear_ucode_stations); 565EXPORT_SYMBOL(il_clear_ucode_stations);
@@ -573,7 +573,7 @@ EXPORT_SYMBOL(il_clear_ucode_stations);
573 * Function sleeps. 573 * Function sleeps.
574 */ 574 */
575void 575void
576il_restore_stations(struct il_priv *priv, struct il_rxon_context *ctx) 576il_restore_stations(struct il_priv *il, struct il_rxon_context *ctx)
577{ 577{
578 struct il_addsta_cmd sta_cmd; 578 struct il_addsta_cmd sta_cmd;
579 struct il_link_quality_cmd lq; 579 struct il_link_quality_cmd lq;
@@ -583,48 +583,48 @@ il_restore_stations(struct il_priv *priv, struct il_rxon_context *ctx)
583 int ret; 583 int ret;
584 bool send_lq; 584 bool send_lq;
585 585
586 if (!il_is_ready(priv)) { 586 if (!il_is_ready(il)) {
587 IL_DEBUG_INFO(priv, 587 IL_DEBUG_INFO(il,
588 "Not ready yet, not restoring any stations.\n"); 588 "Not ready yet, not restoring any stations.\n");
589 return; 589 return;
590 } 590 }
591 591
592 IL_DEBUG_ASSOC(priv, "Restoring all known stations ... start.\n"); 592 IL_DEBUG_ASSOC(il, "Restoring all known stations ... start.\n");
593 spin_lock_irqsave(&priv->sta_lock, flags_spin); 593 spin_lock_irqsave(&il->sta_lock, flags_spin);
594 for (i = 0; i < priv->hw_params.max_stations; i++) { 594 for (i = 0; i < il->hw_params.max_stations; i++) {
595 if (ctx->ctxid != priv->stations[i].ctxid) 595 if (ctx->ctxid != il->stations[i].ctxid)
596 continue; 596 continue;
597 if ((priv->stations[i].used & IL_STA_DRIVER_ACTIVE) && 597 if ((il->stations[i].used & IL_STA_DRIVER_ACTIVE) &&
598 !(priv->stations[i].used & IL_STA_UCODE_ACTIVE)) { 598 !(il->stations[i].used & IL_STA_UCODE_ACTIVE)) {
599 IL_DEBUG_ASSOC(priv, "Restoring sta %pM\n", 599 IL_DEBUG_ASSOC(il, "Restoring sta %pM\n",
600 priv->stations[i].sta.sta.addr); 600 il->stations[i].sta.sta.addr);
601 priv->stations[i].sta.mode = 0; 601 il->stations[i].sta.mode = 0;
602 priv->stations[i].used |= IL_STA_UCODE_INPROGRESS; 602 il->stations[i].used |= IL_STA_UCODE_INPROGRESS;
603 found = true; 603 found = true;
604 } 604 }
605 } 605 }
606 606
607 for (i = 0; i < priv->hw_params.max_stations; i++) { 607 for (i = 0; i < il->hw_params.max_stations; i++) {
608 if ((priv->stations[i].used & IL_STA_UCODE_INPROGRESS)) { 608 if ((il->stations[i].used & IL_STA_UCODE_INPROGRESS)) {
609 memcpy(&sta_cmd, &priv->stations[i].sta, 609 memcpy(&sta_cmd, &il->stations[i].sta,
610 sizeof(struct il_addsta_cmd)); 610 sizeof(struct il_addsta_cmd));
611 send_lq = false; 611 send_lq = false;
612 if (priv->stations[i].lq) { 612 if (il->stations[i].lq) {
613 memcpy(&lq, priv->stations[i].lq, 613 memcpy(&lq, il->stations[i].lq,
614 sizeof(struct il_link_quality_cmd)); 614 sizeof(struct il_link_quality_cmd));
615 send_lq = true; 615 send_lq = true;
616 } 616 }
617 spin_unlock_irqrestore(&priv->sta_lock, flags_spin); 617 spin_unlock_irqrestore(&il->sta_lock, flags_spin);
618 ret = il_send_add_sta(priv, &sta_cmd, CMD_SYNC); 618 ret = il_send_add_sta(il, &sta_cmd, CMD_SYNC);
619 if (ret) { 619 if (ret) {
620 spin_lock_irqsave(&priv->sta_lock, flags_spin); 620 spin_lock_irqsave(&il->sta_lock, flags_spin);
621 IL_ERR(priv, "Adding station %pM failed.\n", 621 IL_ERR(il, "Adding station %pM failed.\n",
622 priv->stations[i].sta.sta.addr); 622 il->stations[i].sta.sta.addr);
623 priv->stations[i].used &= 623 il->stations[i].used &=
624 ~IL_STA_DRIVER_ACTIVE; 624 ~IL_STA_DRIVER_ACTIVE;
625 priv->stations[i].used &= 625 il->stations[i].used &=
626 ~IL_STA_UCODE_INPROGRESS; 626 ~IL_STA_UCODE_INPROGRESS;
627 spin_unlock_irqrestore(&priv->sta_lock, 627 spin_unlock_irqrestore(&il->sta_lock,
628 flags_spin); 628 flags_spin);
629 } 629 }
630 /* 630 /*
@@ -632,71 +632,71 @@ il_restore_stations(struct il_priv *priv, struct il_rxon_context *ctx)
632 * current LQ command 632 * current LQ command
633 */ 633 */
634 if (send_lq) 634 if (send_lq)
635 il_send_lq_cmd(priv, ctx, &lq, 635 il_send_lq_cmd(il, ctx, &lq,
636 CMD_SYNC, true); 636 CMD_SYNC, true);
637 spin_lock_irqsave(&priv->sta_lock, flags_spin); 637 spin_lock_irqsave(&il->sta_lock, flags_spin);
638 priv->stations[i].used &= ~IL_STA_UCODE_INPROGRESS; 638 il->stations[i].used &= ~IL_STA_UCODE_INPROGRESS;
639 } 639 }
640 } 640 }
641 641
642 spin_unlock_irqrestore(&priv->sta_lock, flags_spin); 642 spin_unlock_irqrestore(&il->sta_lock, flags_spin);
643 if (!found) 643 if (!found)
644 IL_DEBUG_INFO(priv, "Restoring all known stations" 644 IL_DEBUG_INFO(il, "Restoring all known stations"
645 " .... no stations to be restored.\n"); 645 " .... no stations to be restored.\n");
646 else 646 else
647 IL_DEBUG_INFO(priv, "Restoring all known stations" 647 IL_DEBUG_INFO(il, "Restoring all known stations"
648 " .... complete.\n"); 648 " .... complete.\n");
649} 649}
650EXPORT_SYMBOL(il_restore_stations); 650EXPORT_SYMBOL(il_restore_stations);
651 651
652int il_get_free_ucode_key_index(struct il_priv *priv) 652int il_get_free_ucode_key_index(struct il_priv *il)
653{ 653{
654 int i; 654 int i;
655 655
656 for (i = 0; i < priv->sta_key_max_num; i++) 656 for (i = 0; i < il->sta_key_max_num; i++)
657 if (!test_and_set_bit(i, &priv->ucode_key_table)) 657 if (!test_and_set_bit(i, &il->ucode_key_table))
658 return i; 658 return i;
659 659
660 return WEP_INVALID_OFFSET; 660 return WEP_INVALID_OFFSET;
661} 661}
662EXPORT_SYMBOL(il_get_free_ucode_key_index); 662EXPORT_SYMBOL(il_get_free_ucode_key_index);
663 663
664void il_dealloc_bcast_stations(struct il_priv *priv) 664void il_dealloc_bcast_stations(struct il_priv *il)
665{ 665{
666 unsigned long flags; 666 unsigned long flags;
667 int i; 667 int i;
668 668
669 spin_lock_irqsave(&priv->sta_lock, flags); 669 spin_lock_irqsave(&il->sta_lock, flags);
670 for (i = 0; i < priv->hw_params.max_stations; i++) { 670 for (i = 0; i < il->hw_params.max_stations; i++) {
671 if (!(priv->stations[i].used & IL_STA_BCAST)) 671 if (!(il->stations[i].used & IL_STA_BCAST))
672 continue; 672 continue;
673 673
674 priv->stations[i].used &= ~IL_STA_UCODE_ACTIVE; 674 il->stations[i].used &= ~IL_STA_UCODE_ACTIVE;
675 priv->num_stations--; 675 il->num_stations--;
676 BUG_ON(priv->num_stations < 0); 676 BUG_ON(il->num_stations < 0);
677 kfree(priv->stations[i].lq); 677 kfree(il->stations[i].lq);
678 priv->stations[i].lq = NULL; 678 il->stations[i].lq = NULL;
679 } 679 }
680 spin_unlock_irqrestore(&priv->sta_lock, flags); 680 spin_unlock_irqrestore(&il->sta_lock, flags);
681} 681}
682EXPORT_SYMBOL_GPL(il_dealloc_bcast_stations); 682EXPORT_SYMBOL_GPL(il_dealloc_bcast_stations);
683 683
684#ifdef CONFIG_IWLWIFI_LEGACY_DEBUG 684#ifdef CONFIG_IWLWIFI_LEGACY_DEBUG
685static void il_dump_lq_cmd(struct il_priv *priv, 685static void il_dump_lq_cmd(struct il_priv *il,
686 struct il_link_quality_cmd *lq) 686 struct il_link_quality_cmd *lq)
687{ 687{
688 int i; 688 int i;
689 IL_DEBUG_RATE(priv, "lq station id 0x%x\n", lq->sta_id); 689 IL_DEBUG_RATE(il, "lq station id 0x%x\n", lq->sta_id);
690 IL_DEBUG_RATE(priv, "lq ant 0x%X 0x%X\n", 690 IL_DEBUG_RATE(il, "lq ant 0x%X 0x%X\n",
691 lq->general_params.single_stream_ant_msk, 691 lq->general_params.single_stream_ant_msk,
692 lq->general_params.dual_stream_ant_msk); 692 lq->general_params.dual_stream_ant_msk);
693 693
694 for (i = 0; i < LINK_QUAL_MAX_RETRY_NUM; i++) 694 for (i = 0; i < LINK_QUAL_MAX_RETRY_NUM; i++)
695 IL_DEBUG_RATE(priv, "lq index %d 0x%X\n", 695 IL_DEBUG_RATE(il, "lq index %d 0x%X\n",
696 i, lq->rs_table[i].rate_n_flags); 696 i, lq->rs_table[i].rate_n_flags);
697} 697}
698#else 698#else
699static inline void il_dump_lq_cmd(struct il_priv *priv, 699static inline void il_dump_lq_cmd(struct il_priv *il,
700 struct il_link_quality_cmd *lq) 700 struct il_link_quality_cmd *lq)
701{ 701{
702} 702}
@@ -713,7 +713,7 @@ static inline void il_dump_lq_cmd(struct il_priv *priv,
713 * Test for this to prevent driver from sending LQ command between the time 713 * Test for this to prevent driver from sending LQ command between the time
714 * RXON flags are updated and when LQ command is updated. 714 * RXON flags are updated and when LQ command is updated.
715 */ 715 */
716static bool il_is_lq_table_valid(struct il_priv *priv, 716static bool il_is_lq_table_valid(struct il_priv *il,
717 struct il_rxon_context *ctx, 717 struct il_rxon_context *ctx,
718 struct il_link_quality_cmd *lq) 718 struct il_link_quality_cmd *lq)
719{ 719{
@@ -722,12 +722,12 @@ static bool il_is_lq_table_valid(struct il_priv *priv,
722 if (ctx->ht.enabled) 722 if (ctx->ht.enabled)
723 return true; 723 return true;
724 724
725 IL_DEBUG_INFO(priv, "Channel %u is not an HT channel\n", 725 IL_DEBUG_INFO(il, "Channel %u is not an HT channel\n",
726 ctx->active.channel); 726 ctx->active.channel);
727 for (i = 0; i < LINK_QUAL_MAX_RETRY_NUM; i++) { 727 for (i = 0; i < LINK_QUAL_MAX_RETRY_NUM; i++) {
728 if (le32_to_cpu(lq->rs_table[i].rate_n_flags) & 728 if (le32_to_cpu(lq->rs_table[i].rate_n_flags) &
729 RATE_MCS_HT_MSK) { 729 RATE_MCS_HT_MSK) {
730 IL_DEBUG_INFO(priv, 730 IL_DEBUG_INFO(il,
731 "index %d of LQ expects HT channel\n", 731 "index %d of LQ expects HT channel\n",
732 i); 732 i);
733 return false; 733 return false;
@@ -746,7 +746,7 @@ static bool il_is_lq_table_valid(struct il_priv *priv,
746 * this case to clear the state indicating that station creation is in 746 * this case to clear the state indicating that station creation is in
747 * progress. 747 * progress.
748 */ 748 */
749int il_send_lq_cmd(struct il_priv *priv, struct il_rxon_context *ctx, 749int il_send_lq_cmd(struct il_priv *il, struct il_rxon_context *ctx,
750 struct il_link_quality_cmd *lq, u8 flags, bool init) 750 struct il_link_quality_cmd *lq, u8 flags, bool init)
751{ 751{
752 int ret = 0; 752 int ret = 0;
@@ -763,18 +763,18 @@ int il_send_lq_cmd(struct il_priv *priv, struct il_rxon_context *ctx,
763 return -EINVAL; 763 return -EINVAL;
764 764
765 765
766 spin_lock_irqsave(&priv->sta_lock, flags_spin); 766 spin_lock_irqsave(&il->sta_lock, flags_spin);
767 if (!(priv->stations[lq->sta_id].used & IL_STA_DRIVER_ACTIVE)) { 767 if (!(il->stations[lq->sta_id].used & IL_STA_DRIVER_ACTIVE)) {
768 spin_unlock_irqrestore(&priv->sta_lock, flags_spin); 768 spin_unlock_irqrestore(&il->sta_lock, flags_spin);
769 return -EINVAL; 769 return -EINVAL;
770 } 770 }
771 spin_unlock_irqrestore(&priv->sta_lock, flags_spin); 771 spin_unlock_irqrestore(&il->sta_lock, flags_spin);
772 772
773 il_dump_lq_cmd(priv, lq); 773 il_dump_lq_cmd(il, lq);
774 BUG_ON(init && (cmd.flags & CMD_ASYNC)); 774 BUG_ON(init && (cmd.flags & CMD_ASYNC));
775 775
776 if (il_is_lq_table_valid(priv, ctx, lq)) 776 if (il_is_lq_table_valid(il, ctx, lq))
777 ret = il_send_cmd(priv, &cmd); 777 ret = il_send_cmd(il, &cmd);
778 else 778 else
779 ret = -EINVAL; 779 ret = -EINVAL;
780 780
@@ -782,12 +782,12 @@ int il_send_lq_cmd(struct il_priv *priv, struct il_rxon_context *ctx,
782 return ret; 782 return ret;
783 783
784 if (init) { 784 if (init) {
785 IL_DEBUG_INFO(priv, "init LQ command complete," 785 IL_DEBUG_INFO(il, "init LQ command complete,"
786 " clearing sta addition status for sta %d\n", 786 " clearing sta addition status for sta %d\n",
787 lq->sta_id); 787 lq->sta_id);
788 spin_lock_irqsave(&priv->sta_lock, flags_spin); 788 spin_lock_irqsave(&il->sta_lock, flags_spin);
789 priv->stations[lq->sta_id].used &= ~IL_STA_UCODE_INPROGRESS; 789 il->stations[lq->sta_id].used &= ~IL_STA_UCODE_INPROGRESS;
790 spin_unlock_irqrestore(&priv->sta_lock, flags_spin); 790 spin_unlock_irqrestore(&il->sta_lock, flags_spin);
791 } 791 }
792 return ret; 792 return ret;
793} 793}
@@ -797,20 +797,20 @@ int il_mac_sta_remove(struct ieee80211_hw *hw,
797 struct ieee80211_vif *vif, 797 struct ieee80211_vif *vif,
798 struct ieee80211_sta *sta) 798 struct ieee80211_sta *sta)
799{ 799{
800 struct il_priv *priv = hw->priv; 800 struct il_priv *il = hw->priv;
801 struct il_station_priv_common *sta_common = (void *)sta->drv_priv; 801 struct il_station_priv_common *sta_common = (void *)sta->drv_priv;
802 int ret; 802 int ret;
803 803
804 IL_DEBUG_INFO(priv, "received request to remove station %pM\n", 804 IL_DEBUG_INFO(il, "received request to remove station %pM\n",
805 sta->addr); 805 sta->addr);
806 mutex_lock(&priv->mutex); 806 mutex_lock(&il->mutex);
807 IL_DEBUG_INFO(priv, "proceeding to remove station %pM\n", 807 IL_DEBUG_INFO(il, "proceeding to remove station %pM\n",
808 sta->addr); 808 sta->addr);
809 ret = il_remove_station(priv, sta_common->sta_id, sta->addr); 809 ret = il_remove_station(il, sta_common->sta_id, sta->addr);
810 if (ret) 810 if (ret)
811 IL_ERR(priv, "Error removing station %pM\n", 811 IL_ERR(il, "Error removing station %pM\n",
812 sta->addr); 812 sta->addr);
813 mutex_unlock(&priv->mutex); 813 mutex_unlock(&il->mutex);
814 return ret; 814 return ret;
815} 815}
816EXPORT_SYMBOL(il_mac_sta_remove); 816EXPORT_SYMBOL(il_mac_sta_remove);
diff --git a/drivers/net/wireless/iwlegacy/iwl-sta.h b/drivers/net/wireless/iwlegacy/iwl-sta.h
index 555b0602cea0..77cdfd4a6674 100644
--- a/drivers/net/wireless/iwlegacy/iwl-sta.h
+++ b/drivers/net/wireless/iwlegacy/iwl-sta.h
@@ -43,56 +43,56 @@
43#define IL_STA_BCAST BIT(4) /* this station is the special bcast station */ 43#define IL_STA_BCAST BIT(4) /* this station is the special bcast station */
44 44
45 45
46void il_restore_stations(struct il_priv *priv, 46void il_restore_stations(struct il_priv *il,
47 struct il_rxon_context *ctx); 47 struct il_rxon_context *ctx);
48void il_clear_ucode_stations(struct il_priv *priv, 48void il_clear_ucode_stations(struct il_priv *il,
49 struct il_rxon_context *ctx); 49 struct il_rxon_context *ctx);
50void il_dealloc_bcast_stations(struct il_priv *priv); 50void il_dealloc_bcast_stations(struct il_priv *il);
51int il_get_free_ucode_key_index(struct il_priv *priv); 51int il_get_free_ucode_key_index(struct il_priv *il);
52int il_send_add_sta(struct il_priv *priv, 52int il_send_add_sta(struct il_priv *il,
53 struct il_addsta_cmd *sta, u8 flags); 53 struct il_addsta_cmd *sta, u8 flags);
54int il_add_station_common(struct il_priv *priv, 54int il_add_station_common(struct il_priv *il,
55 struct il_rxon_context *ctx, 55 struct il_rxon_context *ctx,
56 const u8 *addr, bool is_ap, 56 const u8 *addr, bool is_ap,
57 struct ieee80211_sta *sta, u8 *sta_id_r); 57 struct ieee80211_sta *sta, u8 *sta_id_r);
58int il_remove_station(struct il_priv *priv, 58int il_remove_station(struct il_priv *il,
59 const u8 sta_id, 59 const u8 sta_id,
60 const u8 *addr); 60 const u8 *addr);
61int il_mac_sta_remove(struct ieee80211_hw *hw, 61int il_mac_sta_remove(struct ieee80211_hw *hw,
62 struct ieee80211_vif *vif, 62 struct ieee80211_vif *vif,
63 struct ieee80211_sta *sta); 63 struct ieee80211_sta *sta);
64 64
65u8 il_prep_station(struct il_priv *priv, 65u8 il_prep_station(struct il_priv *il,
66 struct il_rxon_context *ctx, 66 struct il_rxon_context *ctx,
67 const u8 *addr, bool is_ap, 67 const u8 *addr, bool is_ap,
68 struct ieee80211_sta *sta); 68 struct ieee80211_sta *sta);
69 69
70int il_send_lq_cmd(struct il_priv *priv, 70int il_send_lq_cmd(struct il_priv *il,
71 struct il_rxon_context *ctx, 71 struct il_rxon_context *ctx,
72 struct il_link_quality_cmd *lq, 72 struct il_link_quality_cmd *lq,
73 u8 flags, bool init); 73 u8 flags, bool init);
74 74
75/** 75/**
76 * il_clear_driver_stations - clear knowledge of all stations from driver 76 * il_clear_driver_stations - clear knowledge of all stations from driver
77 * @priv: iwl priv struct 77 * @il: iwl il struct
78 * 78 *
79 * This is called during il_down() to make sure that in the case 79 * This is called during il_down() to make sure that in the case
80 * we're coming there from a hardware restart mac80211 will be 80 * we're coming there from a hardware restart mac80211 will be
81 * able to reconfigure stations -- if we're getting there in the 81 * able to reconfigure stations -- if we're getting there in the
82 * normal down flow then the stations will already be cleared. 82 * normal down flow then the stations will already be cleared.
83 */ 83 */
84static inline void il_clear_driver_stations(struct il_priv *priv) 84static inline void il_clear_driver_stations(struct il_priv *il)
85{ 85{
86 unsigned long flags; 86 unsigned long flags;
87 struct il_rxon_context *ctx; 87 struct il_rxon_context *ctx;
88 88
89 spin_lock_irqsave(&priv->sta_lock, flags); 89 spin_lock_irqsave(&il->sta_lock, flags);
90 memset(priv->stations, 0, sizeof(priv->stations)); 90 memset(il->stations, 0, sizeof(il->stations));
91 priv->num_stations = 0; 91 il->num_stations = 0;
92 92
93 priv->ucode_key_table = 0; 93 il->ucode_key_table = 0;
94 94
95 for_each_context(priv, ctx) { 95 for_each_context(il, ctx) {
96 /* 96 /*
97 * Remove all key information that is not stored as part 97 * Remove all key information that is not stored as part
98 * of station information since mac80211 may not have had 98 * of station information since mac80211 may not have had
@@ -104,7 +104,7 @@ static inline void il_clear_driver_stations(struct il_priv *priv)
104 ctx->key_mapping_keys = 0; 104 ctx->key_mapping_keys = 0;
105 } 105 }
106 106
107 spin_unlock_irqrestore(&priv->sta_lock, flags); 107 spin_unlock_irqrestore(&il->sta_lock, flags);
108} 108}
109 109
110static inline int il_sta_id(struct ieee80211_sta *sta) 110static inline int il_sta_id(struct ieee80211_sta *sta)
@@ -117,7 +117,7 @@ static inline int il_sta_id(struct ieee80211_sta *sta)
117 117
118/** 118/**
119 * il_sta_id_or_broadcast - return sta_id or broadcast sta 119 * il_sta_id_or_broadcast - return sta_id or broadcast sta
120 * @priv: iwl priv 120 * @il: iwl il
121 * @context: the current context 121 * @context: the current context
122 * @sta: mac80211 station 122 * @sta: mac80211 station
123 * 123 *
@@ -126,7 +126,7 @@ static inline int il_sta_id(struct ieee80211_sta *sta)
126 * that case, we need to use the broadcast station, so this 126 * that case, we need to use the broadcast station, so this
127 * inline wraps that pattern. 127 * inline wraps that pattern.
128 */ 128 */
129static inline int il_sta_id_or_broadcast(struct il_priv *priv, 129static inline int il_sta_id_or_broadcast(struct il_priv *il,
130 struct il_rxon_context *context, 130 struct il_rxon_context *context,
131 struct ieee80211_sta *sta) 131 struct ieee80211_sta *sta)
132{ 132{
diff --git a/drivers/net/wireless/iwlegacy/iwl-tx.c b/drivers/net/wireless/iwlegacy/iwl-tx.c
index 1c27c60c753a..af6ac4fe2670 100644
--- a/drivers/net/wireless/iwlegacy/iwl-tx.c
+++ b/drivers/net/wireless/iwlegacy/iwl-tx.c
@@ -42,7 +42,7 @@
42 * il_txq_update_write_ptr - Send new write index to hardware 42 * il_txq_update_write_ptr - Send new write index to hardware
43 */ 43 */
44void 44void
45il_txq_update_write_ptr(struct il_priv *priv, struct il_tx_queue *txq) 45il_txq_update_write_ptr(struct il_priv *il, struct il_tx_queue *txq)
46{ 46{
47 u32 reg = 0; 47 u32 reg = 0;
48 int txq_id = txq->q.id; 48 int txq_id = txq->q.id;
@@ -51,22 +51,22 @@ il_txq_update_write_ptr(struct il_priv *priv, struct il_tx_queue *txq)
51 return; 51 return;
52 52
53 /* if we're trying to save power */ 53 /* if we're trying to save power */
54 if (test_bit(STATUS_POWER_PMI, &priv->status)) { 54 if (test_bit(STATUS_POWER_PMI, &il->status)) {
55 /* wake up nic if it's powered down ... 55 /* wake up nic if it's powered down ...
56 * uCode will wake up, and interrupt us again, so next 56 * uCode will wake up, and interrupt us again, so next
57 * time we'll skip this part. */ 57 * time we'll skip this part. */
58 reg = il_read32(priv, CSR_UCODE_DRV_GP1); 58 reg = il_read32(il, CSR_UCODE_DRV_GP1);
59 59
60 if (reg & CSR_UCODE_DRV_GP1_BIT_MAC_SLEEP) { 60 if (reg & CSR_UCODE_DRV_GP1_BIT_MAC_SLEEP) {
61 IL_DEBUG_INFO(priv, 61 IL_DEBUG_INFO(il,
62 "Tx queue %d requesting wakeup," 62 "Tx queue %d requesting wakeup,"
63 " GP1 = 0x%x\n", txq_id, reg); 63 " GP1 = 0x%x\n", txq_id, reg);
64 il_set_bit(priv, CSR_GP_CNTRL, 64 il_set_bit(il, CSR_GP_CNTRL,
65 CSR_GP_CNTRL_REG_FLAG_MAC_ACCESS_REQ); 65 CSR_GP_CNTRL_REG_FLAG_MAC_ACCESS_REQ);
66 return; 66 return;
67 } 67 }
68 68
69 il_write_direct32(priv, HBUS_TARG_WRPTR, 69 il_write_direct32(il, HBUS_TARG_WRPTR,
70 txq->q.write_ptr | (txq_id << 8)); 70 txq->q.write_ptr | (txq_id << 8));
71 71
72 /* 72 /*
@@ -75,7 +75,7 @@ il_txq_update_write_ptr(struct il_priv *priv, struct il_tx_queue *txq)
75 * trying to tx (during RFKILL, we're not trying to tx). 75 * trying to tx (during RFKILL, we're not trying to tx).
76 */ 76 */
77 } else 77 } else
78 il_write32(priv, HBUS_TARG_WRPTR, 78 il_write32(il, HBUS_TARG_WRPTR,
79 txq->q.write_ptr | (txq_id << 8)); 79 txq->q.write_ptr | (txq_id << 8));
80 txq->need_update = 0; 80 txq->need_update = 0;
81} 81}
@@ -84,16 +84,16 @@ EXPORT_SYMBOL(il_txq_update_write_ptr);
84/** 84/**
85 * il_tx_queue_unmap - Unmap any remaining DMA mappings and free skb's 85 * il_tx_queue_unmap - Unmap any remaining DMA mappings and free skb's
86 */ 86 */
87void il_tx_queue_unmap(struct il_priv *priv, int txq_id) 87void il_tx_queue_unmap(struct il_priv *il, int txq_id)
88{ 88{
89 struct il_tx_queue *txq = &priv->txq[txq_id]; 89 struct il_tx_queue *txq = &il->txq[txq_id];
90 struct il_queue *q = &txq->q; 90 struct il_queue *q = &txq->q;
91 91
92 if (q->n_bd == 0) 92 if (q->n_bd == 0)
93 return; 93 return;
94 94
95 while (q->write_ptr != q->read_ptr) { 95 while (q->write_ptr != q->read_ptr) {
96 priv->cfg->ops->lib->txq_free_tfd(priv, txq); 96 il->cfg->ops->lib->txq_free_tfd(il, txq);
97 q->read_ptr = il_queue_inc_wrap(q->read_ptr, q->n_bd); 97 q->read_ptr = il_queue_inc_wrap(q->read_ptr, q->n_bd);
98 } 98 }
99} 99}
@@ -107,13 +107,13 @@ EXPORT_SYMBOL(il_tx_queue_unmap);
107 * Free all buffers. 107 * Free all buffers.
108 * 0-fill, but do not free "txq" descriptor structure. 108 * 0-fill, but do not free "txq" descriptor structure.
109 */ 109 */
110void il_tx_queue_free(struct il_priv *priv, int txq_id) 110void il_tx_queue_free(struct il_priv *il, int txq_id)
111{ 111{
112 struct il_tx_queue *txq = &priv->txq[txq_id]; 112 struct il_tx_queue *txq = &il->txq[txq_id];
113 struct device *dev = &priv->pci_dev->dev; 113 struct device *dev = &il->pci_dev->dev;
114 int i; 114 int i;
115 115
116 il_tx_queue_unmap(priv, txq_id); 116 il_tx_queue_unmap(il, txq_id);
117 117
118 /* De-alloc array of command/tx buffers */ 118 /* De-alloc array of command/tx buffers */
119 for (i = 0; i < TFD_TX_CMD_SLOTS; i++) 119 for (i = 0; i < TFD_TX_CMD_SLOTS; i++)
@@ -121,7 +121,7 @@ void il_tx_queue_free(struct il_priv *priv, int txq_id)
121 121
122 /* De-alloc circular buffer of TFDs */ 122 /* De-alloc circular buffer of TFDs */
123 if (txq->q.n_bd) 123 if (txq->q.n_bd)
124 dma_free_coherent(dev, priv->hw_params.tfd_size * 124 dma_free_coherent(dev, il->hw_params.tfd_size *
125 txq->q.n_bd, txq->tfds, txq->q.dma_addr); 125 txq->q.n_bd, txq->tfds, txq->q.dma_addr);
126 126
127 /* De-alloc array of per-TFD driver data */ 127 /* De-alloc array of per-TFD driver data */
@@ -142,9 +142,9 @@ EXPORT_SYMBOL(il_tx_queue_free);
142/** 142/**
143 * il_cmd_queue_unmap - Unmap any remaining DMA mappings from command queue 143 * il_cmd_queue_unmap - Unmap any remaining DMA mappings from command queue
144 */ 144 */
145void il_cmd_queue_unmap(struct il_priv *priv) 145void il_cmd_queue_unmap(struct il_priv *il)
146{ 146{
147 struct il_tx_queue *txq = &priv->txq[priv->cmd_queue]; 147 struct il_tx_queue *txq = &il->txq[il->cmd_queue];
148 struct il_queue *q = &txq->q; 148 struct il_queue *q = &txq->q;
149 int i; 149 int i;
150 150
@@ -155,7 +155,7 @@ void il_cmd_queue_unmap(struct il_priv *priv)
155 i = il_get_cmd_index(q, q->read_ptr, 0); 155 i = il_get_cmd_index(q, q->read_ptr, 0);
156 156
157 if (txq->meta[i].flags & CMD_MAPPED) { 157 if (txq->meta[i].flags & CMD_MAPPED) {
158 pci_unmap_single(priv->pci_dev, 158 pci_unmap_single(il->pci_dev,
159 dma_unmap_addr(&txq->meta[i], mapping), 159 dma_unmap_addr(&txq->meta[i], mapping),
160 dma_unmap_len(&txq->meta[i], len), 160 dma_unmap_len(&txq->meta[i], len),
161 PCI_DMA_BIDIRECTIONAL); 161 PCI_DMA_BIDIRECTIONAL);
@@ -167,7 +167,7 @@ void il_cmd_queue_unmap(struct il_priv *priv)
167 167
168 i = q->n_window; 168 i = q->n_window;
169 if (txq->meta[i].flags & CMD_MAPPED) { 169 if (txq->meta[i].flags & CMD_MAPPED) {
170 pci_unmap_single(priv->pci_dev, 170 pci_unmap_single(il->pci_dev,
171 dma_unmap_addr(&txq->meta[i], mapping), 171 dma_unmap_addr(&txq->meta[i], mapping),
172 dma_unmap_len(&txq->meta[i], len), 172 dma_unmap_len(&txq->meta[i], len),
173 PCI_DMA_BIDIRECTIONAL); 173 PCI_DMA_BIDIRECTIONAL);
@@ -184,13 +184,13 @@ EXPORT_SYMBOL(il_cmd_queue_unmap);
184 * Free all buffers. 184 * Free all buffers.
185 * 0-fill, but do not free "txq" descriptor structure. 185 * 0-fill, but do not free "txq" descriptor structure.
186 */ 186 */
187void il_cmd_queue_free(struct il_priv *priv) 187void il_cmd_queue_free(struct il_priv *il)
188{ 188{
189 struct il_tx_queue *txq = &priv->txq[priv->cmd_queue]; 189 struct il_tx_queue *txq = &il->txq[il->cmd_queue];
190 struct device *dev = &priv->pci_dev->dev; 190 struct device *dev = &il->pci_dev->dev;
191 int i; 191 int i;
192 192
193 il_cmd_queue_unmap(priv); 193 il_cmd_queue_unmap(il);
194 194
195 /* De-alloc array of command/tx buffers */ 195 /* De-alloc array of command/tx buffers */
196 for (i = 0; i <= TFD_CMD_SLOTS; i++) 196 for (i = 0; i <= TFD_CMD_SLOTS; i++)
@@ -198,7 +198,7 @@ void il_cmd_queue_free(struct il_priv *priv)
198 198
199 /* De-alloc circular buffer of TFDs */ 199 /* De-alloc circular buffer of TFDs */
200 if (txq->q.n_bd) 200 if (txq->q.n_bd)
201 dma_free_coherent(dev, priv->hw_params.tfd_size * txq->q.n_bd, 201 dma_free_coherent(dev, il->hw_params.tfd_size * txq->q.n_bd,
202 txq->tfds, txq->q.dma_addr); 202 txq->tfds, txq->q.dma_addr);
203 203
204 /* deallocate arrays */ 204 /* deallocate arrays */
@@ -256,7 +256,7 @@ EXPORT_SYMBOL(il_queue_space);
256/** 256/**
257 * il_queue_init - Initialize queue's high/low-water and read/write indexes 257 * il_queue_init - Initialize queue's high/low-water and read/write indexes
258 */ 258 */
259static int il_queue_init(struct il_priv *priv, struct il_queue *q, 259static int il_queue_init(struct il_priv *il, struct il_queue *q,
260 int count, int slots_num, u32 id) 260 int count, int slots_num, u32 id)
261{ 261{
262 q->n_bd = count; 262 q->n_bd = count;
@@ -287,19 +287,19 @@ static int il_queue_init(struct il_priv *priv, struct il_queue *q,
287/** 287/**
288 * il_tx_queue_alloc - Alloc driver data and TFD CB for one Tx/cmd queue 288 * il_tx_queue_alloc - Alloc driver data and TFD CB for one Tx/cmd queue
289 */ 289 */
290static int il_tx_queue_alloc(struct il_priv *priv, 290static int il_tx_queue_alloc(struct il_priv *il,
291 struct il_tx_queue *txq, u32 id) 291 struct il_tx_queue *txq, u32 id)
292{ 292{
293 struct device *dev = &priv->pci_dev->dev; 293 struct device *dev = &il->pci_dev->dev;
294 size_t tfd_sz = priv->hw_params.tfd_size * TFD_QUEUE_SIZE_MAX; 294 size_t tfd_sz = il->hw_params.tfd_size * TFD_QUEUE_SIZE_MAX;
295 295
296 /* Driver private data, only for Tx (not command) queues, 296 /* Driver ilate data, only for Tx (not command) queues,
297 * not shared with device. */ 297 * not shared with device. */
298 if (id != priv->cmd_queue) { 298 if (id != il->cmd_queue) {
299 txq->txb = kzalloc(sizeof(txq->txb[0]) * 299 txq->txb = kzalloc(sizeof(txq->txb[0]) *
300 TFD_QUEUE_SIZE_MAX, GFP_KERNEL); 300 TFD_QUEUE_SIZE_MAX, GFP_KERNEL);
301 if (!txq->txb) { 301 if (!txq->txb) {
302 IL_ERR(priv, "kmalloc for auxiliary BD " 302 IL_ERR(il, "kmalloc for auxiliary BD "
303 "structures failed\n"); 303 "structures failed\n");
304 goto error; 304 goto error;
305 } 305 }
@@ -312,7 +312,7 @@ static int il_tx_queue_alloc(struct il_priv *priv,
312 txq->tfds = dma_alloc_coherent(dev, tfd_sz, &txq->q.dma_addr, 312 txq->tfds = dma_alloc_coherent(dev, tfd_sz, &txq->q.dma_addr,
313 GFP_KERNEL); 313 GFP_KERNEL);
314 if (!txq->tfds) { 314 if (!txq->tfds) {
315 IL_ERR(priv, "pci_alloc_consistent(%zd) failed\n", tfd_sz); 315 IL_ERR(il, "pci_alloc_consistent(%zd) failed\n", tfd_sz);
316 goto error; 316 goto error;
317 } 317 }
318 txq->q.id = id; 318 txq->q.id = id;
@@ -329,7 +329,7 @@ static int il_tx_queue_alloc(struct il_priv *priv,
329/** 329/**
330 * il_tx_queue_init - Allocate and initialize one tx/cmd queue 330 * il_tx_queue_init - Allocate and initialize one tx/cmd queue
331 */ 331 */
332int il_tx_queue_init(struct il_priv *priv, struct il_tx_queue *txq, 332int il_tx_queue_init(struct il_priv *il, struct il_tx_queue *txq,
333 int slots_num, u32 txq_id) 333 int slots_num, u32 txq_id)
334{ 334{
335 int i, len; 335 int i, len;
@@ -344,7 +344,7 @@ int il_tx_queue_init(struct il_priv *priv, struct il_tx_queue *txq,
344 * For normal Tx queues (all other queues), no super-size command 344 * For normal Tx queues (all other queues), no super-size command
345 * space is needed. 345 * space is needed.
346 */ 346 */
347 if (txq_id == priv->cmd_queue) 347 if (txq_id == il->cmd_queue)
348 actual_slots++; 348 actual_slots++;
349 349
350 txq->meta = kzalloc(sizeof(struct il_cmd_meta) * actual_slots, 350 txq->meta = kzalloc(sizeof(struct il_cmd_meta) * actual_slots,
@@ -367,7 +367,7 @@ int il_tx_queue_init(struct il_priv *priv, struct il_tx_queue *txq,
367 } 367 }
368 368
369 /* Alloc driver data array and TFD circular buffer */ 369 /* Alloc driver data array and TFD circular buffer */
370 ret = il_tx_queue_alloc(priv, txq, txq_id); 370 ret = il_tx_queue_alloc(il, txq, txq_id);
371 if (ret) 371 if (ret)
372 goto err; 372 goto err;
373 373
@@ -386,11 +386,11 @@ int il_tx_queue_init(struct il_priv *priv, struct il_tx_queue *txq,
386 BUILD_BUG_ON(TFD_QUEUE_SIZE_MAX & (TFD_QUEUE_SIZE_MAX - 1)); 386 BUILD_BUG_ON(TFD_QUEUE_SIZE_MAX & (TFD_QUEUE_SIZE_MAX - 1));
387 387
388 /* Initialize queue's high/low-water marks, and head/tail indexes */ 388 /* Initialize queue's high/low-water marks, and head/tail indexes */
389 il_queue_init(priv, &txq->q, 389 il_queue_init(il, &txq->q,
390 TFD_QUEUE_SIZE_MAX, slots_num, txq_id); 390 TFD_QUEUE_SIZE_MAX, slots_num, txq_id);
391 391
392 /* Tell device where to find queue */ 392 /* Tell device where to find queue */
393 priv->cfg->ops->lib->txq_init(priv, txq); 393 il->cfg->ops->lib->txq_init(il, txq);
394 394
395 return 0; 395 return 0;
396err: 396err:
@@ -404,12 +404,12 @@ out_free_arrays:
404} 404}
405EXPORT_SYMBOL(il_tx_queue_init); 405EXPORT_SYMBOL(il_tx_queue_init);
406 406
407void il_tx_queue_reset(struct il_priv *priv, struct il_tx_queue *txq, 407void il_tx_queue_reset(struct il_priv *il, struct il_tx_queue *txq,
408 int slots_num, u32 txq_id) 408 int slots_num, u32 txq_id)
409{ 409{
410 int actual_slots = slots_num; 410 int actual_slots = slots_num;
411 411
412 if (txq_id == priv->cmd_queue) 412 if (txq_id == il->cmd_queue)
413 actual_slots++; 413 actual_slots++;
414 414
415 memset(txq->meta, 0, sizeof(struct il_cmd_meta) * actual_slots); 415 memset(txq->meta, 0, sizeof(struct il_cmd_meta) * actual_slots);
@@ -417,11 +417,11 @@ void il_tx_queue_reset(struct il_priv *priv, struct il_tx_queue *txq,
417 txq->need_update = 0; 417 txq->need_update = 0;
418 418
419 /* Initialize queue's high/low-water marks, and head/tail indexes */ 419 /* Initialize queue's high/low-water marks, and head/tail indexes */
420 il_queue_init(priv, &txq->q, 420 il_queue_init(il, &txq->q,
421 TFD_QUEUE_SIZE_MAX, slots_num, txq_id); 421 TFD_QUEUE_SIZE_MAX, slots_num, txq_id);
422 422
423 /* Tell device where to find queue */ 423 /* Tell device where to find queue */
424 priv->cfg->ops->lib->txq_init(priv, txq); 424 il->cfg->ops->lib->txq_init(il, txq);
425} 425}
426EXPORT_SYMBOL(il_tx_queue_reset); 426EXPORT_SYMBOL(il_tx_queue_reset);
427 427
@@ -429,16 +429,16 @@ EXPORT_SYMBOL(il_tx_queue_reset);
429 429
430/** 430/**
431 * il_enqueue_hcmd - enqueue a uCode command 431 * il_enqueue_hcmd - enqueue a uCode command
432 * @priv: device private data point 432 * @il: device ilate data point
433 * @cmd: a point to the ucode command structure 433 * @cmd: a point to the ucode command structure
434 * 434 *
435 * The function returns < 0 values to indicate the operation is 435 * The function returns < 0 values to indicate the operation is
436 * failed. On success, it turns the index (> 0) of command in the 436 * failed. On success, it turns the index (> 0) of command in the
437 * command queue. 437 * command queue.
438 */ 438 */
439int il_enqueue_hcmd(struct il_priv *priv, struct il_host_cmd *cmd) 439int il_enqueue_hcmd(struct il_priv *il, struct il_host_cmd *cmd)
440{ 440{
441 struct il_tx_queue *txq = &priv->txq[priv->cmd_queue]; 441 struct il_tx_queue *txq = &il->txq[il->cmd_queue];
442 struct il_queue *q = &txq->q; 442 struct il_queue *q = &txq->q;
443 struct il_device_cmd *out_cmd; 443 struct il_device_cmd *out_cmd;
444 struct il_cmd_meta *out_meta; 444 struct il_cmd_meta *out_meta;
@@ -448,7 +448,7 @@ int il_enqueue_hcmd(struct il_priv *priv, struct il_host_cmd *cmd)
448 u32 idx; 448 u32 idx;
449 u16 fix_size; 449 u16 fix_size;
450 450
451 cmd->len = priv->cfg->ops->utils->get_hcmd_size(cmd->id, cmd->len); 451 cmd->len = il->cfg->ops->utils->get_hcmd_size(cmd->id, cmd->len);
452 fix_size = (u16)(cmd->len + sizeof(out_cmd->hdr)); 452 fix_size = (u16)(cmd->len + sizeof(out_cmd->hdr));
453 453
454 /* If any of the command structures end up being larger than 454 /* If any of the command structures end up being larger than
@@ -460,19 +460,19 @@ int il_enqueue_hcmd(struct il_priv *priv, struct il_host_cmd *cmd)
460 !(cmd->flags & CMD_SIZE_HUGE)); 460 !(cmd->flags & CMD_SIZE_HUGE));
461 BUG_ON(fix_size > IL_MAX_CMD_SIZE); 461 BUG_ON(fix_size > IL_MAX_CMD_SIZE);
462 462
463 if (il_is_rfkill(priv) || il_is_ctkill(priv)) { 463 if (il_is_rfkill(il) || il_is_ctkill(il)) {
464 IL_WARN(priv, "Not sending command - %s KILL\n", 464 IL_WARN(il, "Not sending command - %s KILL\n",
465 il_is_rfkill(priv) ? "RF" : "CT"); 465 il_is_rfkill(il) ? "RF" : "CT");
466 return -EIO; 466 return -EIO;
467 } 467 }
468 468
469 spin_lock_irqsave(&priv->hcmd_lock, flags); 469 spin_lock_irqsave(&il->hcmd_lock, flags);
470 470
471 if (il_queue_space(q) < ((cmd->flags & CMD_ASYNC) ? 2 : 1)) { 471 if (il_queue_space(q) < ((cmd->flags & CMD_ASYNC) ? 2 : 1)) {
472 spin_unlock_irqrestore(&priv->hcmd_lock, flags); 472 spin_unlock_irqrestore(&il->hcmd_lock, flags);
473 473
474 IL_ERR(priv, "Restarting adapter due to command queue full\n"); 474 IL_ERR(il, "Restarting adapter due to command queue full\n");
475 queue_work(priv->workqueue, &priv->restart); 475 queue_work(il->workqueue, &il->restart);
476 return -ENOSPC; 476 return -ENOSPC;
477 } 477 }
478 478
@@ -481,7 +481,7 @@ int il_enqueue_hcmd(struct il_priv *priv, struct il_host_cmd *cmd)
481 out_meta = &txq->meta[idx]; 481 out_meta = &txq->meta[idx];
482 482
483 if (WARN_ON(out_meta->flags & CMD_MAPPED)) { 483 if (WARN_ON(out_meta->flags & CMD_MAPPED)) {
484 spin_unlock_irqrestore(&priv->hcmd_lock, flags); 484 spin_unlock_irqrestore(&il->hcmd_lock, flags);
485 return -ENOSPC; 485 return -ENOSPC;
486 } 486 }
487 487
@@ -499,7 +499,7 @@ int il_enqueue_hcmd(struct il_priv *priv, struct il_host_cmd *cmd)
499 * information */ 499 * information */
500 500
501 out_cmd->hdr.flags = 0; 501 out_cmd->hdr.flags = 0;
502 out_cmd->hdr.sequence = cpu_to_le16(QUEUE_TO_SEQ(priv->cmd_queue) | 502 out_cmd->hdr.sequence = cpu_to_le16(QUEUE_TO_SEQ(il->cmd_queue) |
503 INDEX_TO_SEQ(q->write_ptr)); 503 INDEX_TO_SEQ(q->write_ptr));
504 if (cmd->flags & CMD_SIZE_HUGE) 504 if (cmd->flags & CMD_SIZE_HUGE)
505 out_cmd->hdr.sequence |= SEQ_HUGE_FRAME; 505 out_cmd->hdr.sequence |= SEQ_HUGE_FRAME;
@@ -511,43 +511,43 @@ int il_enqueue_hcmd(struct il_priv *priv, struct il_host_cmd *cmd)
511 switch (out_cmd->hdr.cmd) { 511 switch (out_cmd->hdr.cmd) {
512 case REPLY_TX_LINK_QUALITY_CMD: 512 case REPLY_TX_LINK_QUALITY_CMD:
513 case SENSITIVITY_CMD: 513 case SENSITIVITY_CMD:
514 IL_DEBUG_HC_DUMP(priv, 514 IL_DEBUG_HC_DUMP(il,
515 "Sending command %s (#%x), seq: 0x%04X, " 515 "Sending command %s (#%x), seq: 0x%04X, "
516 "%d bytes at %d[%d]:%d\n", 516 "%d bytes at %d[%d]:%d\n",
517 il_get_cmd_string(out_cmd->hdr.cmd), 517 il_get_cmd_string(out_cmd->hdr.cmd),
518 out_cmd->hdr.cmd, 518 out_cmd->hdr.cmd,
519 le16_to_cpu(out_cmd->hdr.sequence), fix_size, 519 le16_to_cpu(out_cmd->hdr.sequence), fix_size,
520 q->write_ptr, idx, priv->cmd_queue); 520 q->write_ptr, idx, il->cmd_queue);
521 break; 521 break;
522 default: 522 default:
523 IL_DEBUG_HC(priv, "Sending command %s (#%x), seq: 0x%04X, " 523 IL_DEBUG_HC(il, "Sending command %s (#%x), seq: 0x%04X, "
524 "%d bytes at %d[%d]:%d\n", 524 "%d bytes at %d[%d]:%d\n",
525 il_get_cmd_string(out_cmd->hdr.cmd), 525 il_get_cmd_string(out_cmd->hdr.cmd),
526 out_cmd->hdr.cmd, 526 out_cmd->hdr.cmd,
527 le16_to_cpu(out_cmd->hdr.sequence), fix_size, 527 le16_to_cpu(out_cmd->hdr.sequence), fix_size,
528 q->write_ptr, idx, priv->cmd_queue); 528 q->write_ptr, idx, il->cmd_queue);
529 } 529 }
530#endif 530#endif
531 txq->need_update = 1; 531 txq->need_update = 1;
532 532
533 if (priv->cfg->ops->lib->txq_update_byte_cnt_tbl) 533 if (il->cfg->ops->lib->txq_update_byte_cnt_tbl)
534 /* Set up entry in queue's byte count circular buffer */ 534 /* Set up entry in queue's byte count circular buffer */
535 priv->cfg->ops->lib->txq_update_byte_cnt_tbl(priv, txq, 0); 535 il->cfg->ops->lib->txq_update_byte_cnt_tbl(il, txq, 0);
536 536
537 phys_addr = pci_map_single(priv->pci_dev, &out_cmd->hdr, 537 phys_addr = pci_map_single(il->pci_dev, &out_cmd->hdr,
538 fix_size, PCI_DMA_BIDIRECTIONAL); 538 fix_size, PCI_DMA_BIDIRECTIONAL);
539 dma_unmap_addr_set(out_meta, mapping, phys_addr); 539 dma_unmap_addr_set(out_meta, mapping, phys_addr);
540 dma_unmap_len_set(out_meta, len, fix_size); 540 dma_unmap_len_set(out_meta, len, fix_size);
541 541
542 priv->cfg->ops->lib->txq_attach_buf_to_tfd(priv, txq, 542 il->cfg->ops->lib->txq_attach_buf_to_tfd(il, txq,
543 phys_addr, fix_size, 1, 543 phys_addr, fix_size, 1,
544 U32_PAD(cmd->len)); 544 U32_PAD(cmd->len));
545 545
546 /* Increment and update queue's write index */ 546 /* Increment and update queue's write index */
547 q->write_ptr = il_queue_inc_wrap(q->write_ptr, q->n_bd); 547 q->write_ptr = il_queue_inc_wrap(q->write_ptr, q->n_bd);
548 il_txq_update_write_ptr(priv, txq); 548 il_txq_update_write_ptr(il, txq);
549 549
550 spin_unlock_irqrestore(&priv->hcmd_lock, flags); 550 spin_unlock_irqrestore(&il->hcmd_lock, flags);
551 return idx; 551 return idx;
552} 552}
553 553
@@ -558,15 +558,15 @@ int il_enqueue_hcmd(struct il_priv *priv, struct il_host_cmd *cmd)
558 * need to be reclaimed. As result, some free space forms. If there is 558 * need to be reclaimed. As result, some free space forms. If there is
559 * enough free space (> low mark), wake the stack that feeds us. 559 * enough free space (> low mark), wake the stack that feeds us.
560 */ 560 */
561static void il_hcmd_queue_reclaim(struct il_priv *priv, int txq_id, 561static void il_hcmd_queue_reclaim(struct il_priv *il, int txq_id,
562 int idx, int cmd_idx) 562 int idx, int cmd_idx)
563{ 563{
564 struct il_tx_queue *txq = &priv->txq[txq_id]; 564 struct il_tx_queue *txq = &il->txq[txq_id];
565 struct il_queue *q = &txq->q; 565 struct il_queue *q = &txq->q;
566 int nfreed = 0; 566 int nfreed = 0;
567 567
568 if ((idx >= q->n_bd) || (il_queue_used(q, idx) == 0)) { 568 if ((idx >= q->n_bd) || (il_queue_used(q, idx) == 0)) {
569 IL_ERR(priv, "Read index for DMA queue txq id (%d), index %d, " 569 IL_ERR(il, "Read index for DMA queue txq id (%d), index %d, "
570 "is out of range [0-%d] %d %d.\n", txq_id, 570 "is out of range [0-%d] %d %d.\n", txq_id,
571 idx, q->n_bd, q->write_ptr, q->read_ptr); 571 idx, q->n_bd, q->write_ptr, q->read_ptr);
572 return; 572 return;
@@ -576,9 +576,9 @@ static void il_hcmd_queue_reclaim(struct il_priv *priv, int txq_id,
576 q->read_ptr = il_queue_inc_wrap(q->read_ptr, q->n_bd)) { 576 q->read_ptr = il_queue_inc_wrap(q->read_ptr, q->n_bd)) {
577 577
578 if (nfreed++ > 0) { 578 if (nfreed++ > 0) {
579 IL_ERR(priv, "HCMD skipped: index (%d) %d %d\n", idx, 579 IL_ERR(il, "HCMD skipped: index (%d) %d %d\n", idx,
580 q->write_ptr, q->read_ptr); 580 q->write_ptr, q->read_ptr);
581 queue_work(priv->workqueue, &priv->restart); 581 queue_work(il->workqueue, &il->restart);
582 } 582 }
583 583
584 } 584 }
@@ -593,7 +593,7 @@ static void il_hcmd_queue_reclaim(struct il_priv *priv, int txq_id,
593 * if the callback returns 1 593 * if the callback returns 1
594 */ 594 */
595void 595void
596il_tx_cmd_complete(struct il_priv *priv, struct il_rx_mem_buffer *rxb) 596il_tx_cmd_complete(struct il_priv *il, struct il_rx_mem_buffer *rxb)
597{ 597{
598 struct il_rx_packet *pkt = rxb_addr(rxb); 598 struct il_rx_packet *pkt = rxb_addr(rxb);
599 u16 sequence = le16_to_cpu(pkt->hdr.sequence); 599 u16 sequence = le16_to_cpu(pkt->hdr.sequence);
@@ -603,18 +603,18 @@ il_tx_cmd_complete(struct il_priv *priv, struct il_rx_mem_buffer *rxb)
603 bool huge = !!(pkt->hdr.sequence & SEQ_HUGE_FRAME); 603 bool huge = !!(pkt->hdr.sequence & SEQ_HUGE_FRAME);
604 struct il_device_cmd *cmd; 604 struct il_device_cmd *cmd;
605 struct il_cmd_meta *meta; 605 struct il_cmd_meta *meta;
606 struct il_tx_queue *txq = &priv->txq[priv->cmd_queue]; 606 struct il_tx_queue *txq = &il->txq[il->cmd_queue];
607 unsigned long flags; 607 unsigned long flags;
608 608
609 /* If a Tx command is being handled and it isn't in the actual 609 /* If a Tx command is being handled and it isn't in the actual
610 * command queue then there a command routing bug has been introduced 610 * command queue then there a command routing bug has been introduced
611 * in the queue management code. */ 611 * in the queue management code. */
612 if (WARN(txq_id != priv->cmd_queue, 612 if (WARN(txq_id != il->cmd_queue,
613 "wrong command queue %d (should be %d), sequence 0x%X readp=%d writep=%d\n", 613 "wrong command queue %d (should be %d), sequence 0x%X readp=%d writep=%d\n",
614 txq_id, priv->cmd_queue, sequence, 614 txq_id, il->cmd_queue, sequence,
615 priv->txq[priv->cmd_queue].q.read_ptr, 615 il->txq[il->cmd_queue].q.read_ptr,
616 priv->txq[priv->cmd_queue].q.write_ptr)) { 616 il->txq[il->cmd_queue].q.write_ptr)) {
617 il_print_hex_error(priv, pkt, 32); 617 il_print_hex_error(il, pkt, 32);
618 return; 618 return;
619 } 619 }
620 620
@@ -624,7 +624,7 @@ il_tx_cmd_complete(struct il_priv *priv, struct il_rx_mem_buffer *rxb)
624 624
625 txq->time_stamp = jiffies; 625 txq->time_stamp = jiffies;
626 626
627 pci_unmap_single(priv->pci_dev, 627 pci_unmap_single(il->pci_dev,
628 dma_unmap_addr(meta, mapping), 628 dma_unmap_addr(meta, mapping),
629 dma_unmap_len(meta, len), 629 dma_unmap_len(meta, len),
630 PCI_DMA_BIDIRECTIONAL); 630 PCI_DMA_BIDIRECTIONAL);
@@ -634,22 +634,22 @@ il_tx_cmd_complete(struct il_priv *priv, struct il_rx_mem_buffer *rxb)
634 meta->source->reply_page = (unsigned long)rxb_addr(rxb); 634 meta->source->reply_page = (unsigned long)rxb_addr(rxb);
635 rxb->page = NULL; 635 rxb->page = NULL;
636 } else if (meta->callback) 636 } else if (meta->callback)
637 meta->callback(priv, cmd, pkt); 637 meta->callback(il, cmd, pkt);
638 638
639 spin_lock_irqsave(&priv->hcmd_lock, flags); 639 spin_lock_irqsave(&il->hcmd_lock, flags);
640 640
641 il_hcmd_queue_reclaim(priv, txq_id, index, cmd_index); 641 il_hcmd_queue_reclaim(il, txq_id, index, cmd_index);
642 642
643 if (!(meta->flags & CMD_ASYNC)) { 643 if (!(meta->flags & CMD_ASYNC)) {
644 clear_bit(STATUS_HCMD_ACTIVE, &priv->status); 644 clear_bit(STATUS_HCMD_ACTIVE, &il->status);
645 IL_DEBUG_INFO(priv, "Clearing HCMD_ACTIVE for command %s\n", 645 IL_DEBUG_INFO(il, "Clearing HCMD_ACTIVE for command %s\n",
646 il_get_cmd_string(cmd->hdr.cmd)); 646 il_get_cmd_string(cmd->hdr.cmd));
647 wake_up(&priv->wait_command_queue); 647 wake_up(&il->wait_command_queue);
648 } 648 }
649 649
650 /* Mark as unmapped */ 650 /* Mark as unmapped */
651 meta->flags = 0; 651 meta->flags = 0;
652 652
653 spin_unlock_irqrestore(&priv->hcmd_lock, flags); 653 spin_unlock_irqrestore(&il->hcmd_lock, flags);
654} 654}
655EXPORT_SYMBOL(il_tx_cmd_complete); 655EXPORT_SYMBOL(il_tx_cmd_complete);
diff --git a/drivers/net/wireless/iwlegacy/iwl3945-base.c b/drivers/net/wireless/iwlegacy/iwl3945-base.c
index d24937a0014a..2c336a701dc5 100644
--- a/drivers/net/wireless/iwlegacy/iwl3945-base.c
+++ b/drivers/net/wireless/iwlegacy/iwl3945-base.c
@@ -98,18 +98,18 @@ struct il_mod_params il3945_mod_params = {
98 98
99/** 99/**
100 * il3945_get_antenna_flags - Get antenna flags for RXON command 100 * il3945_get_antenna_flags - Get antenna flags for RXON command
101 * @priv: eeprom and antenna fields are used to determine antenna flags 101 * @il: eeprom and antenna fields are used to determine antenna flags
102 * 102 *
103 * priv->eeprom39 is used to determine if antenna AUX/MAIN are reversed 103 * il->eeprom39 is used to determine if antenna AUX/MAIN are reversed
104 * il3945_mod_params.antenna specifies the antenna diversity mode: 104 * il3945_mod_params.antenna specifies the antenna diversity mode:
105 * 105 *
106 * IL_ANTENNA_DIVERSITY - NIC selects best antenna by itself 106 * IL_ANTENNA_DIVERSITY - NIC selects best antenna by itself
107 * IL_ANTENNA_MAIN - Force MAIN antenna 107 * IL_ANTENNA_MAIN - Force MAIN antenna
108 * IL_ANTENNA_AUX - Force AUX antenna 108 * IL_ANTENNA_AUX - Force AUX antenna
109 */ 109 */
110__le32 il3945_get_antenna_flags(const struct il_priv *priv) 110__le32 il3945_get_antenna_flags(const struct il_priv *il)
111{ 111{
112 struct il3945_eeprom *eeprom = (struct il3945_eeprom *)priv->eeprom; 112 struct il3945_eeprom *eeprom = (struct il3945_eeprom *)il->eeprom;
113 113
114 switch (il3945_mod_params.antenna) { 114 switch (il3945_mod_params.antenna) {
115 case IL_ANTENNA_DIVERSITY: 115 case IL_ANTENNA_DIVERSITY:
@@ -127,13 +127,13 @@ __le32 il3945_get_antenna_flags(const struct il_priv *priv)
127 } 127 }
128 128
129 /* bad antenna selector value */ 129 /* bad antenna selector value */
130 IL_ERR(priv, "Bad antenna selector value (0x%x)\n", 130 IL_ERR(il, "Bad antenna selector value (0x%x)\n",
131 il3945_mod_params.antenna); 131 il3945_mod_params.antenna);
132 132
133 return 0; /* "diversity" is default if error */ 133 return 0; /* "diversity" is default if error */
134} 134}
135 135
136static int il3945_set_ccmp_dynamic_key_info(struct il_priv *priv, 136static int il3945_set_ccmp_dynamic_key_info(struct il_priv *il,
137 struct ieee80211_key_conf *keyconf, 137 struct ieee80211_key_conf *keyconf,
138 u8 sta_id) 138 u8 sta_id)
139{ 139{
@@ -144,80 +144,80 @@ static int il3945_set_ccmp_dynamic_key_info(struct il_priv *priv,
144 key_flags |= (STA_KEY_FLG_CCMP | STA_KEY_FLG_MAP_KEY_MSK); 144 key_flags |= (STA_KEY_FLG_CCMP | STA_KEY_FLG_MAP_KEY_MSK);
145 key_flags |= cpu_to_le16(keyconf->keyidx << STA_KEY_FLG_KEYID_POS); 145 key_flags |= cpu_to_le16(keyconf->keyidx << STA_KEY_FLG_KEYID_POS);
146 146
147 if (sta_id == priv->contexts[IL_RXON_CTX_BSS].bcast_sta_id) 147 if (sta_id == il->contexts[IL_RXON_CTX_BSS].bcast_sta_id)
148 key_flags |= STA_KEY_MULTICAST_MSK; 148 key_flags |= STA_KEY_MULTICAST_MSK;
149 149
150 keyconf->flags |= IEEE80211_KEY_FLAG_GENERATE_IV; 150 keyconf->flags |= IEEE80211_KEY_FLAG_GENERATE_IV;
151 keyconf->hw_key_idx = keyconf->keyidx; 151 keyconf->hw_key_idx = keyconf->keyidx;
152 key_flags &= ~STA_KEY_FLG_INVALID; 152 key_flags &= ~STA_KEY_FLG_INVALID;
153 153
154 spin_lock_irqsave(&priv->sta_lock, flags); 154 spin_lock_irqsave(&il->sta_lock, flags);
155 priv->stations[sta_id].keyinfo.cipher = keyconf->cipher; 155 il->stations[sta_id].keyinfo.cipher = keyconf->cipher;
156 priv->stations[sta_id].keyinfo.keylen = keyconf->keylen; 156 il->stations[sta_id].keyinfo.keylen = keyconf->keylen;
157 memcpy(priv->stations[sta_id].keyinfo.key, keyconf->key, 157 memcpy(il->stations[sta_id].keyinfo.key, keyconf->key,
158 keyconf->keylen); 158 keyconf->keylen);
159 159
160 memcpy(priv->stations[sta_id].sta.key.key, keyconf->key, 160 memcpy(il->stations[sta_id].sta.key.key, keyconf->key,
161 keyconf->keylen); 161 keyconf->keylen);
162 162
163 if ((priv->stations[sta_id].sta.key.key_flags & STA_KEY_FLG_ENCRYPT_MSK) 163 if ((il->stations[sta_id].sta.key.key_flags & STA_KEY_FLG_ENCRYPT_MSK)
164 == STA_KEY_FLG_NO_ENC) 164 == STA_KEY_FLG_NO_ENC)
165 priv->stations[sta_id].sta.key.key_offset = 165 il->stations[sta_id].sta.key.key_offset =
166 il_get_free_ucode_key_index(priv); 166 il_get_free_ucode_key_index(il);
167 /* else, we are overriding an existing key => no need to allocated room 167 /* else, we are overriding an existing key => no need to allocated room
168 * in uCode. */ 168 * in uCode. */
169 169
170 WARN(priv->stations[sta_id].sta.key.key_offset == WEP_INVALID_OFFSET, 170 WARN(il->stations[sta_id].sta.key.key_offset == WEP_INVALID_OFFSET,
171 "no space for a new key"); 171 "no space for a new key");
172 172
173 priv->stations[sta_id].sta.key.key_flags = key_flags; 173 il->stations[sta_id].sta.key.key_flags = key_flags;
174 priv->stations[sta_id].sta.sta.modify_mask = STA_MODIFY_KEY_MASK; 174 il->stations[sta_id].sta.sta.modify_mask = STA_MODIFY_KEY_MASK;
175 priv->stations[sta_id].sta.mode = STA_CONTROL_MODIFY_MSK; 175 il->stations[sta_id].sta.mode = STA_CONTROL_MODIFY_MSK;
176 176
177 IL_DEBUG_INFO(priv, "hwcrypto: modify ucode station key info\n"); 177 IL_DEBUG_INFO(il, "hwcrypto: modify ucode station key info\n");
178 178
179 ret = il_send_add_sta(priv, 179 ret = il_send_add_sta(il,
180 &priv->stations[sta_id].sta, CMD_ASYNC); 180 &il->stations[sta_id].sta, CMD_ASYNC);
181 181
182 spin_unlock_irqrestore(&priv->sta_lock, flags); 182 spin_unlock_irqrestore(&il->sta_lock, flags);
183 183
184 return ret; 184 return ret;
185} 185}
186 186
187static int il3945_set_tkip_dynamic_key_info(struct il_priv *priv, 187static int il3945_set_tkip_dynamic_key_info(struct il_priv *il,
188 struct ieee80211_key_conf *keyconf, 188 struct ieee80211_key_conf *keyconf,
189 u8 sta_id) 189 u8 sta_id)
190{ 190{
191 return -EOPNOTSUPP; 191 return -EOPNOTSUPP;
192} 192}
193 193
194static int il3945_set_wep_dynamic_key_info(struct il_priv *priv, 194static int il3945_set_wep_dynamic_key_info(struct il_priv *il,
195 struct ieee80211_key_conf *keyconf, 195 struct ieee80211_key_conf *keyconf,
196 u8 sta_id) 196 u8 sta_id)
197{ 197{
198 return -EOPNOTSUPP; 198 return -EOPNOTSUPP;
199} 199}
200 200
201static int il3945_clear_sta_key_info(struct il_priv *priv, u8 sta_id) 201static int il3945_clear_sta_key_info(struct il_priv *il, u8 sta_id)
202{ 202{
203 unsigned long flags; 203 unsigned long flags;
204 struct il_addsta_cmd sta_cmd; 204 struct il_addsta_cmd sta_cmd;
205 205
206 spin_lock_irqsave(&priv->sta_lock, flags); 206 spin_lock_irqsave(&il->sta_lock, flags);
207 memset(&priv->stations[sta_id].keyinfo, 0, sizeof(struct il_hw_key)); 207 memset(&il->stations[sta_id].keyinfo, 0, sizeof(struct il_hw_key));
208 memset(&priv->stations[sta_id].sta.key, 0, 208 memset(&il->stations[sta_id].sta.key, 0,
209 sizeof(struct il4965_keyinfo)); 209 sizeof(struct il4965_keyinfo));
210 priv->stations[sta_id].sta.key.key_flags = STA_KEY_FLG_NO_ENC; 210 il->stations[sta_id].sta.key.key_flags = STA_KEY_FLG_NO_ENC;
211 priv->stations[sta_id].sta.sta.modify_mask = STA_MODIFY_KEY_MASK; 211 il->stations[sta_id].sta.sta.modify_mask = STA_MODIFY_KEY_MASK;
212 priv->stations[sta_id].sta.mode = STA_CONTROL_MODIFY_MSK; 212 il->stations[sta_id].sta.mode = STA_CONTROL_MODIFY_MSK;
213 memcpy(&sta_cmd, &priv->stations[sta_id].sta, sizeof(struct il_addsta_cmd)); 213 memcpy(&sta_cmd, &il->stations[sta_id].sta, sizeof(struct il_addsta_cmd));
214 spin_unlock_irqrestore(&priv->sta_lock, flags); 214 spin_unlock_irqrestore(&il->sta_lock, flags);
215 215
216 IL_DEBUG_INFO(priv, "hwcrypto: clear ucode station key info\n"); 216 IL_DEBUG_INFO(il, "hwcrypto: clear ucode station key info\n");
217 return il_send_add_sta(priv, &sta_cmd, CMD_SYNC); 217 return il_send_add_sta(il, &sta_cmd, CMD_SYNC);
218} 218}
219 219
220static int il3945_set_dynamic_key(struct il_priv *priv, 220static int il3945_set_dynamic_key(struct il_priv *il,
221 struct ieee80211_key_conf *keyconf, u8 sta_id) 221 struct ieee80211_key_conf *keyconf, u8 sta_id)
222{ 222{
223 int ret = 0; 223 int ret = 0;
@@ -226,154 +226,154 @@ static int il3945_set_dynamic_key(struct il_priv *priv,
226 226
227 switch (keyconf->cipher) { 227 switch (keyconf->cipher) {
228 case WLAN_CIPHER_SUITE_CCMP: 228 case WLAN_CIPHER_SUITE_CCMP:
229 ret = il3945_set_ccmp_dynamic_key_info(priv, keyconf, sta_id); 229 ret = il3945_set_ccmp_dynamic_key_info(il, keyconf, sta_id);
230 break; 230 break;
231 case WLAN_CIPHER_SUITE_TKIP: 231 case WLAN_CIPHER_SUITE_TKIP:
232 ret = il3945_set_tkip_dynamic_key_info(priv, keyconf, sta_id); 232 ret = il3945_set_tkip_dynamic_key_info(il, keyconf, sta_id);
233 break; 233 break;
234 case WLAN_CIPHER_SUITE_WEP40: 234 case WLAN_CIPHER_SUITE_WEP40:
235 case WLAN_CIPHER_SUITE_WEP104: 235 case WLAN_CIPHER_SUITE_WEP104:
236 ret = il3945_set_wep_dynamic_key_info(priv, keyconf, sta_id); 236 ret = il3945_set_wep_dynamic_key_info(il, keyconf, sta_id);
237 break; 237 break;
238 default: 238 default:
239 IL_ERR(priv, "Unknown alg: %s alg=%x\n", __func__, 239 IL_ERR(il, "Unknown alg: %s alg=%x\n", __func__,
240 keyconf->cipher); 240 keyconf->cipher);
241 ret = -EINVAL; 241 ret = -EINVAL;
242 } 242 }
243 243
244 IL_DEBUG_WEP(priv, "Set dynamic key: alg=%x len=%d idx=%d sta=%d ret=%d\n", 244 IL_DEBUG_WEP(il, "Set dynamic key: alg=%x len=%d idx=%d sta=%d ret=%d\n",
245 keyconf->cipher, keyconf->keylen, keyconf->keyidx, 245 keyconf->cipher, keyconf->keylen, keyconf->keyidx,
246 sta_id, ret); 246 sta_id, ret);
247 247
248 return ret; 248 return ret;
249} 249}
250 250
251static int il3945_remove_static_key(struct il_priv *priv) 251static int il3945_remove_static_key(struct il_priv *il)
252{ 252{
253 int ret = -EOPNOTSUPP; 253 int ret = -EOPNOTSUPP;
254 254
255 return ret; 255 return ret;
256} 256}
257 257
258static int il3945_set_static_key(struct il_priv *priv, 258static int il3945_set_static_key(struct il_priv *il,
259 struct ieee80211_key_conf *key) 259 struct ieee80211_key_conf *key)
260{ 260{
261 if (key->cipher == WLAN_CIPHER_SUITE_WEP40 || 261 if (key->cipher == WLAN_CIPHER_SUITE_WEP40 ||
262 key->cipher == WLAN_CIPHER_SUITE_WEP104) 262 key->cipher == WLAN_CIPHER_SUITE_WEP104)
263 return -EOPNOTSUPP; 263 return -EOPNOTSUPP;
264 264
265 IL_ERR(priv, "Static key invalid: cipher %x\n", key->cipher); 265 IL_ERR(il, "Static key invalid: cipher %x\n", key->cipher);
266 return -EINVAL; 266 return -EINVAL;
267} 267}
268 268
269static void il3945_clear_free_frames(struct il_priv *priv) 269static void il3945_clear_free_frames(struct il_priv *il)
270{ 270{
271 struct list_head *element; 271 struct list_head *element;
272 272
273 IL_DEBUG_INFO(priv, "%d frames on pre-allocated heap on clear.\n", 273 IL_DEBUG_INFO(il, "%d frames on pre-allocated heap on clear.\n",
274 priv->frames_count); 274 il->frames_count);
275 275
276 while (!list_empty(&priv->free_frames)) { 276 while (!list_empty(&il->free_frames)) {
277 element = priv->free_frames.next; 277 element = il->free_frames.next;
278 list_del(element); 278 list_del(element);
279 kfree(list_entry(element, struct il3945_frame, list)); 279 kfree(list_entry(element, struct il3945_frame, list));
280 priv->frames_count--; 280 il->frames_count--;
281 } 281 }
282 282
283 if (priv->frames_count) { 283 if (il->frames_count) {
284 IL_WARN(priv, "%d frames still in use. Did we lose one?\n", 284 IL_WARN(il, "%d frames still in use. Did we lose one?\n",
285 priv->frames_count); 285 il->frames_count);
286 priv->frames_count = 0; 286 il->frames_count = 0;
287 } 287 }
288} 288}
289 289
290static struct il3945_frame *il3945_get_free_frame(struct il_priv *priv) 290static struct il3945_frame *il3945_get_free_frame(struct il_priv *il)
291{ 291{
292 struct il3945_frame *frame; 292 struct il3945_frame *frame;
293 struct list_head *element; 293 struct list_head *element;
294 if (list_empty(&priv->free_frames)) { 294 if (list_empty(&il->free_frames)) {
295 frame = kzalloc(sizeof(*frame), GFP_KERNEL); 295 frame = kzalloc(sizeof(*frame), GFP_KERNEL);
296 if (!frame) { 296 if (!frame) {
297 IL_ERR(priv, "Could not allocate frame!\n"); 297 IL_ERR(il, "Could not allocate frame!\n");
298 return NULL; 298 return NULL;
299 } 299 }
300 300
301 priv->frames_count++; 301 il->frames_count++;
302 return frame; 302 return frame;
303 } 303 }
304 304
305 element = priv->free_frames.next; 305 element = il->free_frames.next;
306 list_del(element); 306 list_del(element);
307 return list_entry(element, struct il3945_frame, list); 307 return list_entry(element, struct il3945_frame, list);
308} 308}
309 309
310static void il3945_free_frame(struct il_priv *priv, struct il3945_frame *frame) 310static void il3945_free_frame(struct il_priv *il, struct il3945_frame *frame)
311{ 311{
312 memset(frame, 0, sizeof(*frame)); 312 memset(frame, 0, sizeof(*frame));
313 list_add(&frame->list, &priv->free_frames); 313 list_add(&frame->list, &il->free_frames);
314} 314}
315 315
316unsigned int il3945_fill_beacon_frame(struct il_priv *priv, 316unsigned int il3945_fill_beacon_frame(struct il_priv *il,
317 struct ieee80211_hdr *hdr, 317 struct ieee80211_hdr *hdr,
318 int left) 318 int left)
319{ 319{
320 320
321 if (!il_is_associated(priv, IL_RXON_CTX_BSS) || !priv->beacon_skb) 321 if (!il_is_associated(il, IL_RXON_CTX_BSS) || !il->beacon_skb)
322 return 0; 322 return 0;
323 323
324 if (priv->beacon_skb->len > left) 324 if (il->beacon_skb->len > left)
325 return 0; 325 return 0;
326 326
327 memcpy(hdr, priv->beacon_skb->data, priv->beacon_skb->len); 327 memcpy(hdr, il->beacon_skb->data, il->beacon_skb->len);
328 328
329 return priv->beacon_skb->len; 329 return il->beacon_skb->len;
330} 330}
331 331
332static int il3945_send_beacon_cmd(struct il_priv *priv) 332static int il3945_send_beacon_cmd(struct il_priv *il)
333{ 333{
334 struct il3945_frame *frame; 334 struct il3945_frame *frame;
335 unsigned int frame_size; 335 unsigned int frame_size;
336 int rc; 336 int rc;
337 u8 rate; 337 u8 rate;
338 338
339 frame = il3945_get_free_frame(priv); 339 frame = il3945_get_free_frame(il);
340 340
341 if (!frame) { 341 if (!frame) {
342 IL_ERR(priv, "Could not obtain free frame buffer for beacon " 342 IL_ERR(il, "Could not obtain free frame buffer for beacon "
343 "command.\n"); 343 "command.\n");
344 return -ENOMEM; 344 return -ENOMEM;
345 } 345 }
346 346
347 rate = il_get_lowest_plcp(priv, 347 rate = il_get_lowest_plcp(il,
348 &priv->contexts[IL_RXON_CTX_BSS]); 348 &il->contexts[IL_RXON_CTX_BSS]);
349 349
350 frame_size = il3945_hw_get_beacon_cmd(priv, frame, rate); 350 frame_size = il3945_hw_get_beacon_cmd(il, frame, rate);
351 351
352 rc = il_send_cmd_pdu(priv, REPLY_TX_BEACON, frame_size, 352 rc = il_send_cmd_pdu(il, REPLY_TX_BEACON, frame_size,
353 &frame->u.cmd[0]); 353 &frame->u.cmd[0]);
354 354
355 il3945_free_frame(priv, frame); 355 il3945_free_frame(il, frame);
356 356
357 return rc; 357 return rc;
358} 358}
359 359
360static void il3945_unset_hw_params(struct il_priv *priv) 360static void il3945_unset_hw_params(struct il_priv *il)
361{ 361{
362 if (priv->_3945.shared_virt) 362 if (il->_3945.shared_virt)
363 dma_free_coherent(&priv->pci_dev->dev, 363 dma_free_coherent(&il->pci_dev->dev,
364 sizeof(struct il3945_shared), 364 sizeof(struct il3945_shared),
365 priv->_3945.shared_virt, 365 il->_3945.shared_virt,
366 priv->_3945.shared_phys); 366 il->_3945.shared_phys);
367} 367}
368 368
369static void il3945_build_tx_cmd_hwcrypto(struct il_priv *priv, 369static void il3945_build_tx_cmd_hwcrypto(struct il_priv *il,
370 struct ieee80211_tx_info *info, 370 struct ieee80211_tx_info *info,
371 struct il_device_cmd *cmd, 371 struct il_device_cmd *cmd,
372 struct sk_buff *skb_frag, 372 struct sk_buff *skb_frag,
373 int sta_id) 373 int sta_id)
374{ 374{
375 struct il3945_tx_cmd *tx_cmd = (struct il3945_tx_cmd *)cmd->cmd.payload; 375 struct il3945_tx_cmd *tx_cmd = (struct il3945_tx_cmd *)cmd->cmd.payload;
376 struct il_hw_key *keyinfo = &priv->stations[sta_id].keyinfo; 376 struct il_hw_key *keyinfo = &il->stations[sta_id].keyinfo;
377 377
378 tx_cmd->sec_ctl = 0; 378 tx_cmd->sec_ctl = 0;
379 379
@@ -381,7 +381,7 @@ static void il3945_build_tx_cmd_hwcrypto(struct il_priv *priv,
381 case WLAN_CIPHER_SUITE_CCMP: 381 case WLAN_CIPHER_SUITE_CCMP:
382 tx_cmd->sec_ctl = TX_CMD_SEC_CCM; 382 tx_cmd->sec_ctl = TX_CMD_SEC_CCM;
383 memcpy(tx_cmd->key, keyinfo->key, keyinfo->keylen); 383 memcpy(tx_cmd->key, keyinfo->key, keyinfo->keylen);
384 IL_DEBUG_TX(priv, "tx_cmd with AES hwcrypto\n"); 384 IL_DEBUG_TX(il, "tx_cmd with AES hwcrypto\n");
385 break; 385 break;
386 386
387 case WLAN_CIPHER_SUITE_TKIP: 387 case WLAN_CIPHER_SUITE_TKIP:
@@ -396,12 +396,12 @@ static void il3945_build_tx_cmd_hwcrypto(struct il_priv *priv,
396 396
397 memcpy(&tx_cmd->key[3], keyinfo->key, keyinfo->keylen); 397 memcpy(&tx_cmd->key[3], keyinfo->key, keyinfo->keylen);
398 398
399 IL_DEBUG_TX(priv, "Configuring packet for WEP encryption " 399 IL_DEBUG_TX(il, "Configuring packet for WEP encryption "
400 "with key %d\n", info->control.hw_key->hw_key_idx); 400 "with key %d\n", info->control.hw_key->hw_key_idx);
401 break; 401 break;
402 402
403 default: 403 default:
404 IL_ERR(priv, "Unknown encode cipher %x\n", keyinfo->cipher); 404 IL_ERR(il, "Unknown encode cipher %x\n", keyinfo->cipher);
405 break; 405 break;
406 } 406 }
407} 407}
@@ -409,7 +409,7 @@ static void il3945_build_tx_cmd_hwcrypto(struct il_priv *priv,
409/* 409/*
410 * handle build REPLY_TX command notification. 410 * handle build REPLY_TX command notification.
411 */ 411 */
412static void il3945_build_tx_cmd_basic(struct il_priv *priv, 412static void il3945_build_tx_cmd_basic(struct il_priv *il,
413 struct il_device_cmd *cmd, 413 struct il_device_cmd *cmd,
414 struct ieee80211_tx_info *info, 414 struct ieee80211_tx_info *info,
415 struct ieee80211_hdr *hdr, u8 std_id) 415 struct ieee80211_hdr *hdr, u8 std_id)
@@ -443,7 +443,7 @@ static void il3945_build_tx_cmd_basic(struct il_priv *priv,
443 tx_flags |= TX_CMD_FLG_SEQ_CTL_MSK; 443 tx_flags |= TX_CMD_FLG_SEQ_CTL_MSK;
444 } 444 }
445 445
446 il_tx_cmd_protection(priv, info, fc, &tx_flags); 446 il_tx_cmd_protection(il, info, fc, &tx_flags);
447 447
448 tx_flags &= ~(TX_CMD_FLG_ANT_SEL_MSK); 448 tx_flags &= ~(TX_CMD_FLG_ANT_SEL_MSK);
449 if (ieee80211_is_mgmt(fc)) { 449 if (ieee80211_is_mgmt(fc)) {
@@ -463,7 +463,7 @@ static void il3945_build_tx_cmd_basic(struct il_priv *priv,
463/* 463/*
464 * start REPLY_TX command process 464 * start REPLY_TX command process
465 */ 465 */
466static int il3945_tx_skb(struct il_priv *priv, struct sk_buff *skb) 466static int il3945_tx_skb(struct il_priv *il, struct sk_buff *skb)
467{ 467{
468 struct ieee80211_hdr *hdr = (struct ieee80211_hdr *)skb->data; 468 struct ieee80211_hdr *hdr = (struct ieee80211_hdr *)skb->data;
469 struct ieee80211_tx_info *info = IEEE80211_SKB_CB(skb); 469 struct ieee80211_tx_info *info = IEEE80211_SKB_CB(skb);
@@ -484,14 +484,14 @@ static int il3945_tx_skb(struct il_priv *priv, struct sk_buff *skb)
484 u8 wait_write_ptr = 0; 484 u8 wait_write_ptr = 0;
485 unsigned long flags; 485 unsigned long flags;
486 486
487 spin_lock_irqsave(&priv->lock, flags); 487 spin_lock_irqsave(&il->lock, flags);
488 if (il_is_rfkill(priv)) { 488 if (il_is_rfkill(il)) {
489 IL_DEBUG_DROP(priv, "Dropping - RF KILL\n"); 489 IL_DEBUG_DROP(il, "Dropping - RF KILL\n");
490 goto drop_unlock; 490 goto drop_unlock;
491 } 491 }
492 492
493 if ((ieee80211_get_tx_rate(priv->hw, info)->hw_value & 0xFF) == IL_INVALID_RATE) { 493 if ((ieee80211_get_tx_rate(il->hw, info)->hw_value & 0xFF) == IL_INVALID_RATE) {
494 IL_ERR(priv, "ERROR: No TX rate available.\n"); 494 IL_ERR(il, "ERROR: No TX rate available.\n");
495 goto drop_unlock; 495 goto drop_unlock;
496 } 496 }
497 497
@@ -502,28 +502,28 @@ static int il3945_tx_skb(struct il_priv *priv, struct sk_buff *skb)
502 502
503#ifdef CONFIG_IWLWIFI_LEGACY_DEBUG 503#ifdef CONFIG_IWLWIFI_LEGACY_DEBUG
504 if (ieee80211_is_auth(fc)) 504 if (ieee80211_is_auth(fc))
505 IL_DEBUG_TX(priv, "Sending AUTH frame\n"); 505 IL_DEBUG_TX(il, "Sending AUTH frame\n");
506 else if (ieee80211_is_assoc_req(fc)) 506 else if (ieee80211_is_assoc_req(fc))
507 IL_DEBUG_TX(priv, "Sending ASSOC frame\n"); 507 IL_DEBUG_TX(il, "Sending ASSOC frame\n");
508 else if (ieee80211_is_reassoc_req(fc)) 508 else if (ieee80211_is_reassoc_req(fc))
509 IL_DEBUG_TX(priv, "Sending REASSOC frame\n"); 509 IL_DEBUG_TX(il, "Sending REASSOC frame\n");
510#endif 510#endif
511 511
512 spin_unlock_irqrestore(&priv->lock, flags); 512 spin_unlock_irqrestore(&il->lock, flags);
513 513
514 hdr_len = ieee80211_hdrlen(fc); 514 hdr_len = ieee80211_hdrlen(fc);
515 515
516 /* Find index into station table for destination station */ 516 /* Find index into station table for destination station */
517 sta_id = il_sta_id_or_broadcast( 517 sta_id = il_sta_id_or_broadcast(
518 priv, &priv->contexts[IL_RXON_CTX_BSS], 518 il, &il->contexts[IL_RXON_CTX_BSS],
519 info->control.sta); 519 info->control.sta);
520 if (sta_id == IL_INVALID_STATION) { 520 if (sta_id == IL_INVALID_STATION) {
521 IL_DEBUG_DROP(priv, "Dropping - INVALID STATION: %pM\n", 521 IL_DEBUG_DROP(il, "Dropping - INVALID STATION: %pM\n",
522 hdr->addr1); 522 hdr->addr1);
523 goto drop; 523 goto drop;
524 } 524 }
525 525
526 IL_DEBUG_RATE(priv, "station Id %d\n", sta_id); 526 IL_DEBUG_RATE(il, "station Id %d\n", sta_id);
527 527
528 if (ieee80211_is_data_qos(fc)) { 528 if (ieee80211_is_data_qos(fc)) {
529 u8 *qc = ieee80211_get_qos_ctl(hdr); 529 u8 *qc = ieee80211_get_qos_ctl(hdr);
@@ -533,20 +533,20 @@ static int il3945_tx_skb(struct il_priv *priv, struct sk_buff *skb)
533 } 533 }
534 534
535 /* Descriptor for chosen Tx queue */ 535 /* Descriptor for chosen Tx queue */
536 txq = &priv->txq[txq_id]; 536 txq = &il->txq[txq_id];
537 q = &txq->q; 537 q = &txq->q;
538 538
539 if ((il_queue_space(q) < q->high_mark)) 539 if ((il_queue_space(q) < q->high_mark))
540 goto drop; 540 goto drop;
541 541
542 spin_lock_irqsave(&priv->lock, flags); 542 spin_lock_irqsave(&il->lock, flags);
543 543
544 idx = il_get_cmd_index(q, q->write_ptr, 0); 544 idx = il_get_cmd_index(q, q->write_ptr, 0);
545 545
546 /* Set up driver data for this TFD */ 546 /* Set up driver data for this TFD */
547 memset(&(txq->txb[q->write_ptr]), 0, sizeof(struct il_tx_info)); 547 memset(&(txq->txb[q->write_ptr]), 0, sizeof(struct il_tx_info));
548 txq->txb[q->write_ptr].skb = skb; 548 txq->txb[q->write_ptr].skb = skb;
549 txq->txb[q->write_ptr].ctx = &priv->contexts[IL_RXON_CTX_BSS]; 549 txq->txb[q->write_ptr].ctx = &il->contexts[IL_RXON_CTX_BSS];
550 550
551 /* Init first empty entry in queue's array of Tx/cmd buffers */ 551 /* Init first empty entry in queue's array of Tx/cmd buffers */
552 out_cmd = txq->cmd[idx]; 552 out_cmd = txq->cmd[idx];
@@ -570,20 +570,20 @@ static int il3945_tx_skb(struct il_priv *priv, struct sk_buff *skb)
570 570
571 571
572 if (info->control.hw_key) 572 if (info->control.hw_key)
573 il3945_build_tx_cmd_hwcrypto(priv, info, out_cmd, skb, sta_id); 573 il3945_build_tx_cmd_hwcrypto(il, info, out_cmd, skb, sta_id);
574 574
575 /* TODO need this for burst mode later on */ 575 /* TODO need this for burst mode later on */
576 il3945_build_tx_cmd_basic(priv, out_cmd, info, hdr, sta_id); 576 il3945_build_tx_cmd_basic(il, out_cmd, info, hdr, sta_id);
577 577
578 /* set is_hcca to 0; it probably will never be implemented */ 578 /* set is_hcca to 0; it probably will never be implemented */
579 il3945_hw_build_tx_cmd_rate(priv, out_cmd, info, hdr, sta_id, 0); 579 il3945_hw_build_tx_cmd_rate(il, out_cmd, info, hdr, sta_id, 0);
580 580
581 /* Total # bytes to be transmitted */ 581 /* Total # bytes to be transmitted */
582 len = (u16)skb->len; 582 len = (u16)skb->len;
583 tx_cmd->len = cpu_to_le16(len); 583 tx_cmd->len = cpu_to_le16(len);
584 584
585 il_dbg_log_tx_data_frame(priv, len, hdr); 585 il_dbg_log_tx_data_frame(il, len, hdr);
586 il_update_stats(priv, true, fc, len); 586 il_update_stats(il, true, fc, len);
587 tx_cmd->tx_flags &= ~TX_CMD_FLG_ANT_A_MSK; 587 tx_cmd->tx_flags &= ~TX_CMD_FLG_ANT_A_MSK;
588 tx_cmd->tx_flags &= ~TX_CMD_FLG_ANT_B_MSK; 588 tx_cmd->tx_flags &= ~TX_CMD_FLG_ANT_B_MSK;
589 589
@@ -594,11 +594,11 @@ static int il3945_tx_skb(struct il_priv *priv, struct sk_buff *skb)
594 txq->need_update = 0; 594 txq->need_update = 0;
595 } 595 }
596 596
597 IL_DEBUG_TX(priv, "sequence nr = 0X%x\n", 597 IL_DEBUG_TX(il, "sequence nr = 0X%x\n",
598 le16_to_cpu(out_cmd->hdr.sequence)); 598 le16_to_cpu(out_cmd->hdr.sequence));
599 IL_DEBUG_TX(priv, "tx_flags = 0X%x\n", le32_to_cpu(tx_cmd->tx_flags)); 599 IL_DEBUG_TX(il, "tx_flags = 0X%x\n", le32_to_cpu(tx_cmd->tx_flags));
600 il_print_hex_dump(priv, IL_DL_TX, tx_cmd, sizeof(*tx_cmd)); 600 il_print_hex_dump(il, IL_DL_TX, tx_cmd, sizeof(*tx_cmd));
601 il_print_hex_dump(priv, IL_DL_TX, (u8 *)tx_cmd->hdr, 601 il_print_hex_dump(il, IL_DL_TX, (u8 *)tx_cmd->hdr,
602 ieee80211_hdrlen(fc)); 602 ieee80211_hdrlen(fc));
603 603
604 /* 604 /*
@@ -616,7 +616,7 @@ static int il3945_tx_skb(struct il_priv *priv, struct sk_buff *skb)
616 616
617 /* Physical address of this Tx command's header (not MAC header!), 617 /* Physical address of this Tx command's header (not MAC header!),
618 * within command buffer array. */ 618 * within command buffer array. */
619 txcmd_phys = pci_map_single(priv->pci_dev, &out_cmd->hdr, 619 txcmd_phys = pci_map_single(il->pci_dev, &out_cmd->hdr,
620 len, PCI_DMA_TODEVICE); 620 len, PCI_DMA_TODEVICE);
621 /* we do not map meta data ... so we can safely access address to 621 /* we do not map meta data ... so we can safely access address to
622 * provide to unmap command*/ 622 * provide to unmap command*/
@@ -625,7 +625,7 @@ static int il3945_tx_skb(struct il_priv *priv, struct sk_buff *skb)
625 625
626 /* Add buffer containing Tx command and MAC(!) header to TFD's 626 /* Add buffer containing Tx command and MAC(!) header to TFD's
627 * first entry */ 627 * first entry */
628 priv->cfg->ops->lib->txq_attach_buf_to_tfd(priv, txq, 628 il->cfg->ops->lib->txq_attach_buf_to_tfd(il, txq,
629 txcmd_phys, len, 1, 0); 629 txcmd_phys, len, 1, 0);
630 630
631 631
@@ -633,9 +633,9 @@ static int il3945_tx_skb(struct il_priv *priv, struct sk_buff *skb)
633 * if any (802.11 null frames have no payload). */ 633 * if any (802.11 null frames have no payload). */
634 len = skb->len - hdr_len; 634 len = skb->len - hdr_len;
635 if (len) { 635 if (len) {
636 phys_addr = pci_map_single(priv->pci_dev, skb->data + hdr_len, 636 phys_addr = pci_map_single(il->pci_dev, skb->data + hdr_len,
637 len, PCI_DMA_TODEVICE); 637 len, PCI_DMA_TODEVICE);
638 priv->cfg->ops->lib->txq_attach_buf_to_tfd(priv, txq, 638 il->cfg->ops->lib->txq_attach_buf_to_tfd(il, txq,
639 phys_addr, len, 639 phys_addr, len,
640 0, U32_PAD(len)); 640 0, U32_PAD(len));
641 } 641 }
@@ -643,30 +643,30 @@ static int il3945_tx_skb(struct il_priv *priv, struct sk_buff *skb)
643 643
644 /* Tell device the write index *just past* this latest filled TFD */ 644 /* Tell device the write index *just past* this latest filled TFD */
645 q->write_ptr = il_queue_inc_wrap(q->write_ptr, q->n_bd); 645 q->write_ptr = il_queue_inc_wrap(q->write_ptr, q->n_bd);
646 il_txq_update_write_ptr(priv, txq); 646 il_txq_update_write_ptr(il, txq);
647 spin_unlock_irqrestore(&priv->lock, flags); 647 spin_unlock_irqrestore(&il->lock, flags);
648 648
649 if ((il_queue_space(q) < q->high_mark) 649 if ((il_queue_space(q) < q->high_mark)
650 && priv->mac80211_registered) { 650 && il->mac80211_registered) {
651 if (wait_write_ptr) { 651 if (wait_write_ptr) {
652 spin_lock_irqsave(&priv->lock, flags); 652 spin_lock_irqsave(&il->lock, flags);
653 txq->need_update = 1; 653 txq->need_update = 1;
654 il_txq_update_write_ptr(priv, txq); 654 il_txq_update_write_ptr(il, txq);
655 spin_unlock_irqrestore(&priv->lock, flags); 655 spin_unlock_irqrestore(&il->lock, flags);
656 } 656 }
657 657
658 il_stop_queue(priv, txq); 658 il_stop_queue(il, txq);
659 } 659 }
660 660
661 return 0; 661 return 0;
662 662
663drop_unlock: 663drop_unlock:
664 spin_unlock_irqrestore(&priv->lock, flags); 664 spin_unlock_irqrestore(&il->lock, flags);
665drop: 665drop:
666 return -1; 666 return -1;
667} 667}
668 668
669static int il3945_get_measurement(struct il_priv *priv, 669static int il3945_get_measurement(struct il_priv *il,
670 struct ieee80211_measurement_params *params, 670 struct ieee80211_measurement_params *params,
671 u8 type) 671 u8 type)
672{ 672{
@@ -681,11 +681,11 @@ static int il3945_get_measurement(struct il_priv *priv,
681 int rc; 681 int rc;
682 int spectrum_resp_status; 682 int spectrum_resp_status;
683 int duration = le16_to_cpu(params->duration); 683 int duration = le16_to_cpu(params->duration);
684 struct il_rxon_context *ctx = &priv->contexts[IL_RXON_CTX_BSS]; 684 struct il_rxon_context *ctx = &il->contexts[IL_RXON_CTX_BSS];
685 685
686 if (il_is_associated(priv, IL_RXON_CTX_BSS)) 686 if (il_is_associated(il, IL_RXON_CTX_BSS))
687 add_time = il_usecs_to_beacons(priv, 687 add_time = il_usecs_to_beacons(il,
688 le64_to_cpu(params->start_time) - priv->_3945.last_tsf, 688 le64_to_cpu(params->start_time) - il->_3945.last_tsf,
689 le16_to_cpu(ctx->timing.beacon_interval)); 689 le16_to_cpu(ctx->timing.beacon_interval));
690 690
691 memset(&spectrum, 0, sizeof(spectrum)); 691 memset(&spectrum, 0, sizeof(spectrum));
@@ -697,10 +697,10 @@ static int il3945_get_measurement(struct il_priv *priv,
697 cmd.len = sizeof(spectrum); 697 cmd.len = sizeof(spectrum);
698 spectrum.len = cpu_to_le16(cmd.len - sizeof(spectrum.len)); 698 spectrum.len = cpu_to_le16(cmd.len - sizeof(spectrum.len));
699 699
700 if (il_is_associated(priv, IL_RXON_CTX_BSS)) 700 if (il_is_associated(il, IL_RXON_CTX_BSS))
701 spectrum.start_time = 701 spectrum.start_time =
702 il_add_beacon_time(priv, 702 il_add_beacon_time(il,
703 priv->_3945.last_beacon_time, add_time, 703 il->_3945.last_beacon_time, add_time,
704 le16_to_cpu(ctx->timing.beacon_interval)); 704 le16_to_cpu(ctx->timing.beacon_interval));
705 else 705 else
706 spectrum.start_time = 0; 706 spectrum.start_time = 0;
@@ -712,13 +712,13 @@ static int il3945_get_measurement(struct il_priv *priv,
712 spectrum.flags |= RXON_FLG_BAND_24G_MSK | 712 spectrum.flags |= RXON_FLG_BAND_24G_MSK |
713 RXON_FLG_AUTO_DETECT_MSK | RXON_FLG_TGG_PROTECT_MSK; 713 RXON_FLG_AUTO_DETECT_MSK | RXON_FLG_TGG_PROTECT_MSK;
714 714
715 rc = il_send_cmd_sync(priv, &cmd); 715 rc = il_send_cmd_sync(il, &cmd);
716 if (rc) 716 if (rc)
717 return rc; 717 return rc;
718 718
719 pkt = (struct il_rx_packet *)cmd.reply_page; 719 pkt = (struct il_rx_packet *)cmd.reply_page;
720 if (pkt->hdr.flags & IL_CMD_FAILED_MSK) { 720 if (pkt->hdr.flags & IL_CMD_FAILED_MSK) {
721 IL_ERR(priv, "Bad return from REPLY_RX_ON_ASSOC command\n"); 721 IL_ERR(il, "Bad return from REPLY_RX_ON_ASSOC command\n");
722 rc = -EIO; 722 rc = -EIO;
723 } 723 }
724 724
@@ -726,11 +726,11 @@ static int il3945_get_measurement(struct il_priv *priv,
726 switch (spectrum_resp_status) { 726 switch (spectrum_resp_status) {
727 case 0: /* Command will be handled */ 727 case 0: /* Command will be handled */
728 if (pkt->u.spectrum.id != 0xff) { 728 if (pkt->u.spectrum.id != 0xff) {
729 IL_DEBUG_INFO(priv, "Replaced existing measurement: %d\n", 729 IL_DEBUG_INFO(il, "Replaced existing measurement: %d\n",
730 pkt->u.spectrum.id); 730 pkt->u.spectrum.id);
731 priv->measurement_status &= ~MEASUREMENT_READY; 731 il->measurement_status &= ~MEASUREMENT_READY;
732 } 732 }
733 priv->measurement_status |= MEASUREMENT_ACTIVE; 733 il->measurement_status |= MEASUREMENT_ACTIVE;
734 rc = 0; 734 rc = 0;
735 break; 735 break;
736 736
@@ -739,12 +739,12 @@ static int il3945_get_measurement(struct il_priv *priv,
739 break; 739 break;
740 } 740 }
741 741
742 il_free_pages(priv, cmd.reply_page); 742 il_free_pages(il, cmd.reply_page);
743 743
744 return rc; 744 return rc;
745} 745}
746 746
747static void il3945_rx_reply_alive(struct il_priv *priv, 747static void il3945_rx_reply_alive(struct il_priv *il,
748 struct il_rx_mem_buffer *rxb) 748 struct il_rx_mem_buffer *rxb)
749{ 749{
750 struct il_rx_packet *pkt = rxb_addr(rxb); 750 struct il_rx_packet *pkt = rxb_addr(rxb);
@@ -753,44 +753,44 @@ static void il3945_rx_reply_alive(struct il_priv *priv,
753 753
754 palive = &pkt->u.alive_frame; 754 palive = &pkt->u.alive_frame;
755 755
756 IL_DEBUG_INFO(priv, "Alive ucode status 0x%08X revision " 756 IL_DEBUG_INFO(il, "Alive ucode status 0x%08X revision "
757 "0x%01X 0x%01X\n", 757 "0x%01X 0x%01X\n",
758 palive->is_valid, palive->ver_type, 758 palive->is_valid, palive->ver_type,
759 palive->ver_subtype); 759 palive->ver_subtype);
760 760
761 if (palive->ver_subtype == INITIALIZE_SUBTYPE) { 761 if (palive->ver_subtype == INITIALIZE_SUBTYPE) {
762 IL_DEBUG_INFO(priv, "Initialization Alive received.\n"); 762 IL_DEBUG_INFO(il, "Initialization Alive received.\n");
763 memcpy(&priv->card_alive_init, &pkt->u.alive_frame, 763 memcpy(&il->card_alive_init, &pkt->u.alive_frame,
764 sizeof(struct il_alive_resp)); 764 sizeof(struct il_alive_resp));
765 pwork = &priv->init_alive_start; 765 pwork = &il->init_alive_start;
766 } else { 766 } else {
767 IL_DEBUG_INFO(priv, "Runtime Alive received.\n"); 767 IL_DEBUG_INFO(il, "Runtime Alive received.\n");
768 memcpy(&priv->card_alive, &pkt->u.alive_frame, 768 memcpy(&il->card_alive, &pkt->u.alive_frame,
769 sizeof(struct il_alive_resp)); 769 sizeof(struct il_alive_resp));
770 pwork = &priv->alive_start; 770 pwork = &il->alive_start;
771 il3945_disable_events(priv); 771 il3945_disable_events(il);
772 } 772 }
773 773
774 /* We delay the ALIVE response by 5ms to 774 /* We delay the ALIVE response by 5ms to
775 * give the HW RF Kill time to activate... */ 775 * give the HW RF Kill time to activate... */
776 if (palive->is_valid == UCODE_VALID_OK) 776 if (palive->is_valid == UCODE_VALID_OK)
777 queue_delayed_work(priv->workqueue, pwork, 777 queue_delayed_work(il->workqueue, pwork,
778 msecs_to_jiffies(5)); 778 msecs_to_jiffies(5));
779 else 779 else
780 IL_WARN(priv, "uCode did not respond OK.\n"); 780 IL_WARN(il, "uCode did not respond OK.\n");
781} 781}
782 782
783static void il3945_rx_reply_add_sta(struct il_priv *priv, 783static void il3945_rx_reply_add_sta(struct il_priv *il,
784 struct il_rx_mem_buffer *rxb) 784 struct il_rx_mem_buffer *rxb)
785{ 785{
786#ifdef CONFIG_IWLWIFI_LEGACY_DEBUG 786#ifdef CONFIG_IWLWIFI_LEGACY_DEBUG
787 struct il_rx_packet *pkt = rxb_addr(rxb); 787 struct il_rx_packet *pkt = rxb_addr(rxb);
788#endif 788#endif
789 789
790 IL_DEBUG_RX(priv, "Received REPLY_ADD_STA: 0x%02X\n", pkt->u.status); 790 IL_DEBUG_RX(il, "Received REPLY_ADD_STA: 0x%02X\n", pkt->u.status);
791} 791}
792 792
793static void il3945_rx_beacon_notif(struct il_priv *priv, 793static void il3945_rx_beacon_notif(struct il_priv *il,
794 struct il_rx_mem_buffer *rxb) 794 struct il_rx_mem_buffer *rxb)
795{ 795{
796 struct il_rx_packet *pkt = rxb_addr(rxb); 796 struct il_rx_packet *pkt = rxb_addr(rxb);
@@ -798,7 +798,7 @@ static void il3945_rx_beacon_notif(struct il_priv *priv,
798#ifdef CONFIG_IWLWIFI_LEGACY_DEBUG 798#ifdef CONFIG_IWLWIFI_LEGACY_DEBUG
799 u8 rate = beacon->beacon_notify_hdr.rate; 799 u8 rate = beacon->beacon_notify_hdr.rate;
800 800
801 IL_DEBUG_RX(priv, "beacon status %x retries %d iss %d " 801 IL_DEBUG_RX(il, "beacon status %x retries %d iss %d "
802 "tsf %d %d rate %d\n", 802 "tsf %d %d rate %d\n",
803 le32_to_cpu(beacon->beacon_notify_hdr.status) & TX_STATUS_MSK, 803 le32_to_cpu(beacon->beacon_notify_hdr.status) & TX_STATUS_MSK,
804 beacon->beacon_notify_hdr.failure_frame, 804 beacon->beacon_notify_hdr.failure_frame,
@@ -807,40 +807,40 @@ static void il3945_rx_beacon_notif(struct il_priv *priv,
807 le32_to_cpu(beacon->low_tsf), rate); 807 le32_to_cpu(beacon->low_tsf), rate);
808#endif 808#endif
809 809
810 priv->ibss_manager = le32_to_cpu(beacon->ibss_mgr_status); 810 il->ibss_manager = le32_to_cpu(beacon->ibss_mgr_status);
811 811
812} 812}
813 813
814/* Handle notification from uCode that card's power state is changing 814/* Handle notification from uCode that card's power state is changing
815 * due to software, hardware, or critical temperature RFKILL */ 815 * due to software, hardware, or critical temperature RFKILL */
816static void il3945_rx_card_state_notif(struct il_priv *priv, 816static void il3945_rx_card_state_notif(struct il_priv *il,
817 struct il_rx_mem_buffer *rxb) 817 struct il_rx_mem_buffer *rxb)
818{ 818{
819 struct il_rx_packet *pkt = rxb_addr(rxb); 819 struct il_rx_packet *pkt = rxb_addr(rxb);
820 u32 flags = le32_to_cpu(pkt->u.card_state_notif.flags); 820 u32 flags = le32_to_cpu(pkt->u.card_state_notif.flags);
821 unsigned long status = priv->status; 821 unsigned long status = il->status;
822 822
823 IL_WARN(priv, "Card state received: HW:%s SW:%s\n", 823 IL_WARN(il, "Card state received: HW:%s SW:%s\n",
824 (flags & HW_CARD_DISABLED) ? "Kill" : "On", 824 (flags & HW_CARD_DISABLED) ? "Kill" : "On",
825 (flags & SW_CARD_DISABLED) ? "Kill" : "On"); 825 (flags & SW_CARD_DISABLED) ? "Kill" : "On");
826 826
827 il_write32(priv, CSR_UCODE_DRV_GP1_SET, 827 il_write32(il, CSR_UCODE_DRV_GP1_SET,
828 CSR_UCODE_DRV_GP1_BIT_CMD_BLOCKED); 828 CSR_UCODE_DRV_GP1_BIT_CMD_BLOCKED);
829 829
830 if (flags & HW_CARD_DISABLED) 830 if (flags & HW_CARD_DISABLED)
831 set_bit(STATUS_RF_KILL_HW, &priv->status); 831 set_bit(STATUS_RF_KILL_HW, &il->status);
832 else 832 else
833 clear_bit(STATUS_RF_KILL_HW, &priv->status); 833 clear_bit(STATUS_RF_KILL_HW, &il->status);
834 834
835 835
836 il_scan_cancel(priv); 836 il_scan_cancel(il);
837 837
838 if ((test_bit(STATUS_RF_KILL_HW, &status) != 838 if ((test_bit(STATUS_RF_KILL_HW, &status) !=
839 test_bit(STATUS_RF_KILL_HW, &priv->status))) 839 test_bit(STATUS_RF_KILL_HW, &il->status)))
840 wiphy_rfkill_set_hw_state(priv->hw->wiphy, 840 wiphy_rfkill_set_hw_state(il->hw->wiphy,
841 test_bit(STATUS_RF_KILL_HW, &priv->status)); 841 test_bit(STATUS_RF_KILL_HW, &il->status));
842 else 842 else
843 wake_up(&priv->wait_command_queue); 843 wake_up(&il->wait_command_queue);
844} 844}
845 845
846/** 846/**
@@ -852,32 +852,32 @@ static void il3945_rx_card_state_notif(struct il_priv *priv,
852 * This function chains into the hardware specific files for them to setup 852 * This function chains into the hardware specific files for them to setup
853 * any hardware specific handlers as well. 853 * any hardware specific handlers as well.
854 */ 854 */
855static void il3945_setup_rx_handlers(struct il_priv *priv) 855static void il3945_setup_rx_handlers(struct il_priv *il)
856{ 856{
857 priv->rx_handlers[REPLY_ALIVE] = il3945_rx_reply_alive; 857 il->rx_handlers[REPLY_ALIVE] = il3945_rx_reply_alive;
858 priv->rx_handlers[REPLY_ADD_STA] = il3945_rx_reply_add_sta; 858 il->rx_handlers[REPLY_ADD_STA] = il3945_rx_reply_add_sta;
859 priv->rx_handlers[REPLY_ERROR] = il_rx_reply_error; 859 il->rx_handlers[REPLY_ERROR] = il_rx_reply_error;
860 priv->rx_handlers[CHANNEL_SWITCH_NOTIFICATION] = il_rx_csa; 860 il->rx_handlers[CHANNEL_SWITCH_NOTIFICATION] = il_rx_csa;
861 priv->rx_handlers[SPECTRUM_MEASURE_NOTIFICATION] = 861 il->rx_handlers[SPECTRUM_MEASURE_NOTIFICATION] =
862 il_rx_spectrum_measure_notif; 862 il_rx_spectrum_measure_notif;
863 priv->rx_handlers[PM_SLEEP_NOTIFICATION] = il_rx_pm_sleep_notif; 863 il->rx_handlers[PM_SLEEP_NOTIFICATION] = il_rx_pm_sleep_notif;
864 priv->rx_handlers[PM_DEBUG_STATISTIC_NOTIFIC] = 864 il->rx_handlers[PM_DEBUG_STATISTIC_NOTIFIC] =
865 il_rx_pm_debug_statistics_notif; 865 il_rx_pm_debug_statistics_notif;
866 priv->rx_handlers[BEACON_NOTIFICATION] = il3945_rx_beacon_notif; 866 il->rx_handlers[BEACON_NOTIFICATION] = il3945_rx_beacon_notif;
867 867
868 /* 868 /*
869 * The same handler is used for both the REPLY to a discrete 869 * The same handler is used for both the REPLY to a discrete
870 * statistics request from the host as well as for the periodic 870 * statistics request from the host as well as for the periodic
871 * statistics notifications (after received beacons) from the uCode. 871 * statistics notifications (after received beacons) from the uCode.
872 */ 872 */
873 priv->rx_handlers[REPLY_STATISTICS_CMD] = il3945_reply_statistics; 873 il->rx_handlers[REPLY_STATISTICS_CMD] = il3945_reply_statistics;
874 priv->rx_handlers[STATISTICS_NOTIFICATION] = il3945_hw_rx_statistics; 874 il->rx_handlers[STATISTICS_NOTIFICATION] = il3945_hw_rx_statistics;
875 875
876 il_setup_rx_scan_handlers(priv); 876 il_setup_rx_scan_handlers(il);
877 priv->rx_handlers[CARD_STATE_NOTIFICATION] = il3945_rx_card_state_notif; 877 il->rx_handlers[CARD_STATE_NOTIFICATION] = il3945_rx_card_state_notif;
878 878
879 /* Set up hardware specific Rx handlers */ 879 /* Set up hardware specific Rx handlers */
880 il3945_hw_rx_handler_setup(priv); 880 il3945_hw_rx_handler_setup(il);
881} 881}
882 882
883/************************** RX-FUNCTIONS ****************************/ 883/************************** RX-FUNCTIONS ****************************/
@@ -947,7 +947,7 @@ static void il3945_setup_rx_handlers(struct il_priv *priv)
947/** 947/**
948 * il3945_dma_addr2rbd_ptr - convert a DMA address to a uCode read buffer ptr 948 * il3945_dma_addr2rbd_ptr - convert a DMA address to a uCode read buffer ptr
949 */ 949 */
950static inline __le32 il3945_dma_addr2rbd_ptr(struct il_priv *priv, 950static inline __le32 il3945_dma_addr2rbd_ptr(struct il_priv *il,
951 dma_addr_t dma_addr) 951 dma_addr_t dma_addr)
952{ 952{
953 return cpu_to_le32((u32)dma_addr); 953 return cpu_to_le32((u32)dma_addr);
@@ -964,9 +964,9 @@ static inline __le32 il3945_dma_addr2rbd_ptr(struct il_priv *priv,
964 * also updates the memory address in the firmware to reference the new 964 * also updates the memory address in the firmware to reference the new
965 * target buffer. 965 * target buffer.
966 */ 966 */
967static void il3945_rx_queue_restock(struct il_priv *priv) 967static void il3945_rx_queue_restock(struct il_priv *il)
968{ 968{
969 struct il_rx_queue *rxq = &priv->rxq; 969 struct il_rx_queue *rxq = &il->rxq;
970 struct list_head *element; 970 struct list_head *element;
971 struct il_rx_mem_buffer *rxb; 971 struct il_rx_mem_buffer *rxb;
972 unsigned long flags; 972 unsigned long flags;
@@ -981,7 +981,7 @@ static void il3945_rx_queue_restock(struct il_priv *priv)
981 list_del(element); 981 list_del(element);
982 982
983 /* Point to Rx buffer via next RBD in circular buffer */ 983 /* Point to Rx buffer via next RBD in circular buffer */
984 rxq->bd[rxq->write] = il3945_dma_addr2rbd_ptr(priv, rxb->page_dma); 984 rxq->bd[rxq->write] = il3945_dma_addr2rbd_ptr(il, rxb->page_dma);
985 rxq->queue[rxq->write] = rxb; 985 rxq->queue[rxq->write] = rxb;
986 rxq->write = (rxq->write + 1) & RX_QUEUE_MASK; 986 rxq->write = (rxq->write + 1) & RX_QUEUE_MASK;
987 rxq->free_count--; 987 rxq->free_count--;
@@ -990,7 +990,7 @@ static void il3945_rx_queue_restock(struct il_priv *priv)
990 /* If the pre-allocated buffer pool is dropping low, schedule to 990 /* If the pre-allocated buffer pool is dropping low, schedule to
991 * refill it */ 991 * refill it */
992 if (rxq->free_count <= RX_LOW_WATERMARK) 992 if (rxq->free_count <= RX_LOW_WATERMARK)
993 queue_work(priv->workqueue, &priv->rx_replenish); 993 queue_work(il->workqueue, &il->rx_replenish);
994 994
995 995
996 /* If we've added more space for the firmware to place data, tell it. 996 /* If we've added more space for the firmware to place data, tell it.
@@ -1000,7 +1000,7 @@ static void il3945_rx_queue_restock(struct il_priv *priv)
1000 spin_lock_irqsave(&rxq->lock, flags); 1000 spin_lock_irqsave(&rxq->lock, flags);
1001 rxq->need_update = 1; 1001 rxq->need_update = 1;
1002 spin_unlock_irqrestore(&rxq->lock, flags); 1002 spin_unlock_irqrestore(&rxq->lock, flags);
1003 il_rx_queue_update_write_ptr(priv, rxq); 1003 il_rx_queue_update_write_ptr(il, rxq);
1004 } 1004 }
1005} 1005}
1006 1006
@@ -1012,9 +1012,9 @@ static void il3945_rx_queue_restock(struct il_priv *priv)
1012 * Also restock the Rx queue via il3945_rx_queue_restock. 1012 * Also restock the Rx queue via il3945_rx_queue_restock.
1013 * This is called as a scheduled work item (except for during initialization) 1013 * This is called as a scheduled work item (except for during initialization)
1014 */ 1014 */
1015static void il3945_rx_allocate(struct il_priv *priv, gfp_t priority) 1015static void il3945_rx_allocate(struct il_priv *il, gfp_t priority)
1016{ 1016{
1017 struct il_rx_queue *rxq = &priv->rxq; 1017 struct il_rx_queue *rxq = &il->rxq;
1018 struct list_head *element; 1018 struct list_head *element;
1019 struct il_rx_mem_buffer *rxb; 1019 struct il_rx_mem_buffer *rxb;
1020 struct page *page; 1020 struct page *page;
@@ -1033,17 +1033,17 @@ static void il3945_rx_allocate(struct il_priv *priv, gfp_t priority)
1033 if (rxq->free_count > RX_LOW_WATERMARK) 1033 if (rxq->free_count > RX_LOW_WATERMARK)
1034 gfp_mask |= __GFP_NOWARN; 1034 gfp_mask |= __GFP_NOWARN;
1035 1035
1036 if (priv->hw_params.rx_page_order > 0) 1036 if (il->hw_params.rx_page_order > 0)
1037 gfp_mask |= __GFP_COMP; 1037 gfp_mask |= __GFP_COMP;
1038 1038
1039 /* Alloc a new receive buffer */ 1039 /* Alloc a new receive buffer */
1040 page = alloc_pages(gfp_mask, priv->hw_params.rx_page_order); 1040 page = alloc_pages(gfp_mask, il->hw_params.rx_page_order);
1041 if (!page) { 1041 if (!page) {
1042 if (net_ratelimit()) 1042 if (net_ratelimit())
1043 IL_DEBUG_INFO(priv, "Failed to allocate SKB buffer.\n"); 1043 IL_DEBUG_INFO(il, "Failed to allocate SKB buffer.\n");
1044 if ((rxq->free_count <= RX_LOW_WATERMARK) && 1044 if ((rxq->free_count <= RX_LOW_WATERMARK) &&
1045 net_ratelimit()) 1045 net_ratelimit())
1046 IL_CRIT(priv, "Failed to allocate SKB buffer with %s. Only %u free buffers remaining.\n", 1046 IL_CRIT(il, "Failed to allocate SKB buffer with %s. Only %u free buffers remaining.\n",
1047 priority == GFP_ATOMIC ? "GFP_ATOMIC" : "GFP_KERNEL", 1047 priority == GFP_ATOMIC ? "GFP_ATOMIC" : "GFP_KERNEL",
1048 rxq->free_count); 1048 rxq->free_count);
1049 /* We don't reschedule replenish work here -- we will 1049 /* We don't reschedule replenish work here -- we will
@@ -1055,7 +1055,7 @@ static void il3945_rx_allocate(struct il_priv *priv, gfp_t priority)
1055 spin_lock_irqsave(&rxq->lock, flags); 1055 spin_lock_irqsave(&rxq->lock, flags);
1056 if (list_empty(&rxq->rx_used)) { 1056 if (list_empty(&rxq->rx_used)) {
1057 spin_unlock_irqrestore(&rxq->lock, flags); 1057 spin_unlock_irqrestore(&rxq->lock, flags);
1058 __free_pages(page, priv->hw_params.rx_page_order); 1058 __free_pages(page, il->hw_params.rx_page_order);
1059 return; 1059 return;
1060 } 1060 }
1061 element = rxq->rx_used.next; 1061 element = rxq->rx_used.next;
@@ -1065,21 +1065,21 @@ static void il3945_rx_allocate(struct il_priv *priv, gfp_t priority)
1065 1065
1066 rxb->page = page; 1066 rxb->page = page;
1067 /* Get physical address of RB/SKB */ 1067 /* Get physical address of RB/SKB */
1068 rxb->page_dma = pci_map_page(priv->pci_dev, page, 0, 1068 rxb->page_dma = pci_map_page(il->pci_dev, page, 0,
1069 PAGE_SIZE << priv->hw_params.rx_page_order, 1069 PAGE_SIZE << il->hw_params.rx_page_order,
1070 PCI_DMA_FROMDEVICE); 1070 PCI_DMA_FROMDEVICE);
1071 1071
1072 spin_lock_irqsave(&rxq->lock, flags); 1072 spin_lock_irqsave(&rxq->lock, flags);
1073 1073
1074 list_add_tail(&rxb->list, &rxq->rx_free); 1074 list_add_tail(&rxb->list, &rxq->rx_free);
1075 rxq->free_count++; 1075 rxq->free_count++;
1076 priv->alloc_rxb_page++; 1076 il->alloc_rxb_page++;
1077 1077
1078 spin_unlock_irqrestore(&rxq->lock, flags); 1078 spin_unlock_irqrestore(&rxq->lock, flags);
1079 } 1079 }
1080} 1080}
1081 1081
1082void il3945_rx_queue_reset(struct il_priv *priv, struct il_rx_queue *rxq) 1082void il3945_rx_queue_reset(struct il_priv *il, struct il_rx_queue *rxq)
1083{ 1083{
1084 unsigned long flags; 1084 unsigned long flags;
1085 int i; 1085 int i;
@@ -1091,10 +1091,10 @@ void il3945_rx_queue_reset(struct il_priv *priv, struct il_rx_queue *rxq)
1091 /* In the reset function, these buffers may have been allocated 1091 /* In the reset function, these buffers may have been allocated
1092 * to an SKB, so we need to unmap and free potential storage */ 1092 * to an SKB, so we need to unmap and free potential storage */
1093 if (rxq->pool[i].page != NULL) { 1093 if (rxq->pool[i].page != NULL) {
1094 pci_unmap_page(priv->pci_dev, rxq->pool[i].page_dma, 1094 pci_unmap_page(il->pci_dev, rxq->pool[i].page_dma,
1095 PAGE_SIZE << priv->hw_params.rx_page_order, 1095 PAGE_SIZE << il->hw_params.rx_page_order,
1096 PCI_DMA_FROMDEVICE); 1096 PCI_DMA_FROMDEVICE);
1097 __il_free_pages(priv, rxq->pool[i].page); 1097 __il_free_pages(il, rxq->pool[i].page);
1098 rxq->pool[i].page = NULL; 1098 rxq->pool[i].page = NULL;
1099 } 1099 }
1100 list_add_tail(&rxq->pool[i].list, &rxq->rx_used); 1100 list_add_tail(&rxq->pool[i].list, &rxq->rx_used);
@@ -1110,21 +1110,21 @@ void il3945_rx_queue_reset(struct il_priv *priv, struct il_rx_queue *rxq)
1110 1110
1111void il3945_rx_replenish(void *data) 1111void il3945_rx_replenish(void *data)
1112{ 1112{
1113 struct il_priv *priv = data; 1113 struct il_priv *il = data;
1114 unsigned long flags; 1114 unsigned long flags;
1115 1115
1116 il3945_rx_allocate(priv, GFP_KERNEL); 1116 il3945_rx_allocate(il, GFP_KERNEL);
1117 1117
1118 spin_lock_irqsave(&priv->lock, flags); 1118 spin_lock_irqsave(&il->lock, flags);
1119 il3945_rx_queue_restock(priv); 1119 il3945_rx_queue_restock(il);
1120 spin_unlock_irqrestore(&priv->lock, flags); 1120 spin_unlock_irqrestore(&il->lock, flags);
1121} 1121}
1122 1122
1123static void il3945_rx_replenish_now(struct il_priv *priv) 1123static void il3945_rx_replenish_now(struct il_priv *il)
1124{ 1124{
1125 il3945_rx_allocate(priv, GFP_ATOMIC); 1125 il3945_rx_allocate(il, GFP_ATOMIC);
1126 1126
1127 il3945_rx_queue_restock(priv); 1127 il3945_rx_queue_restock(il);
1128} 1128}
1129 1129
1130 1130
@@ -1133,22 +1133,22 @@ static void il3945_rx_replenish_now(struct il_priv *priv)
1133 * This free routine walks the list of POOL entries and if SKB is set to 1133 * This free routine walks the list of POOL entries and if SKB is set to
1134 * non NULL it is unmapped and freed 1134 * non NULL it is unmapped and freed
1135 */ 1135 */
1136static void il3945_rx_queue_free(struct il_priv *priv, struct il_rx_queue *rxq) 1136static void il3945_rx_queue_free(struct il_priv *il, struct il_rx_queue *rxq)
1137{ 1137{
1138 int i; 1138 int i;
1139 for (i = 0; i < RX_QUEUE_SIZE + RX_FREE_BUFFERS; i++) { 1139 for (i = 0; i < RX_QUEUE_SIZE + RX_FREE_BUFFERS; i++) {
1140 if (rxq->pool[i].page != NULL) { 1140 if (rxq->pool[i].page != NULL) {
1141 pci_unmap_page(priv->pci_dev, rxq->pool[i].page_dma, 1141 pci_unmap_page(il->pci_dev, rxq->pool[i].page_dma,
1142 PAGE_SIZE << priv->hw_params.rx_page_order, 1142 PAGE_SIZE << il->hw_params.rx_page_order,
1143 PCI_DMA_FROMDEVICE); 1143 PCI_DMA_FROMDEVICE);
1144 __il_free_pages(priv, rxq->pool[i].page); 1144 __il_free_pages(il, rxq->pool[i].page);
1145 rxq->pool[i].page = NULL; 1145 rxq->pool[i].page = NULL;
1146 } 1146 }
1147 } 1147 }
1148 1148
1149 dma_free_coherent(&priv->pci_dev->dev, 4 * RX_QUEUE_SIZE, rxq->bd, 1149 dma_free_coherent(&il->pci_dev->dev, 4 * RX_QUEUE_SIZE, rxq->bd,
1150 rxq->bd_dma); 1150 rxq->bd_dma);
1151 dma_free_coherent(&priv->pci_dev->dev, sizeof(struct il_rb_status), 1151 dma_free_coherent(&il->pci_dev->dev, sizeof(struct il_rb_status),
1152 rxq->rb_stts, rxq->rb_stts_dma); 1152 rxq->rb_stts, rxq->rb_stts_dma);
1153 rxq->bd = NULL; 1153 rxq->bd = NULL;
1154 rxq->rb_stts = NULL; 1154 rxq->rb_stts = NULL;
@@ -1195,15 +1195,15 @@ int il3945_calc_db_from_ratio(int sig_ratio)
1195/** 1195/**
1196 * il3945_rx_handle - Main entry function for receiving responses from uCode 1196 * il3945_rx_handle - Main entry function for receiving responses from uCode
1197 * 1197 *
1198 * Uses the priv->rx_handlers callback function array to invoke 1198 * Uses the il->rx_handlers callback function array to invoke
1199 * the appropriate handlers, including command responses, 1199 * the appropriate handlers, including command responses,
1200 * frame-received notifications, and other notifications. 1200 * frame-received notifications, and other notifications.
1201 */ 1201 */
1202static void il3945_rx_handle(struct il_priv *priv) 1202static void il3945_rx_handle(struct il_priv *il)
1203{ 1203{
1204 struct il_rx_mem_buffer *rxb; 1204 struct il_rx_mem_buffer *rxb;
1205 struct il_rx_packet *pkt; 1205 struct il_rx_packet *pkt;
1206 struct il_rx_queue *rxq = &priv->rxq; 1206 struct il_rx_queue *rxq = &il->rxq;
1207 u32 r, i; 1207 u32 r, i;
1208 int reclaim; 1208 int reclaim;
1209 unsigned long flags; 1209 unsigned long flags;
@@ -1225,7 +1225,7 @@ static void il3945_rx_handle(struct il_priv *priv)
1225 fill_rx = 1; 1225 fill_rx = 1;
1226 /* Rx interrupt, but nothing sent from uCode */ 1226 /* Rx interrupt, but nothing sent from uCode */
1227 if (i == r) 1227 if (i == r)
1228 IL_DEBUG_RX(priv, "r = %d, i = %d\n", r, i); 1228 IL_DEBUG_RX(il, "r = %d, i = %d\n", r, i);
1229 1229
1230 while (i != r) { 1230 while (i != r) {
1231 int len; 1231 int len;
@@ -1239,8 +1239,8 @@ static void il3945_rx_handle(struct il_priv *priv)
1239 1239
1240 rxq->queue[i] = NULL; 1240 rxq->queue[i] = NULL;
1241 1241
1242 pci_unmap_page(priv->pci_dev, rxb->page_dma, 1242 pci_unmap_page(il->pci_dev, rxb->page_dma,
1243 PAGE_SIZE << priv->hw_params.rx_page_order, 1243 PAGE_SIZE << il->hw_params.rx_page_order,
1244 PCI_DMA_FROMDEVICE); 1244 PCI_DMA_FROMDEVICE);
1245 pkt = rxb_addr(rxb); 1245 pkt = rxb_addr(rxb);
1246 1246
@@ -1260,14 +1260,14 @@ static void il3945_rx_handle(struct il_priv *priv)
1260 /* Based on type of command response or notification, 1260 /* Based on type of command response or notification,
1261 * handle those that need handling via function in 1261 * handle those that need handling via function in
1262 * rx_handlers table. See il3945_setup_rx_handlers() */ 1262 * rx_handlers table. See il3945_setup_rx_handlers() */
1263 if (priv->rx_handlers[pkt->hdr.cmd]) { 1263 if (il->rx_handlers[pkt->hdr.cmd]) {
1264 IL_DEBUG_RX(priv, "r = %d, i = %d, %s, 0x%02x\n", r, i, 1264 IL_DEBUG_RX(il, "r = %d, i = %d, %s, 0x%02x\n", r, i,
1265 il_get_cmd_string(pkt->hdr.cmd), pkt->hdr.cmd); 1265 il_get_cmd_string(pkt->hdr.cmd), pkt->hdr.cmd);
1266 priv->isr_stats.rx_handlers[pkt->hdr.cmd]++; 1266 il->isr_stats.rx_handlers[pkt->hdr.cmd]++;
1267 priv->rx_handlers[pkt->hdr.cmd] (priv, rxb); 1267 il->rx_handlers[pkt->hdr.cmd] (il, rxb);
1268 } else { 1268 } else {
1269 /* No handling needed */ 1269 /* No handling needed */
1270 IL_DEBUG_RX(priv, 1270 IL_DEBUG_RX(il,
1271 "r %d i %d No handler needed for %s, 0x%02x\n", 1271 "r %d i %d No handler needed for %s, 0x%02x\n",
1272 r, i, il_get_cmd_string(pkt->hdr.cmd), 1272 r, i, il_get_cmd_string(pkt->hdr.cmd),
1273 pkt->hdr.cmd); 1273 pkt->hdr.cmd);
@@ -1285,9 +1285,9 @@ static void il3945_rx_handle(struct il_priv *priv)
1285 * and fire off the (possibly) blocking il_send_cmd() 1285 * and fire off the (possibly) blocking il_send_cmd()
1286 * as we reclaim the driver command queue */ 1286 * as we reclaim the driver command queue */
1287 if (rxb->page) 1287 if (rxb->page)
1288 il_tx_cmd_complete(priv, rxb); 1288 il_tx_cmd_complete(il, rxb);
1289 else 1289 else
1290 IL_WARN(priv, "Claim null rxb?\n"); 1290 IL_WARN(il, "Claim null rxb?\n");
1291 } 1291 }
1292 1292
1293 /* Reuse the page if possible. For notification packets and 1293 /* Reuse the page if possible. For notification packets and
@@ -1295,8 +1295,8 @@ static void il3945_rx_handle(struct il_priv *priv)
1295 * rx_free list for reuse later. */ 1295 * rx_free list for reuse later. */
1296 spin_lock_irqsave(&rxq->lock, flags); 1296 spin_lock_irqsave(&rxq->lock, flags);
1297 if (rxb->page != NULL) { 1297 if (rxb->page != NULL) {
1298 rxb->page_dma = pci_map_page(priv->pci_dev, rxb->page, 1298 rxb->page_dma = pci_map_page(il->pci_dev, rxb->page,
1299 0, PAGE_SIZE << priv->hw_params.rx_page_order, 1299 0, PAGE_SIZE << il->hw_params.rx_page_order,
1300 PCI_DMA_FROMDEVICE); 1300 PCI_DMA_FROMDEVICE);
1301 list_add_tail(&rxb->list, &rxq->rx_free); 1301 list_add_tail(&rxb->list, &rxq->rx_free);
1302 rxq->free_count++; 1302 rxq->free_count++;
@@ -1312,7 +1312,7 @@ static void il3945_rx_handle(struct il_priv *priv)
1312 count++; 1312 count++;
1313 if (count >= 8) { 1313 if (count >= 8) {
1314 rxq->read = i; 1314 rxq->read = i;
1315 il3945_rx_replenish_now(priv); 1315 il3945_rx_replenish_now(il);
1316 count = 0; 1316 count = 0;
1317 } 1317 }
1318 } 1318 }
@@ -1321,17 +1321,17 @@ static void il3945_rx_handle(struct il_priv *priv)
1321 /* Backtrack one entry */ 1321 /* Backtrack one entry */
1322 rxq->read = i; 1322 rxq->read = i;
1323 if (fill_rx) 1323 if (fill_rx)
1324 il3945_rx_replenish_now(priv); 1324 il3945_rx_replenish_now(il);
1325 else 1325 else
1326 il3945_rx_queue_restock(priv); 1326 il3945_rx_queue_restock(il);
1327} 1327}
1328 1328
1329/* call this function to flush any scheduled tasklet */ 1329/* call this function to flush any scheduled tasklet */
1330static inline void il3945_synchronize_irq(struct il_priv *priv) 1330static inline void il3945_synchronize_irq(struct il_priv *il)
1331{ 1331{
1332 /* wait to make sure we flush pending tasklet*/ 1332 /* wait to make sure we flush pending tasklet*/
1333 synchronize_irq(priv->pci_dev->irq); 1333 synchronize_irq(il->pci_dev->irq);
1334 tasklet_kill(&priv->irq_tasklet); 1334 tasklet_kill(&il->irq_tasklet);
1335} 1335}
1336 1336
1337static const char *il3945_desc_lookup(int i) 1337static const char *il3945_desc_lookup(int i)
@@ -1357,55 +1357,55 @@ static const char *il3945_desc_lookup(int i)
1357#define ERROR_START_OFFSET (1 * sizeof(u32)) 1357#define ERROR_START_OFFSET (1 * sizeof(u32))
1358#define ERROR_ELEM_SIZE (7 * sizeof(u32)) 1358#define ERROR_ELEM_SIZE (7 * sizeof(u32))
1359 1359
1360void il3945_dump_nic_error_log(struct il_priv *priv) 1360void il3945_dump_nic_error_log(struct il_priv *il)
1361{ 1361{
1362 u32 i; 1362 u32 i;
1363 u32 desc, time, count, base, data1; 1363 u32 desc, time, count, base, data1;
1364 u32 blink1, blink2, ilink1, ilink2; 1364 u32 blink1, blink2, ilink1, ilink2;
1365 1365
1366 base = le32_to_cpu(priv->card_alive.error_event_table_ptr); 1366 base = le32_to_cpu(il->card_alive.error_event_table_ptr);
1367 1367
1368 if (!il3945_hw_valid_rtc_data_addr(base)) { 1368 if (!il3945_hw_valid_rtc_data_addr(base)) {
1369 IL_ERR(priv, "Not valid error log pointer 0x%08X\n", base); 1369 IL_ERR(il, "Not valid error log pointer 0x%08X\n", base);
1370 return; 1370 return;
1371 } 1371 }
1372 1372
1373 1373
1374 count = il_read_targ_mem(priv, base); 1374 count = il_read_targ_mem(il, base);
1375 1375
1376 if (ERROR_START_OFFSET <= count * ERROR_ELEM_SIZE) { 1376 if (ERROR_START_OFFSET <= count * ERROR_ELEM_SIZE) {
1377 IL_ERR(priv, "Start IWL Error Log Dump:\n"); 1377 IL_ERR(il, "Start IWL Error Log Dump:\n");
1378 IL_ERR(priv, "Status: 0x%08lX, count: %d\n", 1378 IL_ERR(il, "Status: 0x%08lX, count: %d\n",
1379 priv->status, count); 1379 il->status, count);
1380 } 1380 }
1381 1381
1382 IL_ERR(priv, "Desc Time asrtPC blink2 " 1382 IL_ERR(il, "Desc Time asrtPC blink2 "
1383 "ilink1 nmiPC Line\n"); 1383 "ilink1 nmiPC Line\n");
1384 for (i = ERROR_START_OFFSET; 1384 for (i = ERROR_START_OFFSET;
1385 i < (count * ERROR_ELEM_SIZE) + ERROR_START_OFFSET; 1385 i < (count * ERROR_ELEM_SIZE) + ERROR_START_OFFSET;
1386 i += ERROR_ELEM_SIZE) { 1386 i += ERROR_ELEM_SIZE) {
1387 desc = il_read_targ_mem(priv, base + i); 1387 desc = il_read_targ_mem(il, base + i);
1388 time = 1388 time =
1389 il_read_targ_mem(priv, base + i + 1 * sizeof(u32)); 1389 il_read_targ_mem(il, base + i + 1 * sizeof(u32));
1390 blink1 = 1390 blink1 =
1391 il_read_targ_mem(priv, base + i + 2 * sizeof(u32)); 1391 il_read_targ_mem(il, base + i + 2 * sizeof(u32));
1392 blink2 = 1392 blink2 =
1393 il_read_targ_mem(priv, base + i + 3 * sizeof(u32)); 1393 il_read_targ_mem(il, base + i + 3 * sizeof(u32));
1394 ilink1 = 1394 ilink1 =
1395 il_read_targ_mem(priv, base + i + 4 * sizeof(u32)); 1395 il_read_targ_mem(il, base + i + 4 * sizeof(u32));
1396 ilink2 = 1396 ilink2 =
1397 il_read_targ_mem(priv, base + i + 5 * sizeof(u32)); 1397 il_read_targ_mem(il, base + i + 5 * sizeof(u32));
1398 data1 = 1398 data1 =
1399 il_read_targ_mem(priv, base + i + 6 * sizeof(u32)); 1399 il_read_targ_mem(il, base + i + 6 * sizeof(u32));
1400 1400
1401 IL_ERR(priv, 1401 IL_ERR(il,
1402 "%-13s (0x%X) %010u 0x%05X 0x%05X 0x%05X 0x%05X %u\n\n", 1402 "%-13s (0x%X) %010u 0x%05X 0x%05X 0x%05X 0x%05X %u\n\n",
1403 il3945_desc_lookup(desc), desc, time, blink1, blink2, 1403 il3945_desc_lookup(desc), desc, time, blink1, blink2,
1404 ilink1, ilink2, data1); 1404 ilink1, ilink2, data1);
1405 } 1405 }
1406} 1406}
1407 1407
1408static void il3945_irq_tasklet(struct il_priv *priv) 1408static void il3945_irq_tasklet(struct il_priv *il)
1409{ 1409{
1410 u32 inta, handled = 0; 1410 u32 inta, handled = 0;
1411 u32 inta_fh; 1411 u32 inta_fh;
@@ -1414,30 +1414,30 @@ static void il3945_irq_tasklet(struct il_priv *priv)
1414 u32 inta_mask; 1414 u32 inta_mask;
1415#endif 1415#endif
1416 1416
1417 spin_lock_irqsave(&priv->lock, flags); 1417 spin_lock_irqsave(&il->lock, flags);
1418 1418
1419 /* Ack/clear/reset pending uCode interrupts. 1419 /* Ack/clear/reset pending uCode interrupts.
1420 * Note: Some bits in CSR_INT are "OR" of bits in CSR_FH_INT_STATUS, 1420 * Note: Some bits in CSR_INT are "OR" of bits in CSR_FH_INT_STATUS,
1421 * and will clear only when CSR_FH_INT_STATUS gets cleared. */ 1421 * and will clear only when CSR_FH_INT_STATUS gets cleared. */
1422 inta = il_read32(priv, CSR_INT); 1422 inta = il_read32(il, CSR_INT);
1423 il_write32(priv, CSR_INT, inta); 1423 il_write32(il, CSR_INT, inta);
1424 1424
1425 /* Ack/clear/reset pending flow-handler (DMA) interrupts. 1425 /* Ack/clear/reset pending flow-handler (DMA) interrupts.
1426 * Any new interrupts that happen after this, either while we're 1426 * Any new interrupts that happen after this, either while we're
1427 * in this tasklet, or later, will show up in next ISR/tasklet. */ 1427 * in this tasklet, or later, will show up in next ISR/tasklet. */
1428 inta_fh = il_read32(priv, CSR_FH_INT_STATUS); 1428 inta_fh = il_read32(il, CSR_FH_INT_STATUS);
1429 il_write32(priv, CSR_FH_INT_STATUS, inta_fh); 1429 il_write32(il, CSR_FH_INT_STATUS, inta_fh);
1430 1430
1431#ifdef CONFIG_IWLWIFI_LEGACY_DEBUG 1431#ifdef CONFIG_IWLWIFI_LEGACY_DEBUG
1432 if (il_get_debug_level(priv) & IL_DL_ISR) { 1432 if (il_get_debug_level(il) & IL_DL_ISR) {
1433 /* just for debug */ 1433 /* just for debug */
1434 inta_mask = il_read32(priv, CSR_INT_MASK); 1434 inta_mask = il_read32(il, CSR_INT_MASK);
1435 IL_DEBUG_ISR(priv, "inta 0x%08x, enabled 0x%08x, fh 0x%08x\n", 1435 IL_DEBUG_ISR(il, "inta 0x%08x, enabled 0x%08x, fh 0x%08x\n",
1436 inta, inta_mask, inta_fh); 1436 inta, inta_mask, inta_fh);
1437 } 1437 }
1438#endif 1438#endif
1439 1439
1440 spin_unlock_irqrestore(&priv->lock, flags); 1440 spin_unlock_irqrestore(&il->lock, flags);
1441 1441
1442 /* Since CSR_INT and CSR_FH_INT_STATUS reads and clears are not 1442 /* Since CSR_INT and CSR_FH_INT_STATUS reads and clears are not
1443 * atomic, make sure that inta covers all the interrupts that 1443 * atomic, make sure that inta covers all the interrupts that
@@ -1450,13 +1450,13 @@ static void il3945_irq_tasklet(struct il_priv *priv)
1450 1450
1451 /* Now service all interrupt bits discovered above. */ 1451 /* Now service all interrupt bits discovered above. */
1452 if (inta & CSR_INT_BIT_HW_ERR) { 1452 if (inta & CSR_INT_BIT_HW_ERR) {
1453 IL_ERR(priv, "Hardware error detected. Restarting.\n"); 1453 IL_ERR(il, "Hardware error detected. Restarting.\n");
1454 1454
1455 /* Tell the device to stop sending interrupts */ 1455 /* Tell the device to stop sending interrupts */
1456 il_disable_interrupts(priv); 1456 il_disable_interrupts(il);
1457 1457
1458 priv->isr_stats.hw++; 1458 il->isr_stats.hw++;
1459 il_irq_handle_error(priv); 1459 il_irq_handle_error(il);
1460 1460
1461 handled |= CSR_INT_BIT_HW_ERR; 1461 handled |= CSR_INT_BIT_HW_ERR;
1462 1462
@@ -1464,18 +1464,18 @@ static void il3945_irq_tasklet(struct il_priv *priv)
1464 } 1464 }
1465 1465
1466#ifdef CONFIG_IWLWIFI_LEGACY_DEBUG 1466#ifdef CONFIG_IWLWIFI_LEGACY_DEBUG
1467 if (il_get_debug_level(priv) & (IL_DL_ISR)) { 1467 if (il_get_debug_level(il) & (IL_DL_ISR)) {
1468 /* NIC fires this, but we don't use it, redundant with WAKEUP */ 1468 /* NIC fires this, but we don't use it, redundant with WAKEUP */
1469 if (inta & CSR_INT_BIT_SCD) { 1469 if (inta & CSR_INT_BIT_SCD) {
1470 IL_DEBUG_ISR(priv, "Scheduler finished to transmit " 1470 IL_DEBUG_ISR(il, "Scheduler finished to transmit "
1471 "the frame/frames.\n"); 1471 "the frame/frames.\n");
1472 priv->isr_stats.sch++; 1472 il->isr_stats.sch++;
1473 } 1473 }
1474 1474
1475 /* Alive notification via Rx interrupt will do the real work */ 1475 /* Alive notification via Rx interrupt will do the real work */
1476 if (inta & CSR_INT_BIT_ALIVE) { 1476 if (inta & CSR_INT_BIT_ALIVE) {
1477 IL_DEBUG_ISR(priv, "Alive interrupt\n"); 1477 IL_DEBUG_ISR(il, "Alive interrupt\n");
1478 priv->isr_stats.alive++; 1478 il->isr_stats.alive++;
1479 } 1479 }
1480 } 1480 }
1481#endif 1481#endif
@@ -1484,25 +1484,25 @@ static void il3945_irq_tasklet(struct il_priv *priv)
1484 1484
1485 /* Error detected by uCode */ 1485 /* Error detected by uCode */
1486 if (inta & CSR_INT_BIT_SW_ERR) { 1486 if (inta & CSR_INT_BIT_SW_ERR) {
1487 IL_ERR(priv, "Microcode SW error detected. " 1487 IL_ERR(il, "Microcode SW error detected. "
1488 "Restarting 0x%X.\n", inta); 1488 "Restarting 0x%X.\n", inta);
1489 priv->isr_stats.sw++; 1489 il->isr_stats.sw++;
1490 il_irq_handle_error(priv); 1490 il_irq_handle_error(il);
1491 handled |= CSR_INT_BIT_SW_ERR; 1491 handled |= CSR_INT_BIT_SW_ERR;
1492 } 1492 }
1493 1493
1494 /* uCode wakes up after power-down sleep */ 1494 /* uCode wakes up after power-down sleep */
1495 if (inta & CSR_INT_BIT_WAKEUP) { 1495 if (inta & CSR_INT_BIT_WAKEUP) {
1496 IL_DEBUG_ISR(priv, "Wakeup interrupt\n"); 1496 IL_DEBUG_ISR(il, "Wakeup interrupt\n");
1497 il_rx_queue_update_write_ptr(priv, &priv->rxq); 1497 il_rx_queue_update_write_ptr(il, &il->rxq);
1498 il_txq_update_write_ptr(priv, &priv->txq[0]); 1498 il_txq_update_write_ptr(il, &il->txq[0]);
1499 il_txq_update_write_ptr(priv, &priv->txq[1]); 1499 il_txq_update_write_ptr(il, &il->txq[1]);
1500 il_txq_update_write_ptr(priv, &priv->txq[2]); 1500 il_txq_update_write_ptr(il, &il->txq[2]);
1501 il_txq_update_write_ptr(priv, &priv->txq[3]); 1501 il_txq_update_write_ptr(il, &il->txq[3]);
1502 il_txq_update_write_ptr(priv, &priv->txq[4]); 1502 il_txq_update_write_ptr(il, &il->txq[4]);
1503 il_txq_update_write_ptr(priv, &priv->txq[5]); 1503 il_txq_update_write_ptr(il, &il->txq[5]);
1504 1504
1505 priv->isr_stats.wakeup++; 1505 il->isr_stats.wakeup++;
1506 handled |= CSR_INT_BIT_WAKEUP; 1506 handled |= CSR_INT_BIT_WAKEUP;
1507 } 1507 }
1508 1508
@@ -1510,49 +1510,49 @@ static void il3945_irq_tasklet(struct il_priv *priv)
1510 * Rx "responses" (frame-received notification), and other 1510 * Rx "responses" (frame-received notification), and other
1511 * notifications from uCode come through here*/ 1511 * notifications from uCode come through here*/
1512 if (inta & (CSR_INT_BIT_FH_RX | CSR_INT_BIT_SW_RX)) { 1512 if (inta & (CSR_INT_BIT_FH_RX | CSR_INT_BIT_SW_RX)) {
1513 il3945_rx_handle(priv); 1513 il3945_rx_handle(il);
1514 priv->isr_stats.rx++; 1514 il->isr_stats.rx++;
1515 handled |= (CSR_INT_BIT_FH_RX | CSR_INT_BIT_SW_RX); 1515 handled |= (CSR_INT_BIT_FH_RX | CSR_INT_BIT_SW_RX);
1516 } 1516 }
1517 1517
1518 if (inta & CSR_INT_BIT_FH_TX) { 1518 if (inta & CSR_INT_BIT_FH_TX) {
1519 IL_DEBUG_ISR(priv, "Tx interrupt\n"); 1519 IL_DEBUG_ISR(il, "Tx interrupt\n");
1520 priv->isr_stats.tx++; 1520 il->isr_stats.tx++;
1521 1521
1522 il_write32(priv, CSR_FH_INT_STATUS, (1 << 6)); 1522 il_write32(il, CSR_FH_INT_STATUS, (1 << 6));
1523 il_write_direct32(priv, FH39_TCSR_CREDIT 1523 il_write_direct32(il, FH39_TCSR_CREDIT
1524 (FH39_SRVC_CHNL), 0x0); 1524 (FH39_SRVC_CHNL), 0x0);
1525 handled |= CSR_INT_BIT_FH_TX; 1525 handled |= CSR_INT_BIT_FH_TX;
1526 } 1526 }
1527 1527
1528 if (inta & ~handled) { 1528 if (inta & ~handled) {
1529 IL_ERR(priv, "Unhandled INTA bits 0x%08x\n", inta & ~handled); 1529 IL_ERR(il, "Unhandled INTA bits 0x%08x\n", inta & ~handled);
1530 priv->isr_stats.unhandled++; 1530 il->isr_stats.unhandled++;
1531 } 1531 }
1532 1532
1533 if (inta & ~priv->inta_mask) { 1533 if (inta & ~il->inta_mask) {
1534 IL_WARN(priv, "Disabled INTA bits 0x%08x were pending\n", 1534 IL_WARN(il, "Disabled INTA bits 0x%08x were pending\n",
1535 inta & ~priv->inta_mask); 1535 inta & ~il->inta_mask);
1536 IL_WARN(priv, " with FH_INT = 0x%08x\n", inta_fh); 1536 IL_WARN(il, " with FH_INT = 0x%08x\n", inta_fh);
1537 } 1537 }
1538 1538
1539 /* Re-enable all interrupts */ 1539 /* Re-enable all interrupts */
1540 /* only Re-enable if disabled by irq */ 1540 /* only Re-enable if disabled by irq */
1541 if (test_bit(STATUS_INT_ENABLED, &priv->status)) 1541 if (test_bit(STATUS_INT_ENABLED, &il->status))
1542 il_enable_interrupts(priv); 1542 il_enable_interrupts(il);
1543 1543
1544#ifdef CONFIG_IWLWIFI_LEGACY_DEBUG 1544#ifdef CONFIG_IWLWIFI_LEGACY_DEBUG
1545 if (il_get_debug_level(priv) & (IL_DL_ISR)) { 1545 if (il_get_debug_level(il) & (IL_DL_ISR)) {
1546 inta = il_read32(priv, CSR_INT); 1546 inta = il_read32(il, CSR_INT);
1547 inta_mask = il_read32(priv, CSR_INT_MASK); 1547 inta_mask = il_read32(il, CSR_INT_MASK);
1548 inta_fh = il_read32(priv, CSR_FH_INT_STATUS); 1548 inta_fh = il_read32(il, CSR_FH_INT_STATUS);
1549 IL_DEBUG_ISR(priv, "End inta 0x%08x, enabled 0x%08x, fh 0x%08x, " 1549 IL_DEBUG_ISR(il, "End inta 0x%08x, enabled 0x%08x, fh 0x%08x, "
1550 "flags 0x%08lx\n", inta, inta_mask, inta_fh, flags); 1550 "flags 0x%08lx\n", inta, inta_mask, inta_fh, flags);
1551 } 1551 }
1552#endif 1552#endif
1553} 1553}
1554 1554
1555static int il3945_get_channels_for_scan(struct il_priv *priv, 1555static int il3945_get_channels_for_scan(struct il_priv *il,
1556 enum ieee80211_band band, 1556 enum ieee80211_band band,
1557 u8 is_active, u8 n_probes, 1557 u8 is_active, u8 n_probes,
1558 struct il3945_scan_channel *scan_ch, 1558 struct il3945_scan_channel *scan_ch,
@@ -1565,28 +1565,28 @@ static int il3945_get_channels_for_scan(struct il_priv *priv,
1565 u16 active_dwell = 0; 1565 u16 active_dwell = 0;
1566 int added, i; 1566 int added, i;
1567 1567
1568 sband = il_get_hw_mode(priv, band); 1568 sband = il_get_hw_mode(il, band);
1569 if (!sband) 1569 if (!sband)
1570 return 0; 1570 return 0;
1571 1571
1572 active_dwell = il_get_active_dwell_time(priv, band, n_probes); 1572 active_dwell = il_get_active_dwell_time(il, band, n_probes);
1573 passive_dwell = il_get_passive_dwell_time(priv, band, vif); 1573 passive_dwell = il_get_passive_dwell_time(il, band, vif);
1574 1574
1575 if (passive_dwell <= active_dwell) 1575 if (passive_dwell <= active_dwell)
1576 passive_dwell = active_dwell + 1; 1576 passive_dwell = active_dwell + 1;
1577 1577
1578 for (i = 0, added = 0; i < priv->scan_request->n_channels; i++) { 1578 for (i = 0, added = 0; i < il->scan_request->n_channels; i++) {
1579 chan = priv->scan_request->channels[i]; 1579 chan = il->scan_request->channels[i];
1580 1580
1581 if (chan->band != band) 1581 if (chan->band != band)
1582 continue; 1582 continue;
1583 1583
1584 scan_ch->channel = chan->hw_value; 1584 scan_ch->channel = chan->hw_value;
1585 1585
1586 ch_info = il_get_channel_info(priv, band, 1586 ch_info = il_get_channel_info(il, band,
1587 scan_ch->channel); 1587 scan_ch->channel);
1588 if (!il_is_channel_valid(ch_info)) { 1588 if (!il_is_channel_valid(ch_info)) {
1589 IL_DEBUG_SCAN(priv, 1589 IL_DEBUG_SCAN(il,
1590 "Channel %d is INVALID for this band.\n", 1590 "Channel %d is INVALID for this band.\n",
1591 scan_ch->channel); 1591 scan_ch->channel);
1592 continue; 1592 continue;
@@ -1600,7 +1600,7 @@ static int il3945_get_channels_for_scan(struct il_priv *priv,
1600 if (!is_active || il_is_channel_passive(ch_info) || 1600 if (!is_active || il_is_channel_passive(ch_info) ||
1601 (chan->flags & IEEE80211_CHAN_PASSIVE_SCAN)) { 1601 (chan->flags & IEEE80211_CHAN_PASSIVE_SCAN)) {
1602 scan_ch->type = 0; /* passive */ 1602 scan_ch->type = 0; /* passive */
1603 if (IL_UCODE_API(priv->ucode_ver) == 1) 1603 if (IL_UCODE_API(il->ucode_ver) == 1)
1604 scan_ch->active_dwell = cpu_to_le16(passive_dwell - 1); 1604 scan_ch->active_dwell = cpu_to_le16(passive_dwell - 1);
1605 } else { 1605 } else {
1606 scan_ch->type = 1; /* active */ 1606 scan_ch->type = 1; /* active */
@@ -1610,7 +1610,7 @@ static int il3945_get_channels_for_scan(struct il_priv *priv,
1610 * scan channels (probes gets sent right away), 1610 * scan channels (probes gets sent right away),
1611 * or for passive channels (probes get se sent only after 1611 * or for passive channels (probes get se sent only after
1612 * hearing clear Rx packet).*/ 1612 * hearing clear Rx packet).*/
1613 if (IL_UCODE_API(priv->ucode_ver) >= 2) { 1613 if (IL_UCODE_API(il->ucode_ver) >= 2) {
1614 if (n_probes) 1614 if (n_probes)
1615 scan_ch->type |= IWL39_SCAN_PROBE_MASK(n_probes); 1615 scan_ch->type |= IWL39_SCAN_PROBE_MASK(n_probes);
1616 } else { 1616 } else {
@@ -1635,7 +1635,7 @@ static int il3945_get_channels_for_scan(struct il_priv *priv,
1635 */ 1635 */
1636 } 1636 }
1637 1637
1638 IL_DEBUG_SCAN(priv, "Scanning %d [%s %d]\n", 1638 IL_DEBUG_SCAN(il, "Scanning %d [%s %d]\n",
1639 scan_ch->channel, 1639 scan_ch->channel,
1640 (scan_ch->type & 1) ? "ACTIVE" : "PASSIVE", 1640 (scan_ch->type & 1) ? "ACTIVE" : "PASSIVE",
1641 (scan_ch->type & 1) ? 1641 (scan_ch->type & 1) ?
@@ -1645,11 +1645,11 @@ static int il3945_get_channels_for_scan(struct il_priv *priv,
1645 added++; 1645 added++;
1646 } 1646 }
1647 1647
1648 IL_DEBUG_SCAN(priv, "total channels to scan %d\n", added); 1648 IL_DEBUG_SCAN(il, "total channels to scan %d\n", added);
1649 return added; 1649 return added;
1650} 1650}
1651 1651
1652static void il3945_init_hw_rates(struct il_priv *priv, 1652static void il3945_init_hw_rates(struct il_priv *il,
1653 struct ieee80211_rate *rates) 1653 struct ieee80211_rate *rates)
1654{ 1654{
1655 int i; 1655 int i;
@@ -1675,30 +1675,30 @@ static void il3945_init_hw_rates(struct il_priv *priv,
1675 * 1675 *
1676 ******************************************************************************/ 1676 ******************************************************************************/
1677 1677
1678static void il3945_dealloc_ucode_pci(struct il_priv *priv) 1678static void il3945_dealloc_ucode_pci(struct il_priv *il)
1679{ 1679{
1680 il_free_fw_desc(priv->pci_dev, &priv->ucode_code); 1680 il_free_fw_desc(il->pci_dev, &il->ucode_code);
1681 il_free_fw_desc(priv->pci_dev, &priv->ucode_data); 1681 il_free_fw_desc(il->pci_dev, &il->ucode_data);
1682 il_free_fw_desc(priv->pci_dev, &priv->ucode_data_backup); 1682 il_free_fw_desc(il->pci_dev, &il->ucode_data_backup);
1683 il_free_fw_desc(priv->pci_dev, &priv->ucode_init); 1683 il_free_fw_desc(il->pci_dev, &il->ucode_init);
1684 il_free_fw_desc(priv->pci_dev, &priv->ucode_init_data); 1684 il_free_fw_desc(il->pci_dev, &il->ucode_init_data);
1685 il_free_fw_desc(priv->pci_dev, &priv->ucode_boot); 1685 il_free_fw_desc(il->pci_dev, &il->ucode_boot);
1686} 1686}
1687 1687
1688/** 1688/**
1689 * il3945_verify_inst_full - verify runtime uCode image in card vs. host, 1689 * il3945_verify_inst_full - verify runtime uCode image in card vs. host,
1690 * looking at all data. 1690 * looking at all data.
1691 */ 1691 */
1692static int il3945_verify_inst_full(struct il_priv *priv, __le32 *image, u32 len) 1692static int il3945_verify_inst_full(struct il_priv *il, __le32 *image, u32 len)
1693{ 1693{
1694 u32 val; 1694 u32 val;
1695 u32 save_len = len; 1695 u32 save_len = len;
1696 int rc = 0; 1696 int rc = 0;
1697 u32 errcnt; 1697 u32 errcnt;
1698 1698
1699 IL_DEBUG_INFO(priv, "ucode inst image size is %u\n", len); 1699 IL_DEBUG_INFO(il, "ucode inst image size is %u\n", len);
1700 1700
1701 il_write_direct32(priv, HBUS_TARG_MEM_RADDR, 1701 il_write_direct32(il, HBUS_TARG_MEM_RADDR,
1702 IWL39_RTC_INST_LOWER_BOUND); 1702 IWL39_RTC_INST_LOWER_BOUND);
1703 1703
1704 errcnt = 0; 1704 errcnt = 0;
@@ -1706,9 +1706,9 @@ static int il3945_verify_inst_full(struct il_priv *priv, __le32 *image, u32 len)
1706 /* read data comes through single port, auto-incr addr */ 1706 /* read data comes through single port, auto-incr addr */
1707 /* NOTE: Use the debugless read so we don't flood kernel log 1707 /* NOTE: Use the debugless read so we don't flood kernel log
1708 * if IL_DL_IO is set */ 1708 * if IL_DL_IO is set */
1709 val = _il_read_direct32(priv, HBUS_TARG_MEM_RDAT); 1709 val = _il_read_direct32(il, HBUS_TARG_MEM_RDAT);
1710 if (val != le32_to_cpu(*image)) { 1710 if (val != le32_to_cpu(*image)) {
1711 IL_ERR(priv, "uCode INST section is invalid at " 1711 IL_ERR(il, "uCode INST section is invalid at "
1712 "offset 0x%x, is 0x%x, s/b 0x%x\n", 1712 "offset 0x%x, is 0x%x, s/b 0x%x\n",
1713 save_len - len, val, le32_to_cpu(*image)); 1713 save_len - len, val, le32_to_cpu(*image));
1714 rc = -EIO; 1714 rc = -EIO;
@@ -1720,7 +1720,7 @@ static int il3945_verify_inst_full(struct il_priv *priv, __le32 *image, u32 len)
1720 1720
1721 1721
1722 if (!errcnt) 1722 if (!errcnt)
1723 IL_DEBUG_INFO(priv, 1723 IL_DEBUG_INFO(il,
1724 "ucode image in INSTRUCTION memory is good\n"); 1724 "ucode image in INSTRUCTION memory is good\n");
1725 1725
1726 return rc; 1726 return rc;
@@ -1732,25 +1732,25 @@ static int il3945_verify_inst_full(struct il_priv *priv, __le32 *image, u32 len)
1732 * using sample data 100 bytes apart. If these sample points are good, 1732 * using sample data 100 bytes apart. If these sample points are good,
1733 * it's a pretty good bet that everything between them is good, too. 1733 * it's a pretty good bet that everything between them is good, too.
1734 */ 1734 */
1735static int il3945_verify_inst_sparse(struct il_priv *priv, __le32 *image, u32 len) 1735static int il3945_verify_inst_sparse(struct il_priv *il, __le32 *image, u32 len)
1736{ 1736{
1737 u32 val; 1737 u32 val;
1738 int rc = 0; 1738 int rc = 0;
1739 u32 errcnt = 0; 1739 u32 errcnt = 0;
1740 u32 i; 1740 u32 i;
1741 1741
1742 IL_DEBUG_INFO(priv, "ucode inst image size is %u\n", len); 1742 IL_DEBUG_INFO(il, "ucode inst image size is %u\n", len);
1743 1743
1744 for (i = 0; i < len; i += 100, image += 100/sizeof(u32)) { 1744 for (i = 0; i < len; i += 100, image += 100/sizeof(u32)) {
1745 /* read data comes through single port, auto-incr addr */ 1745 /* read data comes through single port, auto-incr addr */
1746 /* NOTE: Use the debugless read so we don't flood kernel log 1746 /* NOTE: Use the debugless read so we don't flood kernel log
1747 * if IL_DL_IO is set */ 1747 * if IL_DL_IO is set */
1748 il_write_direct32(priv, HBUS_TARG_MEM_RADDR, 1748 il_write_direct32(il, HBUS_TARG_MEM_RADDR,
1749 i + IWL39_RTC_INST_LOWER_BOUND); 1749 i + IWL39_RTC_INST_LOWER_BOUND);
1750 val = _il_read_direct32(priv, HBUS_TARG_MEM_RDAT); 1750 val = _il_read_direct32(il, HBUS_TARG_MEM_RDAT);
1751 if (val != le32_to_cpu(*image)) { 1751 if (val != le32_to_cpu(*image)) {
1752#if 0 /* Enable this if you want to see details */ 1752#if 0 /* Enable this if you want to see details */
1753 IL_ERR(priv, "uCode INST section is invalid at " 1753 IL_ERR(il, "uCode INST section is invalid at "
1754 "offset 0x%x, is 0x%x, s/b 0x%x\n", 1754 "offset 0x%x, is 0x%x, s/b 0x%x\n",
1755 i, val, *image); 1755 i, val, *image);
1756#endif 1756#endif
@@ -1769,55 +1769,55 @@ static int il3945_verify_inst_sparse(struct il_priv *priv, __le32 *image, u32 le
1769 * il3945_verify_ucode - determine which instruction image is in SRAM, 1769 * il3945_verify_ucode - determine which instruction image is in SRAM,
1770 * and verify its contents 1770 * and verify its contents
1771 */ 1771 */
1772static int il3945_verify_ucode(struct il_priv *priv) 1772static int il3945_verify_ucode(struct il_priv *il)
1773{ 1773{
1774 __le32 *image; 1774 __le32 *image;
1775 u32 len; 1775 u32 len;
1776 int rc = 0; 1776 int rc = 0;
1777 1777
1778 /* Try bootstrap */ 1778 /* Try bootstrap */
1779 image = (__le32 *)priv->ucode_boot.v_addr; 1779 image = (__le32 *)il->ucode_boot.v_addr;
1780 len = priv->ucode_boot.len; 1780 len = il->ucode_boot.len;
1781 rc = il3945_verify_inst_sparse(priv, image, len); 1781 rc = il3945_verify_inst_sparse(il, image, len);
1782 if (rc == 0) { 1782 if (rc == 0) {
1783 IL_DEBUG_INFO(priv, "Bootstrap uCode is good in inst SRAM\n"); 1783 IL_DEBUG_INFO(il, "Bootstrap uCode is good in inst SRAM\n");
1784 return 0; 1784 return 0;
1785 } 1785 }
1786 1786
1787 /* Try initialize */ 1787 /* Try initialize */
1788 image = (__le32 *)priv->ucode_init.v_addr; 1788 image = (__le32 *)il->ucode_init.v_addr;
1789 len = priv->ucode_init.len; 1789 len = il->ucode_init.len;
1790 rc = il3945_verify_inst_sparse(priv, image, len); 1790 rc = il3945_verify_inst_sparse(il, image, len);
1791 if (rc == 0) { 1791 if (rc == 0) {
1792 IL_DEBUG_INFO(priv, "Initialize uCode is good in inst SRAM\n"); 1792 IL_DEBUG_INFO(il, "Initialize uCode is good in inst SRAM\n");
1793 return 0; 1793 return 0;
1794 } 1794 }
1795 1795
1796 /* Try runtime/protocol */ 1796 /* Try runtime/protocol */
1797 image = (__le32 *)priv->ucode_code.v_addr; 1797 image = (__le32 *)il->ucode_code.v_addr;
1798 len = priv->ucode_code.len; 1798 len = il->ucode_code.len;
1799 rc = il3945_verify_inst_sparse(priv, image, len); 1799 rc = il3945_verify_inst_sparse(il, image, len);
1800 if (rc == 0) { 1800 if (rc == 0) {
1801 IL_DEBUG_INFO(priv, "Runtime uCode is good in inst SRAM\n"); 1801 IL_DEBUG_INFO(il, "Runtime uCode is good in inst SRAM\n");
1802 return 0; 1802 return 0;
1803 } 1803 }
1804 1804
1805 IL_ERR(priv, "NO VALID UCODE IMAGE IN INSTRUCTION SRAM!!\n"); 1805 IL_ERR(il, "NO VALID UCODE IMAGE IN INSTRUCTION SRAM!!\n");
1806 1806
1807 /* Since nothing seems to match, show first several data entries in 1807 /* Since nothing seems to match, show first several data entries in
1808 * instruction SRAM, so maybe visual inspection will give a clue. 1808 * instruction SRAM, so maybe visual inspection will give a clue.
1809 * Selection of bootstrap image (vs. other images) is arbitrary. */ 1809 * Selection of bootstrap image (vs. other images) is arbitrary. */
1810 image = (__le32 *)priv->ucode_boot.v_addr; 1810 image = (__le32 *)il->ucode_boot.v_addr;
1811 len = priv->ucode_boot.len; 1811 len = il->ucode_boot.len;
1812 rc = il3945_verify_inst_full(priv, image, len); 1812 rc = il3945_verify_inst_full(il, image, len);
1813 1813
1814 return rc; 1814 return rc;
1815} 1815}
1816 1816
1817static void il3945_nic_start(struct il_priv *priv) 1817static void il3945_nic_start(struct il_priv *il)
1818{ 1818{
1819 /* Remove all resets to allow NIC to operate */ 1819 /* Remove all resets to allow NIC to operate */
1820 il_write32(priv, CSR_RESET, 0); 1820 il_write32(il, CSR_RESET, 0);
1821} 1821}
1822 1822
1823#define IWL3945_UCODE_GET(item) \ 1823#define IWL3945_UCODE_GET(item) \
@@ -1847,15 +1847,15 @@ IWL3945_UCODE_GET(boot_size);
1847 * 1847 *
1848 * Copy into buffers for card to fetch via bus-mastering 1848 * Copy into buffers for card to fetch via bus-mastering
1849 */ 1849 */
1850static int il3945_read_ucode(struct il_priv *priv) 1850static int il3945_read_ucode(struct il_priv *il)
1851{ 1851{
1852 const struct il_ucode_header *ucode; 1852 const struct il_ucode_header *ucode;
1853 int ret = -EINVAL, index; 1853 int ret = -EINVAL, index;
1854 const struct firmware *ucode_raw; 1854 const struct firmware *ucode_raw;
1855 /* firmware file name contains uCode/driver compatibility version */ 1855 /* firmware file name contains uCode/driver compatibility version */
1856 const char *name_pre = priv->cfg->fw_name_pre; 1856 const char *name_pre = il->cfg->fw_name_pre;
1857 const unsigned int api_max = priv->cfg->ucode_api_max; 1857 const unsigned int api_max = il->cfg->ucode_api_max;
1858 const unsigned int api_min = priv->cfg->ucode_api_min; 1858 const unsigned int api_min = il->cfg->ucode_api_min;
1859 char buf[25]; 1859 char buf[25];
1860 u8 *src; 1860 u8 *src;
1861 size_t len; 1861 size_t len;
@@ -1865,9 +1865,9 @@ static int il3945_read_ucode(struct il_priv *priv)
1865 * request_firmware() is synchronous, file is in memory on return. */ 1865 * request_firmware() is synchronous, file is in memory on return. */
1866 for (index = api_max; index >= api_min; index--) { 1866 for (index = api_max; index >= api_min; index--) {
1867 sprintf(buf, "%s%u%s", name_pre, index, ".ucode"); 1867 sprintf(buf, "%s%u%s", name_pre, index, ".ucode");
1868 ret = request_firmware(&ucode_raw, buf, &priv->pci_dev->dev); 1868 ret = request_firmware(&ucode_raw, buf, &il->pci_dev->dev);
1869 if (ret < 0) { 1869 if (ret < 0) {
1870 IL_ERR(priv, "%s firmware file req failed: %d\n", 1870 IL_ERR(il, "%s firmware file req failed: %d\n",
1871 buf, ret); 1871 buf, ret);
1872 if (ret == -ENOENT) 1872 if (ret == -ENOENT)
1873 continue; 1873 continue;
@@ -1875,11 +1875,11 @@ static int il3945_read_ucode(struct il_priv *priv)
1875 goto error; 1875 goto error;
1876 } else { 1876 } else {
1877 if (index < api_max) 1877 if (index < api_max)
1878 IL_ERR(priv, "Loaded firmware %s, " 1878 IL_ERR(il, "Loaded firmware %s, "
1879 "which is deprecated. " 1879 "which is deprecated. "
1880 " Please use API v%u instead.\n", 1880 " Please use API v%u instead.\n",
1881 buf, api_max); 1881 buf, api_max);
1882 IL_DEBUG_INFO(priv, "Got firmware '%s' file " 1882 IL_DEBUG_INFO(il, "Got firmware '%s' file "
1883 "(%zd bytes) from disk\n", 1883 "(%zd bytes) from disk\n",
1884 buf, ucode_raw->size); 1884 buf, ucode_raw->size);
1885 break; 1885 break;
@@ -1891,7 +1891,7 @@ static int il3945_read_ucode(struct il_priv *priv)
1891 1891
1892 /* Make sure that we got at least our header! */ 1892 /* Make sure that we got at least our header! */
1893 if (ucode_raw->size < il3945_ucode_get_header_size(1)) { 1893 if (ucode_raw->size < il3945_ucode_get_header_size(1)) {
1894 IL_ERR(priv, "File size way too small!\n"); 1894 IL_ERR(il, "File size way too small!\n");
1895 ret = -EINVAL; 1895 ret = -EINVAL;
1896 goto err_release; 1896 goto err_release;
1897 } 1897 }
@@ -1899,8 +1899,8 @@ static int il3945_read_ucode(struct il_priv *priv)
1899 /* Data from ucode file: header followed by uCode images */ 1899 /* Data from ucode file: header followed by uCode images */
1900 ucode = (struct il_ucode_header *)ucode_raw->data; 1900 ucode = (struct il_ucode_header *)ucode_raw->data;
1901 1901
1902 priv->ucode_ver = le32_to_cpu(ucode->ver); 1902 il->ucode_ver = le32_to_cpu(ucode->ver);
1903 api_ver = IL_UCODE_API(priv->ucode_ver); 1903 api_ver = IL_UCODE_API(il->ucode_ver);
1904 inst_size = il3945_ucode_get_inst_size(ucode); 1904 inst_size = il3945_ucode_get_inst_size(ucode);
1905 data_size = il3945_ucode_get_data_size(ucode); 1905 data_size = il3945_ucode_get_data_size(ucode);
1906 init_size = il3945_ucode_get_init_size(ucode); 1906 init_size = il3945_ucode_get_init_size(ucode);
@@ -1913,44 +1913,44 @@ static int il3945_read_ucode(struct il_priv *priv)
1913 * on the API version read from firmware header from here on forward */ 1913 * on the API version read from firmware header from here on forward */
1914 1914
1915 if (api_ver < api_min || api_ver > api_max) { 1915 if (api_ver < api_min || api_ver > api_max) {
1916 IL_ERR(priv, "Driver unable to support your firmware API. " 1916 IL_ERR(il, "Driver unable to support your firmware API. "
1917 "Driver supports v%u, firmware is v%u.\n", 1917 "Driver supports v%u, firmware is v%u.\n",
1918 api_max, api_ver); 1918 api_max, api_ver);
1919 priv->ucode_ver = 0; 1919 il->ucode_ver = 0;
1920 ret = -EINVAL; 1920 ret = -EINVAL;
1921 goto err_release; 1921 goto err_release;
1922 } 1922 }
1923 if (api_ver != api_max) 1923 if (api_ver != api_max)
1924 IL_ERR(priv, "Firmware has old API version. Expected %u, " 1924 IL_ERR(il, "Firmware has old API version. Expected %u, "
1925 "got %u. New firmware can be obtained " 1925 "got %u. New firmware can be obtained "
1926 "from http://www.intellinuxwireless.org.\n", 1926 "from http://www.intellinuxwireless.org.\n",
1927 api_max, api_ver); 1927 api_max, api_ver);
1928 1928
1929 IL_INFO(priv, "loaded firmware version %u.%u.%u.%u\n", 1929 IL_INFO(il, "loaded firmware version %u.%u.%u.%u\n",
1930 IL_UCODE_MAJOR(priv->ucode_ver), 1930 IL_UCODE_MAJOR(il->ucode_ver),
1931 IL_UCODE_MINOR(priv->ucode_ver), 1931 IL_UCODE_MINOR(il->ucode_ver),
1932 IL_UCODE_API(priv->ucode_ver), 1932 IL_UCODE_API(il->ucode_ver),
1933 IL_UCODE_SERIAL(priv->ucode_ver)); 1933 IL_UCODE_SERIAL(il->ucode_ver));
1934 1934
1935 snprintf(priv->hw->wiphy->fw_version, 1935 snprintf(il->hw->wiphy->fw_version,
1936 sizeof(priv->hw->wiphy->fw_version), 1936 sizeof(il->hw->wiphy->fw_version),
1937 "%u.%u.%u.%u", 1937 "%u.%u.%u.%u",
1938 IL_UCODE_MAJOR(priv->ucode_ver), 1938 IL_UCODE_MAJOR(il->ucode_ver),
1939 IL_UCODE_MINOR(priv->ucode_ver), 1939 IL_UCODE_MINOR(il->ucode_ver),
1940 IL_UCODE_API(priv->ucode_ver), 1940 IL_UCODE_API(il->ucode_ver),
1941 IL_UCODE_SERIAL(priv->ucode_ver)); 1941 IL_UCODE_SERIAL(il->ucode_ver));
1942 1942
1943 IL_DEBUG_INFO(priv, "f/w package hdr ucode version raw = 0x%x\n", 1943 IL_DEBUG_INFO(il, "f/w package hdr ucode version raw = 0x%x\n",
1944 priv->ucode_ver); 1944 il->ucode_ver);
1945 IL_DEBUG_INFO(priv, "f/w package hdr runtime inst size = %u\n", 1945 IL_DEBUG_INFO(il, "f/w package hdr runtime inst size = %u\n",
1946 inst_size); 1946 inst_size);
1947 IL_DEBUG_INFO(priv, "f/w package hdr runtime data size = %u\n", 1947 IL_DEBUG_INFO(il, "f/w package hdr runtime data size = %u\n",
1948 data_size); 1948 data_size);
1949 IL_DEBUG_INFO(priv, "f/w package hdr init inst size = %u\n", 1949 IL_DEBUG_INFO(il, "f/w package hdr init inst size = %u\n",
1950 init_size); 1950 init_size);
1951 IL_DEBUG_INFO(priv, "f/w package hdr init data size = %u\n", 1951 IL_DEBUG_INFO(il, "f/w package hdr init data size = %u\n",
1952 init_data_size); 1952 init_data_size);
1953 IL_DEBUG_INFO(priv, "f/w package hdr boot inst size = %u\n", 1953 IL_DEBUG_INFO(il, "f/w package hdr boot inst size = %u\n",
1954 boot_size); 1954 boot_size);
1955 1955
1956 1956
@@ -1959,7 +1959,7 @@ static int il3945_read_ucode(struct il_priv *priv)
1959 inst_size + data_size + init_size + 1959 inst_size + data_size + init_size +
1960 init_data_size + boot_size) { 1960 init_data_size + boot_size) {
1961 1961
1962 IL_DEBUG_INFO(priv, 1962 IL_DEBUG_INFO(il,
1963 "uCode file size %zd does not match expected size\n", 1963 "uCode file size %zd does not match expected size\n",
1964 ucode_raw->size); 1964 ucode_raw->size);
1965 ret = -EINVAL; 1965 ret = -EINVAL;
@@ -1968,34 +1968,34 @@ static int il3945_read_ucode(struct il_priv *priv)
1968 1968
1969 /* Verify that uCode images will fit in card's SRAM */ 1969 /* Verify that uCode images will fit in card's SRAM */
1970 if (inst_size > IWL39_MAX_INST_SIZE) { 1970 if (inst_size > IWL39_MAX_INST_SIZE) {
1971 IL_DEBUG_INFO(priv, "uCode instr len %d too large to fit in\n", 1971 IL_DEBUG_INFO(il, "uCode instr len %d too large to fit in\n",
1972 inst_size); 1972 inst_size);
1973 ret = -EINVAL; 1973 ret = -EINVAL;
1974 goto err_release; 1974 goto err_release;
1975 } 1975 }
1976 1976
1977 if (data_size > IWL39_MAX_DATA_SIZE) { 1977 if (data_size > IWL39_MAX_DATA_SIZE) {
1978 IL_DEBUG_INFO(priv, "uCode data len %d too large to fit in\n", 1978 IL_DEBUG_INFO(il, "uCode data len %d too large to fit in\n",
1979 data_size); 1979 data_size);
1980 ret = -EINVAL; 1980 ret = -EINVAL;
1981 goto err_release; 1981 goto err_release;
1982 } 1982 }
1983 if (init_size > IWL39_MAX_INST_SIZE) { 1983 if (init_size > IWL39_MAX_INST_SIZE) {
1984 IL_DEBUG_INFO(priv, 1984 IL_DEBUG_INFO(il,
1985 "uCode init instr len %d too large to fit in\n", 1985 "uCode init instr len %d too large to fit in\n",
1986 init_size); 1986 init_size);
1987 ret = -EINVAL; 1987 ret = -EINVAL;
1988 goto err_release; 1988 goto err_release;
1989 } 1989 }
1990 if (init_data_size > IWL39_MAX_DATA_SIZE) { 1990 if (init_data_size > IWL39_MAX_DATA_SIZE) {
1991 IL_DEBUG_INFO(priv, 1991 IL_DEBUG_INFO(il,
1992 "uCode init data len %d too large to fit in\n", 1992 "uCode init data len %d too large to fit in\n",
1993 init_data_size); 1993 init_data_size);
1994 ret = -EINVAL; 1994 ret = -EINVAL;
1995 goto err_release; 1995 goto err_release;
1996 } 1996 }
1997 if (boot_size > IWL39_MAX_BSM_SIZE) { 1997 if (boot_size > IWL39_MAX_BSM_SIZE) {
1998 IL_DEBUG_INFO(priv, 1998 IL_DEBUG_INFO(il,
1999 "uCode boot instr len %d too large to fit in\n", 1999 "uCode boot instr len %d too large to fit in\n",
2000 boot_size); 2000 boot_size);
2001 ret = -EINVAL; 2001 ret = -EINVAL;
@@ -2007,37 +2007,37 @@ static int il3945_read_ucode(struct il_priv *priv)
2007 /* Runtime instructions and 2 copies of data: 2007 /* Runtime instructions and 2 copies of data:
2008 * 1) unmodified from disk 2008 * 1) unmodified from disk
2009 * 2) backup cache for save/restore during power-downs */ 2009 * 2) backup cache for save/restore during power-downs */
2010 priv->ucode_code.len = inst_size; 2010 il->ucode_code.len = inst_size;
2011 il_alloc_fw_desc(priv->pci_dev, &priv->ucode_code); 2011 il_alloc_fw_desc(il->pci_dev, &il->ucode_code);
2012 2012
2013 priv->ucode_data.len = data_size; 2013 il->ucode_data.len = data_size;
2014 il_alloc_fw_desc(priv->pci_dev, &priv->ucode_data); 2014 il_alloc_fw_desc(il->pci_dev, &il->ucode_data);
2015 2015
2016 priv->ucode_data_backup.len = data_size; 2016 il->ucode_data_backup.len = data_size;
2017 il_alloc_fw_desc(priv->pci_dev, &priv->ucode_data_backup); 2017 il_alloc_fw_desc(il->pci_dev, &il->ucode_data_backup);
2018 2018
2019 if (!priv->ucode_code.v_addr || !priv->ucode_data.v_addr || 2019 if (!il->ucode_code.v_addr || !il->ucode_data.v_addr ||
2020 !priv->ucode_data_backup.v_addr) 2020 !il->ucode_data_backup.v_addr)
2021 goto err_pci_alloc; 2021 goto err_pci_alloc;
2022 2022
2023 /* Initialization instructions and data */ 2023 /* Initialization instructions and data */
2024 if (init_size && init_data_size) { 2024 if (init_size && init_data_size) {
2025 priv->ucode_init.len = init_size; 2025 il->ucode_init.len = init_size;
2026 il_alloc_fw_desc(priv->pci_dev, &priv->ucode_init); 2026 il_alloc_fw_desc(il->pci_dev, &il->ucode_init);
2027 2027
2028 priv->ucode_init_data.len = init_data_size; 2028 il->ucode_init_data.len = init_data_size;
2029 il_alloc_fw_desc(priv->pci_dev, &priv->ucode_init_data); 2029 il_alloc_fw_desc(il->pci_dev, &il->ucode_init_data);
2030 2030
2031 if (!priv->ucode_init.v_addr || !priv->ucode_init_data.v_addr) 2031 if (!il->ucode_init.v_addr || !il->ucode_init_data.v_addr)
2032 goto err_pci_alloc; 2032 goto err_pci_alloc;
2033 } 2033 }
2034 2034
2035 /* Bootstrap (instructions only, no data) */ 2035 /* Bootstrap (instructions only, no data) */
2036 if (boot_size) { 2036 if (boot_size) {
2037 priv->ucode_boot.len = boot_size; 2037 il->ucode_boot.len = boot_size;
2038 il_alloc_fw_desc(priv->pci_dev, &priv->ucode_boot); 2038 il_alloc_fw_desc(il->pci_dev, &il->ucode_boot);
2039 2039
2040 if (!priv->ucode_boot.v_addr) 2040 if (!il->ucode_boot.v_addr)
2041 goto err_pci_alloc; 2041 goto err_pci_alloc;
2042 } 2042 }
2043 2043
@@ -2045,55 +2045,55 @@ static int il3945_read_ucode(struct il_priv *priv)
2045 2045
2046 /* Runtime instructions (first block of data in file) */ 2046 /* Runtime instructions (first block of data in file) */
2047 len = inst_size; 2047 len = inst_size;
2048 IL_DEBUG_INFO(priv, 2048 IL_DEBUG_INFO(il,
2049 "Copying (but not loading) uCode instr len %zd\n", len); 2049 "Copying (but not loading) uCode instr len %zd\n", len);
2050 memcpy(priv->ucode_code.v_addr, src, len); 2050 memcpy(il->ucode_code.v_addr, src, len);
2051 src += len; 2051 src += len;
2052 2052
2053 IL_DEBUG_INFO(priv, "uCode instr buf vaddr = 0x%p, paddr = 0x%08x\n", 2053 IL_DEBUG_INFO(il, "uCode instr buf vaddr = 0x%p, paddr = 0x%08x\n",
2054 priv->ucode_code.v_addr, (u32)priv->ucode_code.p_addr); 2054 il->ucode_code.v_addr, (u32)il->ucode_code.p_addr);
2055 2055
2056 /* Runtime data (2nd block) 2056 /* Runtime data (2nd block)
2057 * NOTE: Copy into backup buffer will be done in il3945_up() */ 2057 * NOTE: Copy into backup buffer will be done in il3945_up() */
2058 len = data_size; 2058 len = data_size;
2059 IL_DEBUG_INFO(priv, 2059 IL_DEBUG_INFO(il,
2060 "Copying (but not loading) uCode data len %zd\n", len); 2060 "Copying (but not loading) uCode data len %zd\n", len);
2061 memcpy(priv->ucode_data.v_addr, src, len); 2061 memcpy(il->ucode_data.v_addr, src, len);
2062 memcpy(priv->ucode_data_backup.v_addr, src, len); 2062 memcpy(il->ucode_data_backup.v_addr, src, len);
2063 src += len; 2063 src += len;
2064 2064
2065 /* Initialization instructions (3rd block) */ 2065 /* Initialization instructions (3rd block) */
2066 if (init_size) { 2066 if (init_size) {
2067 len = init_size; 2067 len = init_size;
2068 IL_DEBUG_INFO(priv, 2068 IL_DEBUG_INFO(il,
2069 "Copying (but not loading) init instr len %zd\n", len); 2069 "Copying (but not loading) init instr len %zd\n", len);
2070 memcpy(priv->ucode_init.v_addr, src, len); 2070 memcpy(il->ucode_init.v_addr, src, len);
2071 src += len; 2071 src += len;
2072 } 2072 }
2073 2073
2074 /* Initialization data (4th block) */ 2074 /* Initialization data (4th block) */
2075 if (init_data_size) { 2075 if (init_data_size) {
2076 len = init_data_size; 2076 len = init_data_size;
2077 IL_DEBUG_INFO(priv, 2077 IL_DEBUG_INFO(il,
2078 "Copying (but not loading) init data len %zd\n", len); 2078 "Copying (but not loading) init data len %zd\n", len);
2079 memcpy(priv->ucode_init_data.v_addr, src, len); 2079 memcpy(il->ucode_init_data.v_addr, src, len);
2080 src += len; 2080 src += len;
2081 } 2081 }
2082 2082
2083 /* Bootstrap instructions (5th block) */ 2083 /* Bootstrap instructions (5th block) */
2084 len = boot_size; 2084 len = boot_size;
2085 IL_DEBUG_INFO(priv, 2085 IL_DEBUG_INFO(il,
2086 "Copying (but not loading) boot instr len %zd\n", len); 2086 "Copying (but not loading) boot instr len %zd\n", len);
2087 memcpy(priv->ucode_boot.v_addr, src, len); 2087 memcpy(il->ucode_boot.v_addr, src, len);
2088 2088
2089 /* We have our copies now, allow OS release its copies */ 2089 /* We have our copies now, allow OS release its copies */
2090 release_firmware(ucode_raw); 2090 release_firmware(ucode_raw);
2091 return 0; 2091 return 0;
2092 2092
2093 err_pci_alloc: 2093 err_pci_alloc:
2094 IL_ERR(priv, "failed to allocate pci memory\n"); 2094 IL_ERR(il, "failed to allocate pci memory\n");
2095 ret = -ENOMEM; 2095 ret = -ENOMEM;
2096 il3945_dealloc_ucode_pci(priv); 2096 il3945_dealloc_ucode_pci(il);
2097 2097
2098 err_release: 2098 err_release:
2099 release_firmware(ucode_raw); 2099 release_firmware(ucode_raw);
@@ -2112,27 +2112,27 @@ static int il3945_read_ucode(struct il_priv *priv)
2112 * We need to replace them to load runtime uCode inst and data, 2112 * We need to replace them to load runtime uCode inst and data,
2113 * and to save runtime data when powering down. 2113 * and to save runtime data when powering down.
2114 */ 2114 */
2115static int il3945_set_ucode_ptrs(struct il_priv *priv) 2115static int il3945_set_ucode_ptrs(struct il_priv *il)
2116{ 2116{
2117 dma_addr_t pinst; 2117 dma_addr_t pinst;
2118 dma_addr_t pdata; 2118 dma_addr_t pdata;
2119 2119
2120 /* bits 31:0 for 3945 */ 2120 /* bits 31:0 for 3945 */
2121 pinst = priv->ucode_code.p_addr; 2121 pinst = il->ucode_code.p_addr;
2122 pdata = priv->ucode_data_backup.p_addr; 2122 pdata = il->ucode_data_backup.p_addr;
2123 2123
2124 /* Tell bootstrap uCode where to find image to load */ 2124 /* Tell bootstrap uCode where to find image to load */
2125 il_write_prph(priv, BSM_DRAM_INST_PTR_REG, pinst); 2125 il_write_prph(il, BSM_DRAM_INST_PTR_REG, pinst);
2126 il_write_prph(priv, BSM_DRAM_DATA_PTR_REG, pdata); 2126 il_write_prph(il, BSM_DRAM_DATA_PTR_REG, pdata);
2127 il_write_prph(priv, BSM_DRAM_DATA_BYTECOUNT_REG, 2127 il_write_prph(il, BSM_DRAM_DATA_BYTECOUNT_REG,
2128 priv->ucode_data.len); 2128 il->ucode_data.len);
2129 2129
2130 /* Inst byte count must be last to set up, bit 31 signals uCode 2130 /* Inst byte count must be last to set up, bit 31 signals uCode
2131 * that all new ptr/size info is in place */ 2131 * that all new ptr/size info is in place */
2132 il_write_prph(priv, BSM_DRAM_INST_BYTECOUNT_REG, 2132 il_write_prph(il, BSM_DRAM_INST_BYTECOUNT_REG,
2133 priv->ucode_code.len | BSM_DRAM_INST_LOAD); 2133 il->ucode_code.len | BSM_DRAM_INST_LOAD);
2134 2134
2135 IL_DEBUG_INFO(priv, "Runtime uCode pointers are set.\n"); 2135 IL_DEBUG_INFO(il, "Runtime uCode pointers are set.\n");
2136 2136
2137 return 0; 2137 return 0;
2138} 2138}
@@ -2144,40 +2144,40 @@ static int il3945_set_ucode_ptrs(struct il_priv *priv)
2144 * 2144 *
2145 * Tell "initialize" uCode to go ahead and load the runtime uCode. 2145 * Tell "initialize" uCode to go ahead and load the runtime uCode.
2146 */ 2146 */
2147static void il3945_init_alive_start(struct il_priv *priv) 2147static void il3945_init_alive_start(struct il_priv *il)
2148{ 2148{
2149 /* Check alive response for "valid" sign from uCode */ 2149 /* Check alive response for "valid" sign from uCode */
2150 if (priv->card_alive_init.is_valid != UCODE_VALID_OK) { 2150 if (il->card_alive_init.is_valid != UCODE_VALID_OK) {
2151 /* We had an error bringing up the hardware, so take it 2151 /* We had an error bringing up the hardware, so take it
2152 * all the way back down so we can try again */ 2152 * all the way back down so we can try again */
2153 IL_DEBUG_INFO(priv, "Initialize Alive failed.\n"); 2153 IL_DEBUG_INFO(il, "Initialize Alive failed.\n");
2154 goto restart; 2154 goto restart;
2155 } 2155 }
2156 2156
2157 /* Bootstrap uCode has loaded initialize uCode ... verify inst image. 2157 /* Bootstrap uCode has loaded initialize uCode ... verify inst image.
2158 * This is a paranoid check, because we would not have gotten the 2158 * This is a paranoid check, because we would not have gotten the
2159 * "initialize" alive if code weren't properly loaded. */ 2159 * "initialize" alive if code weren't properly loaded. */
2160 if (il3945_verify_ucode(priv)) { 2160 if (il3945_verify_ucode(il)) {
2161 /* Runtime instruction load was bad; 2161 /* Runtime instruction load was bad;
2162 * take it all the way back down so we can try again */ 2162 * take it all the way back down so we can try again */
2163 IL_DEBUG_INFO(priv, "Bad \"initialize\" uCode load.\n"); 2163 IL_DEBUG_INFO(il, "Bad \"initialize\" uCode load.\n");
2164 goto restart; 2164 goto restart;
2165 } 2165 }
2166 2166
2167 /* Send pointers to protocol/runtime uCode image ... init code will 2167 /* Send pointers to protocol/runtime uCode image ... init code will
2168 * load and launch runtime uCode, which will send us another "Alive" 2168 * load and launch runtime uCode, which will send us another "Alive"
2169 * notification. */ 2169 * notification. */
2170 IL_DEBUG_INFO(priv, "Initialization Alive received.\n"); 2170 IL_DEBUG_INFO(il, "Initialization Alive received.\n");
2171 if (il3945_set_ucode_ptrs(priv)) { 2171 if (il3945_set_ucode_ptrs(il)) {
2172 /* Runtime instruction load won't happen; 2172 /* Runtime instruction load won't happen;
2173 * take it all the way back down so we can try again */ 2173 * take it all the way back down so we can try again */
2174 IL_DEBUG_INFO(priv, "Couldn't set up uCode pointers.\n"); 2174 IL_DEBUG_INFO(il, "Couldn't set up uCode pointers.\n");
2175 goto restart; 2175 goto restart;
2176 } 2176 }
2177 return; 2177 return;
2178 2178
2179 restart: 2179 restart:
2180 queue_work(priv->workqueue, &priv->restart); 2180 queue_work(il->workqueue, &il->restart);
2181} 2181}
2182 2182
2183/** 2183/**
@@ -2185,65 +2185,65 @@ static void il3945_init_alive_start(struct il_priv *priv)
2185 * from protocol/runtime uCode (initialization uCode's 2185 * from protocol/runtime uCode (initialization uCode's
2186 * Alive gets handled by il3945_init_alive_start()). 2186 * Alive gets handled by il3945_init_alive_start()).
2187 */ 2187 */
2188static void il3945_alive_start(struct il_priv *priv) 2188static void il3945_alive_start(struct il_priv *il)
2189{ 2189{
2190 int thermal_spin = 0; 2190 int thermal_spin = 0;
2191 u32 rfkill; 2191 u32 rfkill;
2192 struct il_rxon_context *ctx = &priv->contexts[IL_RXON_CTX_BSS]; 2192 struct il_rxon_context *ctx = &il->contexts[IL_RXON_CTX_BSS];
2193 2193
2194 IL_DEBUG_INFO(priv, "Runtime Alive received.\n"); 2194 IL_DEBUG_INFO(il, "Runtime Alive received.\n");
2195 2195
2196 if (priv->card_alive.is_valid != UCODE_VALID_OK) { 2196 if (il->card_alive.is_valid != UCODE_VALID_OK) {
2197 /* We had an error bringing up the hardware, so take it 2197 /* We had an error bringing up the hardware, so take it
2198 * all the way back down so we can try again */ 2198 * all the way back down so we can try again */
2199 IL_DEBUG_INFO(priv, "Alive failed.\n"); 2199 IL_DEBUG_INFO(il, "Alive failed.\n");
2200 goto restart; 2200 goto restart;
2201 } 2201 }
2202 2202
2203 /* Initialize uCode has loaded Runtime uCode ... verify inst image. 2203 /* Initialize uCode has loaded Runtime uCode ... verify inst image.
2204 * This is a paranoid check, because we would not have gotten the 2204 * This is a paranoid check, because we would not have gotten the
2205 * "runtime" alive if code weren't properly loaded. */ 2205 * "runtime" alive if code weren't properly loaded. */
2206 if (il3945_verify_ucode(priv)) { 2206 if (il3945_verify_ucode(il)) {
2207 /* Runtime instruction load was bad; 2207 /* Runtime instruction load was bad;
2208 * take it all the way back down so we can try again */ 2208 * take it all the way back down so we can try again */
2209 IL_DEBUG_INFO(priv, "Bad runtime uCode load.\n"); 2209 IL_DEBUG_INFO(il, "Bad runtime uCode load.\n");
2210 goto restart; 2210 goto restart;
2211 } 2211 }
2212 2212
2213 rfkill = il_read_prph(priv, APMG_RFKILL_REG); 2213 rfkill = il_read_prph(il, APMG_RFKILL_REG);
2214 IL_DEBUG_INFO(priv, "RFKILL status: 0x%x\n", rfkill); 2214 IL_DEBUG_INFO(il, "RFKILL status: 0x%x\n", rfkill);
2215 2215
2216 if (rfkill & 0x1) { 2216 if (rfkill & 0x1) {
2217 clear_bit(STATUS_RF_KILL_HW, &priv->status); 2217 clear_bit(STATUS_RF_KILL_HW, &il->status);
2218 /* if RFKILL is not on, then wait for thermal 2218 /* if RFKILL is not on, then wait for thermal
2219 * sensor in adapter to kick in */ 2219 * sensor in adapter to kick in */
2220 while (il3945_hw_get_temperature(priv) == 0) { 2220 while (il3945_hw_get_temperature(il) == 0) {
2221 thermal_spin++; 2221 thermal_spin++;
2222 udelay(10); 2222 udelay(10);
2223 } 2223 }
2224 2224
2225 if (thermal_spin) 2225 if (thermal_spin)
2226 IL_DEBUG_INFO(priv, "Thermal calibration took %dus\n", 2226 IL_DEBUG_INFO(il, "Thermal calibration took %dus\n",
2227 thermal_spin * 10); 2227 thermal_spin * 10);
2228 } else 2228 } else
2229 set_bit(STATUS_RF_KILL_HW, &priv->status); 2229 set_bit(STATUS_RF_KILL_HW, &il->status);
2230 2230
2231 /* After the ALIVE response, we can send commands to 3945 uCode */ 2231 /* After the ALIVE response, we can send commands to 3945 uCode */
2232 set_bit(STATUS_ALIVE, &priv->status); 2232 set_bit(STATUS_ALIVE, &il->status);
2233 2233
2234 /* Enable watchdog to monitor the driver tx queues */ 2234 /* Enable watchdog to monitor the driver tx queues */
2235 il_setup_watchdog(priv); 2235 il_setup_watchdog(il);
2236 2236
2237 if (il_is_rfkill(priv)) 2237 if (il_is_rfkill(il))
2238 return; 2238 return;
2239 2239
2240 ieee80211_wake_queues(priv->hw); 2240 ieee80211_wake_queues(il->hw);
2241 2241
2242 priv->active_rate = IL_RATES_MASK_3945; 2242 il->active_rate = IL_RATES_MASK_3945;
2243 2243
2244 il_power_update_mode(priv, true); 2244 il_power_update_mode(il, true);
2245 2245
2246 if (il_is_associated(priv, IL_RXON_CTX_BSS)) { 2246 if (il_is_associated(il, IL_RXON_CTX_BSS)) {
2247 struct il3945_rxon_cmd *active_rxon = 2247 struct il3945_rxon_cmd *active_rxon =
2248 (struct il3945_rxon_cmd *)(&ctx->active); 2248 (struct il3945_rxon_cmd *)(&ctx->active);
2249 2249
@@ -2251,205 +2251,205 @@ static void il3945_alive_start(struct il_priv *priv)
2251 active_rxon->filter_flags &= ~RXON_FILTER_ASSOC_MSK; 2251 active_rxon->filter_flags &= ~RXON_FILTER_ASSOC_MSK;
2252 } else { 2252 } else {
2253 /* Initialize our rx_config data */ 2253 /* Initialize our rx_config data */
2254 il_connection_init_rx_config(priv, ctx); 2254 il_connection_init_rx_config(il, ctx);
2255 } 2255 }
2256 2256
2257 /* Configure Bluetooth device coexistence support */ 2257 /* Configure Bluetooth device coexistence support */
2258 il_send_bt_config(priv); 2258 il_send_bt_config(il);
2259 2259
2260 set_bit(STATUS_READY, &priv->status); 2260 set_bit(STATUS_READY, &il->status);
2261 2261
2262 /* Configure the adapter for unassociated operation */ 2262 /* Configure the adapter for unassociated operation */
2263 il3945_commit_rxon(priv, ctx); 2263 il3945_commit_rxon(il, ctx);
2264 2264
2265 il3945_reg_txpower_periodic(priv); 2265 il3945_reg_txpower_periodic(il);
2266 2266
2267 IL_DEBUG_INFO(priv, "ALIVE processing complete.\n"); 2267 IL_DEBUG_INFO(il, "ALIVE processing complete.\n");
2268 wake_up(&priv->wait_command_queue); 2268 wake_up(&il->wait_command_queue);
2269 2269
2270 return; 2270 return;
2271 2271
2272 restart: 2272 restart:
2273 queue_work(priv->workqueue, &priv->restart); 2273 queue_work(il->workqueue, &il->restart);
2274} 2274}
2275 2275
2276static void il3945_cancel_deferred_work(struct il_priv *priv); 2276static void il3945_cancel_deferred_work(struct il_priv *il);
2277 2277
2278static void __il3945_down(struct il_priv *priv) 2278static void __il3945_down(struct il_priv *il)
2279{ 2279{
2280 unsigned long flags; 2280 unsigned long flags;
2281 int exit_pending; 2281 int exit_pending;
2282 2282
2283 IL_DEBUG_INFO(priv, DRV_NAME " is going down\n"); 2283 IL_DEBUG_INFO(il, DRV_NAME " is going down\n");
2284 2284
2285 il_scan_cancel_timeout(priv, 200); 2285 il_scan_cancel_timeout(il, 200);
2286 2286
2287 exit_pending = test_and_set_bit(STATUS_EXIT_PENDING, &priv->status); 2287 exit_pending = test_and_set_bit(STATUS_EXIT_PENDING, &il->status);
2288 2288
2289 /* Stop TX queues watchdog. We need to have STATUS_EXIT_PENDING bit set 2289 /* Stop TX queues watchdog. We need to have STATUS_EXIT_PENDING bit set
2290 * to prevent rearm timer */ 2290 * to prevent rearm timer */
2291 del_timer_sync(&priv->watchdog); 2291 del_timer_sync(&il->watchdog);
2292 2292
2293 /* Station information will now be cleared in device */ 2293 /* Station information will now be cleared in device */
2294 il_clear_ucode_stations(priv, NULL); 2294 il_clear_ucode_stations(il, NULL);
2295 il_dealloc_bcast_stations(priv); 2295 il_dealloc_bcast_stations(il);
2296 il_clear_driver_stations(priv); 2296 il_clear_driver_stations(il);
2297 2297
2298 /* Unblock any waiting calls */ 2298 /* Unblock any waiting calls */
2299 wake_up_all(&priv->wait_command_queue); 2299 wake_up_all(&il->wait_command_queue);
2300 2300
2301 /* Wipe out the EXIT_PENDING status bit if we are not actually 2301 /* Wipe out the EXIT_PENDING status bit if we are not actually
2302 * exiting the module */ 2302 * exiting the module */
2303 if (!exit_pending) 2303 if (!exit_pending)
2304 clear_bit(STATUS_EXIT_PENDING, &priv->status); 2304 clear_bit(STATUS_EXIT_PENDING, &il->status);
2305 2305
2306 /* stop and reset the on-board processor */ 2306 /* stop and reset the on-board processor */
2307 il_write32(priv, CSR_RESET, CSR_RESET_REG_FLAG_NEVO_RESET); 2307 il_write32(il, CSR_RESET, CSR_RESET_REG_FLAG_NEVO_RESET);
2308 2308
2309 /* tell the device to stop sending interrupts */ 2309 /* tell the device to stop sending interrupts */
2310 spin_lock_irqsave(&priv->lock, flags); 2310 spin_lock_irqsave(&il->lock, flags);
2311 il_disable_interrupts(priv); 2311 il_disable_interrupts(il);
2312 spin_unlock_irqrestore(&priv->lock, flags); 2312 spin_unlock_irqrestore(&il->lock, flags);
2313 il3945_synchronize_irq(priv); 2313 il3945_synchronize_irq(il);
2314 2314
2315 if (priv->mac80211_registered) 2315 if (il->mac80211_registered)
2316 ieee80211_stop_queues(priv->hw); 2316 ieee80211_stop_queues(il->hw);
2317 2317
2318 /* If we have not previously called il3945_init() then 2318 /* If we have not previously called il3945_init() then
2319 * clear all bits but the RF Kill bits and return */ 2319 * clear all bits but the RF Kill bits and return */
2320 if (!il_is_init(priv)) { 2320 if (!il_is_init(il)) {
2321 priv->status = test_bit(STATUS_RF_KILL_HW, &priv->status) << 2321 il->status = test_bit(STATUS_RF_KILL_HW, &il->status) <<
2322 STATUS_RF_KILL_HW | 2322 STATUS_RF_KILL_HW |
2323 test_bit(STATUS_GEO_CONFIGURED, &priv->status) << 2323 test_bit(STATUS_GEO_CONFIGURED, &il->status) <<
2324 STATUS_GEO_CONFIGURED | 2324 STATUS_GEO_CONFIGURED |
2325 test_bit(STATUS_EXIT_PENDING, &priv->status) << 2325 test_bit(STATUS_EXIT_PENDING, &il->status) <<
2326 STATUS_EXIT_PENDING; 2326 STATUS_EXIT_PENDING;
2327 goto exit; 2327 goto exit;
2328 } 2328 }
2329 2329
2330 /* ...otherwise clear out all the status bits but the RF Kill 2330 /* ...otherwise clear out all the status bits but the RF Kill
2331 * bit and continue taking the NIC down. */ 2331 * bit and continue taking the NIC down. */
2332 priv->status &= test_bit(STATUS_RF_KILL_HW, &priv->status) << 2332 il->status &= test_bit(STATUS_RF_KILL_HW, &il->status) <<
2333 STATUS_RF_KILL_HW | 2333 STATUS_RF_KILL_HW |
2334 test_bit(STATUS_GEO_CONFIGURED, &priv->status) << 2334 test_bit(STATUS_GEO_CONFIGURED, &il->status) <<
2335 STATUS_GEO_CONFIGURED | 2335 STATUS_GEO_CONFIGURED |
2336 test_bit(STATUS_FW_ERROR, &priv->status) << 2336 test_bit(STATUS_FW_ERROR, &il->status) <<
2337 STATUS_FW_ERROR | 2337 STATUS_FW_ERROR |
2338 test_bit(STATUS_EXIT_PENDING, &priv->status) << 2338 test_bit(STATUS_EXIT_PENDING, &il->status) <<
2339 STATUS_EXIT_PENDING; 2339 STATUS_EXIT_PENDING;
2340 2340
2341 il3945_hw_txq_ctx_stop(priv); 2341 il3945_hw_txq_ctx_stop(il);
2342 il3945_hw_rxq_stop(priv); 2342 il3945_hw_rxq_stop(il);
2343 2343
2344 /* Power-down device's busmaster DMA clocks */ 2344 /* Power-down device's busmaster DMA clocks */
2345 il_write_prph(priv, APMG_CLK_DIS_REG, APMG_CLK_VAL_DMA_CLK_RQT); 2345 il_write_prph(il, APMG_CLK_DIS_REG, APMG_CLK_VAL_DMA_CLK_RQT);
2346 udelay(5); 2346 udelay(5);
2347 2347
2348 /* Stop the device, and put it in low power state */ 2348 /* Stop the device, and put it in low power state */
2349 il_apm_stop(priv); 2349 il_apm_stop(il);
2350 2350
2351 exit: 2351 exit:
2352 memset(&priv->card_alive, 0, sizeof(struct il_alive_resp)); 2352 memset(&il->card_alive, 0, sizeof(struct il_alive_resp));
2353 2353
2354 if (priv->beacon_skb) 2354 if (il->beacon_skb)
2355 dev_kfree_skb(priv->beacon_skb); 2355 dev_kfree_skb(il->beacon_skb);
2356 priv->beacon_skb = NULL; 2356 il->beacon_skb = NULL;
2357 2357
2358 /* clear out any free frames */ 2358 /* clear out any free frames */
2359 il3945_clear_free_frames(priv); 2359 il3945_clear_free_frames(il);
2360} 2360}
2361 2361
2362static void il3945_down(struct il_priv *priv) 2362static void il3945_down(struct il_priv *il)
2363{ 2363{
2364 mutex_lock(&priv->mutex); 2364 mutex_lock(&il->mutex);
2365 __il3945_down(priv); 2365 __il3945_down(il);
2366 mutex_unlock(&priv->mutex); 2366 mutex_unlock(&il->mutex);
2367 2367
2368 il3945_cancel_deferred_work(priv); 2368 il3945_cancel_deferred_work(il);
2369} 2369}
2370 2370
2371#define MAX_HW_RESTARTS 5 2371#define MAX_HW_RESTARTS 5
2372 2372
2373static int il3945_alloc_bcast_station(struct il_priv *priv) 2373static int il3945_alloc_bcast_station(struct il_priv *il)
2374{ 2374{
2375 struct il_rxon_context *ctx = &priv->contexts[IL_RXON_CTX_BSS]; 2375 struct il_rxon_context *ctx = &il->contexts[IL_RXON_CTX_BSS];
2376 unsigned long flags; 2376 unsigned long flags;
2377 u8 sta_id; 2377 u8 sta_id;
2378 2378
2379 spin_lock_irqsave(&priv->sta_lock, flags); 2379 spin_lock_irqsave(&il->sta_lock, flags);
2380 sta_id = il_prep_station(priv, ctx, 2380 sta_id = il_prep_station(il, ctx,
2381 iwlegacy_bcast_addr, false, NULL); 2381 iwlegacy_bcast_addr, false, NULL);
2382 if (sta_id == IL_INVALID_STATION) { 2382 if (sta_id == IL_INVALID_STATION) {
2383 IL_ERR(priv, "Unable to prepare broadcast station\n"); 2383 IL_ERR(il, "Unable to prepare broadcast station\n");
2384 spin_unlock_irqrestore(&priv->sta_lock, flags); 2384 spin_unlock_irqrestore(&il->sta_lock, flags);
2385 2385
2386 return -EINVAL; 2386 return -EINVAL;
2387 } 2387 }
2388 2388
2389 priv->stations[sta_id].used |= IL_STA_DRIVER_ACTIVE; 2389 il->stations[sta_id].used |= IL_STA_DRIVER_ACTIVE;
2390 priv->stations[sta_id].used |= IL_STA_BCAST; 2390 il->stations[sta_id].used |= IL_STA_BCAST;
2391 spin_unlock_irqrestore(&priv->sta_lock, flags); 2391 spin_unlock_irqrestore(&il->sta_lock, flags);
2392 2392
2393 return 0; 2393 return 0;
2394} 2394}
2395 2395
2396static int __il3945_up(struct il_priv *priv) 2396static int __il3945_up(struct il_priv *il)
2397{ 2397{
2398 int rc, i; 2398 int rc, i;
2399 2399
2400 rc = il3945_alloc_bcast_station(priv); 2400 rc = il3945_alloc_bcast_station(il);
2401 if (rc) 2401 if (rc)
2402 return rc; 2402 return rc;
2403 2403
2404 if (test_bit(STATUS_EXIT_PENDING, &priv->status)) { 2404 if (test_bit(STATUS_EXIT_PENDING, &il->status)) {
2405 IL_WARN(priv, "Exit pending; will not bring the NIC up\n"); 2405 IL_WARN(il, "Exit pending; will not bring the NIC up\n");
2406 return -EIO; 2406 return -EIO;
2407 } 2407 }
2408 2408
2409 if (!priv->ucode_data_backup.v_addr || !priv->ucode_data.v_addr) { 2409 if (!il->ucode_data_backup.v_addr || !il->ucode_data.v_addr) {
2410 IL_ERR(priv, "ucode not available for device bring up\n"); 2410 IL_ERR(il, "ucode not available for device bring up\n");
2411 return -EIO; 2411 return -EIO;
2412 } 2412 }
2413 2413
2414 /* If platform's RF_KILL switch is NOT set to KILL */ 2414 /* If platform's RF_KILL switch is NOT set to KILL */
2415 if (il_read32(priv, CSR_GP_CNTRL) & 2415 if (il_read32(il, CSR_GP_CNTRL) &
2416 CSR_GP_CNTRL_REG_FLAG_HW_RF_KILL_SW) 2416 CSR_GP_CNTRL_REG_FLAG_HW_RF_KILL_SW)
2417 clear_bit(STATUS_RF_KILL_HW, &priv->status); 2417 clear_bit(STATUS_RF_KILL_HW, &il->status);
2418 else { 2418 else {
2419 set_bit(STATUS_RF_KILL_HW, &priv->status); 2419 set_bit(STATUS_RF_KILL_HW, &il->status);
2420 IL_WARN(priv, "Radio disabled by HW RF Kill switch\n"); 2420 IL_WARN(il, "Radio disabled by HW RF Kill switch\n");
2421 return -ENODEV; 2421 return -ENODEV;
2422 } 2422 }
2423 2423
2424 il_write32(priv, CSR_INT, 0xFFFFFFFF); 2424 il_write32(il, CSR_INT, 0xFFFFFFFF);
2425 2425
2426 rc = il3945_hw_nic_init(priv); 2426 rc = il3945_hw_nic_init(il);
2427 if (rc) { 2427 if (rc) {
2428 IL_ERR(priv, "Unable to int nic\n"); 2428 IL_ERR(il, "Unable to int nic\n");
2429 return rc; 2429 return rc;
2430 } 2430 }
2431 2431
2432 /* make sure rfkill handshake bits are cleared */ 2432 /* make sure rfkill handshake bits are cleared */
2433 il_write32(priv, CSR_UCODE_DRV_GP1_CLR, CSR_UCODE_SW_BIT_RFKILL); 2433 il_write32(il, CSR_UCODE_DRV_GP1_CLR, CSR_UCODE_SW_BIT_RFKILL);
2434 il_write32(priv, CSR_UCODE_DRV_GP1_CLR, 2434 il_write32(il, CSR_UCODE_DRV_GP1_CLR,
2435 CSR_UCODE_DRV_GP1_BIT_CMD_BLOCKED); 2435 CSR_UCODE_DRV_GP1_BIT_CMD_BLOCKED);
2436 2436
2437 /* clear (again), then enable host interrupts */ 2437 /* clear (again), then enable host interrupts */
2438 il_write32(priv, CSR_INT, 0xFFFFFFFF); 2438 il_write32(il, CSR_INT, 0xFFFFFFFF);
2439 il_enable_interrupts(priv); 2439 il_enable_interrupts(il);
2440 2440
2441 /* really make sure rfkill handshake bits are cleared */ 2441 /* really make sure rfkill handshake bits are cleared */
2442 il_write32(priv, CSR_UCODE_DRV_GP1_CLR, CSR_UCODE_SW_BIT_RFKILL); 2442 il_write32(il, CSR_UCODE_DRV_GP1_CLR, CSR_UCODE_SW_BIT_RFKILL);
2443 il_write32(priv, CSR_UCODE_DRV_GP1_CLR, CSR_UCODE_SW_BIT_RFKILL); 2443 il_write32(il, CSR_UCODE_DRV_GP1_CLR, CSR_UCODE_SW_BIT_RFKILL);
2444 2444
2445 /* Copy original ucode data image from disk into backup cache. 2445 /* Copy original ucode data image from disk into backup cache.
2446 * This will be used to initialize the on-board processor's 2446 * This will be used to initialize the on-board processor's
2447 * data SRAM for a clean start when the runtime program first loads. */ 2447 * data SRAM for a clean start when the runtime program first loads. */
2448 memcpy(priv->ucode_data_backup.v_addr, priv->ucode_data.v_addr, 2448 memcpy(il->ucode_data_backup.v_addr, il->ucode_data.v_addr,
2449 priv->ucode_data.len); 2449 il->ucode_data.len);
2450 2450
2451 /* We return success when we resume from suspend and rf_kill is on. */ 2451 /* We return success when we resume from suspend and rf_kill is on. */
2452 if (test_bit(STATUS_RF_KILL_HW, &priv->status)) 2452 if (test_bit(STATUS_RF_KILL_HW, &il->status))
2453 return 0; 2453 return 0;
2454 2454
2455 for (i = 0; i < MAX_HW_RESTARTS; i++) { 2455 for (i = 0; i < MAX_HW_RESTARTS; i++) {
@@ -2457,29 +2457,29 @@ static int __il3945_up(struct il_priv *priv)
2457 /* load bootstrap state machine, 2457 /* load bootstrap state machine,
2458 * load bootstrap program into processor's memory, 2458 * load bootstrap program into processor's memory,
2459 * prepare to load the "initialize" uCode */ 2459 * prepare to load the "initialize" uCode */
2460 rc = priv->cfg->ops->lib->load_ucode(priv); 2460 rc = il->cfg->ops->lib->load_ucode(il);
2461 2461
2462 if (rc) { 2462 if (rc) {
2463 IL_ERR(priv, 2463 IL_ERR(il,
2464 "Unable to set up bootstrap uCode: %d\n", rc); 2464 "Unable to set up bootstrap uCode: %d\n", rc);
2465 continue; 2465 continue;
2466 } 2466 }
2467 2467
2468 /* start card; "initialize" will load runtime ucode */ 2468 /* start card; "initialize" will load runtime ucode */
2469 il3945_nic_start(priv); 2469 il3945_nic_start(il);
2470 2470
2471 IL_DEBUG_INFO(priv, DRV_NAME " is coming up\n"); 2471 IL_DEBUG_INFO(il, DRV_NAME " is coming up\n");
2472 2472
2473 return 0; 2473 return 0;
2474 } 2474 }
2475 2475
2476 set_bit(STATUS_EXIT_PENDING, &priv->status); 2476 set_bit(STATUS_EXIT_PENDING, &il->status);
2477 __il3945_down(priv); 2477 __il3945_down(il);
2478 clear_bit(STATUS_EXIT_PENDING, &priv->status); 2478 clear_bit(STATUS_EXIT_PENDING, &il->status);
2479 2479
2480 /* tried to restart and config the device for as long as our 2480 /* tried to restart and config the device for as long as our
2481 * patience could withstand */ 2481 * patience could withstand */
2482 IL_ERR(priv, "Unable to initialize device after %d attempts.\n", i); 2482 IL_ERR(il, "Unable to initialize device after %d attempts.\n", i);
2483 return -EIO; 2483 return -EIO;
2484} 2484}
2485 2485
@@ -2492,30 +2492,30 @@ static int __il3945_up(struct il_priv *priv)
2492 2492
2493static void il3945_bg_init_alive_start(struct work_struct *data) 2493static void il3945_bg_init_alive_start(struct work_struct *data)
2494{ 2494{
2495 struct il_priv *priv = 2495 struct il_priv *il =
2496 container_of(data, struct il_priv, init_alive_start.work); 2496 container_of(data, struct il_priv, init_alive_start.work);
2497 2497
2498 mutex_lock(&priv->mutex); 2498 mutex_lock(&il->mutex);
2499 if (test_bit(STATUS_EXIT_PENDING, &priv->status)) 2499 if (test_bit(STATUS_EXIT_PENDING, &il->status))
2500 goto out; 2500 goto out;
2501 2501
2502 il3945_init_alive_start(priv); 2502 il3945_init_alive_start(il);
2503out: 2503out:
2504 mutex_unlock(&priv->mutex); 2504 mutex_unlock(&il->mutex);
2505} 2505}
2506 2506
2507static void il3945_bg_alive_start(struct work_struct *data) 2507static void il3945_bg_alive_start(struct work_struct *data)
2508{ 2508{
2509 struct il_priv *priv = 2509 struct il_priv *il =
2510 container_of(data, struct il_priv, alive_start.work); 2510 container_of(data, struct il_priv, alive_start.work);
2511 2511
2512 mutex_lock(&priv->mutex); 2512 mutex_lock(&il->mutex);
2513 if (test_bit(STATUS_EXIT_PENDING, &priv->status)) 2513 if (test_bit(STATUS_EXIT_PENDING, &il->status))
2514 goto out; 2514 goto out;
2515 2515
2516 il3945_alive_start(priv); 2516 il3945_alive_start(il);
2517out: 2517out:
2518 mutex_unlock(&priv->mutex); 2518 mutex_unlock(&il->mutex);
2519} 2519}
2520 2520
2521/* 2521/*
@@ -2526,32 +2526,32 @@ out:
2526 */ 2526 */
2527static void il3945_rfkill_poll(struct work_struct *data) 2527static void il3945_rfkill_poll(struct work_struct *data)
2528{ 2528{
2529 struct il_priv *priv = 2529 struct il_priv *il =
2530 container_of(data, struct il_priv, _3945.rfkill_poll.work); 2530 container_of(data, struct il_priv, _3945.rfkill_poll.work);
2531 bool old_rfkill = test_bit(STATUS_RF_KILL_HW, &priv->status); 2531 bool old_rfkill = test_bit(STATUS_RF_KILL_HW, &il->status);
2532 bool new_rfkill = !(il_read32(priv, CSR_GP_CNTRL) 2532 bool new_rfkill = !(il_read32(il, CSR_GP_CNTRL)
2533 & CSR_GP_CNTRL_REG_FLAG_HW_RF_KILL_SW); 2533 & CSR_GP_CNTRL_REG_FLAG_HW_RF_KILL_SW);
2534 2534
2535 if (new_rfkill != old_rfkill) { 2535 if (new_rfkill != old_rfkill) {
2536 if (new_rfkill) 2536 if (new_rfkill)
2537 set_bit(STATUS_RF_KILL_HW, &priv->status); 2537 set_bit(STATUS_RF_KILL_HW, &il->status);
2538 else 2538 else
2539 clear_bit(STATUS_RF_KILL_HW, &priv->status); 2539 clear_bit(STATUS_RF_KILL_HW, &il->status);
2540 2540
2541 wiphy_rfkill_set_hw_state(priv->hw->wiphy, new_rfkill); 2541 wiphy_rfkill_set_hw_state(il->hw->wiphy, new_rfkill);
2542 2542
2543 IL_DEBUG_RF_KILL(priv, "RF_KILL bit toggled to %s.\n", 2543 IL_DEBUG_RF_KILL(il, "RF_KILL bit toggled to %s.\n",
2544 new_rfkill ? "disable radio" : "enable radio"); 2544 new_rfkill ? "disable radio" : "enable radio");
2545 } 2545 }
2546 2546
2547 /* Keep this running, even if radio now enabled. This will be 2547 /* Keep this running, even if radio now enabled. This will be
2548 * cancelled in mac_start() if system decides to start again */ 2548 * cancelled in mac_start() if system decides to start again */
2549 queue_delayed_work(priv->workqueue, &priv->_3945.rfkill_poll, 2549 queue_delayed_work(il->workqueue, &il->_3945.rfkill_poll,
2550 round_jiffies_relative(2 * HZ)); 2550 round_jiffies_relative(2 * HZ));
2551 2551
2552} 2552}
2553 2553
2554int il3945_request_scan(struct il_priv *priv, struct ieee80211_vif *vif) 2554int il3945_request_scan(struct il_priv *il, struct ieee80211_vif *vif)
2555{ 2555{
2556 struct il_host_cmd cmd = { 2556 struct il_host_cmd cmd = {
2557 .id = REPLY_SCAN_CMD, 2557 .id = REPLY_SCAN_CMD,
@@ -2565,29 +2565,29 @@ int il3945_request_scan(struct il_priv *priv, struct ieee80211_vif *vif)
2565 int ret; 2565 int ret;
2566 u16 len; 2566 u16 len;
2567 2567
2568 lockdep_assert_held(&priv->mutex); 2568 lockdep_assert_held(&il->mutex);
2569 2569
2570 if (!priv->scan_cmd) { 2570 if (!il->scan_cmd) {
2571 priv->scan_cmd = kmalloc(sizeof(struct il3945_scan_cmd) + 2571 il->scan_cmd = kmalloc(sizeof(struct il3945_scan_cmd) +
2572 IL_MAX_SCAN_SIZE, GFP_KERNEL); 2572 IL_MAX_SCAN_SIZE, GFP_KERNEL);
2573 if (!priv->scan_cmd) { 2573 if (!il->scan_cmd) {
2574 IL_DEBUG_SCAN(priv, "Fail to allocate scan memory\n"); 2574 IL_DEBUG_SCAN(il, "Fail to allocate scan memory\n");
2575 return -ENOMEM; 2575 return -ENOMEM;
2576 } 2576 }
2577 } 2577 }
2578 scan = priv->scan_cmd; 2578 scan = il->scan_cmd;
2579 memset(scan, 0, sizeof(struct il3945_scan_cmd) + IL_MAX_SCAN_SIZE); 2579 memset(scan, 0, sizeof(struct il3945_scan_cmd) + IL_MAX_SCAN_SIZE);
2580 2580
2581 scan->quiet_plcp_th = IL_PLCP_QUIET_THRESH; 2581 scan->quiet_plcp_th = IL_PLCP_QUIET_THRESH;
2582 scan->quiet_time = IL_ACTIVE_QUIET_TIME; 2582 scan->quiet_time = IL_ACTIVE_QUIET_TIME;
2583 2583
2584 if (il_is_associated(priv, IL_RXON_CTX_BSS)) { 2584 if (il_is_associated(il, IL_RXON_CTX_BSS)) {
2585 u16 interval; 2585 u16 interval;
2586 u32 extra; 2586 u32 extra;
2587 u32 suspend_time = 100; 2587 u32 suspend_time = 100;
2588 u32 scan_suspend_time = 100; 2588 u32 scan_suspend_time = 100;
2589 2589
2590 IL_DEBUG_INFO(priv, "Scanning while associated...\n"); 2590 IL_DEBUG_INFO(il, "Scanning while associated...\n");
2591 2591
2592 interval = vif->bss_conf.beacon_int; 2592 interval = vif->bss_conf.beacon_int;
2593 2593
@@ -2607,39 +2607,39 @@ int il3945_request_scan(struct il_priv *priv, struct ieee80211_vif *vif)
2607 (extra | ((suspend_time % interval) * 1024)); 2607 (extra | ((suspend_time % interval) * 1024));
2608 2608
2609 scan->suspend_time = cpu_to_le32(scan_suspend_time); 2609 scan->suspend_time = cpu_to_le32(scan_suspend_time);
2610 IL_DEBUG_SCAN(priv, "suspend_time 0x%X beacon interval %d\n", 2610 IL_DEBUG_SCAN(il, "suspend_time 0x%X beacon interval %d\n",
2611 scan_suspend_time, interval); 2611 scan_suspend_time, interval);
2612 } 2612 }
2613 2613
2614 if (priv->scan_request->n_ssids) { 2614 if (il->scan_request->n_ssids) {
2615 int i, p = 0; 2615 int i, p = 0;
2616 IL_DEBUG_SCAN(priv, "Kicking off active scan\n"); 2616 IL_DEBUG_SCAN(il, "Kicking off active scan\n");
2617 for (i = 0; i < priv->scan_request->n_ssids; i++) { 2617 for (i = 0; i < il->scan_request->n_ssids; i++) {
2618 /* always does wildcard anyway */ 2618 /* always does wildcard anyway */
2619 if (!priv->scan_request->ssids[i].ssid_len) 2619 if (!il->scan_request->ssids[i].ssid_len)
2620 continue; 2620 continue;
2621 scan->direct_scan[p].id = WLAN_EID_SSID; 2621 scan->direct_scan[p].id = WLAN_EID_SSID;
2622 scan->direct_scan[p].len = 2622 scan->direct_scan[p].len =
2623 priv->scan_request->ssids[i].ssid_len; 2623 il->scan_request->ssids[i].ssid_len;
2624 memcpy(scan->direct_scan[p].ssid, 2624 memcpy(scan->direct_scan[p].ssid,
2625 priv->scan_request->ssids[i].ssid, 2625 il->scan_request->ssids[i].ssid,
2626 priv->scan_request->ssids[i].ssid_len); 2626 il->scan_request->ssids[i].ssid_len);
2627 n_probes++; 2627 n_probes++;
2628 p++; 2628 p++;
2629 } 2629 }
2630 is_active = true; 2630 is_active = true;
2631 } else 2631 } else
2632 IL_DEBUG_SCAN(priv, "Kicking off passive scan.\n"); 2632 IL_DEBUG_SCAN(il, "Kicking off passive scan.\n");
2633 2633
2634 /* We don't build a direct scan probe request; the uCode will do 2634 /* We don't build a direct scan probe request; the uCode will do
2635 * that based on the direct_mask added to each channel entry */ 2635 * that based on the direct_mask added to each channel entry */
2636 scan->tx_cmd.tx_flags = TX_CMD_FLG_SEQ_CTL_MSK; 2636 scan->tx_cmd.tx_flags = TX_CMD_FLG_SEQ_CTL_MSK;
2637 scan->tx_cmd.sta_id = priv->contexts[IL_RXON_CTX_BSS].bcast_sta_id; 2637 scan->tx_cmd.sta_id = il->contexts[IL_RXON_CTX_BSS].bcast_sta_id;
2638 scan->tx_cmd.stop_time.life_time = TX_CMD_LIFE_TIME_INFINITE; 2638 scan->tx_cmd.stop_time.life_time = TX_CMD_LIFE_TIME_INFINITE;
2639 2639
2640 /* flags + rate selection */ 2640 /* flags + rate selection */
2641 2641
2642 switch (priv->scan_band) { 2642 switch (il->scan_band) {
2643 case IEEE80211_BAND_2GHZ: 2643 case IEEE80211_BAND_2GHZ:
2644 scan->flags = RXON_FLG_BAND_24G_MSK | RXON_FLG_AUTO_DETECT_MSK; 2644 scan->flags = RXON_FLG_BAND_24G_MSK | RXON_FLG_AUTO_DETECT_MSK;
2645 scan->tx_cmd.rate = IL_RATE_1M_PLCP; 2645 scan->tx_cmd.rate = IL_RATE_1M_PLCP;
@@ -2650,7 +2650,7 @@ int il3945_request_scan(struct il_priv *priv, struct ieee80211_vif *vif)
2650 band = IEEE80211_BAND_5GHZ; 2650 band = IEEE80211_BAND_5GHZ;
2651 break; 2651 break;
2652 default: 2652 default:
2653 IL_WARN(priv, "Invalid scan band\n"); 2653 IL_WARN(il, "Invalid scan band\n");
2654 return -EIO; 2654 return -EIO;
2655 } 2655 }
2656 2656
@@ -2662,19 +2662,19 @@ int il3945_request_scan(struct il_priv *priv, struct ieee80211_vif *vif)
2662 scan->good_CRC_th = is_active ? IL_GOOD_CRC_TH_DEFAULT : 2662 scan->good_CRC_th = is_active ? IL_GOOD_CRC_TH_DEFAULT :
2663 IL_GOOD_CRC_TH_DISABLED; 2663 IL_GOOD_CRC_TH_DISABLED;
2664 2664
2665 len = il_fill_probe_req(priv, (struct ieee80211_mgmt *)scan->data, 2665 len = il_fill_probe_req(il, (struct ieee80211_mgmt *)scan->data,
2666 vif->addr, priv->scan_request->ie, 2666 vif->addr, il->scan_request->ie,
2667 priv->scan_request->ie_len, 2667 il->scan_request->ie_len,
2668 IL_MAX_SCAN_SIZE - sizeof(*scan)); 2668 IL_MAX_SCAN_SIZE - sizeof(*scan));
2669 scan->tx_cmd.len = cpu_to_le16(len); 2669 scan->tx_cmd.len = cpu_to_le16(len);
2670 2670
2671 /* select Rx antennas */ 2671 /* select Rx antennas */
2672 scan->flags |= il3945_get_antenna_flags(priv); 2672 scan->flags |= il3945_get_antenna_flags(il);
2673 2673
2674 scan->channel_count = il3945_get_channels_for_scan(priv, band, is_active, n_probes, 2674 scan->channel_count = il3945_get_channels_for_scan(il, band, is_active, n_probes,
2675 (void *)&scan->data[len], vif); 2675 (void *)&scan->data[len], vif);
2676 if (scan->channel_count == 0) { 2676 if (scan->channel_count == 0) {
2677 IL_DEBUG_SCAN(priv, "channel count %d\n", scan->channel_count); 2677 IL_DEBUG_SCAN(il, "channel count %d\n", scan->channel_count);
2678 return -EIO; 2678 return -EIO;
2679 } 2679 }
2680 2680
@@ -2683,101 +2683,101 @@ int il3945_request_scan(struct il_priv *priv, struct ieee80211_vif *vif)
2683 cmd.data = scan; 2683 cmd.data = scan;
2684 scan->len = cpu_to_le16(cmd.len); 2684 scan->len = cpu_to_le16(cmd.len);
2685 2685
2686 set_bit(STATUS_SCAN_HW, &priv->status); 2686 set_bit(STATUS_SCAN_HW, &il->status);
2687 ret = il_send_cmd_sync(priv, &cmd); 2687 ret = il_send_cmd_sync(il, &cmd);
2688 if (ret) 2688 if (ret)
2689 clear_bit(STATUS_SCAN_HW, &priv->status); 2689 clear_bit(STATUS_SCAN_HW, &il->status);
2690 return ret; 2690 return ret;
2691} 2691}
2692 2692
2693void il3945_post_scan(struct il_priv *priv) 2693void il3945_post_scan(struct il_priv *il)
2694{ 2694{
2695 struct il_rxon_context *ctx = &priv->contexts[IL_RXON_CTX_BSS]; 2695 struct il_rxon_context *ctx = &il->contexts[IL_RXON_CTX_BSS];
2696 2696
2697 /* 2697 /*
2698 * Since setting the RXON may have been deferred while 2698 * Since setting the RXON may have been deferred while
2699 * performing the scan, fire one off if needed 2699 * performing the scan, fire one off if needed
2700 */ 2700 */
2701 if (memcmp(&ctx->staging, &ctx->active, sizeof(ctx->staging))) 2701 if (memcmp(&ctx->staging, &ctx->active, sizeof(ctx->staging)))
2702 il3945_commit_rxon(priv, ctx); 2702 il3945_commit_rxon(il, ctx);
2703} 2703}
2704 2704
2705static void il3945_bg_restart(struct work_struct *data) 2705static void il3945_bg_restart(struct work_struct *data)
2706{ 2706{
2707 struct il_priv *priv = container_of(data, struct il_priv, restart); 2707 struct il_priv *il = container_of(data, struct il_priv, restart);
2708 2708
2709 if (test_bit(STATUS_EXIT_PENDING, &priv->status)) 2709 if (test_bit(STATUS_EXIT_PENDING, &il->status))
2710 return; 2710 return;
2711 2711
2712 if (test_and_clear_bit(STATUS_FW_ERROR, &priv->status)) { 2712 if (test_and_clear_bit(STATUS_FW_ERROR, &il->status)) {
2713 struct il_rxon_context *ctx; 2713 struct il_rxon_context *ctx;
2714 mutex_lock(&priv->mutex); 2714 mutex_lock(&il->mutex);
2715 for_each_context(priv, ctx) 2715 for_each_context(il, ctx)
2716 ctx->vif = NULL; 2716 ctx->vif = NULL;
2717 priv->is_open = 0; 2717 il->is_open = 0;
2718 mutex_unlock(&priv->mutex); 2718 mutex_unlock(&il->mutex);
2719 il3945_down(priv); 2719 il3945_down(il);
2720 ieee80211_restart_hw(priv->hw); 2720 ieee80211_restart_hw(il->hw);
2721 } else { 2721 } else {
2722 il3945_down(priv); 2722 il3945_down(il);
2723 2723
2724 mutex_lock(&priv->mutex); 2724 mutex_lock(&il->mutex);
2725 if (test_bit(STATUS_EXIT_PENDING, &priv->status)) { 2725 if (test_bit(STATUS_EXIT_PENDING, &il->status)) {
2726 mutex_unlock(&priv->mutex); 2726 mutex_unlock(&il->mutex);
2727 return; 2727 return;
2728 } 2728 }
2729 2729
2730 __il3945_up(priv); 2730 __il3945_up(il);
2731 mutex_unlock(&priv->mutex); 2731 mutex_unlock(&il->mutex);
2732 } 2732 }
2733} 2733}
2734 2734
2735static void il3945_bg_rx_replenish(struct work_struct *data) 2735static void il3945_bg_rx_replenish(struct work_struct *data)
2736{ 2736{
2737 struct il_priv *priv = 2737 struct il_priv *il =
2738 container_of(data, struct il_priv, rx_replenish); 2738 container_of(data, struct il_priv, rx_replenish);
2739 2739
2740 mutex_lock(&priv->mutex); 2740 mutex_lock(&il->mutex);
2741 if (test_bit(STATUS_EXIT_PENDING, &priv->status)) 2741 if (test_bit(STATUS_EXIT_PENDING, &il->status))
2742 goto out; 2742 goto out;
2743 2743
2744 il3945_rx_replenish(priv); 2744 il3945_rx_replenish(il);
2745out: 2745out:
2746 mutex_unlock(&priv->mutex); 2746 mutex_unlock(&il->mutex);
2747} 2747}
2748 2748
2749void il3945_post_associate(struct il_priv *priv) 2749void il3945_post_associate(struct il_priv *il)
2750{ 2750{
2751 int rc = 0; 2751 int rc = 0;
2752 struct ieee80211_conf *conf = NULL; 2752 struct ieee80211_conf *conf = NULL;
2753 struct il_rxon_context *ctx = &priv->contexts[IL_RXON_CTX_BSS]; 2753 struct il_rxon_context *ctx = &il->contexts[IL_RXON_CTX_BSS];
2754 2754
2755 if (!ctx->vif || !priv->is_open) 2755 if (!ctx->vif || !il->is_open)
2756 return; 2756 return;
2757 2757
2758 IL_DEBUG_ASSOC(priv, "Associated as %d to: %pM\n", 2758 IL_DEBUG_ASSOC(il, "Associated as %d to: %pM\n",
2759 ctx->vif->bss_conf.aid, ctx->active.bssid_addr); 2759 ctx->vif->bss_conf.aid, ctx->active.bssid_addr);
2760 2760
2761 if (test_bit(STATUS_EXIT_PENDING, &priv->status)) 2761 if (test_bit(STATUS_EXIT_PENDING, &il->status))
2762 return; 2762 return;
2763 2763
2764 il_scan_cancel_timeout(priv, 200); 2764 il_scan_cancel_timeout(il, 200);
2765 2765
2766 conf = il_ieee80211_get_hw_conf(priv->hw); 2766 conf = il_ieee80211_get_hw_conf(il->hw);
2767 2767
2768 ctx->staging.filter_flags &= ~RXON_FILTER_ASSOC_MSK; 2768 ctx->staging.filter_flags &= ~RXON_FILTER_ASSOC_MSK;
2769 il3945_commit_rxon(priv, ctx); 2769 il3945_commit_rxon(il, ctx);
2770 2770
2771 rc = il_send_rxon_timing(priv, ctx); 2771 rc = il_send_rxon_timing(il, ctx);
2772 if (rc) 2772 if (rc)
2773 IL_WARN(priv, "REPLY_RXON_TIMING failed - " 2773 IL_WARN(il, "REPLY_RXON_TIMING failed - "
2774 "Attempting to continue.\n"); 2774 "Attempting to continue.\n");
2775 2775
2776 ctx->staging.filter_flags |= RXON_FILTER_ASSOC_MSK; 2776 ctx->staging.filter_flags |= RXON_FILTER_ASSOC_MSK;
2777 2777
2778 ctx->staging.assoc_id = cpu_to_le16(ctx->vif->bss_conf.aid); 2778 ctx->staging.assoc_id = cpu_to_le16(ctx->vif->bss_conf.aid);
2779 2779
2780 IL_DEBUG_ASSOC(priv, "assoc id %d beacon interval %d\n", 2780 IL_DEBUG_ASSOC(il, "assoc id %d beacon interval %d\n",
2781 ctx->vif->bss_conf.aid, ctx->vif->bss_conf.beacon_int); 2781 ctx->vif->bss_conf.aid, ctx->vif->bss_conf.beacon_int);
2782 2782
2783 if (ctx->vif->bss_conf.use_short_preamble) 2783 if (ctx->vif->bss_conf.use_short_preamble)
@@ -2792,17 +2792,17 @@ void il3945_post_associate(struct il_priv *priv)
2792 ctx->staging.flags &= ~RXON_FLG_SHORT_SLOT_MSK; 2792 ctx->staging.flags &= ~RXON_FLG_SHORT_SLOT_MSK;
2793 } 2793 }
2794 2794
2795 il3945_commit_rxon(priv, ctx); 2795 il3945_commit_rxon(il, ctx);
2796 2796
2797 switch (ctx->vif->type) { 2797 switch (ctx->vif->type) {
2798 case NL80211_IFTYPE_STATION: 2798 case NL80211_IFTYPE_STATION:
2799 il3945_rate_scale_init(priv->hw, IL_AP_ID); 2799 il3945_rate_scale_init(il->hw, IL_AP_ID);
2800 break; 2800 break;
2801 case NL80211_IFTYPE_ADHOC: 2801 case NL80211_IFTYPE_ADHOC:
2802 il3945_send_beacon_cmd(priv); 2802 il3945_send_beacon_cmd(il);
2803 break; 2803 break;
2804 default: 2804 default:
2805 IL_ERR(priv, "%s Should not be called in %d mode\n", 2805 IL_ERR(il, "%s Should not be called in %d mode\n",
2806 __func__, ctx->vif->type); 2806 __func__, ctx->vif->type);
2807 break; 2807 break;
2808 } 2808 }
@@ -2818,43 +2818,43 @@ void il3945_post_associate(struct il_priv *priv)
2818 2818
2819static int il3945_mac_start(struct ieee80211_hw *hw) 2819static int il3945_mac_start(struct ieee80211_hw *hw)
2820{ 2820{
2821 struct il_priv *priv = hw->priv; 2821 struct il_priv *il = hw->priv;
2822 int ret; 2822 int ret;
2823 2823
2824 IL_DEBUG_MAC80211(priv, "enter\n"); 2824 IL_DEBUG_MAC80211(il, "enter\n");
2825 2825
2826 /* we should be verifying the device is ready to be opened */ 2826 /* we should be verifying the device is ready to be opened */
2827 mutex_lock(&priv->mutex); 2827 mutex_lock(&il->mutex);
2828 2828
2829 /* fetch ucode file from disk, alloc and copy to bus-master buffers ... 2829 /* fetch ucode file from disk, alloc and copy to bus-master buffers ...
2830 * ucode filename and max sizes are card-specific. */ 2830 * ucode filename and max sizes are card-specific. */
2831 2831
2832 if (!priv->ucode_code.len) { 2832 if (!il->ucode_code.len) {
2833 ret = il3945_read_ucode(priv); 2833 ret = il3945_read_ucode(il);
2834 if (ret) { 2834 if (ret) {
2835 IL_ERR(priv, "Could not read microcode: %d\n", ret); 2835 IL_ERR(il, "Could not read microcode: %d\n", ret);
2836 mutex_unlock(&priv->mutex); 2836 mutex_unlock(&il->mutex);
2837 goto out_release_irq; 2837 goto out_release_irq;
2838 } 2838 }
2839 } 2839 }
2840 2840
2841 ret = __il3945_up(priv); 2841 ret = __il3945_up(il);
2842 2842
2843 mutex_unlock(&priv->mutex); 2843 mutex_unlock(&il->mutex);
2844 2844
2845 if (ret) 2845 if (ret)
2846 goto out_release_irq; 2846 goto out_release_irq;
2847 2847
2848 IL_DEBUG_INFO(priv, "Start UP work.\n"); 2848 IL_DEBUG_INFO(il, "Start UP work.\n");
2849 2849
2850 /* Wait for START_ALIVE from ucode. Otherwise callbacks from 2850 /* Wait for START_ALIVE from ucode. Otherwise callbacks from
2851 * mac80211 will not be run successfully. */ 2851 * mac80211 will not be run successfully. */
2852 ret = wait_event_timeout(priv->wait_command_queue, 2852 ret = wait_event_timeout(il->wait_command_queue,
2853 test_bit(STATUS_READY, &priv->status), 2853 test_bit(STATUS_READY, &il->status),
2854 UCODE_READY_TIMEOUT); 2854 UCODE_READY_TIMEOUT);
2855 if (!ret) { 2855 if (!ret) {
2856 if (!test_bit(STATUS_READY, &priv->status)) { 2856 if (!test_bit(STATUS_READY, &il->status)) {
2857 IL_ERR(priv, 2857 IL_ERR(il,
2858 "Wait for START_ALIVE timeout after %dms.\n", 2858 "Wait for START_ALIVE timeout after %dms.\n",
2859 jiffies_to_msecs(UCODE_READY_TIMEOUT)); 2859 jiffies_to_msecs(UCODE_READY_TIMEOUT));
2860 ret = -ETIMEDOUT; 2860 ret = -ETIMEDOUT;
@@ -2864,77 +2864,77 @@ static int il3945_mac_start(struct ieee80211_hw *hw)
2864 2864
2865 /* ucode is running and will send rfkill notifications, 2865 /* ucode is running and will send rfkill notifications,
2866 * no need to poll the killswitch state anymore */ 2866 * no need to poll the killswitch state anymore */
2867 cancel_delayed_work(&priv->_3945.rfkill_poll); 2867 cancel_delayed_work(&il->_3945.rfkill_poll);
2868 2868
2869 priv->is_open = 1; 2869 il->is_open = 1;
2870 IL_DEBUG_MAC80211(priv, "leave\n"); 2870 IL_DEBUG_MAC80211(il, "leave\n");
2871 return 0; 2871 return 0;
2872 2872
2873out_release_irq: 2873out_release_irq:
2874 priv->is_open = 0; 2874 il->is_open = 0;
2875 IL_DEBUG_MAC80211(priv, "leave - failed\n"); 2875 IL_DEBUG_MAC80211(il, "leave - failed\n");
2876 return ret; 2876 return ret;
2877} 2877}
2878 2878
2879static void il3945_mac_stop(struct ieee80211_hw *hw) 2879static void il3945_mac_stop(struct ieee80211_hw *hw)
2880{ 2880{
2881 struct il_priv *priv = hw->priv; 2881 struct il_priv *il = hw->priv;
2882 2882
2883 IL_DEBUG_MAC80211(priv, "enter\n"); 2883 IL_DEBUG_MAC80211(il, "enter\n");
2884 2884
2885 if (!priv->is_open) { 2885 if (!il->is_open) {
2886 IL_DEBUG_MAC80211(priv, "leave - skip\n"); 2886 IL_DEBUG_MAC80211(il, "leave - skip\n");
2887 return; 2887 return;
2888 } 2888 }
2889 2889
2890 priv->is_open = 0; 2890 il->is_open = 0;
2891 2891
2892 il3945_down(priv); 2892 il3945_down(il);
2893 2893
2894 flush_workqueue(priv->workqueue); 2894 flush_workqueue(il->workqueue);
2895 2895
2896 /* start polling the killswitch state again */ 2896 /* start polling the killswitch state again */
2897 queue_delayed_work(priv->workqueue, &priv->_3945.rfkill_poll, 2897 queue_delayed_work(il->workqueue, &il->_3945.rfkill_poll,
2898 round_jiffies_relative(2 * HZ)); 2898 round_jiffies_relative(2 * HZ));
2899 2899
2900 IL_DEBUG_MAC80211(priv, "leave\n"); 2900 IL_DEBUG_MAC80211(il, "leave\n");
2901} 2901}
2902 2902
2903static void il3945_mac_tx(struct ieee80211_hw *hw, struct sk_buff *skb) 2903static void il3945_mac_tx(struct ieee80211_hw *hw, struct sk_buff *skb)
2904{ 2904{
2905 struct il_priv *priv = hw->priv; 2905 struct il_priv *il = hw->priv;
2906 2906
2907 IL_DEBUG_MAC80211(priv, "enter\n"); 2907 IL_DEBUG_MAC80211(il, "enter\n");
2908 2908
2909 IL_DEBUG_TX(priv, "dev->xmit(%d bytes) at rate 0x%02x\n", skb->len, 2909 IL_DEBUG_TX(il, "dev->xmit(%d bytes) at rate 0x%02x\n", skb->len,
2910 ieee80211_get_tx_rate(hw, IEEE80211_SKB_CB(skb))->bitrate); 2910 ieee80211_get_tx_rate(hw, IEEE80211_SKB_CB(skb))->bitrate);
2911 2911
2912 if (il3945_tx_skb(priv, skb)) 2912 if (il3945_tx_skb(il, skb))
2913 dev_kfree_skb_any(skb); 2913 dev_kfree_skb_any(skb);
2914 2914
2915 IL_DEBUG_MAC80211(priv, "leave\n"); 2915 IL_DEBUG_MAC80211(il, "leave\n");
2916} 2916}
2917 2917
2918void il3945_config_ap(struct il_priv *priv) 2918void il3945_config_ap(struct il_priv *il)
2919{ 2919{
2920 struct il_rxon_context *ctx = &priv->contexts[IL_RXON_CTX_BSS]; 2920 struct il_rxon_context *ctx = &il->contexts[IL_RXON_CTX_BSS];
2921 struct ieee80211_vif *vif = ctx->vif; 2921 struct ieee80211_vif *vif = ctx->vif;
2922 int rc = 0; 2922 int rc = 0;
2923 2923
2924 if (test_bit(STATUS_EXIT_PENDING, &priv->status)) 2924 if (test_bit(STATUS_EXIT_PENDING, &il->status))
2925 return; 2925 return;
2926 2926
2927 /* The following should be done only at AP bring up */ 2927 /* The following should be done only at AP bring up */
2928 if (!(il_is_associated(priv, IL_RXON_CTX_BSS))) { 2928 if (!(il_is_associated(il, IL_RXON_CTX_BSS))) {
2929 2929
2930 /* RXON - unassoc (to set timing command) */ 2930 /* RXON - unassoc (to set timing command) */
2931 ctx->staging.filter_flags &= ~RXON_FILTER_ASSOC_MSK; 2931 ctx->staging.filter_flags &= ~RXON_FILTER_ASSOC_MSK;
2932 il3945_commit_rxon(priv, ctx); 2932 il3945_commit_rxon(il, ctx);
2933 2933
2934 /* RXON Timing */ 2934 /* RXON Timing */
2935 rc = il_send_rxon_timing(priv, ctx); 2935 rc = il_send_rxon_timing(il, ctx);
2936 if (rc) 2936 if (rc)
2937 IL_WARN(priv, "REPLY_RXON_TIMING failed - " 2937 IL_WARN(il, "REPLY_RXON_TIMING failed - "
2938 "Attempting to continue.\n"); 2938 "Attempting to continue.\n");
2939 2939
2940 ctx->staging.assoc_id = 0; 2940 ctx->staging.assoc_id = 0;
@@ -2956,9 +2956,9 @@ void il3945_config_ap(struct il_priv *priv)
2956 } 2956 }
2957 /* restore RXON assoc */ 2957 /* restore RXON assoc */
2958 ctx->staging.filter_flags |= RXON_FILTER_ASSOC_MSK; 2958 ctx->staging.filter_flags |= RXON_FILTER_ASSOC_MSK;
2959 il3945_commit_rxon(priv, ctx); 2959 il3945_commit_rxon(il, ctx);
2960 } 2960 }
2961 il3945_send_beacon_cmd(priv); 2961 il3945_send_beacon_cmd(il);
2962} 2962}
2963 2963
2964static int il3945_mac_set_key(struct ieee80211_hw *hw, enum set_key_cmd cmd, 2964static int il3945_mac_set_key(struct ieee80211_hw *hw, enum set_key_cmd cmd,
@@ -2966,15 +2966,15 @@ static int il3945_mac_set_key(struct ieee80211_hw *hw, enum set_key_cmd cmd,
2966 struct ieee80211_sta *sta, 2966 struct ieee80211_sta *sta,
2967 struct ieee80211_key_conf *key) 2967 struct ieee80211_key_conf *key)
2968{ 2968{
2969 struct il_priv *priv = hw->priv; 2969 struct il_priv *il = hw->priv;
2970 int ret = 0; 2970 int ret = 0;
2971 u8 sta_id = IL_INVALID_STATION; 2971 u8 sta_id = IL_INVALID_STATION;
2972 u8 static_key; 2972 u8 static_key;
2973 2973
2974 IL_DEBUG_MAC80211(priv, "enter\n"); 2974 IL_DEBUG_MAC80211(il, "enter\n");
2975 2975
2976 if (il3945_mod_params.sw_crypto) { 2976 if (il3945_mod_params.sw_crypto) {
2977 IL_DEBUG_MAC80211(priv, "leave - hwcrypto disabled\n"); 2977 IL_DEBUG_MAC80211(il, "leave - hwcrypto disabled\n");
2978 return -EOPNOTSUPP; 2978 return -EOPNOTSUPP;
2979 } 2979 }
2980 2980
@@ -2986,39 +2986,39 @@ static int il3945_mac_set_key(struct ieee80211_hw *hw, enum set_key_cmd cmd,
2986 !(key->flags & IEEE80211_KEY_FLAG_PAIRWISE)) 2986 !(key->flags & IEEE80211_KEY_FLAG_PAIRWISE))
2987 return -EOPNOTSUPP; 2987 return -EOPNOTSUPP;
2988 2988
2989 static_key = !il_is_associated(priv, IL_RXON_CTX_BSS); 2989 static_key = !il_is_associated(il, IL_RXON_CTX_BSS);
2990 2990
2991 if (!static_key) { 2991 if (!static_key) {
2992 sta_id = il_sta_id_or_broadcast( 2992 sta_id = il_sta_id_or_broadcast(
2993 priv, &priv->contexts[IL_RXON_CTX_BSS], sta); 2993 il, &il->contexts[IL_RXON_CTX_BSS], sta);
2994 if (sta_id == IL_INVALID_STATION) 2994 if (sta_id == IL_INVALID_STATION)
2995 return -EINVAL; 2995 return -EINVAL;
2996 } 2996 }
2997 2997
2998 mutex_lock(&priv->mutex); 2998 mutex_lock(&il->mutex);
2999 il_scan_cancel_timeout(priv, 100); 2999 il_scan_cancel_timeout(il, 100);
3000 3000
3001 switch (cmd) { 3001 switch (cmd) {
3002 case SET_KEY: 3002 case SET_KEY:
3003 if (static_key) 3003 if (static_key)
3004 ret = il3945_set_static_key(priv, key); 3004 ret = il3945_set_static_key(il, key);
3005 else 3005 else
3006 ret = il3945_set_dynamic_key(priv, key, sta_id); 3006 ret = il3945_set_dynamic_key(il, key, sta_id);
3007 IL_DEBUG_MAC80211(priv, "enable hwcrypto key\n"); 3007 IL_DEBUG_MAC80211(il, "enable hwcrypto key\n");
3008 break; 3008 break;
3009 case DISABLE_KEY: 3009 case DISABLE_KEY:
3010 if (static_key) 3010 if (static_key)
3011 ret = il3945_remove_static_key(priv); 3011 ret = il3945_remove_static_key(il);
3012 else 3012 else
3013 ret = il3945_clear_sta_key_info(priv, sta_id); 3013 ret = il3945_clear_sta_key_info(il, sta_id);
3014 IL_DEBUG_MAC80211(priv, "disable hwcrypto key\n"); 3014 IL_DEBUG_MAC80211(il, "disable hwcrypto key\n");
3015 break; 3015 break;
3016 default: 3016 default:
3017 ret = -EINVAL; 3017 ret = -EINVAL;
3018 } 3018 }
3019 3019
3020 mutex_unlock(&priv->mutex); 3020 mutex_unlock(&il->mutex);
3021 IL_DEBUG_MAC80211(priv, "leave\n"); 3021 IL_DEBUG_MAC80211(il, "leave\n");
3022 3022
3023 return ret; 3023 return ret;
3024} 3024}
@@ -3027,38 +3027,38 @@ static int il3945_mac_sta_add(struct ieee80211_hw *hw,
3027 struct ieee80211_vif *vif, 3027 struct ieee80211_vif *vif,
3028 struct ieee80211_sta *sta) 3028 struct ieee80211_sta *sta)
3029{ 3029{
3030 struct il_priv *priv = hw->priv; 3030 struct il_priv *il = hw->priv;
3031 struct il3945_sta_priv *sta_priv = (void *)sta->drv_priv; 3031 struct il3945_sta_priv *sta_priv = (void *)sta->drv_priv;
3032 int ret; 3032 int ret;
3033 bool is_ap = vif->type == NL80211_IFTYPE_STATION; 3033 bool is_ap = vif->type == NL80211_IFTYPE_STATION;
3034 u8 sta_id; 3034 u8 sta_id;
3035 3035
3036 IL_DEBUG_INFO(priv, "received request to add station %pM\n", 3036 IL_DEBUG_INFO(il, "received request to add station %pM\n",
3037 sta->addr); 3037 sta->addr);
3038 mutex_lock(&priv->mutex); 3038 mutex_lock(&il->mutex);
3039 IL_DEBUG_INFO(priv, "proceeding to add station %pM\n", 3039 IL_DEBUG_INFO(il, "proceeding to add station %pM\n",
3040 sta->addr); 3040 sta->addr);
3041 sta_priv->common.sta_id = IL_INVALID_STATION; 3041 sta_priv->common.sta_id = IL_INVALID_STATION;
3042 3042
3043 3043
3044 ret = il_add_station_common(priv, 3044 ret = il_add_station_common(il,
3045 &priv->contexts[IL_RXON_CTX_BSS], 3045 &il->contexts[IL_RXON_CTX_BSS],
3046 sta->addr, is_ap, sta, &sta_id); 3046 sta->addr, is_ap, sta, &sta_id);
3047 if (ret) { 3047 if (ret) {
3048 IL_ERR(priv, "Unable to add station %pM (%d)\n", 3048 IL_ERR(il, "Unable to add station %pM (%d)\n",
3049 sta->addr, ret); 3049 sta->addr, ret);
3050 /* Should we return success if return code is EEXIST ? */ 3050 /* Should we return success if return code is EEXIST ? */
3051 mutex_unlock(&priv->mutex); 3051 mutex_unlock(&il->mutex);
3052 return ret; 3052 return ret;
3053 } 3053 }
3054 3054
3055 sta_priv->common.sta_id = sta_id; 3055 sta_priv->common.sta_id = sta_id;
3056 3056
3057 /* Initialize rate scaling */ 3057 /* Initialize rate scaling */
3058 IL_DEBUG_INFO(priv, "Initializing rate scaling for station %pM\n", 3058 IL_DEBUG_INFO(il, "Initializing rate scaling for station %pM\n",
3059 sta->addr); 3059 sta->addr);
3060 il3945_rs_rate_init(priv, sta, sta_id); 3060 il3945_rs_rate_init(il, sta, sta_id);
3061 mutex_unlock(&priv->mutex); 3061 mutex_unlock(&il->mutex);
3062 3062
3063 return 0; 3063 return 0;
3064} 3064}
@@ -3068,9 +3068,9 @@ static void il3945_configure_filter(struct ieee80211_hw *hw,
3068 unsigned int *total_flags, 3068 unsigned int *total_flags,
3069 u64 multicast) 3069 u64 multicast)
3070{ 3070{
3071 struct il_priv *priv = hw->priv; 3071 struct il_priv *il = hw->priv;
3072 __le32 filter_or = 0, filter_nand = 0; 3072 __le32 filter_or = 0, filter_nand = 0;
3073 struct il_rxon_context *ctx = &priv->contexts[IL_RXON_CTX_BSS]; 3073 struct il_rxon_context *ctx = &il->contexts[IL_RXON_CTX_BSS];
3074 3074
3075#define CHK(test, flag) do { \ 3075#define CHK(test, flag) do { \
3076 if (*total_flags & (test)) \ 3076 if (*total_flags & (test)) \
@@ -3079,7 +3079,7 @@ static void il3945_configure_filter(struct ieee80211_hw *hw,
3079 filter_nand |= (flag); \ 3079 filter_nand |= (flag); \
3080 } while (0) 3080 } while (0)
3081 3081
3082 IL_DEBUG_MAC80211(priv, "Enter: changed: 0x%x, total: 0x%x\n", 3082 IL_DEBUG_MAC80211(il, "Enter: changed: 0x%x, total: 0x%x\n",
3083 changed_flags, *total_flags); 3083 changed_flags, *total_flags);
3084 3084
3085 CHK(FIF_OTHER_BSS | FIF_PROMISC_IN_BSS, RXON_FILTER_PROMISC_MSK); 3085 CHK(FIF_OTHER_BSS | FIF_PROMISC_IN_BSS, RXON_FILTER_PROMISC_MSK);
@@ -3088,7 +3088,7 @@ static void il3945_configure_filter(struct ieee80211_hw *hw,
3088 3088
3089#undef CHK 3089#undef CHK
3090 3090
3091 mutex_lock(&priv->mutex); 3091 mutex_lock(&il->mutex);
3092 3092
3093 ctx->staging.filter_flags &= ~filter_nand; 3093 ctx->staging.filter_flags &= ~filter_nand;
3094 ctx->staging.filter_flags |= filter_or; 3094 ctx->staging.filter_flags |= filter_or;
@@ -3099,7 +3099,7 @@ static void il3945_configure_filter(struct ieee80211_hw *hw,
3099 * we'll eventually commit the filter flags change anyway. 3099 * we'll eventually commit the filter flags change anyway.
3100 */ 3100 */
3101 3101
3102 mutex_unlock(&priv->mutex); 3102 mutex_unlock(&il->mutex);
3103 3103
3104 /* 3104 /*
3105 * Receiving all multicast frames is always enabled by the 3105 * Receiving all multicast frames is always enabled by the
@@ -3134,24 +3134,24 @@ static void il3945_configure_filter(struct ieee80211_hw *hw,
3134static ssize_t il3945_show_debug_level(struct device *d, 3134static ssize_t il3945_show_debug_level(struct device *d,
3135 struct device_attribute *attr, char *buf) 3135 struct device_attribute *attr, char *buf)
3136{ 3136{
3137 struct il_priv *priv = dev_get_drvdata(d); 3137 struct il_priv *il = dev_get_drvdata(d);
3138 return sprintf(buf, "0x%08X\n", il_get_debug_level(priv)); 3138 return sprintf(buf, "0x%08X\n", il_get_debug_level(il));
3139} 3139}
3140static ssize_t il3945_store_debug_level(struct device *d, 3140static ssize_t il3945_store_debug_level(struct device *d,
3141 struct device_attribute *attr, 3141 struct device_attribute *attr,
3142 const char *buf, size_t count) 3142 const char *buf, size_t count)
3143{ 3143{
3144 struct il_priv *priv = dev_get_drvdata(d); 3144 struct il_priv *il = dev_get_drvdata(d);
3145 unsigned long val; 3145 unsigned long val;
3146 int ret; 3146 int ret;
3147 3147
3148 ret = strict_strtoul(buf, 0, &val); 3148 ret = strict_strtoul(buf, 0, &val);
3149 if (ret) 3149 if (ret)
3150 IL_INFO(priv, "%s is not in hex or decimal form.\n", buf); 3150 IL_INFO(il, "%s is not in hex or decimal form.\n", buf);
3151 else { 3151 else {
3152 priv->debug_level = val; 3152 il->debug_level = val;
3153 if (il_alloc_traffic_mem(priv)) 3153 if (il_alloc_traffic_mem(il))
3154 IL_ERR(priv, 3154 IL_ERR(il,
3155 "Not enough memory to generate traffic log\n"); 3155 "Not enough memory to generate traffic log\n");
3156 } 3156 }
3157 return strnlen(buf, count); 3157 return strnlen(buf, count);
@@ -3165,12 +3165,12 @@ static DEVICE_ATTR(debug_level, S_IWUSR | S_IRUGO,
3165static ssize_t il3945_show_temperature(struct device *d, 3165static ssize_t il3945_show_temperature(struct device *d,
3166 struct device_attribute *attr, char *buf) 3166 struct device_attribute *attr, char *buf)
3167{ 3167{
3168 struct il_priv *priv = dev_get_drvdata(d); 3168 struct il_priv *il = dev_get_drvdata(d);
3169 3169
3170 if (!il_is_alive(priv)) 3170 if (!il_is_alive(il))
3171 return -EAGAIN; 3171 return -EAGAIN;
3172 3172
3173 return sprintf(buf, "%d\n", il3945_hw_get_temperature(priv)); 3173 return sprintf(buf, "%d\n", il3945_hw_get_temperature(il));
3174} 3174}
3175 3175
3176static DEVICE_ATTR(temperature, S_IRUGO, il3945_show_temperature, NULL); 3176static DEVICE_ATTR(temperature, S_IRUGO, il3945_show_temperature, NULL);
@@ -3178,23 +3178,23 @@ static DEVICE_ATTR(temperature, S_IRUGO, il3945_show_temperature, NULL);
3178static ssize_t il3945_show_tx_power(struct device *d, 3178static ssize_t il3945_show_tx_power(struct device *d,
3179 struct device_attribute *attr, char *buf) 3179 struct device_attribute *attr, char *buf)
3180{ 3180{
3181 struct il_priv *priv = dev_get_drvdata(d); 3181 struct il_priv *il = dev_get_drvdata(d);
3182 return sprintf(buf, "%d\n", priv->tx_power_user_lmt); 3182 return sprintf(buf, "%d\n", il->tx_power_user_lmt);
3183} 3183}
3184 3184
3185static ssize_t il3945_store_tx_power(struct device *d, 3185static ssize_t il3945_store_tx_power(struct device *d,
3186 struct device_attribute *attr, 3186 struct device_attribute *attr,
3187 const char *buf, size_t count) 3187 const char *buf, size_t count)
3188{ 3188{
3189 struct il_priv *priv = dev_get_drvdata(d); 3189 struct il_priv *il = dev_get_drvdata(d);
3190 char *p = (char *)buf; 3190 char *p = (char *)buf;
3191 u32 val; 3191 u32 val;
3192 3192
3193 val = simple_strtoul(p, &p, 10); 3193 val = simple_strtoul(p, &p, 10);
3194 if (p == buf) 3194 if (p == buf)
3195 IL_INFO(priv, ": %s is not in decimal form.\n", buf); 3195 IL_INFO(il, ": %s is not in decimal form.\n", buf);
3196 else 3196 else
3197 il3945_hw_reg_set_txpower(priv, val); 3197 il3945_hw_reg_set_txpower(il, val);
3198 3198
3199 return count; 3199 return count;
3200} 3200}
@@ -3204,8 +3204,8 @@ static DEVICE_ATTR(tx_power, S_IWUSR | S_IRUGO, il3945_show_tx_power, il3945_sto
3204static ssize_t il3945_show_flags(struct device *d, 3204static ssize_t il3945_show_flags(struct device *d,
3205 struct device_attribute *attr, char *buf) 3205 struct device_attribute *attr, char *buf)
3206{ 3206{
3207 struct il_priv *priv = dev_get_drvdata(d); 3207 struct il_priv *il = dev_get_drvdata(d);
3208 struct il_rxon_context *ctx = &priv->contexts[IL_RXON_CTX_BSS]; 3208 struct il_rxon_context *ctx = &il->contexts[IL_RXON_CTX_BSS];
3209 3209
3210 return sprintf(buf, "0x%04X\n", ctx->active.flags); 3210 return sprintf(buf, "0x%04X\n", ctx->active.flags);
3211} 3211}
@@ -3214,23 +3214,23 @@ static ssize_t il3945_store_flags(struct device *d,
3214 struct device_attribute *attr, 3214 struct device_attribute *attr,
3215 const char *buf, size_t count) 3215 const char *buf, size_t count)
3216{ 3216{
3217 struct il_priv *priv = dev_get_drvdata(d); 3217 struct il_priv *il = dev_get_drvdata(d);
3218 u32 flags = simple_strtoul(buf, NULL, 0); 3218 u32 flags = simple_strtoul(buf, NULL, 0);
3219 struct il_rxon_context *ctx = &priv->contexts[IL_RXON_CTX_BSS]; 3219 struct il_rxon_context *ctx = &il->contexts[IL_RXON_CTX_BSS];
3220 3220
3221 mutex_lock(&priv->mutex); 3221 mutex_lock(&il->mutex);
3222 if (le32_to_cpu(ctx->staging.flags) != flags) { 3222 if (le32_to_cpu(ctx->staging.flags) != flags) {
3223 /* Cancel any currently running scans... */ 3223 /* Cancel any currently running scans... */
3224 if (il_scan_cancel_timeout(priv, 100)) 3224 if (il_scan_cancel_timeout(il, 100))
3225 IL_WARN(priv, "Could not cancel scan.\n"); 3225 IL_WARN(il, "Could not cancel scan.\n");
3226 else { 3226 else {
3227 IL_DEBUG_INFO(priv, "Committing rxon.flags = 0x%04X\n", 3227 IL_DEBUG_INFO(il, "Committing rxon.flags = 0x%04X\n",
3228 flags); 3228 flags);
3229 ctx->staging.flags = cpu_to_le32(flags); 3229 ctx->staging.flags = cpu_to_le32(flags);
3230 il3945_commit_rxon(priv, ctx); 3230 il3945_commit_rxon(il, ctx);
3231 } 3231 }
3232 } 3232 }
3233 mutex_unlock(&priv->mutex); 3233 mutex_unlock(&il->mutex);
3234 3234
3235 return count; 3235 return count;
3236} 3236}
@@ -3240,8 +3240,8 @@ static DEVICE_ATTR(flags, S_IWUSR | S_IRUGO, il3945_show_flags, il3945_store_fla
3240static ssize_t il3945_show_filter_flags(struct device *d, 3240static ssize_t il3945_show_filter_flags(struct device *d,
3241 struct device_attribute *attr, char *buf) 3241 struct device_attribute *attr, char *buf)
3242{ 3242{
3243 struct il_priv *priv = dev_get_drvdata(d); 3243 struct il_priv *il = dev_get_drvdata(d);
3244 struct il_rxon_context *ctx = &priv->contexts[IL_RXON_CTX_BSS]; 3244 struct il_rxon_context *ctx = &il->contexts[IL_RXON_CTX_BSS];
3245 3245
3246 return sprintf(buf, "0x%04X\n", 3246 return sprintf(buf, "0x%04X\n",
3247 le32_to_cpu(ctx->active.filter_flags)); 3247 le32_to_cpu(ctx->active.filter_flags));
@@ -3251,24 +3251,24 @@ static ssize_t il3945_store_filter_flags(struct device *d,
3251 struct device_attribute *attr, 3251 struct device_attribute *attr,
3252 const char *buf, size_t count) 3252 const char *buf, size_t count)
3253{ 3253{
3254 struct il_priv *priv = dev_get_drvdata(d); 3254 struct il_priv *il = dev_get_drvdata(d);
3255 struct il_rxon_context *ctx = &priv->contexts[IL_RXON_CTX_BSS]; 3255 struct il_rxon_context *ctx = &il->contexts[IL_RXON_CTX_BSS];
3256 u32 filter_flags = simple_strtoul(buf, NULL, 0); 3256 u32 filter_flags = simple_strtoul(buf, NULL, 0);
3257 3257
3258 mutex_lock(&priv->mutex); 3258 mutex_lock(&il->mutex);
3259 if (le32_to_cpu(ctx->staging.filter_flags) != filter_flags) { 3259 if (le32_to_cpu(ctx->staging.filter_flags) != filter_flags) {
3260 /* Cancel any currently running scans... */ 3260 /* Cancel any currently running scans... */
3261 if (il_scan_cancel_timeout(priv, 100)) 3261 if (il_scan_cancel_timeout(il, 100))
3262 IL_WARN(priv, "Could not cancel scan.\n"); 3262 IL_WARN(il, "Could not cancel scan.\n");
3263 else { 3263 else {
3264 IL_DEBUG_INFO(priv, "Committing rxon.filter_flags = " 3264 IL_DEBUG_INFO(il, "Committing rxon.filter_flags = "
3265 "0x%04X\n", filter_flags); 3265 "0x%04X\n", filter_flags);
3266 ctx->staging.filter_flags = 3266 ctx->staging.filter_flags =
3267 cpu_to_le32(filter_flags); 3267 cpu_to_le32(filter_flags);
3268 il3945_commit_rxon(priv, ctx); 3268 il3945_commit_rxon(il, ctx);
3269 } 3269 }
3270 } 3270 }
3271 mutex_unlock(&priv->mutex); 3271 mutex_unlock(&il->mutex);
3272 3272
3273 return count; 3273 return count;
3274} 3274}
@@ -3279,20 +3279,20 @@ static DEVICE_ATTR(filter_flags, S_IWUSR | S_IRUGO, il3945_show_filter_flags,
3279static ssize_t il3945_show_measurement(struct device *d, 3279static ssize_t il3945_show_measurement(struct device *d,
3280 struct device_attribute *attr, char *buf) 3280 struct device_attribute *attr, char *buf)
3281{ 3281{
3282 struct il_priv *priv = dev_get_drvdata(d); 3282 struct il_priv *il = dev_get_drvdata(d);
3283 struct il_spectrum_notification measure_report; 3283 struct il_spectrum_notification measure_report;
3284 u32 size = sizeof(measure_report), len = 0, ofs = 0; 3284 u32 size = sizeof(measure_report), len = 0, ofs = 0;
3285 u8 *data = (u8 *)&measure_report; 3285 u8 *data = (u8 *)&measure_report;
3286 unsigned long flags; 3286 unsigned long flags;
3287 3287
3288 spin_lock_irqsave(&priv->lock, flags); 3288 spin_lock_irqsave(&il->lock, flags);
3289 if (!(priv->measurement_status & MEASUREMENT_READY)) { 3289 if (!(il->measurement_status & MEASUREMENT_READY)) {
3290 spin_unlock_irqrestore(&priv->lock, flags); 3290 spin_unlock_irqrestore(&il->lock, flags);
3291 return 0; 3291 return 0;
3292 } 3292 }
3293 memcpy(&measure_report, &priv->measure_report, size); 3293 memcpy(&measure_report, &il->measure_report, size);
3294 priv->measurement_status = 0; 3294 il->measurement_status = 0;
3295 spin_unlock_irqrestore(&priv->lock, flags); 3295 spin_unlock_irqrestore(&il->lock, flags);
3296 3296
3297 while (size && (PAGE_SIZE - len)) { 3297 while (size && (PAGE_SIZE - len)) {
3298 hex_dump_to_buffer(data + ofs, size, 16, 1, buf + len, 3298 hex_dump_to_buffer(data + ofs, size, 16, 1, buf + len,
@@ -3312,11 +3312,11 @@ static ssize_t il3945_store_measurement(struct device *d,
3312 struct device_attribute *attr, 3312 struct device_attribute *attr,
3313 const char *buf, size_t count) 3313 const char *buf, size_t count)
3314{ 3314{
3315 struct il_priv *priv = dev_get_drvdata(d); 3315 struct il_priv *il = dev_get_drvdata(d);
3316 struct il_rxon_context *ctx = &priv->contexts[IL_RXON_CTX_BSS]; 3316 struct il_rxon_context *ctx = &il->contexts[IL_RXON_CTX_BSS];
3317 struct ieee80211_measurement_params params = { 3317 struct ieee80211_measurement_params params = {
3318 .channel = le16_to_cpu(ctx->active.channel), 3318 .channel = le16_to_cpu(ctx->active.channel),
3319 .start_time = cpu_to_le64(priv->_3945.last_tsf), 3319 .start_time = cpu_to_le64(il->_3945.last_tsf),
3320 .duration = cpu_to_le16(1), 3320 .duration = cpu_to_le16(1),
3321 }; 3321 };
3322 u8 type = IL_MEASURE_BASIC; 3322 u8 type = IL_MEASURE_BASIC;
@@ -3337,9 +3337,9 @@ static ssize_t il3945_store_measurement(struct device *d,
3337 type = simple_strtoul(p + 1, NULL, 0); 3337 type = simple_strtoul(p + 1, NULL, 0);
3338 } 3338 }
3339 3339
3340 IL_DEBUG_INFO(priv, "Invoking measurement of type %d on " 3340 IL_DEBUG_INFO(il, "Invoking measurement of type %d on "
3341 "channel %d (for '%s')\n", type, params.channel, buf); 3341 "channel %d (for '%s')\n", type, params.channel, buf);
3342 il3945_get_measurement(priv, &params, type); 3342 il3945_get_measurement(il, &params, type);
3343 3343
3344 return count; 3344 return count;
3345} 3345}
@@ -3351,11 +3351,11 @@ static ssize_t il3945_store_retry_rate(struct device *d,
3351 struct device_attribute *attr, 3351 struct device_attribute *attr,
3352 const char *buf, size_t count) 3352 const char *buf, size_t count)
3353{ 3353{
3354 struct il_priv *priv = dev_get_drvdata(d); 3354 struct il_priv *il = dev_get_drvdata(d);
3355 3355
3356 priv->retry_rate = simple_strtoul(buf, NULL, 0); 3356 il->retry_rate = simple_strtoul(buf, NULL, 0);
3357 if (priv->retry_rate <= 0) 3357 if (il->retry_rate <= 0)
3358 priv->retry_rate = 1; 3358 il->retry_rate = 1;
3359 3359
3360 return count; 3360 return count;
3361} 3361}
@@ -3363,8 +3363,8 @@ static ssize_t il3945_store_retry_rate(struct device *d,
3363static ssize_t il3945_show_retry_rate(struct device *d, 3363static ssize_t il3945_show_retry_rate(struct device *d,
3364 struct device_attribute *attr, char *buf) 3364 struct device_attribute *attr, char *buf)
3365{ 3365{
3366 struct il_priv *priv = dev_get_drvdata(d); 3366 struct il_priv *il = dev_get_drvdata(d);
3367 return sprintf(buf, "%d", priv->retry_rate); 3367 return sprintf(buf, "%d", il->retry_rate);
3368} 3368}
3369 3369
3370static DEVICE_ATTR(retry_rate, S_IWUSR | S_IRUSR, il3945_show_retry_rate, 3370static DEVICE_ATTR(retry_rate, S_IWUSR | S_IRUSR, il3945_show_retry_rate,
@@ -3383,9 +3383,9 @@ static DEVICE_ATTR(channels, S_IRUSR, il3945_show_channels, NULL);
3383static ssize_t il3945_show_antenna(struct device *d, 3383static ssize_t il3945_show_antenna(struct device *d,
3384 struct device_attribute *attr, char *buf) 3384 struct device_attribute *attr, char *buf)
3385{ 3385{
3386 struct il_priv *priv = dev_get_drvdata(d); 3386 struct il_priv *il = dev_get_drvdata(d);
3387 3387
3388 if (!il_is_alive(priv)) 3388 if (!il_is_alive(il))
3389 return -EAGAIN; 3389 return -EAGAIN;
3390 3390
3391 return sprintf(buf, "%d\n", il3945_mod_params.antenna); 3391 return sprintf(buf, "%d\n", il3945_mod_params.antenna);
@@ -3395,22 +3395,22 @@ static ssize_t il3945_store_antenna(struct device *d,
3395 struct device_attribute *attr, 3395 struct device_attribute *attr,
3396 const char *buf, size_t count) 3396 const char *buf, size_t count)
3397{ 3397{
3398 struct il_priv *priv __maybe_unused = dev_get_drvdata(d); 3398 struct il_priv *il __maybe_unused = dev_get_drvdata(d);
3399 int ant; 3399 int ant;
3400 3400
3401 if (count == 0) 3401 if (count == 0)
3402 return 0; 3402 return 0;
3403 3403
3404 if (sscanf(buf, "%1i", &ant) != 1) { 3404 if (sscanf(buf, "%1i", &ant) != 1) {
3405 IL_DEBUG_INFO(priv, "not in hex or decimal form.\n"); 3405 IL_DEBUG_INFO(il, "not in hex or decimal form.\n");
3406 return count; 3406 return count;
3407 } 3407 }
3408 3408
3409 if ((ant >= 0) && (ant <= 2)) { 3409 if ((ant >= 0) && (ant <= 2)) {
3410 IL_DEBUG_INFO(priv, "Setting antenna select to %d.\n", ant); 3410 IL_DEBUG_INFO(il, "Setting antenna select to %d.\n", ant);
3411 il3945_mod_params.antenna = (enum il3945_antenna)ant; 3411 il3945_mod_params.antenna = (enum il3945_antenna)ant;
3412 } else 3412 } else
3413 IL_DEBUG_INFO(priv, "Bad antenna select value %d.\n", ant); 3413 IL_DEBUG_INFO(il, "Bad antenna select value %d.\n", ant);
3414 3414
3415 3415
3416 return count; 3416 return count;
@@ -3421,10 +3421,10 @@ static DEVICE_ATTR(antenna, S_IWUSR | S_IRUGO, il3945_show_antenna, il3945_store
3421static ssize_t il3945_show_status(struct device *d, 3421static ssize_t il3945_show_status(struct device *d,
3422 struct device_attribute *attr, char *buf) 3422 struct device_attribute *attr, char *buf)
3423{ 3423{
3424 struct il_priv *priv = dev_get_drvdata(d); 3424 struct il_priv *il = dev_get_drvdata(d);
3425 if (!il_is_alive(priv)) 3425 if (!il_is_alive(il))
3426 return -EAGAIN; 3426 return -EAGAIN;
3427 return sprintf(buf, "0x%08x\n", (int)priv->status); 3427 return sprintf(buf, "0x%08x\n", (int)il->status);
3428} 3428}
3429 3429
3430static DEVICE_ATTR(status, S_IRUGO, il3945_show_status, NULL); 3430static DEVICE_ATTR(status, S_IRUGO, il3945_show_status, NULL);
@@ -3433,11 +3433,11 @@ static ssize_t il3945_dump_error_log(struct device *d,
3433 struct device_attribute *attr, 3433 struct device_attribute *attr,
3434 const char *buf, size_t count) 3434 const char *buf, size_t count)
3435{ 3435{
3436 struct il_priv *priv = dev_get_drvdata(d); 3436 struct il_priv *il = dev_get_drvdata(d);
3437 char *p = (char *)buf; 3437 char *p = (char *)buf;
3438 3438
3439 if (p[0] == '1') 3439 if (p[0] == '1')
3440 il3945_dump_nic_error_log(priv); 3440 il3945_dump_nic_error_log(il);
3441 3441
3442 return strnlen(buf, count); 3442 return strnlen(buf, count);
3443} 3443}
@@ -3450,38 +3450,38 @@ static DEVICE_ATTR(dump_errors, S_IWUSR, NULL, il3945_dump_error_log);
3450 * 3450 *
3451 *****************************************************************************/ 3451 *****************************************************************************/
3452 3452
3453static void il3945_setup_deferred_work(struct il_priv *priv) 3453static void il3945_setup_deferred_work(struct il_priv *il)
3454{ 3454{
3455 priv->workqueue = create_singlethread_workqueue(DRV_NAME); 3455 il->workqueue = create_singlethread_workqueue(DRV_NAME);
3456 3456
3457 init_waitqueue_head(&priv->wait_command_queue); 3457 init_waitqueue_head(&il->wait_command_queue);
3458 3458
3459 INIT_WORK(&priv->restart, il3945_bg_restart); 3459 INIT_WORK(&il->restart, il3945_bg_restart);
3460 INIT_WORK(&priv->rx_replenish, il3945_bg_rx_replenish); 3460 INIT_WORK(&il->rx_replenish, il3945_bg_rx_replenish);
3461 INIT_DELAYED_WORK(&priv->init_alive_start, il3945_bg_init_alive_start); 3461 INIT_DELAYED_WORK(&il->init_alive_start, il3945_bg_init_alive_start);
3462 INIT_DELAYED_WORK(&priv->alive_start, il3945_bg_alive_start); 3462 INIT_DELAYED_WORK(&il->alive_start, il3945_bg_alive_start);
3463 INIT_DELAYED_WORK(&priv->_3945.rfkill_poll, il3945_rfkill_poll); 3463 INIT_DELAYED_WORK(&il->_3945.rfkill_poll, il3945_rfkill_poll);
3464 3464
3465 il_setup_scan_deferred_work(priv); 3465 il_setup_scan_deferred_work(il);
3466 3466
3467 il3945_hw_setup_deferred_work(priv); 3467 il3945_hw_setup_deferred_work(il);
3468 3468
3469 init_timer(&priv->watchdog); 3469 init_timer(&il->watchdog);
3470 priv->watchdog.data = (unsigned long)priv; 3470 il->watchdog.data = (unsigned long)il;
3471 priv->watchdog.function = il_bg_watchdog; 3471 il->watchdog.function = il_bg_watchdog;
3472 3472
3473 tasklet_init(&priv->irq_tasklet, (void (*)(unsigned long)) 3473 tasklet_init(&il->irq_tasklet, (void (*)(unsigned long))
3474 il3945_irq_tasklet, (unsigned long)priv); 3474 il3945_irq_tasklet, (unsigned long)il);
3475} 3475}
3476 3476
3477static void il3945_cancel_deferred_work(struct il_priv *priv) 3477static void il3945_cancel_deferred_work(struct il_priv *il)
3478{ 3478{
3479 il3945_hw_cancel_deferred_work(priv); 3479 il3945_hw_cancel_deferred_work(il);
3480 3480
3481 cancel_delayed_work_sync(&priv->init_alive_start); 3481 cancel_delayed_work_sync(&il->init_alive_start);
3482 cancel_delayed_work(&priv->alive_start); 3482 cancel_delayed_work(&il->alive_start);
3483 3483
3484 il_cancel_scan_deferred_work(priv); 3484 il_cancel_scan_deferred_work(il);
3485} 3485}
3486 3486
3487static struct attribute *il3945_sysfs_entries[] = { 3487static struct attribute *il3945_sysfs_entries[] = {
@@ -3525,70 +3525,70 @@ struct ieee80211_ops il3945_hw_ops = {
3525 .tx_last_beacon = il_mac_tx_last_beacon, 3525 .tx_last_beacon = il_mac_tx_last_beacon,
3526}; 3526};
3527 3527
3528static int il3945_init_drv(struct il_priv *priv) 3528static int il3945_init_drv(struct il_priv *il)
3529{ 3529{
3530 int ret; 3530 int ret;
3531 struct il3945_eeprom *eeprom = (struct il3945_eeprom *)priv->eeprom; 3531 struct il3945_eeprom *eeprom = (struct il3945_eeprom *)il->eeprom;
3532 3532
3533 priv->retry_rate = 1; 3533 il->retry_rate = 1;
3534 priv->beacon_skb = NULL; 3534 il->beacon_skb = NULL;
3535 3535
3536 spin_lock_init(&priv->sta_lock); 3536 spin_lock_init(&il->sta_lock);
3537 spin_lock_init(&priv->hcmd_lock); 3537 spin_lock_init(&il->hcmd_lock);
3538 3538
3539 INIT_LIST_HEAD(&priv->free_frames); 3539 INIT_LIST_HEAD(&il->free_frames);
3540 3540
3541 mutex_init(&priv->mutex); 3541 mutex_init(&il->mutex);
3542 3542
3543 priv->ieee_channels = NULL; 3543 il->ieee_channels = NULL;
3544 priv->ieee_rates = NULL; 3544 il->ieee_rates = NULL;
3545 priv->band = IEEE80211_BAND_2GHZ; 3545 il->band = IEEE80211_BAND_2GHZ;
3546 3546
3547 priv->iw_mode = NL80211_IFTYPE_STATION; 3547 il->iw_mode = NL80211_IFTYPE_STATION;
3548 priv->missed_beacon_threshold = IL_MISSED_BEACON_THRESHOLD_DEF; 3548 il->missed_beacon_threshold = IL_MISSED_BEACON_THRESHOLD_DEF;
3549 3549
3550 /* initialize force reset */ 3550 /* initialize force reset */
3551 priv->force_reset.reset_duration = IL_DELAY_NEXT_FORCE_FW_RELOAD; 3551 il->force_reset.reset_duration = IL_DELAY_NEXT_FORCE_FW_RELOAD;
3552 3552
3553 if (eeprom->version < EEPROM_3945_EEPROM_VERSION) { 3553 if (eeprom->version < EEPROM_3945_EEPROM_VERSION) {
3554 IL_WARN(priv, "Unsupported EEPROM version: 0x%04X\n", 3554 IL_WARN(il, "Unsupported EEPROM version: 0x%04X\n",
3555 eeprom->version); 3555 eeprom->version);
3556 ret = -EINVAL; 3556 ret = -EINVAL;
3557 goto err; 3557 goto err;
3558 } 3558 }
3559 ret = il_init_channel_map(priv); 3559 ret = il_init_channel_map(il);
3560 if (ret) { 3560 if (ret) {
3561 IL_ERR(priv, "initializing regulatory failed: %d\n", ret); 3561 IL_ERR(il, "initializing regulatory failed: %d\n", ret);
3562 goto err; 3562 goto err;
3563 } 3563 }
3564 3564
3565 /* Set up txpower settings in driver for all channels */ 3565 /* Set up txpower settings in driver for all channels */
3566 if (il3945_txpower_set_from_eeprom(priv)) { 3566 if (il3945_txpower_set_from_eeprom(il)) {
3567 ret = -EIO; 3567 ret = -EIO;
3568 goto err_free_channel_map; 3568 goto err_free_channel_map;
3569 } 3569 }
3570 3570
3571 ret = il_init_geos(priv); 3571 ret = il_init_geos(il);
3572 if (ret) { 3572 if (ret) {
3573 IL_ERR(priv, "initializing geos failed: %d\n", ret); 3573 IL_ERR(il, "initializing geos failed: %d\n", ret);
3574 goto err_free_channel_map; 3574 goto err_free_channel_map;
3575 } 3575 }
3576 il3945_init_hw_rates(priv, priv->ieee_rates); 3576 il3945_init_hw_rates(il, il->ieee_rates);
3577 3577
3578 return 0; 3578 return 0;
3579 3579
3580err_free_channel_map: 3580err_free_channel_map:
3581 il_free_channel_map(priv); 3581 il_free_channel_map(il);
3582err: 3582err:
3583 return ret; 3583 return ret;
3584} 3584}
3585 3585
3586#define IWL3945_MAX_PROBE_REQUEST 200 3586#define IWL3945_MAX_PROBE_REQUEST 200
3587 3587
3588static int il3945_setup_mac(struct il_priv *priv) 3588static int il3945_setup_mac(struct il_priv *il)
3589{ 3589{
3590 int ret; 3590 int ret;
3591 struct ieee80211_hw *hw = priv->hw; 3591 struct ieee80211_hw *hw = il->hw;
3592 3592
3593 hw->rate_control_algorithm = "iwl-3945-rs"; 3593 hw->rate_control_algorithm = "iwl-3945-rs";
3594 hw->sta_data_size = sizeof(struct il3945_sta_priv); 3594 hw->sta_data_size = sizeof(struct il3945_sta_priv);
@@ -3599,7 +3599,7 @@ static int il3945_setup_mac(struct il_priv *priv)
3599 IEEE80211_HW_SPECTRUM_MGMT; 3599 IEEE80211_HW_SPECTRUM_MGMT;
3600 3600
3601 hw->wiphy->interface_modes = 3601 hw->wiphy->interface_modes =
3602 priv->contexts[IL_RXON_CTX_BSS].interface_modes; 3602 il->contexts[IL_RXON_CTX_BSS].interface_modes;
3603 3603
3604 hw->wiphy->flags |= WIPHY_FLAG_CUSTOM_REGULATORY | 3604 hw->wiphy->flags |= WIPHY_FLAG_CUSTOM_REGULATORY |
3605 WIPHY_FLAG_DISABLE_BEACON_HINTS | 3605 WIPHY_FLAG_DISABLE_BEACON_HINTS |
@@ -3612,22 +3612,22 @@ static int il3945_setup_mac(struct il_priv *priv)
3612 /* Default value; 4 EDCA QOS priorities */ 3612 /* Default value; 4 EDCA QOS priorities */
3613 hw->queues = 4; 3613 hw->queues = 4;
3614 3614
3615 if (priv->bands[IEEE80211_BAND_2GHZ].n_channels) 3615 if (il->bands[IEEE80211_BAND_2GHZ].n_channels)
3616 priv->hw->wiphy->bands[IEEE80211_BAND_2GHZ] = 3616 il->hw->wiphy->bands[IEEE80211_BAND_2GHZ] =
3617 &priv->bands[IEEE80211_BAND_2GHZ]; 3617 &il->bands[IEEE80211_BAND_2GHZ];
3618 3618
3619 if (priv->bands[IEEE80211_BAND_5GHZ].n_channels) 3619 if (il->bands[IEEE80211_BAND_5GHZ].n_channels)
3620 priv->hw->wiphy->bands[IEEE80211_BAND_5GHZ] = 3620 il->hw->wiphy->bands[IEEE80211_BAND_5GHZ] =
3621 &priv->bands[IEEE80211_BAND_5GHZ]; 3621 &il->bands[IEEE80211_BAND_5GHZ];
3622 3622
3623 il_leds_init(priv); 3623 il_leds_init(il);
3624 3624
3625 ret = ieee80211_register_hw(priv->hw); 3625 ret = ieee80211_register_hw(il->hw);
3626 if (ret) { 3626 if (ret) {
3627 IL_ERR(priv, "Failed to register hw (error %d)\n", ret); 3627 IL_ERR(il, "Failed to register hw (error %d)\n", ret);
3628 return ret; 3628 return ret;
3629 } 3629 }
3630 priv->mac80211_registered = 1; 3630 il->mac80211_registered = 1;
3631 3631
3632 return 0; 3632 return 0;
3633} 3633}
@@ -3635,7 +3635,7 @@ static int il3945_setup_mac(struct il_priv *priv)
3635static int il3945_pci_probe(struct pci_dev *pdev, const struct pci_device_id *ent) 3635static int il3945_pci_probe(struct pci_dev *pdev, const struct pci_device_id *ent)
3636{ 3636{
3637 int err = 0, i; 3637 int err = 0, i;
3638 struct il_priv *priv; 3638 struct il_priv *il;
3639 struct ieee80211_hw *hw; 3639 struct ieee80211_hw *hw;
3640 struct il_cfg *cfg = (struct il_cfg *)(ent->driver_data); 3640 struct il_cfg *cfg = (struct il_cfg *)(ent->driver_data);
3641 struct il3945_eeprom *eeprom; 3641 struct il3945_eeprom *eeprom;
@@ -3646,53 +3646,53 @@ static int il3945_pci_probe(struct pci_dev *pdev, const struct pci_device_id *en
3646 * ********************/ 3646 * ********************/
3647 3647
3648 /* mac80211 allocates memory for this device instance, including 3648 /* mac80211 allocates memory for this device instance, including
3649 * space for this driver's private structure */ 3649 * space for this driver's ilate structure */
3650 hw = il_alloc_all(cfg); 3650 hw = il_alloc_all(cfg);
3651 if (hw == NULL) { 3651 if (hw == NULL) {
3652 pr_err("Can not allocate network device\n"); 3652 pr_err("Can not allocate network device\n");
3653 err = -ENOMEM; 3653 err = -ENOMEM;
3654 goto out; 3654 goto out;
3655 } 3655 }
3656 priv = hw->priv; 3656 il = hw->priv;
3657 SET_IEEE80211_DEV(hw, &pdev->dev); 3657 SET_IEEE80211_DEV(hw, &pdev->dev);
3658 3658
3659 priv->cmd_queue = IWL39_CMD_QUEUE_NUM; 3659 il->cmd_queue = IWL39_CMD_QUEUE_NUM;
3660 3660
3661 /* 3945 has only one valid context */ 3661 /* 3945 has only one valid context */
3662 priv->valid_contexts = BIT(IL_RXON_CTX_BSS); 3662 il->valid_contexts = BIT(IL_RXON_CTX_BSS);
3663 3663
3664 for (i = 0; i < NUM_IL_RXON_CTX; i++) 3664 for (i = 0; i < NUM_IL_RXON_CTX; i++)
3665 priv->contexts[i].ctxid = i; 3665 il->contexts[i].ctxid = i;
3666 3666
3667 priv->contexts[IL_RXON_CTX_BSS].rxon_cmd = REPLY_RXON; 3667 il->contexts[IL_RXON_CTX_BSS].rxon_cmd = REPLY_RXON;
3668 priv->contexts[IL_RXON_CTX_BSS].rxon_timing_cmd = REPLY_RXON_TIMING; 3668 il->contexts[IL_RXON_CTX_BSS].rxon_timing_cmd = REPLY_RXON_TIMING;
3669 priv->contexts[IL_RXON_CTX_BSS].rxon_assoc_cmd = REPLY_RXON_ASSOC; 3669 il->contexts[IL_RXON_CTX_BSS].rxon_assoc_cmd = REPLY_RXON_ASSOC;
3670 priv->contexts[IL_RXON_CTX_BSS].qos_cmd = REPLY_QOS_PARAM; 3670 il->contexts[IL_RXON_CTX_BSS].qos_cmd = REPLY_QOS_PARAM;
3671 priv->contexts[IL_RXON_CTX_BSS].ap_sta_id = IL_AP_ID; 3671 il->contexts[IL_RXON_CTX_BSS].ap_sta_id = IL_AP_ID;
3672 priv->contexts[IL_RXON_CTX_BSS].wep_key_cmd = REPLY_WEPKEY; 3672 il->contexts[IL_RXON_CTX_BSS].wep_key_cmd = REPLY_WEPKEY;
3673 priv->contexts[IL_RXON_CTX_BSS].interface_modes = 3673 il->contexts[IL_RXON_CTX_BSS].interface_modes =
3674 BIT(NL80211_IFTYPE_STATION) | 3674 BIT(NL80211_IFTYPE_STATION) |
3675 BIT(NL80211_IFTYPE_ADHOC); 3675 BIT(NL80211_IFTYPE_ADHOC);
3676 priv->contexts[IL_RXON_CTX_BSS].ibss_devtype = RXON_DEV_TYPE_IBSS; 3676 il->contexts[IL_RXON_CTX_BSS].ibss_devtype = RXON_DEV_TYPE_IBSS;
3677 priv->contexts[IL_RXON_CTX_BSS].station_devtype = RXON_DEV_TYPE_ESS; 3677 il->contexts[IL_RXON_CTX_BSS].station_devtype = RXON_DEV_TYPE_ESS;
3678 priv->contexts[IL_RXON_CTX_BSS].unused_devtype = RXON_DEV_TYPE_ESS; 3678 il->contexts[IL_RXON_CTX_BSS].unused_devtype = RXON_DEV_TYPE_ESS;
3679 3679
3680 /* 3680 /*
3681 * Disabling hardware scan means that mac80211 will perform scans 3681 * Disabling hardware scan means that mac80211 will perform scans
3682 * "the hard way", rather than using device's scan. 3682 * "the hard way", rather than using device's scan.
3683 */ 3683 */
3684 if (il3945_mod_params.disable_hw_scan) { 3684 if (il3945_mod_params.disable_hw_scan) {
3685 IL_DEBUG_INFO(priv, "Disabling hw_scan\n"); 3685 IL_DEBUG_INFO(il, "Disabling hw_scan\n");
3686 il3945_hw_ops.hw_scan = NULL; 3686 il3945_hw_ops.hw_scan = NULL;
3687 } 3687 }
3688 3688
3689 IL_DEBUG_INFO(priv, "*** LOAD DRIVER ***\n"); 3689 IL_DEBUG_INFO(il, "*** LOAD DRIVER ***\n");
3690 priv->cfg = cfg; 3690 il->cfg = cfg;
3691 priv->pci_dev = pdev; 3691 il->pci_dev = pdev;
3692 priv->inta_mask = CSR_INI_SET_MASK; 3692 il->inta_mask = CSR_INI_SET_MASK;
3693 3693
3694 if (il_alloc_traffic_mem(priv)) 3694 if (il_alloc_traffic_mem(il))
3695 IL_ERR(priv, "Not enough memory to generate traffic log\n"); 3695 IL_ERR(il, "Not enough memory to generate traffic log\n");
3696 3696
3697 /*************************** 3697 /***************************
3698 * 2. Initializing PCI bus 3698 * 2. Initializing PCI bus
@@ -3711,11 +3711,11 @@ static int il3945_pci_probe(struct pci_dev *pdev, const struct pci_device_id *en
3711 if (!err) 3711 if (!err)
3712 err = pci_set_consistent_dma_mask(pdev, DMA_BIT_MASK(32)); 3712 err = pci_set_consistent_dma_mask(pdev, DMA_BIT_MASK(32));
3713 if (err) { 3713 if (err) {
3714 IL_WARN(priv, "No suitable DMA available.\n"); 3714 IL_WARN(il, "No suitable DMA available.\n");
3715 goto out_pci_disable_device; 3715 goto out_pci_disable_device;
3716 } 3716 }
3717 3717
3718 pci_set_drvdata(pdev, priv); 3718 pci_set_drvdata(pdev, il);
3719 err = pci_request_regions(pdev, DRV_NAME); 3719 err = pci_request_regions(pdev, DRV_NAME);
3720 if (err) 3720 if (err)
3721 goto out_pci_disable_device; 3721 goto out_pci_disable_device;
@@ -3723,15 +3723,15 @@ static int il3945_pci_probe(struct pci_dev *pdev, const struct pci_device_id *en
3723 /*********************** 3723 /***********************
3724 * 3. Read REV Register 3724 * 3. Read REV Register
3725 * ********************/ 3725 * ********************/
3726 priv->hw_base = pci_iomap(pdev, 0, 0); 3726 il->hw_base = pci_iomap(pdev, 0, 0);
3727 if (!priv->hw_base) { 3727 if (!il->hw_base) {
3728 err = -ENODEV; 3728 err = -ENODEV;
3729 goto out_pci_release_regions; 3729 goto out_pci_release_regions;
3730 } 3730 }
3731 3731
3732 IL_DEBUG_INFO(priv, "pci_resource_len = 0x%08llx\n", 3732 IL_DEBUG_INFO(il, "pci_resource_len = 0x%08llx\n",
3733 (unsigned long long) pci_resource_len(pdev, 0)); 3733 (unsigned long long) pci_resource_len(pdev, 0));
3734 IL_DEBUG_INFO(priv, "pci_resource_base = %p\n", priv->hw_base); 3734 IL_DEBUG_INFO(il, "pci_resource_base = %p\n", il->hw_base);
3735 3735
3736 /* We disable the RETRY_TIMEOUT register (0x41) to keep 3736 /* We disable the RETRY_TIMEOUT register (0x41) to keep
3737 * PCI Tx retries from interfering with C3 CPU state */ 3737 * PCI Tx retries from interfering with C3 CPU state */
@@ -3740,152 +3740,152 @@ static int il3945_pci_probe(struct pci_dev *pdev, const struct pci_device_id *en
3740 /* these spin locks will be used in apm_ops.init and EEPROM access 3740 /* these spin locks will be used in apm_ops.init and EEPROM access
3741 * we should init now 3741 * we should init now
3742 */ 3742 */
3743 spin_lock_init(&priv->reg_lock); 3743 spin_lock_init(&il->reg_lock);
3744 spin_lock_init(&priv->lock); 3744 spin_lock_init(&il->lock);
3745 3745
3746 /* 3746 /*
3747 * stop and reset the on-board processor just in case it is in a 3747 * stop and reset the on-board processor just in case it is in a
3748 * strange state ... like being left stranded by a primary kernel 3748 * strange state ... like being left stranded by a primary kernel
3749 * and this is now the kdump kernel trying to start up 3749 * and this is now the kdump kernel trying to start up
3750 */ 3750 */
3751 il_write32(priv, CSR_RESET, CSR_RESET_REG_FLAG_NEVO_RESET); 3751 il_write32(il, CSR_RESET, CSR_RESET_REG_FLAG_NEVO_RESET);
3752 3752
3753 /*********************** 3753 /***********************
3754 * 4. Read EEPROM 3754 * 4. Read EEPROM
3755 * ********************/ 3755 * ********************/
3756 3756
3757 /* Read the EEPROM */ 3757 /* Read the EEPROM */
3758 err = il_eeprom_init(priv); 3758 err = il_eeprom_init(il);
3759 if (err) { 3759 if (err) {
3760 IL_ERR(priv, "Unable to init EEPROM\n"); 3760 IL_ERR(il, "Unable to init EEPROM\n");
3761 goto out_iounmap; 3761 goto out_iounmap;
3762 } 3762 }
3763 /* MAC Address location in EEPROM same for 3945/4965 */ 3763 /* MAC Address location in EEPROM same for 3945/4965 */
3764 eeprom = (struct il3945_eeprom *)priv->eeprom; 3764 eeprom = (struct il3945_eeprom *)il->eeprom;
3765 IL_DEBUG_INFO(priv, "MAC address: %pM\n", eeprom->mac_address); 3765 IL_DEBUG_INFO(il, "MAC address: %pM\n", eeprom->mac_address);
3766 SET_IEEE80211_PERM_ADDR(priv->hw, eeprom->mac_address); 3766 SET_IEEE80211_PERM_ADDR(il->hw, eeprom->mac_address);
3767 3767
3768 /*********************** 3768 /***********************
3769 * 5. Setup HW Constants 3769 * 5. Setup HW Constants
3770 * ********************/ 3770 * ********************/
3771 /* Device-specific setup */ 3771 /* Device-specific setup */
3772 if (il3945_hw_set_hw_params(priv)) { 3772 if (il3945_hw_set_hw_params(il)) {
3773 IL_ERR(priv, "failed to set hw settings\n"); 3773 IL_ERR(il, "failed to set hw settings\n");
3774 goto out_eeprom_free; 3774 goto out_eeprom_free;
3775 } 3775 }
3776 3776
3777 /*********************** 3777 /***********************
3778 * 6. Setup priv 3778 * 6. Setup il
3779 * ********************/ 3779 * ********************/
3780 3780
3781 err = il3945_init_drv(priv); 3781 err = il3945_init_drv(il);
3782 if (err) { 3782 if (err) {
3783 IL_ERR(priv, "initializing driver failed\n"); 3783 IL_ERR(il, "initializing driver failed\n");
3784 goto out_unset_hw_params; 3784 goto out_unset_hw_params;
3785 } 3785 }
3786 3786
3787 IL_INFO(priv, "Detected Intel Wireless WiFi Link %s\n", 3787 IL_INFO(il, "Detected Intel Wireless WiFi Link %s\n",
3788 priv->cfg->name); 3788 il->cfg->name);
3789 3789
3790 /*********************** 3790 /***********************
3791 * 7. Setup Services 3791 * 7. Setup Services
3792 * ********************/ 3792 * ********************/
3793 3793
3794 spin_lock_irqsave(&priv->lock, flags); 3794 spin_lock_irqsave(&il->lock, flags);
3795 il_disable_interrupts(priv); 3795 il_disable_interrupts(il);
3796 spin_unlock_irqrestore(&priv->lock, flags); 3796 spin_unlock_irqrestore(&il->lock, flags);
3797 3797
3798 pci_enable_msi(priv->pci_dev); 3798 pci_enable_msi(il->pci_dev);
3799 3799
3800 err = request_irq(priv->pci_dev->irq, il_isr, 3800 err = request_irq(il->pci_dev->irq, il_isr,
3801 IRQF_SHARED, DRV_NAME, priv); 3801 IRQF_SHARED, DRV_NAME, il);
3802 if (err) { 3802 if (err) {
3803 IL_ERR(priv, "Error allocating IRQ %d\n", priv->pci_dev->irq); 3803 IL_ERR(il, "Error allocating IRQ %d\n", il->pci_dev->irq);
3804 goto out_disable_msi; 3804 goto out_disable_msi;
3805 } 3805 }
3806 3806
3807 err = sysfs_create_group(&pdev->dev.kobj, &il3945_attribute_group); 3807 err = sysfs_create_group(&pdev->dev.kobj, &il3945_attribute_group);
3808 if (err) { 3808 if (err) {
3809 IL_ERR(priv, "failed to create sysfs device attributes\n"); 3809 IL_ERR(il, "failed to create sysfs device attributes\n");
3810 goto out_release_irq; 3810 goto out_release_irq;
3811 } 3811 }
3812 3812
3813 il_set_rxon_channel(priv, 3813 il_set_rxon_channel(il,
3814 &priv->bands[IEEE80211_BAND_2GHZ].channels[5], 3814 &il->bands[IEEE80211_BAND_2GHZ].channels[5],
3815 &priv->contexts[IL_RXON_CTX_BSS]); 3815 &il->contexts[IL_RXON_CTX_BSS]);
3816 il3945_setup_deferred_work(priv); 3816 il3945_setup_deferred_work(il);
3817 il3945_setup_rx_handlers(priv); 3817 il3945_setup_rx_handlers(il);
3818 il_power_initialize(priv); 3818 il_power_initialize(il);
3819 3819
3820 /********************************* 3820 /*********************************
3821 * 8. Setup and Register mac80211 3821 * 8. Setup and Register mac80211
3822 * *******************************/ 3822 * *******************************/
3823 3823
3824 il_enable_interrupts(priv); 3824 il_enable_interrupts(il);
3825 3825
3826 err = il3945_setup_mac(priv); 3826 err = il3945_setup_mac(il);
3827 if (err) 3827 if (err)
3828 goto out_remove_sysfs; 3828 goto out_remove_sysfs;
3829 3829
3830 err = il_dbgfs_register(priv, DRV_NAME); 3830 err = il_dbgfs_register(il, DRV_NAME);
3831 if (err) 3831 if (err)
3832 IL_ERR(priv, "failed to create debugfs files. Ignoring error: %d\n", err); 3832 IL_ERR(il, "failed to create debugfs files. Ignoring error: %d\n", err);
3833 3833
3834 /* Start monitoring the killswitch */ 3834 /* Start monitoring the killswitch */
3835 queue_delayed_work(priv->workqueue, &priv->_3945.rfkill_poll, 3835 queue_delayed_work(il->workqueue, &il->_3945.rfkill_poll,
3836 2 * HZ); 3836 2 * HZ);
3837 3837
3838 return 0; 3838 return 0;
3839 3839
3840 out_remove_sysfs: 3840 out_remove_sysfs:
3841 destroy_workqueue(priv->workqueue); 3841 destroy_workqueue(il->workqueue);
3842 priv->workqueue = NULL; 3842 il->workqueue = NULL;
3843 sysfs_remove_group(&pdev->dev.kobj, &il3945_attribute_group); 3843 sysfs_remove_group(&pdev->dev.kobj, &il3945_attribute_group);
3844 out_release_irq: 3844 out_release_irq:
3845 free_irq(priv->pci_dev->irq, priv); 3845 free_irq(il->pci_dev->irq, il);
3846 out_disable_msi: 3846 out_disable_msi:
3847 pci_disable_msi(priv->pci_dev); 3847 pci_disable_msi(il->pci_dev);
3848 il_free_geos(priv); 3848 il_free_geos(il);
3849 il_free_channel_map(priv); 3849 il_free_channel_map(il);
3850 out_unset_hw_params: 3850 out_unset_hw_params:
3851 il3945_unset_hw_params(priv); 3851 il3945_unset_hw_params(il);
3852 out_eeprom_free: 3852 out_eeprom_free:
3853 il_eeprom_free(priv); 3853 il_eeprom_free(il);
3854 out_iounmap: 3854 out_iounmap:
3855 pci_iounmap(pdev, priv->hw_base); 3855 pci_iounmap(pdev, il->hw_base);
3856 out_pci_release_regions: 3856 out_pci_release_regions:
3857 pci_release_regions(pdev); 3857 pci_release_regions(pdev);
3858 out_pci_disable_device: 3858 out_pci_disable_device:
3859 pci_set_drvdata(pdev, NULL); 3859 pci_set_drvdata(pdev, NULL);
3860 pci_disable_device(pdev); 3860 pci_disable_device(pdev);
3861 out_ieee80211_free_hw: 3861 out_ieee80211_free_hw:
3862 il_free_traffic_mem(priv); 3862 il_free_traffic_mem(il);
3863 ieee80211_free_hw(priv->hw); 3863 ieee80211_free_hw(il->hw);
3864 out: 3864 out:
3865 return err; 3865 return err;
3866} 3866}
3867 3867
3868static void __devexit il3945_pci_remove(struct pci_dev *pdev) 3868static void __devexit il3945_pci_remove(struct pci_dev *pdev)
3869{ 3869{
3870 struct il_priv *priv = pci_get_drvdata(pdev); 3870 struct il_priv *il = pci_get_drvdata(pdev);
3871 unsigned long flags; 3871 unsigned long flags;
3872 3872
3873 if (!priv) 3873 if (!il)
3874 return; 3874 return;
3875 3875
3876 IL_DEBUG_INFO(priv, "*** UNLOAD DRIVER ***\n"); 3876 IL_DEBUG_INFO(il, "*** UNLOAD DRIVER ***\n");
3877 3877
3878 il_dbgfs_unregister(priv); 3878 il_dbgfs_unregister(il);
3879 3879
3880 set_bit(STATUS_EXIT_PENDING, &priv->status); 3880 set_bit(STATUS_EXIT_PENDING, &il->status);
3881 3881
3882 il_leds_exit(priv); 3882 il_leds_exit(il);
3883 3883
3884 if (priv->mac80211_registered) { 3884 if (il->mac80211_registered) {
3885 ieee80211_unregister_hw(priv->hw); 3885 ieee80211_unregister_hw(il->hw);
3886 priv->mac80211_registered = 0; 3886 il->mac80211_registered = 0;
3887 } else { 3887 } else {
3888 il3945_down(priv); 3888 il3945_down(il);
3889 } 3889 }
3890 3890
3891 /* 3891 /*
@@ -3895,54 +3895,54 @@ static void __devexit il3945_pci_remove(struct pci_dev *pdev)
3895 * paths to avoid running il_down() at all before leaving driver. 3895 * paths to avoid running il_down() at all before leaving driver.
3896 * This (inexpensive) call *makes sure* device is reset. 3896 * This (inexpensive) call *makes sure* device is reset.
3897 */ 3897 */
3898 il_apm_stop(priv); 3898 il_apm_stop(il);
3899 3899
3900 /* make sure we flush any pending irq or 3900 /* make sure we flush any pending irq or
3901 * tasklet for the driver 3901 * tasklet for the driver
3902 */ 3902 */
3903 spin_lock_irqsave(&priv->lock, flags); 3903 spin_lock_irqsave(&il->lock, flags);
3904 il_disable_interrupts(priv); 3904 il_disable_interrupts(il);
3905 spin_unlock_irqrestore(&priv->lock, flags); 3905 spin_unlock_irqrestore(&il->lock, flags);
3906 3906
3907 il3945_synchronize_irq(priv); 3907 il3945_synchronize_irq(il);
3908 3908
3909 sysfs_remove_group(&pdev->dev.kobj, &il3945_attribute_group); 3909 sysfs_remove_group(&pdev->dev.kobj, &il3945_attribute_group);
3910 3910
3911 cancel_delayed_work_sync(&priv->_3945.rfkill_poll); 3911 cancel_delayed_work_sync(&il->_3945.rfkill_poll);
3912 3912
3913 il3945_dealloc_ucode_pci(priv); 3913 il3945_dealloc_ucode_pci(il);
3914 3914
3915 if (priv->rxq.bd) 3915 if (il->rxq.bd)
3916 il3945_rx_queue_free(priv, &priv->rxq); 3916 il3945_rx_queue_free(il, &il->rxq);
3917 il3945_hw_txq_ctx_free(priv); 3917 il3945_hw_txq_ctx_free(il);
3918 3918
3919 il3945_unset_hw_params(priv); 3919 il3945_unset_hw_params(il);
3920 3920
3921 /*netif_stop_queue(dev); */ 3921 /*netif_stop_queue(dev); */
3922 flush_workqueue(priv->workqueue); 3922 flush_workqueue(il->workqueue);
3923 3923
3924 /* ieee80211_unregister_hw calls il3945_mac_stop, which flushes 3924 /* ieee80211_unregister_hw calls il3945_mac_stop, which flushes
3925 * priv->workqueue... so we can't take down the workqueue 3925 * il->workqueue... so we can't take down the workqueue
3926 * until now... */ 3926 * until now... */
3927 destroy_workqueue(priv->workqueue); 3927 destroy_workqueue(il->workqueue);
3928 priv->workqueue = NULL; 3928 il->workqueue = NULL;
3929 il_free_traffic_mem(priv); 3929 il_free_traffic_mem(il);
3930 3930
3931 free_irq(pdev->irq, priv); 3931 free_irq(pdev->irq, il);
3932 pci_disable_msi(pdev); 3932 pci_disable_msi(pdev);
3933 3933
3934 pci_iounmap(pdev, priv->hw_base); 3934 pci_iounmap(pdev, il->hw_base);
3935 pci_release_regions(pdev); 3935 pci_release_regions(pdev);
3936 pci_disable_device(pdev); 3936 pci_disable_device(pdev);
3937 pci_set_drvdata(pdev, NULL); 3937 pci_set_drvdata(pdev, NULL);
3938 3938
3939 il_free_channel_map(priv); 3939 il_free_channel_map(il);
3940 il_free_geos(priv); 3940 il_free_geos(il);
3941 kfree(priv->scan_cmd); 3941 kfree(il->scan_cmd);
3942 if (priv->beacon_skb) 3942 if (il->beacon_skb)
3943 dev_kfree_skb(priv->beacon_skb); 3943 dev_kfree_skb(il->beacon_skb);
3944 3944
3945 ieee80211_free_hw(priv->hw); 3945 ieee80211_free_hw(il->hw);
3946} 3946}
3947 3947
3948 3948
diff --git a/drivers/net/wireless/iwlegacy/iwl4965-base.c b/drivers/net/wireless/iwlegacy/iwl4965-base.c
index bd37c9226e65..ae8a93751561 100644
--- a/drivers/net/wireless/iwlegacy/iwl4965-base.c
+++ b/drivers/net/wireless/iwlegacy/iwl4965-base.c
@@ -87,85 +87,85 @@ MODULE_AUTHOR(DRV_COPYRIGHT " " DRV_AUTHOR);
87MODULE_LICENSE("GPL"); 87MODULE_LICENSE("GPL");
88MODULE_ALIAS("iwl4965"); 88MODULE_ALIAS("iwl4965");
89 89
90void il4965_update_chain_flags(struct il_priv *priv) 90void il4965_update_chain_flags(struct il_priv *il)
91{ 91{
92 struct il_rxon_context *ctx; 92 struct il_rxon_context *ctx;
93 93
94 if (priv->cfg->ops->hcmd->set_rxon_chain) { 94 if (il->cfg->ops->hcmd->set_rxon_chain) {
95 for_each_context(priv, ctx) { 95 for_each_context(il, ctx) {
96 priv->cfg->ops->hcmd->set_rxon_chain(priv, ctx); 96 il->cfg->ops->hcmd->set_rxon_chain(il, ctx);
97 if (ctx->active.rx_chain != ctx->staging.rx_chain) 97 if (ctx->active.rx_chain != ctx->staging.rx_chain)
98 il_commit_rxon(priv, ctx); 98 il_commit_rxon(il, ctx);
99 } 99 }
100 } 100 }
101} 101}
102 102
103static void il4965_clear_free_frames(struct il_priv *priv) 103static void il4965_clear_free_frames(struct il_priv *il)
104{ 104{
105 struct list_head *element; 105 struct list_head *element;
106 106
107 IL_DEBUG_INFO(priv, "%d frames on pre-allocated heap on clear.\n", 107 IL_DEBUG_INFO(il, "%d frames on pre-allocated heap on clear.\n",
108 priv->frames_count); 108 il->frames_count);
109 109
110 while (!list_empty(&priv->free_frames)) { 110 while (!list_empty(&il->free_frames)) {
111 element = priv->free_frames.next; 111 element = il->free_frames.next;
112 list_del(element); 112 list_del(element);
113 kfree(list_entry(element, struct il_frame, list)); 113 kfree(list_entry(element, struct il_frame, list));
114 priv->frames_count--; 114 il->frames_count--;
115 } 115 }
116 116
117 if (priv->frames_count) { 117 if (il->frames_count) {
118 IL_WARN(priv, "%d frames still in use. Did we lose one?\n", 118 IL_WARN(il, "%d frames still in use. Did we lose one?\n",
119 priv->frames_count); 119 il->frames_count);
120 priv->frames_count = 0; 120 il->frames_count = 0;
121 } 121 }
122} 122}
123 123
124static struct il_frame *il4965_get_free_frame(struct il_priv *priv) 124static struct il_frame *il4965_get_free_frame(struct il_priv *il)
125{ 125{
126 struct il_frame *frame; 126 struct il_frame *frame;
127 struct list_head *element; 127 struct list_head *element;
128 if (list_empty(&priv->free_frames)) { 128 if (list_empty(&il->free_frames)) {
129 frame = kzalloc(sizeof(*frame), GFP_KERNEL); 129 frame = kzalloc(sizeof(*frame), GFP_KERNEL);
130 if (!frame) { 130 if (!frame) {
131 IL_ERR(priv, "Could not allocate frame!\n"); 131 IL_ERR(il, "Could not allocate frame!\n");
132 return NULL; 132 return NULL;
133 } 133 }
134 134
135 priv->frames_count++; 135 il->frames_count++;
136 return frame; 136 return frame;
137 } 137 }
138 138
139 element = priv->free_frames.next; 139 element = il->free_frames.next;
140 list_del(element); 140 list_del(element);
141 return list_entry(element, struct il_frame, list); 141 return list_entry(element, struct il_frame, list);
142} 142}
143 143
144static void il4965_free_frame(struct il_priv *priv, struct il_frame *frame) 144static void il4965_free_frame(struct il_priv *il, struct il_frame *frame)
145{ 145{
146 memset(frame, 0, sizeof(*frame)); 146 memset(frame, 0, sizeof(*frame));
147 list_add(&frame->list, &priv->free_frames); 147 list_add(&frame->list, &il->free_frames);
148} 148}
149 149
150static u32 il4965_fill_beacon_frame(struct il_priv *priv, 150static u32 il4965_fill_beacon_frame(struct il_priv *il,
151 struct ieee80211_hdr *hdr, 151 struct ieee80211_hdr *hdr,
152 int left) 152 int left)
153{ 153{
154 lockdep_assert_held(&priv->mutex); 154 lockdep_assert_held(&il->mutex);
155 155
156 if (!priv->beacon_skb) 156 if (!il->beacon_skb)
157 return 0; 157 return 0;
158 158
159 if (priv->beacon_skb->len > left) 159 if (il->beacon_skb->len > left)
160 return 0; 160 return 0;
161 161
162 memcpy(hdr, priv->beacon_skb->data, priv->beacon_skb->len); 162 memcpy(hdr, il->beacon_skb->data, il->beacon_skb->len);
163 163
164 return priv->beacon_skb->len; 164 return il->beacon_skb->len;
165} 165}
166 166
167/* Parse the beacon frame to find the TIM element and set tim_idx & tim_size */ 167/* Parse the beacon frame to find the TIM element and set tim_idx & tim_size */
168static void il4965_set_beacon_tim(struct il_priv *priv, 168static void il4965_set_beacon_tim(struct il_priv *il,
169 struct il_tx_beacon_cmd *tx_beacon_cmd, 169 struct il_tx_beacon_cmd *tx_beacon_cmd,
170 u8 *beacon, u32 frame_size) 170 u8 *beacon, u32 frame_size)
171{ 171{
@@ -188,10 +188,10 @@ static void il4965_set_beacon_tim(struct il_priv *priv,
188 tx_beacon_cmd->tim_idx = cpu_to_le16(tim_idx); 188 tx_beacon_cmd->tim_idx = cpu_to_le16(tim_idx);
189 tx_beacon_cmd->tim_size = beacon[tim_idx+1]; 189 tx_beacon_cmd->tim_size = beacon[tim_idx+1];
190 } else 190 } else
191 IL_WARN(priv, "Unable to find TIM Element in beacon\n"); 191 IL_WARN(il, "Unable to find TIM Element in beacon\n");
192} 192}
193 193
194static unsigned int il4965_hw_get_beacon_cmd(struct il_priv *priv, 194static unsigned int il4965_hw_get_beacon_cmd(struct il_priv *il,
195 struct il_frame *frame) 195 struct il_frame *frame)
196{ 196{
197 struct il_tx_beacon_cmd *tx_beacon_cmd; 197 struct il_tx_beacon_cmd *tx_beacon_cmd;
@@ -203,10 +203,10 @@ static unsigned int il4965_hw_get_beacon_cmd(struct il_priv *priv,
203 * beacon contents. 203 * beacon contents.
204 */ 204 */
205 205
206 lockdep_assert_held(&priv->mutex); 206 lockdep_assert_held(&il->mutex);
207 207
208 if (!priv->beacon_ctx) { 208 if (!il->beacon_ctx) {
209 IL_ERR(priv, "trying to build beacon w/o beacon context!\n"); 209 IL_ERR(il, "trying to build beacon w/o beacon context!\n");
210 return 0; 210 return 0;
211 } 211 }
212 212
@@ -215,7 +215,7 @@ static unsigned int il4965_hw_get_beacon_cmd(struct il_priv *priv,
215 memset(tx_beacon_cmd, 0, sizeof(*tx_beacon_cmd)); 215 memset(tx_beacon_cmd, 0, sizeof(*tx_beacon_cmd));
216 216
217 /* Set up TX beacon contents */ 217 /* Set up TX beacon contents */
218 frame_size = il4965_fill_beacon_frame(priv, tx_beacon_cmd->frame, 218 frame_size = il4965_fill_beacon_frame(il, tx_beacon_cmd->frame,
219 sizeof(frame->u) - sizeof(*tx_beacon_cmd)); 219 sizeof(frame->u) - sizeof(*tx_beacon_cmd));
220 if (WARN_ON_ONCE(frame_size > MAX_MPDU_SIZE)) 220 if (WARN_ON_ONCE(frame_size > MAX_MPDU_SIZE))
221 return 0; 221 return 0;
@@ -224,20 +224,20 @@ static unsigned int il4965_hw_get_beacon_cmd(struct il_priv *priv,
224 224
225 /* Set up TX command fields */ 225 /* Set up TX command fields */
226 tx_beacon_cmd->tx.len = cpu_to_le16((u16)frame_size); 226 tx_beacon_cmd->tx.len = cpu_to_le16((u16)frame_size);
227 tx_beacon_cmd->tx.sta_id = priv->beacon_ctx->bcast_sta_id; 227 tx_beacon_cmd->tx.sta_id = il->beacon_ctx->bcast_sta_id;
228 tx_beacon_cmd->tx.stop_time.life_time = TX_CMD_LIFE_TIME_INFINITE; 228 tx_beacon_cmd->tx.stop_time.life_time = TX_CMD_LIFE_TIME_INFINITE;
229 tx_beacon_cmd->tx.tx_flags = TX_CMD_FLG_SEQ_CTL_MSK | 229 tx_beacon_cmd->tx.tx_flags = TX_CMD_FLG_SEQ_CTL_MSK |
230 TX_CMD_FLG_TSF_MSK | TX_CMD_FLG_STA_RATE_MSK; 230 TX_CMD_FLG_TSF_MSK | TX_CMD_FLG_STA_RATE_MSK;
231 231
232 /* Set up TX beacon command fields */ 232 /* Set up TX beacon command fields */
233 il4965_set_beacon_tim(priv, tx_beacon_cmd, (u8 *)tx_beacon_cmd->frame, 233 il4965_set_beacon_tim(il, tx_beacon_cmd, (u8 *)tx_beacon_cmd->frame,
234 frame_size); 234 frame_size);
235 235
236 /* Set up packet rate and flags */ 236 /* Set up packet rate and flags */
237 rate = il_get_lowest_plcp(priv, priv->beacon_ctx); 237 rate = il_get_lowest_plcp(il, il->beacon_ctx);
238 priv->mgmt_tx_ant = il4965_toggle_tx_ant(priv, priv->mgmt_tx_ant, 238 il->mgmt_tx_ant = il4965_toggle_tx_ant(il, il->mgmt_tx_ant,
239 priv->hw_params.valid_tx_ant); 239 il->hw_params.valid_tx_ant);
240 rate_flags = il4965_ant_idx_to_flags(priv->mgmt_tx_ant); 240 rate_flags = il4965_ant_idx_to_flags(il->mgmt_tx_ant);
241 if ((rate >= IL_FIRST_CCK_RATE) && (rate <= IL_LAST_CCK_RATE)) 241 if ((rate >= IL_FIRST_CCK_RATE) && (rate <= IL_LAST_CCK_RATE))
242 rate_flags |= RATE_MCS_CCK_MSK; 242 rate_flags |= RATE_MCS_CCK_MSK;
243 tx_beacon_cmd->tx.rate_n_flags = il4965_hw_set_rate_n_flags(rate, 243 tx_beacon_cmd->tx.rate_n_flags = il4965_hw_set_rate_n_flags(rate,
@@ -246,30 +246,30 @@ static unsigned int il4965_hw_get_beacon_cmd(struct il_priv *priv,
246 return sizeof(*tx_beacon_cmd) + frame_size; 246 return sizeof(*tx_beacon_cmd) + frame_size;
247} 247}
248 248
249int il4965_send_beacon_cmd(struct il_priv *priv) 249int il4965_send_beacon_cmd(struct il_priv *il)
250{ 250{
251 struct il_frame *frame; 251 struct il_frame *frame;
252 unsigned int frame_size; 252 unsigned int frame_size;
253 int rc; 253 int rc;
254 254
255 frame = il4965_get_free_frame(priv); 255 frame = il4965_get_free_frame(il);
256 if (!frame) { 256 if (!frame) {
257 IL_ERR(priv, "Could not obtain free frame buffer for beacon " 257 IL_ERR(il, "Could not obtain free frame buffer for beacon "
258 "command.\n"); 258 "command.\n");
259 return -ENOMEM; 259 return -ENOMEM;
260 } 260 }
261 261
262 frame_size = il4965_hw_get_beacon_cmd(priv, frame); 262 frame_size = il4965_hw_get_beacon_cmd(il, frame);
263 if (!frame_size) { 263 if (!frame_size) {
264 IL_ERR(priv, "Error configuring the beacon command\n"); 264 IL_ERR(il, "Error configuring the beacon command\n");
265 il4965_free_frame(priv, frame); 265 il4965_free_frame(il, frame);
266 return -EINVAL; 266 return -EINVAL;
267 } 267 }
268 268
269 rc = il_send_cmd_pdu(priv, REPLY_TX_BEACON, frame_size, 269 rc = il_send_cmd_pdu(il, REPLY_TX_BEACON, frame_size,
270 &frame->u.cmd[0]); 270 &frame->u.cmd[0]);
271 271
272 il4965_free_frame(priv, frame); 272 il4965_free_frame(il, frame);
273 273
274 return rc; 274 return rc;
275} 275}
@@ -315,17 +315,17 @@ static inline u8 il4965_tfd_get_num_tbs(struct il_tfd *tfd)
315 315
316/** 316/**
317 * il4965_hw_txq_free_tfd - Free all chunks referenced by TFD [txq->q.read_ptr] 317 * il4965_hw_txq_free_tfd - Free all chunks referenced by TFD [txq->q.read_ptr]
318 * @priv - driver private data 318 * @il - driver ilate data
319 * @txq - tx queue 319 * @txq - tx queue
320 * 320 *
321 * Does NOT advance any TFD circular buffer read/write indexes 321 * Does NOT advance any TFD circular buffer read/write indexes
322 * Does NOT free the TFD itself (which is within circular buffer) 322 * Does NOT free the TFD itself (which is within circular buffer)
323 */ 323 */
324void il4965_hw_txq_free_tfd(struct il_priv *priv, struct il_tx_queue *txq) 324void il4965_hw_txq_free_tfd(struct il_priv *il, struct il_tx_queue *txq)
325{ 325{
326 struct il_tfd *tfd_tmp = (struct il_tfd *)txq->tfds; 326 struct il_tfd *tfd_tmp = (struct il_tfd *)txq->tfds;
327 struct il_tfd *tfd; 327 struct il_tfd *tfd;
328 struct pci_dev *dev = priv->pci_dev; 328 struct pci_dev *dev = il->pci_dev;
329 int index = txq->q.read_ptr; 329 int index = txq->q.read_ptr;
330 int i; 330 int i;
331 int num_tbs; 331 int num_tbs;
@@ -336,7 +336,7 @@ void il4965_hw_txq_free_tfd(struct il_priv *priv, struct il_tx_queue *txq)
336 num_tbs = il4965_tfd_get_num_tbs(tfd); 336 num_tbs = il4965_tfd_get_num_tbs(tfd);
337 337
338 if (num_tbs >= IL_NUM_OF_TBS) { 338 if (num_tbs >= IL_NUM_OF_TBS) {
339 IL_ERR(priv, "Too many chunks: %i\n", num_tbs); 339 IL_ERR(il, "Too many chunks: %i\n", num_tbs);
340 /* @todo issue fatal error, it is quite serious situation */ 340 /* @todo issue fatal error, it is quite serious situation */
341 return; 341 return;
342 } 342 }
@@ -368,7 +368,7 @@ void il4965_hw_txq_free_tfd(struct il_priv *priv, struct il_tx_queue *txq)
368 } 368 }
369} 369}
370 370
371int il4965_hw_txq_attach_buf_to_tfd(struct il_priv *priv, 371int il4965_hw_txq_attach_buf_to_tfd(struct il_priv *il,
372 struct il_tx_queue *txq, 372 struct il_tx_queue *txq,
373 dma_addr_t addr, u16 len, 373 dma_addr_t addr, u16 len,
374 u8 reset, u8 pad) 374 u8 reset, u8 pad)
@@ -388,14 +388,14 @@ int il4965_hw_txq_attach_buf_to_tfd(struct il_priv *priv,
388 388
389 /* Each TFD can point to a maximum 20 Tx buffers */ 389 /* Each TFD can point to a maximum 20 Tx buffers */
390 if (num_tbs >= IL_NUM_OF_TBS) { 390 if (num_tbs >= IL_NUM_OF_TBS) {
391 IL_ERR(priv, "Error can not send more than %d chunks\n", 391 IL_ERR(il, "Error can not send more than %d chunks\n",
392 IL_NUM_OF_TBS); 392 IL_NUM_OF_TBS);
393 return -EINVAL; 393 return -EINVAL;
394 } 394 }
395 395
396 BUG_ON(addr & ~DMA_BIT_MASK(36)); 396 BUG_ON(addr & ~DMA_BIT_MASK(36));
397 if (unlikely(addr & ~IL_TX_DMA_MASK)) 397 if (unlikely(addr & ~IL_TX_DMA_MASK))
398 IL_ERR(priv, "Unaligned address = %llx\n", 398 IL_ERR(il, "Unaligned address = %llx\n",
399 (unsigned long long)addr); 399 (unsigned long long)addr);
400 400
401 il4965_tfd_set_tb(tfd, num_tbs, addr, len); 401 il4965_tfd_set_tb(tfd, num_tbs, addr, len);
@@ -410,13 +410,13 @@ int il4965_hw_txq_attach_buf_to_tfd(struct il_priv *priv,
410 * 4965 supports up to 16 Tx queues in DRAM, mapped to up to 8 Tx DMA 410 * 4965 supports up to 16 Tx queues in DRAM, mapped to up to 8 Tx DMA
411 * channels supported in hardware. 411 * channels supported in hardware.
412 */ 412 */
413int il4965_hw_tx_queue_init(struct il_priv *priv, 413int il4965_hw_tx_queue_init(struct il_priv *il,
414 struct il_tx_queue *txq) 414 struct il_tx_queue *txq)
415{ 415{
416 int txq_id = txq->q.id; 416 int txq_id = txq->q.id;
417 417
418 /* Circular buffer (TFD queue in DRAM) physical base address */ 418 /* Circular buffer (TFD queue in DRAM) physical base address */
419 il_write_direct32(priv, FH_MEM_CBBC_QUEUE(txq_id), 419 il_write_direct32(il, FH_MEM_CBBC_QUEUE(txq_id),
420 txq->q.dma_addr >> 8); 420 txq->q.dma_addr >> 8);
421 421
422 return 0; 422 return 0;
@@ -427,7 +427,7 @@ int il4965_hw_tx_queue_init(struct il_priv *priv,
427 * Generic RX handler implementations 427 * Generic RX handler implementations
428 * 428 *
429 ******************************************************************************/ 429 ******************************************************************************/
430static void il4965_rx_reply_alive(struct il_priv *priv, 430static void il4965_rx_reply_alive(struct il_priv *il,
431 struct il_rx_mem_buffer *rxb) 431 struct il_rx_mem_buffer *rxb)
432{ 432{
433 struct il_rx_packet *pkt = rxb_addr(rxb); 433 struct il_rx_packet *pkt = rxb_addr(rxb);
@@ -436,31 +436,31 @@ static void il4965_rx_reply_alive(struct il_priv *priv,
436 436
437 palive = &pkt->u.alive_frame; 437 palive = &pkt->u.alive_frame;
438 438
439 IL_DEBUG_INFO(priv, "Alive ucode status 0x%08X revision " 439 IL_DEBUG_INFO(il, "Alive ucode status 0x%08X revision "
440 "0x%01X 0x%01X\n", 440 "0x%01X 0x%01X\n",
441 palive->is_valid, palive->ver_type, 441 palive->is_valid, palive->ver_type,
442 palive->ver_subtype); 442 palive->ver_subtype);
443 443
444 if (palive->ver_subtype == INITIALIZE_SUBTYPE) { 444 if (palive->ver_subtype == INITIALIZE_SUBTYPE) {
445 IL_DEBUG_INFO(priv, "Initialization Alive received.\n"); 445 IL_DEBUG_INFO(il, "Initialization Alive received.\n");
446 memcpy(&priv->card_alive_init, 446 memcpy(&il->card_alive_init,
447 &pkt->u.alive_frame, 447 &pkt->u.alive_frame,
448 sizeof(struct il_init_alive_resp)); 448 sizeof(struct il_init_alive_resp));
449 pwork = &priv->init_alive_start; 449 pwork = &il->init_alive_start;
450 } else { 450 } else {
451 IL_DEBUG_INFO(priv, "Runtime Alive received.\n"); 451 IL_DEBUG_INFO(il, "Runtime Alive received.\n");
452 memcpy(&priv->card_alive, &pkt->u.alive_frame, 452 memcpy(&il->card_alive, &pkt->u.alive_frame,
453 sizeof(struct il_alive_resp)); 453 sizeof(struct il_alive_resp));
454 pwork = &priv->alive_start; 454 pwork = &il->alive_start;
455 } 455 }
456 456
457 /* We delay the ALIVE response by 5ms to 457 /* We delay the ALIVE response by 5ms to
458 * give the HW RF Kill time to activate... */ 458 * give the HW RF Kill time to activate... */
459 if (palive->is_valid == UCODE_VALID_OK) 459 if (palive->is_valid == UCODE_VALID_OK)
460 queue_delayed_work(priv->workqueue, pwork, 460 queue_delayed_work(il->workqueue, pwork,
461 msecs_to_jiffies(5)); 461 msecs_to_jiffies(5));
462 else 462 else
463 IL_WARN(priv, "uCode did not respond OK.\n"); 463 IL_WARN(il, "uCode did not respond OK.\n");
464} 464}
465 465
466/** 466/**
@@ -475,19 +475,19 @@ static void il4965_rx_reply_alive(struct il_priv *priv,
475 */ 475 */
476static void il4965_bg_statistics_periodic(unsigned long data) 476static void il4965_bg_statistics_periodic(unsigned long data)
477{ 477{
478 struct il_priv *priv = (struct il_priv *)data; 478 struct il_priv *il = (struct il_priv *)data;
479 479
480 if (test_bit(STATUS_EXIT_PENDING, &priv->status)) 480 if (test_bit(STATUS_EXIT_PENDING, &il->status))
481 return; 481 return;
482 482
483 /* dont send host command if rf-kill is on */ 483 /* dont send host command if rf-kill is on */
484 if (!il_is_ready_rf(priv)) 484 if (!il_is_ready_rf(il))
485 return; 485 return;
486 486
487 il_send_statistics_request(priv, CMD_ASYNC, false); 487 il_send_statistics_request(il, CMD_ASYNC, false);
488} 488}
489 489
490static void il4965_rx_beacon_notif(struct il_priv *priv, 490static void il4965_rx_beacon_notif(struct il_priv *il,
491 struct il_rx_mem_buffer *rxb) 491 struct il_rx_mem_buffer *rxb)
492{ 492{
493 struct il_rx_packet *pkt = rxb_addr(rxb); 493 struct il_rx_packet *pkt = rxb_addr(rxb);
@@ -496,7 +496,7 @@ static void il4965_rx_beacon_notif(struct il_priv *priv,
496#ifdef CONFIG_IWLWIFI_LEGACY_DEBUG 496#ifdef CONFIG_IWLWIFI_LEGACY_DEBUG
497 u8 rate = il4965_hw_get_rate(beacon->beacon_notify_hdr.rate_n_flags); 497 u8 rate = il4965_hw_get_rate(beacon->beacon_notify_hdr.rate_n_flags);
498 498
499 IL_DEBUG_RX(priv, "beacon status %x retries %d iss %d " 499 IL_DEBUG_RX(il, "beacon status %x retries %d iss %d "
500 "tsf %d %d rate %d\n", 500 "tsf %d %d rate %d\n",
501 le32_to_cpu(beacon->beacon_notify_hdr.u.status) & TX_STATUS_MSK, 501 le32_to_cpu(beacon->beacon_notify_hdr.u.status) & TX_STATUS_MSK,
502 beacon->beacon_notify_hdr.failure_frame, 502 beacon->beacon_notify_hdr.failure_frame,
@@ -505,38 +505,38 @@ static void il4965_rx_beacon_notif(struct il_priv *priv,
505 le32_to_cpu(beacon->low_tsf), rate); 505 le32_to_cpu(beacon->low_tsf), rate);
506#endif 506#endif
507 507
508 priv->ibss_manager = le32_to_cpu(beacon->ibss_mgr_status); 508 il->ibss_manager = le32_to_cpu(beacon->ibss_mgr_status);
509} 509}
510 510
511static void il4965_perform_ct_kill_task(struct il_priv *priv) 511static void il4965_perform_ct_kill_task(struct il_priv *il)
512{ 512{
513 unsigned long flags; 513 unsigned long flags;
514 514
515 IL_DEBUG_POWER(priv, "Stop all queues\n"); 515 IL_DEBUG_POWER(il, "Stop all queues\n");
516 516
517 if (priv->mac80211_registered) 517 if (il->mac80211_registered)
518 ieee80211_stop_queues(priv->hw); 518 ieee80211_stop_queues(il->hw);
519 519
520 il_write32(priv, CSR_UCODE_DRV_GP1_SET, 520 il_write32(il, CSR_UCODE_DRV_GP1_SET,
521 CSR_UCODE_DRV_GP1_REG_BIT_CT_KILL_EXIT); 521 CSR_UCODE_DRV_GP1_REG_BIT_CT_KILL_EXIT);
522 il_read32(priv, CSR_UCODE_DRV_GP1); 522 il_read32(il, CSR_UCODE_DRV_GP1);
523 523
524 spin_lock_irqsave(&priv->reg_lock, flags); 524 spin_lock_irqsave(&il->reg_lock, flags);
525 if (!il_grab_nic_access(priv)) 525 if (!il_grab_nic_access(il))
526 il_release_nic_access(priv); 526 il_release_nic_access(il);
527 spin_unlock_irqrestore(&priv->reg_lock, flags); 527 spin_unlock_irqrestore(&il->reg_lock, flags);
528} 528}
529 529
530/* Handle notification from uCode that card's power state is changing 530/* Handle notification from uCode that card's power state is changing
531 * due to software, hardware, or critical temperature RFKILL */ 531 * due to software, hardware, or critical temperature RFKILL */
532static void il4965_rx_card_state_notif(struct il_priv *priv, 532static void il4965_rx_card_state_notif(struct il_priv *il,
533 struct il_rx_mem_buffer *rxb) 533 struct il_rx_mem_buffer *rxb)
534{ 534{
535 struct il_rx_packet *pkt = rxb_addr(rxb); 535 struct il_rx_packet *pkt = rxb_addr(rxb);
536 u32 flags = le32_to_cpu(pkt->u.card_state_notif.flags); 536 u32 flags = le32_to_cpu(pkt->u.card_state_notif.flags);
537 unsigned long status = priv->status; 537 unsigned long status = il->status;
538 538
539 IL_DEBUG_RF_KILL(priv, "Card state received: HW:%s SW:%s CT:%s\n", 539 IL_DEBUG_RF_KILL(il, "Card state received: HW:%s SW:%s CT:%s\n",
540 (flags & HW_CARD_DISABLED) ? "Kill" : "On", 540 (flags & HW_CARD_DISABLED) ? "Kill" : "On",
541 (flags & SW_CARD_DISABLED) ? "Kill" : "On", 541 (flags & SW_CARD_DISABLED) ? "Kill" : "On",
542 (flags & CT_CARD_DISABLED) ? 542 (flags & CT_CARD_DISABLED) ?
@@ -545,37 +545,37 @@ static void il4965_rx_card_state_notif(struct il_priv *priv,
545 if (flags & (SW_CARD_DISABLED | HW_CARD_DISABLED | 545 if (flags & (SW_CARD_DISABLED | HW_CARD_DISABLED |
546 CT_CARD_DISABLED)) { 546 CT_CARD_DISABLED)) {
547 547
548 il_write32(priv, CSR_UCODE_DRV_GP1_SET, 548 il_write32(il, CSR_UCODE_DRV_GP1_SET,
549 CSR_UCODE_DRV_GP1_BIT_CMD_BLOCKED); 549 CSR_UCODE_DRV_GP1_BIT_CMD_BLOCKED);
550 550
551 il_write_direct32(priv, HBUS_TARG_MBX_C, 551 il_write_direct32(il, HBUS_TARG_MBX_C,
552 HBUS_TARG_MBX_C_REG_BIT_CMD_BLOCKED); 552 HBUS_TARG_MBX_C_REG_BIT_CMD_BLOCKED);
553 553
554 if (!(flags & RXON_CARD_DISABLED)) { 554 if (!(flags & RXON_CARD_DISABLED)) {
555 il_write32(priv, CSR_UCODE_DRV_GP1_CLR, 555 il_write32(il, CSR_UCODE_DRV_GP1_CLR,
556 CSR_UCODE_DRV_GP1_BIT_CMD_BLOCKED); 556 CSR_UCODE_DRV_GP1_BIT_CMD_BLOCKED);
557 il_write_direct32(priv, HBUS_TARG_MBX_C, 557 il_write_direct32(il, HBUS_TARG_MBX_C,
558 HBUS_TARG_MBX_C_REG_BIT_CMD_BLOCKED); 558 HBUS_TARG_MBX_C_REG_BIT_CMD_BLOCKED);
559 } 559 }
560 } 560 }
561 561
562 if (flags & CT_CARD_DISABLED) 562 if (flags & CT_CARD_DISABLED)
563 il4965_perform_ct_kill_task(priv); 563 il4965_perform_ct_kill_task(il);
564 564
565 if (flags & HW_CARD_DISABLED) 565 if (flags & HW_CARD_DISABLED)
566 set_bit(STATUS_RF_KILL_HW, &priv->status); 566 set_bit(STATUS_RF_KILL_HW, &il->status);
567 else 567 else
568 clear_bit(STATUS_RF_KILL_HW, &priv->status); 568 clear_bit(STATUS_RF_KILL_HW, &il->status);
569 569
570 if (!(flags & RXON_CARD_DISABLED)) 570 if (!(flags & RXON_CARD_DISABLED))
571 il_scan_cancel(priv); 571 il_scan_cancel(il);
572 572
573 if ((test_bit(STATUS_RF_KILL_HW, &status) != 573 if ((test_bit(STATUS_RF_KILL_HW, &status) !=
574 test_bit(STATUS_RF_KILL_HW, &priv->status))) 574 test_bit(STATUS_RF_KILL_HW, &il->status)))
575 wiphy_rfkill_set_hw_state(priv->hw->wiphy, 575 wiphy_rfkill_set_hw_state(il->hw->wiphy,
576 test_bit(STATUS_RF_KILL_HW, &priv->status)); 576 test_bit(STATUS_RF_KILL_HW, &il->status));
577 else 577 else
578 wake_up(&priv->wait_command_queue); 578 wake_up(&il->wait_command_queue);
579} 579}
580 580
581/** 581/**
@@ -587,55 +587,55 @@ static void il4965_rx_card_state_notif(struct il_priv *priv,
587 * This function chains into the hardware specific files for them to setup 587 * This function chains into the hardware specific files for them to setup
588 * any hardware specific handlers as well. 588 * any hardware specific handlers as well.
589 */ 589 */
590static void il4965_setup_rx_handlers(struct il_priv *priv) 590static void il4965_setup_rx_handlers(struct il_priv *il)
591{ 591{
592 priv->rx_handlers[REPLY_ALIVE] = il4965_rx_reply_alive; 592 il->rx_handlers[REPLY_ALIVE] = il4965_rx_reply_alive;
593 priv->rx_handlers[REPLY_ERROR] = il_rx_reply_error; 593 il->rx_handlers[REPLY_ERROR] = il_rx_reply_error;
594 priv->rx_handlers[CHANNEL_SWITCH_NOTIFICATION] = il_rx_csa; 594 il->rx_handlers[CHANNEL_SWITCH_NOTIFICATION] = il_rx_csa;
595 priv->rx_handlers[SPECTRUM_MEASURE_NOTIFICATION] = 595 il->rx_handlers[SPECTRUM_MEASURE_NOTIFICATION] =
596 il_rx_spectrum_measure_notif; 596 il_rx_spectrum_measure_notif;
597 priv->rx_handlers[PM_SLEEP_NOTIFICATION] = il_rx_pm_sleep_notif; 597 il->rx_handlers[PM_SLEEP_NOTIFICATION] = il_rx_pm_sleep_notif;
598 priv->rx_handlers[PM_DEBUG_STATISTIC_NOTIFIC] = 598 il->rx_handlers[PM_DEBUG_STATISTIC_NOTIFIC] =
599 il_rx_pm_debug_statistics_notif; 599 il_rx_pm_debug_statistics_notif;
600 priv->rx_handlers[BEACON_NOTIFICATION] = il4965_rx_beacon_notif; 600 il->rx_handlers[BEACON_NOTIFICATION] = il4965_rx_beacon_notif;
601 601
602 /* 602 /*
603 * The same handler is used for both the REPLY to a discrete 603 * The same handler is used for both the REPLY to a discrete
604 * statistics request from the host as well as for the periodic 604 * statistics request from the host as well as for the periodic
605 * statistics notifications (after received beacons) from the uCode. 605 * statistics notifications (after received beacons) from the uCode.
606 */ 606 */
607 priv->rx_handlers[REPLY_STATISTICS_CMD] = il4965_reply_statistics; 607 il->rx_handlers[REPLY_STATISTICS_CMD] = il4965_reply_statistics;
608 priv->rx_handlers[STATISTICS_NOTIFICATION] = il4965_rx_statistics; 608 il->rx_handlers[STATISTICS_NOTIFICATION] = il4965_rx_statistics;
609 609
610 il_setup_rx_scan_handlers(priv); 610 il_setup_rx_scan_handlers(il);
611 611
612 /* status change handler */ 612 /* status change handler */
613 priv->rx_handlers[CARD_STATE_NOTIFICATION] = 613 il->rx_handlers[CARD_STATE_NOTIFICATION] =
614 il4965_rx_card_state_notif; 614 il4965_rx_card_state_notif;
615 615
616 priv->rx_handlers[MISSED_BEACONS_NOTIFICATION] = 616 il->rx_handlers[MISSED_BEACONS_NOTIFICATION] =
617 il4965_rx_missed_beacon_notif; 617 il4965_rx_missed_beacon_notif;
618 /* Rx handlers */ 618 /* Rx handlers */
619 priv->rx_handlers[REPLY_RX_PHY_CMD] = il4965_rx_reply_rx_phy; 619 il->rx_handlers[REPLY_RX_PHY_CMD] = il4965_rx_reply_rx_phy;
620 priv->rx_handlers[REPLY_RX_MPDU_CMD] = il4965_rx_reply_rx; 620 il->rx_handlers[REPLY_RX_MPDU_CMD] = il4965_rx_reply_rx;
621 /* block ack */ 621 /* block ack */
622 priv->rx_handlers[REPLY_COMPRESSED_BA] = il4965_rx_reply_compressed_ba; 622 il->rx_handlers[REPLY_COMPRESSED_BA] = il4965_rx_reply_compressed_ba;
623 /* Set up hardware specific Rx handlers */ 623 /* Set up hardware specific Rx handlers */
624 priv->cfg->ops->lib->rx_handler_setup(priv); 624 il->cfg->ops->lib->rx_handler_setup(il);
625} 625}
626 626
627/** 627/**
628 * il4965_rx_handle - Main entry function for receiving responses from uCode 628 * il4965_rx_handle - Main entry function for receiving responses from uCode
629 * 629 *
630 * Uses the priv->rx_handlers callback function array to invoke 630 * Uses the il->rx_handlers callback function array to invoke
631 * the appropriate handlers, including command responses, 631 * the appropriate handlers, including command responses,
632 * frame-received notifications, and other notifications. 632 * frame-received notifications, and other notifications.
633 */ 633 */
634void il4965_rx_handle(struct il_priv *priv) 634void il4965_rx_handle(struct il_priv *il)
635{ 635{
636 struct il_rx_mem_buffer *rxb; 636 struct il_rx_mem_buffer *rxb;
637 struct il_rx_packet *pkt; 637 struct il_rx_packet *pkt;
638 struct il_rx_queue *rxq = &priv->rxq; 638 struct il_rx_queue *rxq = &il->rxq;
639 u32 r, i; 639 u32 r, i;
640 int reclaim; 640 int reclaim;
641 unsigned long flags; 641 unsigned long flags;
@@ -650,7 +650,7 @@ void il4965_rx_handle(struct il_priv *priv)
650 650
651 /* Rx interrupt, but nothing sent from uCode */ 651 /* Rx interrupt, but nothing sent from uCode */
652 if (i == r) 652 if (i == r)
653 IL_DEBUG_RX(priv, "r = %d, i = %d\n", r, i); 653 IL_DEBUG_RX(il, "r = %d, i = %d\n", r, i);
654 654
655 /* calculate total frames need to be restock after handling RX */ 655 /* calculate total frames need to be restock after handling RX */
656 total_empty = r - rxq->write_actual; 656 total_empty = r - rxq->write_actual;
@@ -672,8 +672,8 @@ void il4965_rx_handle(struct il_priv *priv)
672 672
673 rxq->queue[i] = NULL; 673 rxq->queue[i] = NULL;
674 674
675 pci_unmap_page(priv->pci_dev, rxb->page_dma, 675 pci_unmap_page(il->pci_dev, rxb->page_dma,
676 PAGE_SIZE << priv->hw_params.rx_page_order, 676 PAGE_SIZE << il->hw_params.rx_page_order,
677 PCI_DMA_FROMDEVICE); 677 PCI_DMA_FROMDEVICE);
678 pkt = rxb_addr(rxb); 678 pkt = rxb_addr(rxb);
679 679
@@ -697,15 +697,15 @@ void il4965_rx_handle(struct il_priv *priv)
697 /* Based on type of command response or notification, 697 /* Based on type of command response or notification,
698 * handle those that need handling via function in 698 * handle those that need handling via function in
699 * rx_handlers table. See il4965_setup_rx_handlers() */ 699 * rx_handlers table. See il4965_setup_rx_handlers() */
700 if (priv->rx_handlers[pkt->hdr.cmd]) { 700 if (il->rx_handlers[pkt->hdr.cmd]) {
701 IL_DEBUG_RX(priv, "r = %d, i = %d, %s, 0x%02x\n", r, 701 IL_DEBUG_RX(il, "r = %d, i = %d, %s, 0x%02x\n", r,
702 i, il_get_cmd_string(pkt->hdr.cmd), 702 i, il_get_cmd_string(pkt->hdr.cmd),
703 pkt->hdr.cmd); 703 pkt->hdr.cmd);
704 priv->isr_stats.rx_handlers[pkt->hdr.cmd]++; 704 il->isr_stats.rx_handlers[pkt->hdr.cmd]++;
705 priv->rx_handlers[pkt->hdr.cmd] (priv, rxb); 705 il->rx_handlers[pkt->hdr.cmd] (il, rxb);
706 } else { 706 } else {
707 /* No handling needed */ 707 /* No handling needed */
708 IL_DEBUG_RX(priv, 708 IL_DEBUG_RX(il,
709 "r %d i %d No handler needed for %s, 0x%02x\n", 709 "r %d i %d No handler needed for %s, 0x%02x\n",
710 r, i, il_get_cmd_string(pkt->hdr.cmd), 710 r, i, il_get_cmd_string(pkt->hdr.cmd),
711 pkt->hdr.cmd); 711 pkt->hdr.cmd);
@@ -723,9 +723,9 @@ void il4965_rx_handle(struct il_priv *priv)
723 * and fire off the (possibly) blocking il_send_cmd() 723 * and fire off the (possibly) blocking il_send_cmd()
724 * as we reclaim the driver command queue */ 724 * as we reclaim the driver command queue */
725 if (rxb->page) 725 if (rxb->page)
726 il_tx_cmd_complete(priv, rxb); 726 il_tx_cmd_complete(il, rxb);
727 else 727 else
728 IL_WARN(priv, "Claim null rxb?\n"); 728 IL_WARN(il, "Claim null rxb?\n");
729 } 729 }
730 730
731 /* Reuse the page if possible. For notification packets and 731 /* Reuse the page if possible. For notification packets and
@@ -733,8 +733,8 @@ void il4965_rx_handle(struct il_priv *priv)
733 * rx_free list for reuse later. */ 733 * rx_free list for reuse later. */
734 spin_lock_irqsave(&rxq->lock, flags); 734 spin_lock_irqsave(&rxq->lock, flags);
735 if (rxb->page != NULL) { 735 if (rxb->page != NULL) {
736 rxb->page_dma = pci_map_page(priv->pci_dev, rxb->page, 736 rxb->page_dma = pci_map_page(il->pci_dev, rxb->page,
737 0, PAGE_SIZE << priv->hw_params.rx_page_order, 737 0, PAGE_SIZE << il->hw_params.rx_page_order,
738 PCI_DMA_FROMDEVICE); 738 PCI_DMA_FROMDEVICE);
739 list_add_tail(&rxb->list, &rxq->rx_free); 739 list_add_tail(&rxb->list, &rxq->rx_free);
740 rxq->free_count++; 740 rxq->free_count++;
@@ -750,7 +750,7 @@ void il4965_rx_handle(struct il_priv *priv)
750 count++; 750 count++;
751 if (count >= 8) { 751 if (count >= 8) {
752 rxq->read = i; 752 rxq->read = i;
753 il4965_rx_replenish_now(priv); 753 il4965_rx_replenish_now(il);
754 count = 0; 754 count = 0;
755 } 755 }
756 } 756 }
@@ -759,20 +759,20 @@ void il4965_rx_handle(struct il_priv *priv)
759 /* Backtrack one entry */ 759 /* Backtrack one entry */
760 rxq->read = i; 760 rxq->read = i;
761 if (fill_rx) 761 if (fill_rx)
762 il4965_rx_replenish_now(priv); 762 il4965_rx_replenish_now(il);
763 else 763 else
764 il4965_rx_queue_restock(priv); 764 il4965_rx_queue_restock(il);
765} 765}
766 766
767/* call this function to flush any scheduled tasklet */ 767/* call this function to flush any scheduled tasklet */
768static inline void il4965_synchronize_irq(struct il_priv *priv) 768static inline void il4965_synchronize_irq(struct il_priv *il)
769{ 769{
770 /* wait to make sure we flush pending tasklet*/ 770 /* wait to make sure we flush pending tasklet*/
771 synchronize_irq(priv->pci_dev->irq); 771 synchronize_irq(il->pci_dev->irq);
772 tasklet_kill(&priv->irq_tasklet); 772 tasklet_kill(&il->irq_tasklet);
773} 773}
774 774
775static void il4965_irq_tasklet(struct il_priv *priv) 775static void il4965_irq_tasklet(struct il_priv *il)
776{ 776{
777 u32 inta, handled = 0; 777 u32 inta, handled = 0;
778 u32 inta_fh; 778 u32 inta_fh;
@@ -782,30 +782,30 @@ static void il4965_irq_tasklet(struct il_priv *priv)
782 u32 inta_mask; 782 u32 inta_mask;
783#endif 783#endif
784 784
785 spin_lock_irqsave(&priv->lock, flags); 785 spin_lock_irqsave(&il->lock, flags);
786 786
787 /* Ack/clear/reset pending uCode interrupts. 787 /* Ack/clear/reset pending uCode interrupts.
788 * Note: Some bits in CSR_INT are "OR" of bits in CSR_FH_INT_STATUS, 788 * Note: Some bits in CSR_INT are "OR" of bits in CSR_FH_INT_STATUS,
789 * and will clear only when CSR_FH_INT_STATUS gets cleared. */ 789 * and will clear only when CSR_FH_INT_STATUS gets cleared. */
790 inta = il_read32(priv, CSR_INT); 790 inta = il_read32(il, CSR_INT);
791 il_write32(priv, CSR_INT, inta); 791 il_write32(il, CSR_INT, inta);
792 792
793 /* Ack/clear/reset pending flow-handler (DMA) interrupts. 793 /* Ack/clear/reset pending flow-handler (DMA) interrupts.
794 * Any new interrupts that happen after this, either while we're 794 * Any new interrupts that happen after this, either while we're
795 * in this tasklet, or later, will show up in next ISR/tasklet. */ 795 * in this tasklet, or later, will show up in next ISR/tasklet. */
796 inta_fh = il_read32(priv, CSR_FH_INT_STATUS); 796 inta_fh = il_read32(il, CSR_FH_INT_STATUS);
797 il_write32(priv, CSR_FH_INT_STATUS, inta_fh); 797 il_write32(il, CSR_FH_INT_STATUS, inta_fh);
798 798
799#ifdef CONFIG_IWLWIFI_LEGACY_DEBUG 799#ifdef CONFIG_IWLWIFI_LEGACY_DEBUG
800 if (il_get_debug_level(priv) & IL_DL_ISR) { 800 if (il_get_debug_level(il) & IL_DL_ISR) {
801 /* just for debug */ 801 /* just for debug */
802 inta_mask = il_read32(priv, CSR_INT_MASK); 802 inta_mask = il_read32(il, CSR_INT_MASK);
803 IL_DEBUG_ISR(priv, "inta 0x%08x, enabled 0x%08x, fh 0x%08x\n", 803 IL_DEBUG_ISR(il, "inta 0x%08x, enabled 0x%08x, fh 0x%08x\n",
804 inta, inta_mask, inta_fh); 804 inta, inta_mask, inta_fh);
805 } 805 }
806#endif 806#endif
807 807
808 spin_unlock_irqrestore(&priv->lock, flags); 808 spin_unlock_irqrestore(&il->lock, flags);
809 809
810 /* Since CSR_INT and CSR_FH_INT_STATUS reads and clears are not 810 /* Since CSR_INT and CSR_FH_INT_STATUS reads and clears are not
811 * atomic, make sure that inta covers all the interrupts that 811 * atomic, make sure that inta covers all the interrupts that
@@ -818,13 +818,13 @@ static void il4965_irq_tasklet(struct il_priv *priv)
818 818
819 /* Now service all interrupt bits discovered above. */ 819 /* Now service all interrupt bits discovered above. */
820 if (inta & CSR_INT_BIT_HW_ERR) { 820 if (inta & CSR_INT_BIT_HW_ERR) {
821 IL_ERR(priv, "Hardware error detected. Restarting.\n"); 821 IL_ERR(il, "Hardware error detected. Restarting.\n");
822 822
823 /* Tell the device to stop sending interrupts */ 823 /* Tell the device to stop sending interrupts */
824 il_disable_interrupts(priv); 824 il_disable_interrupts(il);
825 825
826 priv->isr_stats.hw++; 826 il->isr_stats.hw++;
827 il_irq_handle_error(priv); 827 il_irq_handle_error(il);
828 828
829 handled |= CSR_INT_BIT_HW_ERR; 829 handled |= CSR_INT_BIT_HW_ERR;
830 830
@@ -832,18 +832,18 @@ static void il4965_irq_tasklet(struct il_priv *priv)
832 } 832 }
833 833
834#ifdef CONFIG_IWLWIFI_LEGACY_DEBUG 834#ifdef CONFIG_IWLWIFI_LEGACY_DEBUG
835 if (il_get_debug_level(priv) & (IL_DL_ISR)) { 835 if (il_get_debug_level(il) & (IL_DL_ISR)) {
836 /* NIC fires this, but we don't use it, redundant with WAKEUP */ 836 /* NIC fires this, but we don't use it, redundant with WAKEUP */
837 if (inta & CSR_INT_BIT_SCD) { 837 if (inta & CSR_INT_BIT_SCD) {
838 IL_DEBUG_ISR(priv, "Scheduler finished to transmit " 838 IL_DEBUG_ISR(il, "Scheduler finished to transmit "
839 "the frame/frames.\n"); 839 "the frame/frames.\n");
840 priv->isr_stats.sch++; 840 il->isr_stats.sch++;
841 } 841 }
842 842
843 /* Alive notification via Rx interrupt will do the real work */ 843 /* Alive notification via Rx interrupt will do the real work */
844 if (inta & CSR_INT_BIT_ALIVE) { 844 if (inta & CSR_INT_BIT_ALIVE) {
845 IL_DEBUG_ISR(priv, "Alive interrupt\n"); 845 IL_DEBUG_ISR(il, "Alive interrupt\n");
846 priv->isr_stats.alive++; 846 il->isr_stats.alive++;
847 } 847 }
848 } 848 }
849#endif 849#endif
@@ -853,26 +853,26 @@ static void il4965_irq_tasklet(struct il_priv *priv)
853 /* HW RF KILL switch toggled */ 853 /* HW RF KILL switch toggled */
854 if (inta & CSR_INT_BIT_RF_KILL) { 854 if (inta & CSR_INT_BIT_RF_KILL) {
855 int hw_rf_kill = 0; 855 int hw_rf_kill = 0;
856 if (!(il_read32(priv, CSR_GP_CNTRL) & 856 if (!(il_read32(il, CSR_GP_CNTRL) &
857 CSR_GP_CNTRL_REG_FLAG_HW_RF_KILL_SW)) 857 CSR_GP_CNTRL_REG_FLAG_HW_RF_KILL_SW))
858 hw_rf_kill = 1; 858 hw_rf_kill = 1;
859 859
860 IL_WARN(priv, "RF_KILL bit toggled to %s.\n", 860 IL_WARN(il, "RF_KILL bit toggled to %s.\n",
861 hw_rf_kill ? "disable radio" : "enable radio"); 861 hw_rf_kill ? "disable radio" : "enable radio");
862 862
863 priv->isr_stats.rfkill++; 863 il->isr_stats.rfkill++;
864 864
865 /* driver only loads ucode once setting the interface up. 865 /* driver only loads ucode once setting the interface up.
866 * the driver allows loading the ucode even if the radio 866 * the driver allows loading the ucode even if the radio
867 * is killed. Hence update the killswitch state here. The 867 * is killed. Hence update the killswitch state here. The
868 * rfkill handler will care about restarting if needed. 868 * rfkill handler will care about restarting if needed.
869 */ 869 */
870 if (!test_bit(STATUS_ALIVE, &priv->status)) { 870 if (!test_bit(STATUS_ALIVE, &il->status)) {
871 if (hw_rf_kill) 871 if (hw_rf_kill)
872 set_bit(STATUS_RF_KILL_HW, &priv->status); 872 set_bit(STATUS_RF_KILL_HW, &il->status);
873 else 873 else
874 clear_bit(STATUS_RF_KILL_HW, &priv->status); 874 clear_bit(STATUS_RF_KILL_HW, &il->status);
875 wiphy_rfkill_set_hw_state(priv->hw->wiphy, hw_rf_kill); 875 wiphy_rfkill_set_hw_state(il->hw->wiphy, hw_rf_kill);
876 } 876 }
877 877
878 handled |= CSR_INT_BIT_RF_KILL; 878 handled |= CSR_INT_BIT_RF_KILL;
@@ -880,17 +880,17 @@ static void il4965_irq_tasklet(struct il_priv *priv)
880 880
881 /* Chip got too hot and stopped itself */ 881 /* Chip got too hot and stopped itself */
882 if (inta & CSR_INT_BIT_CT_KILL) { 882 if (inta & CSR_INT_BIT_CT_KILL) {
883 IL_ERR(priv, "Microcode CT kill error detected.\n"); 883 IL_ERR(il, "Microcode CT kill error detected.\n");
884 priv->isr_stats.ctkill++; 884 il->isr_stats.ctkill++;
885 handled |= CSR_INT_BIT_CT_KILL; 885 handled |= CSR_INT_BIT_CT_KILL;
886 } 886 }
887 887
888 /* Error detected by uCode */ 888 /* Error detected by uCode */
889 if (inta & CSR_INT_BIT_SW_ERR) { 889 if (inta & CSR_INT_BIT_SW_ERR) {
890 IL_ERR(priv, "Microcode SW error detected. " 890 IL_ERR(il, "Microcode SW error detected. "
891 " Restarting 0x%X.\n", inta); 891 " Restarting 0x%X.\n", inta);
892 priv->isr_stats.sw++; 892 il->isr_stats.sw++;
893 il_irq_handle_error(priv); 893 il_irq_handle_error(il);
894 handled |= CSR_INT_BIT_SW_ERR; 894 handled |= CSR_INT_BIT_SW_ERR;
895 } 895 }
896 896
@@ -900,11 +900,11 @@ static void il4965_irq_tasklet(struct il_priv *priv)
900 * and about any Rx buffers made available while asleep. 900 * and about any Rx buffers made available while asleep.
901 */ 901 */
902 if (inta & CSR_INT_BIT_WAKEUP) { 902 if (inta & CSR_INT_BIT_WAKEUP) {
903 IL_DEBUG_ISR(priv, "Wakeup interrupt\n"); 903 IL_DEBUG_ISR(il, "Wakeup interrupt\n");
904 il_rx_queue_update_write_ptr(priv, &priv->rxq); 904 il_rx_queue_update_write_ptr(il, &il->rxq);
905 for (i = 0; i < priv->hw_params.max_txq_num; i++) 905 for (i = 0; i < il->hw_params.max_txq_num; i++)
906 il_txq_update_write_ptr(priv, &priv->txq[i]); 906 il_txq_update_write_ptr(il, &il->txq[i]);
907 priv->isr_stats.wakeup++; 907 il->isr_stats.wakeup++;
908 handled |= CSR_INT_BIT_WAKEUP; 908 handled |= CSR_INT_BIT_WAKEUP;
909 } 909 }
910 910
@@ -912,46 +912,46 @@ static void il4965_irq_tasklet(struct il_priv *priv)
912 * Rx "responses" (frame-received notification), and other 912 * Rx "responses" (frame-received notification), and other
913 * notifications from uCode come through here*/ 913 * notifications from uCode come through here*/
914 if (inta & (CSR_INT_BIT_FH_RX | CSR_INT_BIT_SW_RX)) { 914 if (inta & (CSR_INT_BIT_FH_RX | CSR_INT_BIT_SW_RX)) {
915 il4965_rx_handle(priv); 915 il4965_rx_handle(il);
916 priv->isr_stats.rx++; 916 il->isr_stats.rx++;
917 handled |= (CSR_INT_BIT_FH_RX | CSR_INT_BIT_SW_RX); 917 handled |= (CSR_INT_BIT_FH_RX | CSR_INT_BIT_SW_RX);
918 } 918 }
919 919
920 /* This "Tx" DMA channel is used only for loading uCode */ 920 /* This "Tx" DMA channel is used only for loading uCode */
921 if (inta & CSR_INT_BIT_FH_TX) { 921 if (inta & CSR_INT_BIT_FH_TX) {
922 IL_DEBUG_ISR(priv, "uCode load interrupt\n"); 922 IL_DEBUG_ISR(il, "uCode load interrupt\n");
923 priv->isr_stats.tx++; 923 il->isr_stats.tx++;
924 handled |= CSR_INT_BIT_FH_TX; 924 handled |= CSR_INT_BIT_FH_TX;
925 /* Wake up uCode load routine, now that load is complete */ 925 /* Wake up uCode load routine, now that load is complete */
926 priv->ucode_write_complete = 1; 926 il->ucode_write_complete = 1;
927 wake_up(&priv->wait_command_queue); 927 wake_up(&il->wait_command_queue);
928 } 928 }
929 929
930 if (inta & ~handled) { 930 if (inta & ~handled) {
931 IL_ERR(priv, "Unhandled INTA bits 0x%08x\n", inta & ~handled); 931 IL_ERR(il, "Unhandled INTA bits 0x%08x\n", inta & ~handled);
932 priv->isr_stats.unhandled++; 932 il->isr_stats.unhandled++;
933 } 933 }
934 934
935 if (inta & ~(priv->inta_mask)) { 935 if (inta & ~(il->inta_mask)) {
936 IL_WARN(priv, "Disabled INTA bits 0x%08x were pending\n", 936 IL_WARN(il, "Disabled INTA bits 0x%08x were pending\n",
937 inta & ~priv->inta_mask); 937 inta & ~il->inta_mask);
938 IL_WARN(priv, " with FH_INT = 0x%08x\n", inta_fh); 938 IL_WARN(il, " with FH_INT = 0x%08x\n", inta_fh);
939 } 939 }
940 940
941 /* Re-enable all interrupts */ 941 /* Re-enable all interrupts */
942 /* only Re-enable if disabled by irq */ 942 /* only Re-enable if disabled by irq */
943 if (test_bit(STATUS_INT_ENABLED, &priv->status)) 943 if (test_bit(STATUS_INT_ENABLED, &il->status))
944 il_enable_interrupts(priv); 944 il_enable_interrupts(il);
945 /* Re-enable RF_KILL if it occurred */ 945 /* Re-enable RF_KILL if it occurred */
946 else if (handled & CSR_INT_BIT_RF_KILL) 946 else if (handled & CSR_INT_BIT_RF_KILL)
947 il_enable_rfkill_int(priv); 947 il_enable_rfkill_int(il);
948 948
949#ifdef CONFIG_IWLWIFI_LEGACY_DEBUG 949#ifdef CONFIG_IWLWIFI_LEGACY_DEBUG
950 if (il_get_debug_level(priv) & (IL_DL_ISR)) { 950 if (il_get_debug_level(il) & (IL_DL_ISR)) {
951 inta = il_read32(priv, CSR_INT); 951 inta = il_read32(il, CSR_INT);
952 inta_mask = il_read32(priv, CSR_INT_MASK); 952 inta_mask = il_read32(il, CSR_INT_MASK);
953 inta_fh = il_read32(priv, CSR_FH_INT_STATUS); 953 inta_fh = il_read32(il, CSR_FH_INT_STATUS);
954 IL_DEBUG_ISR(priv, 954 IL_DEBUG_ISR(il,
955 "End inta 0x%08x, enabled 0x%08x, fh 0x%08x, " 955 "End inta 0x%08x, enabled 0x%08x, fh 0x%08x, "
956 "flags 0x%08lx\n", inta, inta_mask, inta_fh, flags); 956 "flags 0x%08lx\n", inta, inta_mask, inta_fh, flags);
957 } 957 }
@@ -980,24 +980,24 @@ static void il4965_irq_tasklet(struct il_priv *priv)
980static ssize_t il4965_show_debug_level(struct device *d, 980static ssize_t il4965_show_debug_level(struct device *d,
981 struct device_attribute *attr, char *buf) 981 struct device_attribute *attr, char *buf)
982{ 982{
983 struct il_priv *priv = dev_get_drvdata(d); 983 struct il_priv *il = dev_get_drvdata(d);
984 return sprintf(buf, "0x%08X\n", il_get_debug_level(priv)); 984 return sprintf(buf, "0x%08X\n", il_get_debug_level(il));
985} 985}
986static ssize_t il4965_store_debug_level(struct device *d, 986static ssize_t il4965_store_debug_level(struct device *d,
987 struct device_attribute *attr, 987 struct device_attribute *attr,
988 const char *buf, size_t count) 988 const char *buf, size_t count)
989{ 989{
990 struct il_priv *priv = dev_get_drvdata(d); 990 struct il_priv *il = dev_get_drvdata(d);
991 unsigned long val; 991 unsigned long val;
992 int ret; 992 int ret;
993 993
994 ret = strict_strtoul(buf, 0, &val); 994 ret = strict_strtoul(buf, 0, &val);
995 if (ret) 995 if (ret)
996 IL_ERR(priv, "%s is not in hex or decimal form.\n", buf); 996 IL_ERR(il, "%s is not in hex or decimal form.\n", buf);
997 else { 997 else {
998 priv->debug_level = val; 998 il->debug_level = val;
999 if (il_alloc_traffic_mem(priv)) 999 if (il_alloc_traffic_mem(il))
1000 IL_ERR(priv, 1000 IL_ERR(il,
1001 "Not enough memory to generate traffic log\n"); 1001 "Not enough memory to generate traffic log\n");
1002 } 1002 }
1003 return strnlen(buf, count); 1003 return strnlen(buf, count);
@@ -1013,12 +1013,12 @@ static DEVICE_ATTR(debug_level, S_IWUSR | S_IRUGO,
1013static ssize_t il4965_show_temperature(struct device *d, 1013static ssize_t il4965_show_temperature(struct device *d,
1014 struct device_attribute *attr, char *buf) 1014 struct device_attribute *attr, char *buf)
1015{ 1015{
1016 struct il_priv *priv = dev_get_drvdata(d); 1016 struct il_priv *il = dev_get_drvdata(d);
1017 1017
1018 if (!il_is_alive(priv)) 1018 if (!il_is_alive(il))
1019 return -EAGAIN; 1019 return -EAGAIN;
1020 1020
1021 return sprintf(buf, "%d\n", priv->temperature); 1021 return sprintf(buf, "%d\n", il->temperature);
1022} 1022}
1023 1023
1024static DEVICE_ATTR(temperature, S_IRUGO, il4965_show_temperature, NULL); 1024static DEVICE_ATTR(temperature, S_IRUGO, il4965_show_temperature, NULL);
@@ -1026,29 +1026,29 @@ static DEVICE_ATTR(temperature, S_IRUGO, il4965_show_temperature, NULL);
1026static ssize_t il4965_show_tx_power(struct device *d, 1026static ssize_t il4965_show_tx_power(struct device *d,
1027 struct device_attribute *attr, char *buf) 1027 struct device_attribute *attr, char *buf)
1028{ 1028{
1029 struct il_priv *priv = dev_get_drvdata(d); 1029 struct il_priv *il = dev_get_drvdata(d);
1030 1030
1031 if (!il_is_ready_rf(priv)) 1031 if (!il_is_ready_rf(il))
1032 return sprintf(buf, "off\n"); 1032 return sprintf(buf, "off\n");
1033 else 1033 else
1034 return sprintf(buf, "%d\n", priv->tx_power_user_lmt); 1034 return sprintf(buf, "%d\n", il->tx_power_user_lmt);
1035} 1035}
1036 1036
1037static ssize_t il4965_store_tx_power(struct device *d, 1037static ssize_t il4965_store_tx_power(struct device *d,
1038 struct device_attribute *attr, 1038 struct device_attribute *attr,
1039 const char *buf, size_t count) 1039 const char *buf, size_t count)
1040{ 1040{
1041 struct il_priv *priv = dev_get_drvdata(d); 1041 struct il_priv *il = dev_get_drvdata(d);
1042 unsigned long val; 1042 unsigned long val;
1043 int ret; 1043 int ret;
1044 1044
1045 ret = strict_strtoul(buf, 10, &val); 1045 ret = strict_strtoul(buf, 10, &val);
1046 if (ret) 1046 if (ret)
1047 IL_INFO(priv, "%s is not in decimal form.\n", buf); 1047 IL_INFO(il, "%s is not in decimal form.\n", buf);
1048 else { 1048 else {
1049 ret = il_set_tx_power(priv, val, false); 1049 ret = il_set_tx_power(il, val, false);
1050 if (ret) 1050 if (ret)
1051 IL_ERR(priv, "failed setting tx power (0x%d).\n", 1051 IL_ERR(il, "failed setting tx power (0x%d).\n",
1052 ret); 1052 ret);
1053 else 1053 else
1054 ret = count; 1054 ret = count;
@@ -1079,52 +1079,52 @@ static struct attribute_group il_attribute_group = {
1079 * 1079 *
1080 ******************************************************************************/ 1080 ******************************************************************************/
1081 1081
1082static void il4965_dealloc_ucode_pci(struct il_priv *priv) 1082static void il4965_dealloc_ucode_pci(struct il_priv *il)
1083{ 1083{
1084 il_free_fw_desc(priv->pci_dev, &priv->ucode_code); 1084 il_free_fw_desc(il->pci_dev, &il->ucode_code);
1085 il_free_fw_desc(priv->pci_dev, &priv->ucode_data); 1085 il_free_fw_desc(il->pci_dev, &il->ucode_data);
1086 il_free_fw_desc(priv->pci_dev, &priv->ucode_data_backup); 1086 il_free_fw_desc(il->pci_dev, &il->ucode_data_backup);
1087 il_free_fw_desc(priv->pci_dev, &priv->ucode_init); 1087 il_free_fw_desc(il->pci_dev, &il->ucode_init);
1088 il_free_fw_desc(priv->pci_dev, &priv->ucode_init_data); 1088 il_free_fw_desc(il->pci_dev, &il->ucode_init_data);
1089 il_free_fw_desc(priv->pci_dev, &priv->ucode_boot); 1089 il_free_fw_desc(il->pci_dev, &il->ucode_boot);
1090} 1090}
1091 1091
1092static void il4965_nic_start(struct il_priv *priv) 1092static void il4965_nic_start(struct il_priv *il)
1093{ 1093{
1094 /* Remove all resets to allow NIC to operate */ 1094 /* Remove all resets to allow NIC to operate */
1095 il_write32(priv, CSR_RESET, 0); 1095 il_write32(il, CSR_RESET, 0);
1096} 1096}
1097 1097
1098static void il4965_ucode_callback(const struct firmware *ucode_raw, 1098static void il4965_ucode_callback(const struct firmware *ucode_raw,
1099 void *context); 1099 void *context);
1100static int il4965_mac_setup_register(struct il_priv *priv, 1100static int il4965_mac_setup_register(struct il_priv *il,
1101 u32 max_probe_length); 1101 u32 max_probe_length);
1102 1102
1103static int __must_check il4965_request_firmware(struct il_priv *priv, bool first) 1103static int __must_check il4965_request_firmware(struct il_priv *il, bool first)
1104{ 1104{
1105 const char *name_pre = priv->cfg->fw_name_pre; 1105 const char *name_pre = il->cfg->fw_name_pre;
1106 char tag[8]; 1106 char tag[8];
1107 1107
1108 if (first) { 1108 if (first) {
1109 priv->fw_index = priv->cfg->ucode_api_max; 1109 il->fw_index = il->cfg->ucode_api_max;
1110 sprintf(tag, "%d", priv->fw_index); 1110 sprintf(tag, "%d", il->fw_index);
1111 } else { 1111 } else {
1112 priv->fw_index--; 1112 il->fw_index--;
1113 sprintf(tag, "%d", priv->fw_index); 1113 sprintf(tag, "%d", il->fw_index);
1114 } 1114 }
1115 1115
1116 if (priv->fw_index < priv->cfg->ucode_api_min) { 1116 if (il->fw_index < il->cfg->ucode_api_min) {
1117 IL_ERR(priv, "no suitable firmware found!\n"); 1117 IL_ERR(il, "no suitable firmware found!\n");
1118 return -ENOENT; 1118 return -ENOENT;
1119 } 1119 }
1120 1120
1121 sprintf(priv->firmware_name, "%s%s%s", name_pre, tag, ".ucode"); 1121 sprintf(il->firmware_name, "%s%s%s", name_pre, tag, ".ucode");
1122 1122
1123 IL_DEBUG_INFO(priv, "attempting to load firmware '%s'\n", 1123 IL_DEBUG_INFO(il, "attempting to load firmware '%s'\n",
1124 priv->firmware_name); 1124 il->firmware_name);
1125 1125
1126 return request_firmware_nowait(THIS_MODULE, 1, priv->firmware_name, 1126 return request_firmware_nowait(THIS_MODULE, 1, il->firmware_name,
1127 &priv->pci_dev->dev, GFP_KERNEL, priv, 1127 &il->pci_dev->dev, GFP_KERNEL, il,
1128 il4965_ucode_callback); 1128 il4965_ucode_callback);
1129} 1129}
1130 1130
@@ -1133,7 +1133,7 @@ struct il4965_firmware_pieces {
1133 size_t inst_size, data_size, init_size, init_data_size, boot_size; 1133 size_t inst_size, data_size, init_size, init_data_size, boot_size;
1134}; 1134};
1135 1135
1136static int il4965_load_firmware(struct il_priv *priv, 1136static int il4965_load_firmware(struct il_priv *il,
1137 const struct firmware *ucode_raw, 1137 const struct firmware *ucode_raw,
1138 struct il4965_firmware_pieces *pieces) 1138 struct il4965_firmware_pieces *pieces)
1139{ 1139{
@@ -1141,8 +1141,8 @@ static int il4965_load_firmware(struct il_priv *priv,
1141 u32 api_ver, hdr_size; 1141 u32 api_ver, hdr_size;
1142 const u8 *src; 1142 const u8 *src;
1143 1143
1144 priv->ucode_ver = le32_to_cpu(ucode->ver); 1144 il->ucode_ver = le32_to_cpu(ucode->ver);
1145 api_ver = IL_UCODE_API(priv->ucode_ver); 1145 api_ver = IL_UCODE_API(il->ucode_ver);
1146 1146
1147 switch (api_ver) { 1147 switch (api_ver) {
1148 default: 1148 default:
@@ -1151,7 +1151,7 @@ static int il4965_load_firmware(struct il_priv *priv,
1151 case 2: 1151 case 2:
1152 hdr_size = 24; 1152 hdr_size = 24;
1153 if (ucode_raw->size < hdr_size) { 1153 if (ucode_raw->size < hdr_size) {
1154 IL_ERR(priv, "File size too small!\n"); 1154 IL_ERR(il, "File size too small!\n");
1155 return -EINVAL; 1155 return -EINVAL;
1156 } 1156 }
1157 pieces->inst_size = le32_to_cpu(ucode->v1.inst_size); 1157 pieces->inst_size = le32_to_cpu(ucode->v1.inst_size);
@@ -1169,7 +1169,7 @@ static int il4965_load_firmware(struct il_priv *priv,
1169 pieces->data_size + pieces->init_size + 1169 pieces->data_size + pieces->init_size +
1170 pieces->init_data_size + pieces->boot_size) { 1170 pieces->init_data_size + pieces->boot_size) {
1171 1171
1172 IL_ERR(priv, 1172 IL_ERR(il,
1173 "uCode file size %d does not match expected size\n", 1173 "uCode file size %d does not match expected size\n",
1174 (int)ucode_raw->size); 1174 (int)ucode_raw->size);
1175 return -EINVAL; 1175 return -EINVAL;
@@ -1198,12 +1198,12 @@ static int il4965_load_firmware(struct il_priv *priv,
1198static void 1198static void
1199il4965_ucode_callback(const struct firmware *ucode_raw, void *context) 1199il4965_ucode_callback(const struct firmware *ucode_raw, void *context)
1200{ 1200{
1201 struct il_priv *priv = context; 1201 struct il_priv *il = context;
1202 struct il_ucode_header *ucode; 1202 struct il_ucode_header *ucode;
1203 int err; 1203 int err;
1204 struct il4965_firmware_pieces pieces; 1204 struct il4965_firmware_pieces pieces;
1205 const unsigned int api_max = priv->cfg->ucode_api_max; 1205 const unsigned int api_max = il->cfg->ucode_api_max;
1206 const unsigned int api_min = priv->cfg->ucode_api_min; 1206 const unsigned int api_min = il->cfg->ucode_api_min;
1207 u32 api_ver; 1207 u32 api_ver;
1208 1208
1209 u32 max_probe_length = 200; 1209 u32 max_probe_length = 200;
@@ -1213,31 +1213,31 @@ il4965_ucode_callback(const struct firmware *ucode_raw, void *context)
1213 memset(&pieces, 0, sizeof(pieces)); 1213 memset(&pieces, 0, sizeof(pieces));
1214 1214
1215 if (!ucode_raw) { 1215 if (!ucode_raw) {
1216 if (priv->fw_index <= priv->cfg->ucode_api_max) 1216 if (il->fw_index <= il->cfg->ucode_api_max)
1217 IL_ERR(priv, 1217 IL_ERR(il,
1218 "request for firmware file '%s' failed.\n", 1218 "request for firmware file '%s' failed.\n",
1219 priv->firmware_name); 1219 il->firmware_name);
1220 goto try_again; 1220 goto try_again;
1221 } 1221 }
1222 1222
1223 IL_DEBUG_INFO(priv, "Loaded firmware file '%s' (%zd bytes).\n", 1223 IL_DEBUG_INFO(il, "Loaded firmware file '%s' (%zd bytes).\n",
1224 priv->firmware_name, ucode_raw->size); 1224 il->firmware_name, ucode_raw->size);
1225 1225
1226 /* Make sure that we got at least the API version number */ 1226 /* Make sure that we got at least the API version number */
1227 if (ucode_raw->size < 4) { 1227 if (ucode_raw->size < 4) {
1228 IL_ERR(priv, "File size way too small!\n"); 1228 IL_ERR(il, "File size way too small!\n");
1229 goto try_again; 1229 goto try_again;
1230 } 1230 }
1231 1231
1232 /* Data from ucode file: header followed by uCode images */ 1232 /* Data from ucode file: header followed by uCode images */
1233 ucode = (struct il_ucode_header *)ucode_raw->data; 1233 ucode = (struct il_ucode_header *)ucode_raw->data;
1234 1234
1235 err = il4965_load_firmware(priv, ucode_raw, &pieces); 1235 err = il4965_load_firmware(il, ucode_raw, &pieces);
1236 1236
1237 if (err) 1237 if (err)
1238 goto try_again; 1238 goto try_again;
1239 1239
1240 api_ver = IL_UCODE_API(priv->ucode_ver); 1240 api_ver = IL_UCODE_API(il->ucode_ver);
1241 1241
1242 /* 1242 /*
1243 * api_ver should match the api version forming part of the 1243 * api_ver should match the api version forming part of the
@@ -1245,7 +1245,7 @@ il4965_ucode_callback(const struct firmware *ucode_raw, void *context)
1245 * on the API version read from firmware header from here on forward 1245 * on the API version read from firmware header from here on forward
1246 */ 1246 */
1247 if (api_ver < api_min || api_ver > api_max) { 1247 if (api_ver < api_min || api_ver > api_max) {
1248 IL_ERR(priv, 1248 IL_ERR(il,
1249 "Driver unable to support your firmware API. " 1249 "Driver unable to support your firmware API. "
1250 "Driver supports v%u, firmware is v%u.\n", 1250 "Driver supports v%u, firmware is v%u.\n",
1251 api_max, api_ver); 1251 api_max, api_ver);
@@ -1253,25 +1253,25 @@ il4965_ucode_callback(const struct firmware *ucode_raw, void *context)
1253 } 1253 }
1254 1254
1255 if (api_ver != api_max) 1255 if (api_ver != api_max)
1256 IL_ERR(priv, 1256 IL_ERR(il,
1257 "Firmware has old API version. Expected v%u, " 1257 "Firmware has old API version. Expected v%u, "
1258 "got v%u. New firmware can be obtained " 1258 "got v%u. New firmware can be obtained "
1259 "from http://www.intellinuxwireless.org.\n", 1259 "from http://www.intellinuxwireless.org.\n",
1260 api_max, api_ver); 1260 api_max, api_ver);
1261 1261
1262 IL_INFO(priv, "loaded firmware version %u.%u.%u.%u\n", 1262 IL_INFO(il, "loaded firmware version %u.%u.%u.%u\n",
1263 IL_UCODE_MAJOR(priv->ucode_ver), 1263 IL_UCODE_MAJOR(il->ucode_ver),
1264 IL_UCODE_MINOR(priv->ucode_ver), 1264 IL_UCODE_MINOR(il->ucode_ver),
1265 IL_UCODE_API(priv->ucode_ver), 1265 IL_UCODE_API(il->ucode_ver),
1266 IL_UCODE_SERIAL(priv->ucode_ver)); 1266 IL_UCODE_SERIAL(il->ucode_ver));
1267 1267
1268 snprintf(priv->hw->wiphy->fw_version, 1268 snprintf(il->hw->wiphy->fw_version,
1269 sizeof(priv->hw->wiphy->fw_version), 1269 sizeof(il->hw->wiphy->fw_version),
1270 "%u.%u.%u.%u", 1270 "%u.%u.%u.%u",
1271 IL_UCODE_MAJOR(priv->ucode_ver), 1271 IL_UCODE_MAJOR(il->ucode_ver),
1272 IL_UCODE_MINOR(priv->ucode_ver), 1272 IL_UCODE_MINOR(il->ucode_ver),
1273 IL_UCODE_API(priv->ucode_ver), 1273 IL_UCODE_API(il->ucode_ver),
1274 IL_UCODE_SERIAL(priv->ucode_ver)); 1274 IL_UCODE_SERIAL(il->ucode_ver));
1275 1275
1276 /* 1276 /*
1277 * For any of the failures below (before allocating pci memory) 1277 * For any of the failures below (before allocating pci memory)
@@ -1279,46 +1279,46 @@ il4965_ucode_callback(const struct firmware *ucode_raw, void *context)
1279 * user just got a corrupted version of the latest API. 1279 * user just got a corrupted version of the latest API.
1280 */ 1280 */
1281 1281
1282 IL_DEBUG_INFO(priv, "f/w package hdr ucode version raw = 0x%x\n", 1282 IL_DEBUG_INFO(il, "f/w package hdr ucode version raw = 0x%x\n",
1283 priv->ucode_ver); 1283 il->ucode_ver);
1284 IL_DEBUG_INFO(priv, "f/w package hdr runtime inst size = %Zd\n", 1284 IL_DEBUG_INFO(il, "f/w package hdr runtime inst size = %Zd\n",
1285 pieces.inst_size); 1285 pieces.inst_size);
1286 IL_DEBUG_INFO(priv, "f/w package hdr runtime data size = %Zd\n", 1286 IL_DEBUG_INFO(il, "f/w package hdr runtime data size = %Zd\n",
1287 pieces.data_size); 1287 pieces.data_size);
1288 IL_DEBUG_INFO(priv, "f/w package hdr init inst size = %Zd\n", 1288 IL_DEBUG_INFO(il, "f/w package hdr init inst size = %Zd\n",
1289 pieces.init_size); 1289 pieces.init_size);
1290 IL_DEBUG_INFO(priv, "f/w package hdr init data size = %Zd\n", 1290 IL_DEBUG_INFO(il, "f/w package hdr init data size = %Zd\n",
1291 pieces.init_data_size); 1291 pieces.init_data_size);
1292 IL_DEBUG_INFO(priv, "f/w package hdr boot inst size = %Zd\n", 1292 IL_DEBUG_INFO(il, "f/w package hdr boot inst size = %Zd\n",
1293 pieces.boot_size); 1293 pieces.boot_size);
1294 1294
1295 /* Verify that uCode images will fit in card's SRAM */ 1295 /* Verify that uCode images will fit in card's SRAM */
1296 if (pieces.inst_size > priv->hw_params.max_inst_size) { 1296 if (pieces.inst_size > il->hw_params.max_inst_size) {
1297 IL_ERR(priv, "uCode instr len %Zd too large to fit in\n", 1297 IL_ERR(il, "uCode instr len %Zd too large to fit in\n",
1298 pieces.inst_size); 1298 pieces.inst_size);
1299 goto try_again; 1299 goto try_again;
1300 } 1300 }
1301 1301
1302 if (pieces.data_size > priv->hw_params.max_data_size) { 1302 if (pieces.data_size > il->hw_params.max_data_size) {
1303 IL_ERR(priv, "uCode data len %Zd too large to fit in\n", 1303 IL_ERR(il, "uCode data len %Zd too large to fit in\n",
1304 pieces.data_size); 1304 pieces.data_size);
1305 goto try_again; 1305 goto try_again;
1306 } 1306 }
1307 1307
1308 if (pieces.init_size > priv->hw_params.max_inst_size) { 1308 if (pieces.init_size > il->hw_params.max_inst_size) {
1309 IL_ERR(priv, "uCode init instr len %Zd too large to fit in\n", 1309 IL_ERR(il, "uCode init instr len %Zd too large to fit in\n",
1310 pieces.init_size); 1310 pieces.init_size);
1311 goto try_again; 1311 goto try_again;
1312 } 1312 }
1313 1313
1314 if (pieces.init_data_size > priv->hw_params.max_data_size) { 1314 if (pieces.init_data_size > il->hw_params.max_data_size) {
1315 IL_ERR(priv, "uCode init data len %Zd too large to fit in\n", 1315 IL_ERR(il, "uCode init data len %Zd too large to fit in\n",
1316 pieces.init_data_size); 1316 pieces.init_data_size);
1317 goto try_again; 1317 goto try_again;
1318 } 1318 }
1319 1319
1320 if (pieces.boot_size > priv->hw_params.max_bsm_size) { 1320 if (pieces.boot_size > il->hw_params.max_bsm_size) {
1321 IL_ERR(priv, "uCode boot instr len %Zd too large to fit in\n", 1321 IL_ERR(il, "uCode boot instr len %Zd too large to fit in\n",
1322 pieces.boot_size); 1322 pieces.boot_size);
1323 goto try_again; 1323 goto try_again;
1324 } 1324 }
@@ -1328,92 +1328,92 @@ il4965_ucode_callback(const struct firmware *ucode_raw, void *context)
1328 /* Runtime instructions and 2 copies of data: 1328 /* Runtime instructions and 2 copies of data:
1329 * 1) unmodified from disk 1329 * 1) unmodified from disk
1330 * 2) backup cache for save/restore during power-downs */ 1330 * 2) backup cache for save/restore during power-downs */
1331 priv->ucode_code.len = pieces.inst_size; 1331 il->ucode_code.len = pieces.inst_size;
1332 il_alloc_fw_desc(priv->pci_dev, &priv->ucode_code); 1332 il_alloc_fw_desc(il->pci_dev, &il->ucode_code);
1333 1333
1334 priv->ucode_data.len = pieces.data_size; 1334 il->ucode_data.len = pieces.data_size;
1335 il_alloc_fw_desc(priv->pci_dev, &priv->ucode_data); 1335 il_alloc_fw_desc(il->pci_dev, &il->ucode_data);
1336 1336
1337 priv->ucode_data_backup.len = pieces.data_size; 1337 il->ucode_data_backup.len = pieces.data_size;
1338 il_alloc_fw_desc(priv->pci_dev, &priv->ucode_data_backup); 1338 il_alloc_fw_desc(il->pci_dev, &il->ucode_data_backup);
1339 1339
1340 if (!priv->ucode_code.v_addr || !priv->ucode_data.v_addr || 1340 if (!il->ucode_code.v_addr || !il->ucode_data.v_addr ||
1341 !priv->ucode_data_backup.v_addr) 1341 !il->ucode_data_backup.v_addr)
1342 goto err_pci_alloc; 1342 goto err_pci_alloc;
1343 1343
1344 /* Initialization instructions and data */ 1344 /* Initialization instructions and data */
1345 if (pieces.init_size && pieces.init_data_size) { 1345 if (pieces.init_size && pieces.init_data_size) {
1346 priv->ucode_init.len = pieces.init_size; 1346 il->ucode_init.len = pieces.init_size;
1347 il_alloc_fw_desc(priv->pci_dev, &priv->ucode_init); 1347 il_alloc_fw_desc(il->pci_dev, &il->ucode_init);
1348 1348
1349 priv->ucode_init_data.len = pieces.init_data_size; 1349 il->ucode_init_data.len = pieces.init_data_size;
1350 il_alloc_fw_desc(priv->pci_dev, &priv->ucode_init_data); 1350 il_alloc_fw_desc(il->pci_dev, &il->ucode_init_data);
1351 1351
1352 if (!priv->ucode_init.v_addr || !priv->ucode_init_data.v_addr) 1352 if (!il->ucode_init.v_addr || !il->ucode_init_data.v_addr)
1353 goto err_pci_alloc; 1353 goto err_pci_alloc;
1354 } 1354 }
1355 1355
1356 /* Bootstrap (instructions only, no data) */ 1356 /* Bootstrap (instructions only, no data) */
1357 if (pieces.boot_size) { 1357 if (pieces.boot_size) {
1358 priv->ucode_boot.len = pieces.boot_size; 1358 il->ucode_boot.len = pieces.boot_size;
1359 il_alloc_fw_desc(priv->pci_dev, &priv->ucode_boot); 1359 il_alloc_fw_desc(il->pci_dev, &il->ucode_boot);
1360 1360
1361 if (!priv->ucode_boot.v_addr) 1361 if (!il->ucode_boot.v_addr)
1362 goto err_pci_alloc; 1362 goto err_pci_alloc;
1363 } 1363 }
1364 1364
1365 /* Now that we can no longer fail, copy information */ 1365 /* Now that we can no longer fail, copy information */
1366 1366
1367 priv->sta_key_max_num = STA_KEY_MAX_NUM; 1367 il->sta_key_max_num = STA_KEY_MAX_NUM;
1368 1368
1369 /* Copy images into buffers for card's bus-master reads ... */ 1369 /* Copy images into buffers for card's bus-master reads ... */
1370 1370
1371 /* Runtime instructions (first block of data in file) */ 1371 /* Runtime instructions (first block of data in file) */
1372 IL_DEBUG_INFO(priv, "Copying (but not loading) uCode instr len %Zd\n", 1372 IL_DEBUG_INFO(il, "Copying (but not loading) uCode instr len %Zd\n",
1373 pieces.inst_size); 1373 pieces.inst_size);
1374 memcpy(priv->ucode_code.v_addr, pieces.inst, pieces.inst_size); 1374 memcpy(il->ucode_code.v_addr, pieces.inst, pieces.inst_size);
1375 1375
1376 IL_DEBUG_INFO(priv, "uCode instr buf vaddr = 0x%p, paddr = 0x%08x\n", 1376 IL_DEBUG_INFO(il, "uCode instr buf vaddr = 0x%p, paddr = 0x%08x\n",
1377 priv->ucode_code.v_addr, (u32)priv->ucode_code.p_addr); 1377 il->ucode_code.v_addr, (u32)il->ucode_code.p_addr);
1378 1378
1379 /* 1379 /*
1380 * Runtime data 1380 * Runtime data
1381 * NOTE: Copy into backup buffer will be done in il_up() 1381 * NOTE: Copy into backup buffer will be done in il_up()
1382 */ 1382 */
1383 IL_DEBUG_INFO(priv, "Copying (but not loading) uCode data len %Zd\n", 1383 IL_DEBUG_INFO(il, "Copying (but not loading) uCode data len %Zd\n",
1384 pieces.data_size); 1384 pieces.data_size);
1385 memcpy(priv->ucode_data.v_addr, pieces.data, pieces.data_size); 1385 memcpy(il->ucode_data.v_addr, pieces.data, pieces.data_size);
1386 memcpy(priv->ucode_data_backup.v_addr, pieces.data, pieces.data_size); 1386 memcpy(il->ucode_data_backup.v_addr, pieces.data, pieces.data_size);
1387 1387
1388 /* Initialization instructions */ 1388 /* Initialization instructions */
1389 if (pieces.init_size) { 1389 if (pieces.init_size) {
1390 IL_DEBUG_INFO(priv, 1390 IL_DEBUG_INFO(il,
1391 "Copying (but not loading) init instr len %Zd\n", 1391 "Copying (but not loading) init instr len %Zd\n",
1392 pieces.init_size); 1392 pieces.init_size);
1393 memcpy(priv->ucode_init.v_addr, pieces.init, pieces.init_size); 1393 memcpy(il->ucode_init.v_addr, pieces.init, pieces.init_size);
1394 } 1394 }
1395 1395
1396 /* Initialization data */ 1396 /* Initialization data */
1397 if (pieces.init_data_size) { 1397 if (pieces.init_data_size) {
1398 IL_DEBUG_INFO(priv, 1398 IL_DEBUG_INFO(il,
1399 "Copying (but not loading) init data len %Zd\n", 1399 "Copying (but not loading) init data len %Zd\n",
1400 pieces.init_data_size); 1400 pieces.init_data_size);
1401 memcpy(priv->ucode_init_data.v_addr, pieces.init_data, 1401 memcpy(il->ucode_init_data.v_addr, pieces.init_data,
1402 pieces.init_data_size); 1402 pieces.init_data_size);
1403 } 1403 }
1404 1404
1405 /* Bootstrap instructions */ 1405 /* Bootstrap instructions */
1406 IL_DEBUG_INFO(priv, "Copying (but not loading) boot instr len %Zd\n", 1406 IL_DEBUG_INFO(il, "Copying (but not loading) boot instr len %Zd\n",
1407 pieces.boot_size); 1407 pieces.boot_size);
1408 memcpy(priv->ucode_boot.v_addr, pieces.boot, pieces.boot_size); 1408 memcpy(il->ucode_boot.v_addr, pieces.boot, pieces.boot_size);
1409 1409
1410 /* 1410 /*
1411 * figure out the offset of chain noise reset and gain commands 1411 * figure out the offset of chain noise reset and gain commands
1412 * base on the size of standard phy calibration commands table size 1412 * base on the size of standard phy calibration commands table size
1413 */ 1413 */
1414 priv->_4965.phy_calib_chain_noise_reset_cmd = 1414 il->_4965.phy_calib_chain_noise_reset_cmd =
1415 standard_phy_calibration_size; 1415 standard_phy_calibration_size;
1416 priv->_4965.phy_calib_chain_noise_gain_cmd = 1416 il->_4965.phy_calib_chain_noise_gain_cmd =
1417 standard_phy_calibration_size + 1; 1417 standard_phy_calibration_size + 1;
1418 1418
1419 /************************************************** 1419 /**************************************************
@@ -1421,40 +1421,40 @@ il4965_ucode_callback(const struct firmware *ucode_raw, void *context)
1421 * 1421 *
1422 * 9. Setup and register with mac80211 and debugfs 1422 * 9. Setup and register with mac80211 and debugfs
1423 **************************************************/ 1423 **************************************************/
1424 err = il4965_mac_setup_register(priv, max_probe_length); 1424 err = il4965_mac_setup_register(il, max_probe_length);
1425 if (err) 1425 if (err)
1426 goto out_unbind; 1426 goto out_unbind;
1427 1427
1428 err = il_dbgfs_register(priv, DRV_NAME); 1428 err = il_dbgfs_register(il, DRV_NAME);
1429 if (err) 1429 if (err)
1430 IL_ERR(priv, 1430 IL_ERR(il,
1431 "failed to create debugfs files. Ignoring error: %d\n", err); 1431 "failed to create debugfs files. Ignoring error: %d\n", err);
1432 1432
1433 err = sysfs_create_group(&priv->pci_dev->dev.kobj, 1433 err = sysfs_create_group(&il->pci_dev->dev.kobj,
1434 &il_attribute_group); 1434 &il_attribute_group);
1435 if (err) { 1435 if (err) {
1436 IL_ERR(priv, "failed to create sysfs device attributes\n"); 1436 IL_ERR(il, "failed to create sysfs device attributes\n");
1437 goto out_unbind; 1437 goto out_unbind;
1438 } 1438 }
1439 1439
1440 /* We have our copies now, allow OS release its copies */ 1440 /* We have our copies now, allow OS release its copies */
1441 release_firmware(ucode_raw); 1441 release_firmware(ucode_raw);
1442 complete(&priv->_4965.firmware_loading_complete); 1442 complete(&il->_4965.firmware_loading_complete);
1443 return; 1443 return;
1444 1444
1445 try_again: 1445 try_again:
1446 /* try next, if any */ 1446 /* try next, if any */
1447 if (il4965_request_firmware(priv, false)) 1447 if (il4965_request_firmware(il, false))
1448 goto out_unbind; 1448 goto out_unbind;
1449 release_firmware(ucode_raw); 1449 release_firmware(ucode_raw);
1450 return; 1450 return;
1451 1451
1452 err_pci_alloc: 1452 err_pci_alloc:
1453 IL_ERR(priv, "failed to allocate pci memory\n"); 1453 IL_ERR(il, "failed to allocate pci memory\n");
1454 il4965_dealloc_ucode_pci(priv); 1454 il4965_dealloc_ucode_pci(il);
1455 out_unbind: 1455 out_unbind:
1456 complete(&priv->_4965.firmware_loading_complete); 1456 complete(&il->_4965.firmware_loading_complete);
1457 device_release_driver(&priv->pci_dev->dev); 1457 device_release_driver(&il->pci_dev->dev);
1458 release_firmware(ucode_raw); 1458 release_firmware(ucode_raw);
1459} 1459}
1460 1460
@@ -1527,79 +1527,79 @@ static const char *il4965_desc_lookup(u32 num)
1527#define ERROR_START_OFFSET (1 * sizeof(u32)) 1527#define ERROR_START_OFFSET (1 * sizeof(u32))
1528#define ERROR_ELEM_SIZE (7 * sizeof(u32)) 1528#define ERROR_ELEM_SIZE (7 * sizeof(u32))
1529 1529
1530void il4965_dump_nic_error_log(struct il_priv *priv) 1530void il4965_dump_nic_error_log(struct il_priv *il)
1531{ 1531{
1532 u32 data2, line; 1532 u32 data2, line;
1533 u32 desc, time, count, base, data1; 1533 u32 desc, time, count, base, data1;
1534 u32 blink1, blink2, ilink1, ilink2; 1534 u32 blink1, blink2, ilink1, ilink2;
1535 u32 pc, hcmd; 1535 u32 pc, hcmd;
1536 1536
1537 if (priv->ucode_type == UCODE_INIT) { 1537 if (il->ucode_type == UCODE_INIT) {
1538 base = le32_to_cpu(priv->card_alive_init.error_event_table_ptr); 1538 base = le32_to_cpu(il->card_alive_init.error_event_table_ptr);
1539 } else { 1539 } else {
1540 base = le32_to_cpu(priv->card_alive.error_event_table_ptr); 1540 base = le32_to_cpu(il->card_alive.error_event_table_ptr);
1541 } 1541 }
1542 1542
1543 if (!priv->cfg->ops->lib->is_valid_rtc_data_addr(base)) { 1543 if (!il->cfg->ops->lib->is_valid_rtc_data_addr(base)) {
1544 IL_ERR(priv, 1544 IL_ERR(il,
1545 "Not valid error log pointer 0x%08X for %s uCode\n", 1545 "Not valid error log pointer 0x%08X for %s uCode\n",
1546 base, (priv->ucode_type == UCODE_INIT) ? "Init" : "RT"); 1546 base, (il->ucode_type == UCODE_INIT) ? "Init" : "RT");
1547 return; 1547 return;
1548 } 1548 }
1549 1549
1550 count = il_read_targ_mem(priv, base); 1550 count = il_read_targ_mem(il, base);
1551 1551
1552 if (ERROR_START_OFFSET <= count * ERROR_ELEM_SIZE) { 1552 if (ERROR_START_OFFSET <= count * ERROR_ELEM_SIZE) {
1553 IL_ERR(priv, "Start IWL Error Log Dump:\n"); 1553 IL_ERR(il, "Start IWL Error Log Dump:\n");
1554 IL_ERR(priv, "Status: 0x%08lX, count: %d\n", 1554 IL_ERR(il, "Status: 0x%08lX, count: %d\n",
1555 priv->status, count); 1555 il->status, count);
1556 } 1556 }
1557 1557
1558 desc = il_read_targ_mem(priv, base + 1 * sizeof(u32)); 1558 desc = il_read_targ_mem(il, base + 1 * sizeof(u32));
1559 priv->isr_stats.err_code = desc; 1559 il->isr_stats.err_code = desc;
1560 pc = il_read_targ_mem(priv, base + 2 * sizeof(u32)); 1560 pc = il_read_targ_mem(il, base + 2 * sizeof(u32));
1561 blink1 = il_read_targ_mem(priv, base + 3 * sizeof(u32)); 1561 blink1 = il_read_targ_mem(il, base + 3 * sizeof(u32));
1562 blink2 = il_read_targ_mem(priv, base + 4 * sizeof(u32)); 1562 blink2 = il_read_targ_mem(il, base + 4 * sizeof(u32));
1563 ilink1 = il_read_targ_mem(priv, base + 5 * sizeof(u32)); 1563 ilink1 = il_read_targ_mem(il, base + 5 * sizeof(u32));
1564 ilink2 = il_read_targ_mem(priv, base + 6 * sizeof(u32)); 1564 ilink2 = il_read_targ_mem(il, base + 6 * sizeof(u32));
1565 data1 = il_read_targ_mem(priv, base + 7 * sizeof(u32)); 1565 data1 = il_read_targ_mem(il, base + 7 * sizeof(u32));
1566 data2 = il_read_targ_mem(priv, base + 8 * sizeof(u32)); 1566 data2 = il_read_targ_mem(il, base + 8 * sizeof(u32));
1567 line = il_read_targ_mem(priv, base + 9 * sizeof(u32)); 1567 line = il_read_targ_mem(il, base + 9 * sizeof(u32));
1568 time = il_read_targ_mem(priv, base + 11 * sizeof(u32)); 1568 time = il_read_targ_mem(il, base + 11 * sizeof(u32));
1569 hcmd = il_read_targ_mem(priv, base + 22 * sizeof(u32)); 1569 hcmd = il_read_targ_mem(il, base + 22 * sizeof(u32));
1570 1570
1571 IL_ERR(priv, "Desc Time " 1571 IL_ERR(il, "Desc Time "
1572 "data1 data2 line\n"); 1572 "data1 data2 line\n");
1573 IL_ERR(priv, "%-28s (0x%04X) %010u 0x%08X 0x%08X %u\n", 1573 IL_ERR(il, "%-28s (0x%04X) %010u 0x%08X 0x%08X %u\n",
1574 il4965_desc_lookup(desc), desc, time, data1, data2, line); 1574 il4965_desc_lookup(desc), desc, time, data1, data2, line);
1575 IL_ERR(priv, "pc blink1 blink2 ilink1 ilink2 hcmd\n"); 1575 IL_ERR(il, "pc blink1 blink2 ilink1 ilink2 hcmd\n");
1576 IL_ERR(priv, "0x%05X 0x%05X 0x%05X 0x%05X 0x%05X 0x%05X\n", 1576 IL_ERR(il, "0x%05X 0x%05X 0x%05X 0x%05X 0x%05X 0x%05X\n",
1577 pc, blink1, blink2, ilink1, ilink2, hcmd); 1577 pc, blink1, blink2, ilink1, ilink2, hcmd);
1578} 1578}
1579 1579
1580static void il4965_rf_kill_ct_config(struct il_priv *priv) 1580static void il4965_rf_kill_ct_config(struct il_priv *il)
1581{ 1581{
1582 struct il_ct_kill_config cmd; 1582 struct il_ct_kill_config cmd;
1583 unsigned long flags; 1583 unsigned long flags;
1584 int ret = 0; 1584 int ret = 0;
1585 1585
1586 spin_lock_irqsave(&priv->lock, flags); 1586 spin_lock_irqsave(&il->lock, flags);
1587 il_write32(priv, CSR_UCODE_DRV_GP1_CLR, 1587 il_write32(il, CSR_UCODE_DRV_GP1_CLR,
1588 CSR_UCODE_DRV_GP1_REG_BIT_CT_KILL_EXIT); 1588 CSR_UCODE_DRV_GP1_REG_BIT_CT_KILL_EXIT);
1589 spin_unlock_irqrestore(&priv->lock, flags); 1589 spin_unlock_irqrestore(&il->lock, flags);
1590 1590
1591 cmd.critical_temperature_R = 1591 cmd.critical_temperature_R =
1592 cpu_to_le32(priv->hw_params.ct_kill_threshold); 1592 cpu_to_le32(il->hw_params.ct_kill_threshold);
1593 1593
1594 ret = il_send_cmd_pdu(priv, REPLY_CT_KILL_CONFIG_CMD, 1594 ret = il_send_cmd_pdu(il, REPLY_CT_KILL_CONFIG_CMD,
1595 sizeof(cmd), &cmd); 1595 sizeof(cmd), &cmd);
1596 if (ret) 1596 if (ret)
1597 IL_ERR(priv, "REPLY_CT_KILL_CONFIG_CMD failed\n"); 1597 IL_ERR(il, "REPLY_CT_KILL_CONFIG_CMD failed\n");
1598 else 1598 else
1599 IL_DEBUG_INFO(priv, "REPLY_CT_KILL_CONFIG_CMD " 1599 IL_DEBUG_INFO(il, "REPLY_CT_KILL_CONFIG_CMD "
1600 "succeeded, " 1600 "succeeded, "
1601 "critical temperature is %d\n", 1601 "critical temperature is %d\n",
1602 priv->hw_params.ct_kill_threshold); 1602 il->hw_params.ct_kill_threshold);
1603} 1603}
1604 1604
1605static const s8 default_queue_to_tx_fifo[] = { 1605static const s8 default_queue_to_tx_fifo[] = {
@@ -1612,62 +1612,62 @@ static const s8 default_queue_to_tx_fifo[] = {
1612 IL_TX_FIFO_UNUSED, 1612 IL_TX_FIFO_UNUSED,
1613}; 1613};
1614 1614
1615static int il4965_alive_notify(struct il_priv *priv) 1615static int il4965_alive_notify(struct il_priv *il)
1616{ 1616{
1617 u32 a; 1617 u32 a;
1618 unsigned long flags; 1618 unsigned long flags;
1619 int i, chan; 1619 int i, chan;
1620 u32 reg_val; 1620 u32 reg_val;
1621 1621
1622 spin_lock_irqsave(&priv->lock, flags); 1622 spin_lock_irqsave(&il->lock, flags);
1623 1623
1624 /* Clear 4965's internal Tx Scheduler data base */ 1624 /* Clear 4965's internal Tx Scheduler data base */
1625 priv->scd_base_addr = il_read_prph(priv, 1625 il->scd_base_addr = il_read_prph(il,
1626 IWL49_SCD_SRAM_BASE_ADDR); 1626 IWL49_SCD_SRAM_BASE_ADDR);
1627 a = priv->scd_base_addr + IWL49_SCD_CONTEXT_DATA_OFFSET; 1627 a = il->scd_base_addr + IWL49_SCD_CONTEXT_DATA_OFFSET;
1628 for (; a < priv->scd_base_addr + IWL49_SCD_TX_STTS_BITMAP_OFFSET; a += 4) 1628 for (; a < il->scd_base_addr + IWL49_SCD_TX_STTS_BITMAP_OFFSET; a += 4)
1629 il_write_targ_mem(priv, a, 0); 1629 il_write_targ_mem(il, a, 0);
1630 for (; a < priv->scd_base_addr + IWL49_SCD_TRANSLATE_TBL_OFFSET; a += 4) 1630 for (; a < il->scd_base_addr + IWL49_SCD_TRANSLATE_TBL_OFFSET; a += 4)
1631 il_write_targ_mem(priv, a, 0); 1631 il_write_targ_mem(il, a, 0);
1632 for (; a < priv->scd_base_addr + 1632 for (; a < il->scd_base_addr +
1633 IWL49_SCD_TRANSLATE_TBL_OFFSET_QUEUE(priv->hw_params.max_txq_num); a += 4) 1633 IWL49_SCD_TRANSLATE_TBL_OFFSET_QUEUE(il->hw_params.max_txq_num); a += 4)
1634 il_write_targ_mem(priv, a, 0); 1634 il_write_targ_mem(il, a, 0);
1635 1635
1636 /* Tel 4965 where to find Tx byte count tables */ 1636 /* Tel 4965 where to find Tx byte count tables */
1637 il_write_prph(priv, IWL49_SCD_DRAM_BASE_ADDR, 1637 il_write_prph(il, IWL49_SCD_DRAM_BASE_ADDR,
1638 priv->scd_bc_tbls.dma >> 10); 1638 il->scd_bc_tbls.dma >> 10);
1639 1639
1640 /* Enable DMA channel */ 1640 /* Enable DMA channel */
1641 for (chan = 0; chan < FH49_TCSR_CHNL_NUM ; chan++) 1641 for (chan = 0; chan < FH49_TCSR_CHNL_NUM ; chan++)
1642 il_write_direct32(priv, 1642 il_write_direct32(il,
1643 FH_TCSR_CHNL_TX_CONFIG_REG(chan), 1643 FH_TCSR_CHNL_TX_CONFIG_REG(chan),
1644 FH_TCSR_TX_CONFIG_REG_VAL_DMA_CHNL_ENABLE | 1644 FH_TCSR_TX_CONFIG_REG_VAL_DMA_CHNL_ENABLE |
1645 FH_TCSR_TX_CONFIG_REG_VAL_DMA_CREDIT_ENABLE); 1645 FH_TCSR_TX_CONFIG_REG_VAL_DMA_CREDIT_ENABLE);
1646 1646
1647 /* Update FH chicken bits */ 1647 /* Update FH chicken bits */
1648 reg_val = il_read_direct32(priv, FH_TX_CHICKEN_BITS_REG); 1648 reg_val = il_read_direct32(il, FH_TX_CHICKEN_BITS_REG);
1649 il_write_direct32(priv, FH_TX_CHICKEN_BITS_REG, 1649 il_write_direct32(il, FH_TX_CHICKEN_BITS_REG,
1650 reg_val | FH_TX_CHICKEN_BITS_SCD_AUTO_RETRY_EN); 1650 reg_val | FH_TX_CHICKEN_BITS_SCD_AUTO_RETRY_EN);
1651 1651
1652 /* Disable chain mode for all queues */ 1652 /* Disable chain mode for all queues */
1653 il_write_prph(priv, IWL49_SCD_QUEUECHAIN_SEL, 0); 1653 il_write_prph(il, IWL49_SCD_QUEUECHAIN_SEL, 0);
1654 1654
1655 /* Initialize each Tx queue (including the command queue) */ 1655 /* Initialize each Tx queue (including the command queue) */
1656 for (i = 0; i < priv->hw_params.max_txq_num; i++) { 1656 for (i = 0; i < il->hw_params.max_txq_num; i++) {
1657 1657
1658 /* TFD circular buffer read/write indexes */ 1658 /* TFD circular buffer read/write indexes */
1659 il_write_prph(priv, IWL49_SCD_QUEUE_RDPTR(i), 0); 1659 il_write_prph(il, IWL49_SCD_QUEUE_RDPTR(i), 0);
1660 il_write_direct32(priv, HBUS_TARG_WRPTR, 0 | (i << 8)); 1660 il_write_direct32(il, HBUS_TARG_WRPTR, 0 | (i << 8));
1661 1661
1662 /* Max Tx Window size for Scheduler-ACK mode */ 1662 /* Max Tx Window size for Scheduler-ACK mode */
1663 il_write_targ_mem(priv, priv->scd_base_addr + 1663 il_write_targ_mem(il, il->scd_base_addr +
1664 IWL49_SCD_CONTEXT_QUEUE_OFFSET(i), 1664 IWL49_SCD_CONTEXT_QUEUE_OFFSET(i),
1665 (SCD_WIN_SIZE << 1665 (SCD_WIN_SIZE <<
1666 IWL49_SCD_QUEUE_CTX_REG1_WIN_SIZE_POS) & 1666 IWL49_SCD_QUEUE_CTX_REG1_WIN_SIZE_POS) &
1667 IWL49_SCD_QUEUE_CTX_REG1_WIN_SIZE_MSK); 1667 IWL49_SCD_QUEUE_CTX_REG1_WIN_SIZE_MSK);
1668 1668
1669 /* Frame limit */ 1669 /* Frame limit */
1670 il_write_targ_mem(priv, priv->scd_base_addr + 1670 il_write_targ_mem(il, il->scd_base_addr +
1671 IWL49_SCD_CONTEXT_QUEUE_OFFSET(i) + 1671 IWL49_SCD_CONTEXT_QUEUE_OFFSET(i) +
1672 sizeof(u32), 1672 sizeof(u32),
1673 (SCD_FRAME_LIMIT << 1673 (SCD_FRAME_LIMIT <<
@@ -1675,36 +1675,36 @@ static int il4965_alive_notify(struct il_priv *priv)
1675 IWL49_SCD_QUEUE_CTX_REG2_FRAME_LIMIT_MSK); 1675 IWL49_SCD_QUEUE_CTX_REG2_FRAME_LIMIT_MSK);
1676 1676
1677 } 1677 }
1678 il_write_prph(priv, IWL49_SCD_INTERRUPT_MASK, 1678 il_write_prph(il, IWL49_SCD_INTERRUPT_MASK,
1679 (1 << priv->hw_params.max_txq_num) - 1); 1679 (1 << il->hw_params.max_txq_num) - 1);
1680 1680
1681 /* Activate all Tx DMA/FIFO channels */ 1681 /* Activate all Tx DMA/FIFO channels */
1682 il4965_txq_set_sched(priv, IL_MASK(0, 6)); 1682 il4965_txq_set_sched(il, IL_MASK(0, 6));
1683 1683
1684 il4965_set_wr_ptrs(priv, IL_DEFAULT_CMD_QUEUE_NUM, 0); 1684 il4965_set_wr_ptrs(il, IL_DEFAULT_CMD_QUEUE_NUM, 0);
1685 1685
1686 /* make sure all queue are not stopped */ 1686 /* make sure all queue are not stopped */
1687 memset(&priv->queue_stopped[0], 0, sizeof(priv->queue_stopped)); 1687 memset(&il->queue_stopped[0], 0, sizeof(il->queue_stopped));
1688 for (i = 0; i < 4; i++) 1688 for (i = 0; i < 4; i++)
1689 atomic_set(&priv->queue_stop_count[i], 0); 1689 atomic_set(&il->queue_stop_count[i], 0);
1690 1690
1691 /* reset to 0 to enable all the queue first */ 1691 /* reset to 0 to enable all the queue first */
1692 priv->txq_ctx_active_msk = 0; 1692 il->txq_ctx_active_msk = 0;
1693 /* Map each Tx/cmd queue to its corresponding fifo */ 1693 /* Map each Tx/cmd queue to its corresponding fifo */
1694 BUILD_BUG_ON(ARRAY_SIZE(default_queue_to_tx_fifo) != 7); 1694 BUILD_BUG_ON(ARRAY_SIZE(default_queue_to_tx_fifo) != 7);
1695 1695
1696 for (i = 0; i < ARRAY_SIZE(default_queue_to_tx_fifo); i++) { 1696 for (i = 0; i < ARRAY_SIZE(default_queue_to_tx_fifo); i++) {
1697 int ac = default_queue_to_tx_fifo[i]; 1697 int ac = default_queue_to_tx_fifo[i];
1698 1698
1699 il_txq_ctx_activate(priv, i); 1699 il_txq_ctx_activate(il, i);
1700 1700
1701 if (ac == IL_TX_FIFO_UNUSED) 1701 if (ac == IL_TX_FIFO_UNUSED)
1702 continue; 1702 continue;
1703 1703
1704 il4965_tx_queue_set_status(priv, &priv->txq[i], ac, 0); 1704 il4965_tx_queue_set_status(il, &il->txq[i], ac, 0);
1705 } 1705 }
1706 1706
1707 spin_unlock_irqrestore(&priv->lock, flags); 1707 spin_unlock_irqrestore(&il->lock, flags);
1708 1708
1709 return 0; 1709 return 0;
1710} 1710}
@@ -1714,50 +1714,50 @@ static int il4965_alive_notify(struct il_priv *priv)
1714 * from protocol/runtime uCode (initialization uCode's 1714 * from protocol/runtime uCode (initialization uCode's
1715 * Alive gets handled by il_init_alive_start()). 1715 * Alive gets handled by il_init_alive_start()).
1716 */ 1716 */
1717static void il4965_alive_start(struct il_priv *priv) 1717static void il4965_alive_start(struct il_priv *il)
1718{ 1718{
1719 int ret = 0; 1719 int ret = 0;
1720 struct il_rxon_context *ctx = &priv->contexts[IL_RXON_CTX_BSS]; 1720 struct il_rxon_context *ctx = &il->contexts[IL_RXON_CTX_BSS];
1721 1721
1722 IL_DEBUG_INFO(priv, "Runtime Alive received.\n"); 1722 IL_DEBUG_INFO(il, "Runtime Alive received.\n");
1723 1723
1724 if (priv->card_alive.is_valid != UCODE_VALID_OK) { 1724 if (il->card_alive.is_valid != UCODE_VALID_OK) {
1725 /* We had an error bringing up the hardware, so take it 1725 /* We had an error bringing up the hardware, so take it
1726 * all the way back down so we can try again */ 1726 * all the way back down so we can try again */
1727 IL_DEBUG_INFO(priv, "Alive failed.\n"); 1727 IL_DEBUG_INFO(il, "Alive failed.\n");
1728 goto restart; 1728 goto restart;
1729 } 1729 }
1730 1730
1731 /* Initialize uCode has loaded Runtime uCode ... verify inst image. 1731 /* Initialize uCode has loaded Runtime uCode ... verify inst image.
1732 * This is a paranoid check, because we would not have gotten the 1732 * This is a paranoid check, because we would not have gotten the
1733 * "runtime" alive if code weren't properly loaded. */ 1733 * "runtime" alive if code weren't properly loaded. */
1734 if (il4965_verify_ucode(priv)) { 1734 if (il4965_verify_ucode(il)) {
1735 /* Runtime instruction load was bad; 1735 /* Runtime instruction load was bad;
1736 * take it all the way back down so we can try again */ 1736 * take it all the way back down so we can try again */
1737 IL_DEBUG_INFO(priv, "Bad runtime uCode load.\n"); 1737 IL_DEBUG_INFO(il, "Bad runtime uCode load.\n");
1738 goto restart; 1738 goto restart;
1739 } 1739 }
1740 1740
1741 ret = il4965_alive_notify(priv); 1741 ret = il4965_alive_notify(il);
1742 if (ret) { 1742 if (ret) {
1743 IL_WARN(priv, 1743 IL_WARN(il,
1744 "Could not complete ALIVE transition [ntf]: %d\n", ret); 1744 "Could not complete ALIVE transition [ntf]: %d\n", ret);
1745 goto restart; 1745 goto restart;
1746 } 1746 }
1747 1747
1748 1748
1749 /* After the ALIVE response, we can send host commands to the uCode */ 1749 /* After the ALIVE response, we can send host commands to the uCode */
1750 set_bit(STATUS_ALIVE, &priv->status); 1750 set_bit(STATUS_ALIVE, &il->status);
1751 1751
1752 /* Enable watchdog to monitor the driver tx queues */ 1752 /* Enable watchdog to monitor the driver tx queues */
1753 il_setup_watchdog(priv); 1753 il_setup_watchdog(il);
1754 1754
1755 if (il_is_rfkill(priv)) 1755 if (il_is_rfkill(il))
1756 return; 1756 return;
1757 1757
1758 ieee80211_wake_queues(priv->hw); 1758 ieee80211_wake_queues(il->hw);
1759 1759
1760 priv->active_rate = IL_RATES_MASK; 1760 il->active_rate = IL_RATES_MASK;
1761 1761
1762 if (il_is_associated_ctx(ctx)) { 1762 if (il_is_associated_ctx(ctx)) {
1763 struct il_rxon_cmd *active_rxon = 1763 struct il_rxon_cmd *active_rxon =
@@ -1768,290 +1768,290 @@ static void il4965_alive_start(struct il_priv *priv)
1768 } else { 1768 } else {
1769 struct il_rxon_context *tmp; 1769 struct il_rxon_context *tmp;
1770 /* Initialize our rx_config data */ 1770 /* Initialize our rx_config data */
1771 for_each_context(priv, tmp) 1771 for_each_context(il, tmp)
1772 il_connection_init_rx_config(priv, tmp); 1772 il_connection_init_rx_config(il, tmp);
1773 1773
1774 if (priv->cfg->ops->hcmd->set_rxon_chain) 1774 if (il->cfg->ops->hcmd->set_rxon_chain)
1775 priv->cfg->ops->hcmd->set_rxon_chain(priv, ctx); 1775 il->cfg->ops->hcmd->set_rxon_chain(il, ctx);
1776 } 1776 }
1777 1777
1778 /* Configure bluetooth coexistence if enabled */ 1778 /* Configure bluetooth coexistence if enabled */
1779 il_send_bt_config(priv); 1779 il_send_bt_config(il);
1780 1780
1781 il4965_reset_run_time_calib(priv); 1781 il4965_reset_run_time_calib(il);
1782 1782
1783 set_bit(STATUS_READY, &priv->status); 1783 set_bit(STATUS_READY, &il->status);
1784 1784
1785 /* Configure the adapter for unassociated operation */ 1785 /* Configure the adapter for unassociated operation */
1786 il_commit_rxon(priv, ctx); 1786 il_commit_rxon(il, ctx);
1787 1787
1788 /* At this point, the NIC is initialized and operational */ 1788 /* At this point, the NIC is initialized and operational */
1789 il4965_rf_kill_ct_config(priv); 1789 il4965_rf_kill_ct_config(il);
1790 1790
1791 IL_DEBUG_INFO(priv, "ALIVE processing complete.\n"); 1791 IL_DEBUG_INFO(il, "ALIVE processing complete.\n");
1792 wake_up(&priv->wait_command_queue); 1792 wake_up(&il->wait_command_queue);
1793 1793
1794 il_power_update_mode(priv, true); 1794 il_power_update_mode(il, true);
1795 IL_DEBUG_INFO(priv, "Updated power mode\n"); 1795 IL_DEBUG_INFO(il, "Updated power mode\n");
1796 1796
1797 return; 1797 return;
1798 1798
1799 restart: 1799 restart:
1800 queue_work(priv->workqueue, &priv->restart); 1800 queue_work(il->workqueue, &il->restart);
1801} 1801}
1802 1802
1803static void il4965_cancel_deferred_work(struct il_priv *priv); 1803static void il4965_cancel_deferred_work(struct il_priv *il);
1804 1804
1805static void __il4965_down(struct il_priv *priv) 1805static void __il4965_down(struct il_priv *il)
1806{ 1806{
1807 unsigned long flags; 1807 unsigned long flags;
1808 int exit_pending; 1808 int exit_pending;
1809 1809
1810 IL_DEBUG_INFO(priv, DRV_NAME " is going down\n"); 1810 IL_DEBUG_INFO(il, DRV_NAME " is going down\n");
1811 1811
1812 il_scan_cancel_timeout(priv, 200); 1812 il_scan_cancel_timeout(il, 200);
1813 1813
1814 exit_pending = test_and_set_bit(STATUS_EXIT_PENDING, &priv->status); 1814 exit_pending = test_and_set_bit(STATUS_EXIT_PENDING, &il->status);
1815 1815
1816 /* Stop TX queues watchdog. We need to have STATUS_EXIT_PENDING bit set 1816 /* Stop TX queues watchdog. We need to have STATUS_EXIT_PENDING bit set
1817 * to prevent rearm timer */ 1817 * to prevent rearm timer */
1818 del_timer_sync(&priv->watchdog); 1818 del_timer_sync(&il->watchdog);
1819 1819
1820 il_clear_ucode_stations(priv, NULL); 1820 il_clear_ucode_stations(il, NULL);
1821 il_dealloc_bcast_stations(priv); 1821 il_dealloc_bcast_stations(il);
1822 il_clear_driver_stations(priv); 1822 il_clear_driver_stations(il);
1823 1823
1824 /* Unblock any waiting calls */ 1824 /* Unblock any waiting calls */
1825 wake_up_all(&priv->wait_command_queue); 1825 wake_up_all(&il->wait_command_queue);
1826 1826
1827 /* Wipe out the EXIT_PENDING status bit if we are not actually 1827 /* Wipe out the EXIT_PENDING status bit if we are not actually
1828 * exiting the module */ 1828 * exiting the module */
1829 if (!exit_pending) 1829 if (!exit_pending)
1830 clear_bit(STATUS_EXIT_PENDING, &priv->status); 1830 clear_bit(STATUS_EXIT_PENDING, &il->status);
1831 1831
1832 /* stop and reset the on-board processor */ 1832 /* stop and reset the on-board processor */
1833 il_write32(priv, CSR_RESET, CSR_RESET_REG_FLAG_NEVO_RESET); 1833 il_write32(il, CSR_RESET, CSR_RESET_REG_FLAG_NEVO_RESET);
1834 1834
1835 /* tell the device to stop sending interrupts */ 1835 /* tell the device to stop sending interrupts */
1836 spin_lock_irqsave(&priv->lock, flags); 1836 spin_lock_irqsave(&il->lock, flags);
1837 il_disable_interrupts(priv); 1837 il_disable_interrupts(il);
1838 spin_unlock_irqrestore(&priv->lock, flags); 1838 spin_unlock_irqrestore(&il->lock, flags);
1839 il4965_synchronize_irq(priv); 1839 il4965_synchronize_irq(il);
1840 1840
1841 if (priv->mac80211_registered) 1841 if (il->mac80211_registered)
1842 ieee80211_stop_queues(priv->hw); 1842 ieee80211_stop_queues(il->hw);
1843 1843
1844 /* If we have not previously called il_init() then 1844 /* If we have not previously called il_init() then
1845 * clear all bits but the RF Kill bit and return */ 1845 * clear all bits but the RF Kill bit and return */
1846 if (!il_is_init(priv)) { 1846 if (!il_is_init(il)) {
1847 priv->status = test_bit(STATUS_RF_KILL_HW, &priv->status) << 1847 il->status = test_bit(STATUS_RF_KILL_HW, &il->status) <<
1848 STATUS_RF_KILL_HW | 1848 STATUS_RF_KILL_HW |
1849 test_bit(STATUS_GEO_CONFIGURED, &priv->status) << 1849 test_bit(STATUS_GEO_CONFIGURED, &il->status) <<
1850 STATUS_GEO_CONFIGURED | 1850 STATUS_GEO_CONFIGURED |
1851 test_bit(STATUS_EXIT_PENDING, &priv->status) << 1851 test_bit(STATUS_EXIT_PENDING, &il->status) <<
1852 STATUS_EXIT_PENDING; 1852 STATUS_EXIT_PENDING;
1853 goto exit; 1853 goto exit;
1854 } 1854 }
1855 1855
1856 /* ...otherwise clear out all the status bits but the RF Kill 1856 /* ...otherwise clear out all the status bits but the RF Kill
1857 * bit and continue taking the NIC down. */ 1857 * bit and continue taking the NIC down. */
1858 priv->status &= test_bit(STATUS_RF_KILL_HW, &priv->status) << 1858 il->status &= test_bit(STATUS_RF_KILL_HW, &il->status) <<
1859 STATUS_RF_KILL_HW | 1859 STATUS_RF_KILL_HW |
1860 test_bit(STATUS_GEO_CONFIGURED, &priv->status) << 1860 test_bit(STATUS_GEO_CONFIGURED, &il->status) <<
1861 STATUS_GEO_CONFIGURED | 1861 STATUS_GEO_CONFIGURED |
1862 test_bit(STATUS_FW_ERROR, &priv->status) << 1862 test_bit(STATUS_FW_ERROR, &il->status) <<
1863 STATUS_FW_ERROR | 1863 STATUS_FW_ERROR |
1864 test_bit(STATUS_EXIT_PENDING, &priv->status) << 1864 test_bit(STATUS_EXIT_PENDING, &il->status) <<
1865 STATUS_EXIT_PENDING; 1865 STATUS_EXIT_PENDING;
1866 1866
1867 il4965_txq_ctx_stop(priv); 1867 il4965_txq_ctx_stop(il);
1868 il4965_rxq_stop(priv); 1868 il4965_rxq_stop(il);
1869 1869
1870 /* Power-down device's busmaster DMA clocks */ 1870 /* Power-down device's busmaster DMA clocks */
1871 il_write_prph(priv, APMG_CLK_DIS_REG, APMG_CLK_VAL_DMA_CLK_RQT); 1871 il_write_prph(il, APMG_CLK_DIS_REG, APMG_CLK_VAL_DMA_CLK_RQT);
1872 udelay(5); 1872 udelay(5);
1873 1873
1874 /* Make sure (redundant) we've released our request to stay awake */ 1874 /* Make sure (redundant) we've released our request to stay awake */
1875 il_clear_bit(priv, CSR_GP_CNTRL, 1875 il_clear_bit(il, CSR_GP_CNTRL,
1876 CSR_GP_CNTRL_REG_FLAG_MAC_ACCESS_REQ); 1876 CSR_GP_CNTRL_REG_FLAG_MAC_ACCESS_REQ);
1877 1877
1878 /* Stop the device, and put it in low power state */ 1878 /* Stop the device, and put it in low power state */
1879 il_apm_stop(priv); 1879 il_apm_stop(il);
1880 1880
1881 exit: 1881 exit:
1882 memset(&priv->card_alive, 0, sizeof(struct il_alive_resp)); 1882 memset(&il->card_alive, 0, sizeof(struct il_alive_resp));
1883 1883
1884 dev_kfree_skb(priv->beacon_skb); 1884 dev_kfree_skb(il->beacon_skb);
1885 priv->beacon_skb = NULL; 1885 il->beacon_skb = NULL;
1886 1886
1887 /* clear out any free frames */ 1887 /* clear out any free frames */
1888 il4965_clear_free_frames(priv); 1888 il4965_clear_free_frames(il);
1889} 1889}
1890 1890
1891static void il4965_down(struct il_priv *priv) 1891static void il4965_down(struct il_priv *il)
1892{ 1892{
1893 mutex_lock(&priv->mutex); 1893 mutex_lock(&il->mutex);
1894 __il4965_down(priv); 1894 __il4965_down(il);
1895 mutex_unlock(&priv->mutex); 1895 mutex_unlock(&il->mutex);
1896 1896
1897 il4965_cancel_deferred_work(priv); 1897 il4965_cancel_deferred_work(il);
1898} 1898}
1899 1899
1900#define HW_READY_TIMEOUT (50) 1900#define HW_READY_TIMEOUT (50)
1901 1901
1902static int il4965_set_hw_ready(struct il_priv *priv) 1902static int il4965_set_hw_ready(struct il_priv *il)
1903{ 1903{
1904 int ret = 0; 1904 int ret = 0;
1905 1905
1906 il_set_bit(priv, CSR_HW_IF_CONFIG_REG, 1906 il_set_bit(il, CSR_HW_IF_CONFIG_REG,
1907 CSR_HW_IF_CONFIG_REG_BIT_NIC_READY); 1907 CSR_HW_IF_CONFIG_REG_BIT_NIC_READY);
1908 1908
1909 /* See if we got it */ 1909 /* See if we got it */
1910 ret = il_poll_bit(priv, CSR_HW_IF_CONFIG_REG, 1910 ret = il_poll_bit(il, CSR_HW_IF_CONFIG_REG,
1911 CSR_HW_IF_CONFIG_REG_BIT_NIC_READY, 1911 CSR_HW_IF_CONFIG_REG_BIT_NIC_READY,
1912 CSR_HW_IF_CONFIG_REG_BIT_NIC_READY, 1912 CSR_HW_IF_CONFIG_REG_BIT_NIC_READY,
1913 HW_READY_TIMEOUT); 1913 HW_READY_TIMEOUT);
1914 if (ret != -ETIMEDOUT) 1914 if (ret != -ETIMEDOUT)
1915 priv->hw_ready = true; 1915 il->hw_ready = true;
1916 else 1916 else
1917 priv->hw_ready = false; 1917 il->hw_ready = false;
1918 1918
1919 IL_DEBUG_INFO(priv, "hardware %s\n", 1919 IL_DEBUG_INFO(il, "hardware %s\n",
1920 (priv->hw_ready == 1) ? "ready" : "not ready"); 1920 (il->hw_ready == 1) ? "ready" : "not ready");
1921 return ret; 1921 return ret;
1922} 1922}
1923 1923
1924static int il4965_prepare_card_hw(struct il_priv *priv) 1924static int il4965_prepare_card_hw(struct il_priv *il)
1925{ 1925{
1926 int ret = 0; 1926 int ret = 0;
1927 1927
1928 IL_DEBUG_INFO(priv, "il4965_prepare_card_hw enter\n"); 1928 IL_DEBUG_INFO(il, "il4965_prepare_card_hw enter\n");
1929 1929
1930 ret = il4965_set_hw_ready(priv); 1930 ret = il4965_set_hw_ready(il);
1931 if (priv->hw_ready) 1931 if (il->hw_ready)
1932 return ret; 1932 return ret;
1933 1933
1934 /* If HW is not ready, prepare the conditions to check again */ 1934 /* If HW is not ready, prepare the conditions to check again */
1935 il_set_bit(priv, CSR_HW_IF_CONFIG_REG, 1935 il_set_bit(il, CSR_HW_IF_CONFIG_REG,
1936 CSR_HW_IF_CONFIG_REG_PREPARE); 1936 CSR_HW_IF_CONFIG_REG_PREPARE);
1937 1937
1938 ret = il_poll_bit(priv, CSR_HW_IF_CONFIG_REG, 1938 ret = il_poll_bit(il, CSR_HW_IF_CONFIG_REG,
1939 ~CSR_HW_IF_CONFIG_REG_BIT_NIC_PREPARE_DONE, 1939 ~CSR_HW_IF_CONFIG_REG_BIT_NIC_PREPARE_DONE,
1940 CSR_HW_IF_CONFIG_REG_BIT_NIC_PREPARE_DONE, 150000); 1940 CSR_HW_IF_CONFIG_REG_BIT_NIC_PREPARE_DONE, 150000);
1941 1941
1942 /* HW should be ready by now, check again. */ 1942 /* HW should be ready by now, check again. */
1943 if (ret != -ETIMEDOUT) 1943 if (ret != -ETIMEDOUT)
1944 il4965_set_hw_ready(priv); 1944 il4965_set_hw_ready(il);
1945 1945
1946 return ret; 1946 return ret;
1947} 1947}
1948 1948
1949#define MAX_HW_RESTARTS 5 1949#define MAX_HW_RESTARTS 5
1950 1950
1951static int __il4965_up(struct il_priv *priv) 1951static int __il4965_up(struct il_priv *il)
1952{ 1952{
1953 struct il_rxon_context *ctx; 1953 struct il_rxon_context *ctx;
1954 int i; 1954 int i;
1955 int ret; 1955 int ret;
1956 1956
1957 if (test_bit(STATUS_EXIT_PENDING, &priv->status)) { 1957 if (test_bit(STATUS_EXIT_PENDING, &il->status)) {
1958 IL_WARN(priv, "Exit pending; will not bring the NIC up\n"); 1958 IL_WARN(il, "Exit pending; will not bring the NIC up\n");
1959 return -EIO; 1959 return -EIO;
1960 } 1960 }
1961 1961
1962 if (!priv->ucode_data_backup.v_addr || !priv->ucode_data.v_addr) { 1962 if (!il->ucode_data_backup.v_addr || !il->ucode_data.v_addr) {
1963 IL_ERR(priv, "ucode not available for device bringup\n"); 1963 IL_ERR(il, "ucode not available for device bringup\n");
1964 return -EIO; 1964 return -EIO;
1965 } 1965 }
1966 1966
1967 for_each_context(priv, ctx) { 1967 for_each_context(il, ctx) {
1968 ret = il4965_alloc_bcast_station(priv, ctx); 1968 ret = il4965_alloc_bcast_station(il, ctx);
1969 if (ret) { 1969 if (ret) {
1970 il_dealloc_bcast_stations(priv); 1970 il_dealloc_bcast_stations(il);
1971 return ret; 1971 return ret;
1972 } 1972 }
1973 } 1973 }
1974 1974
1975 il4965_prepare_card_hw(priv); 1975 il4965_prepare_card_hw(il);
1976 1976
1977 if (!priv->hw_ready) { 1977 if (!il->hw_ready) {
1978 IL_WARN(priv, "Exit HW not ready\n"); 1978 IL_WARN(il, "Exit HW not ready\n");
1979 return -EIO; 1979 return -EIO;
1980 } 1980 }
1981 1981
1982 /* If platform's RF_KILL switch is NOT set to KILL */ 1982 /* If platform's RF_KILL switch is NOT set to KILL */
1983 if (il_read32(priv, 1983 if (il_read32(il,
1984 CSR_GP_CNTRL) & CSR_GP_CNTRL_REG_FLAG_HW_RF_KILL_SW) 1984 CSR_GP_CNTRL) & CSR_GP_CNTRL_REG_FLAG_HW_RF_KILL_SW)
1985 clear_bit(STATUS_RF_KILL_HW, &priv->status); 1985 clear_bit(STATUS_RF_KILL_HW, &il->status);
1986 else 1986 else
1987 set_bit(STATUS_RF_KILL_HW, &priv->status); 1987 set_bit(STATUS_RF_KILL_HW, &il->status);
1988 1988
1989 if (il_is_rfkill(priv)) { 1989 if (il_is_rfkill(il)) {
1990 wiphy_rfkill_set_hw_state(priv->hw->wiphy, true); 1990 wiphy_rfkill_set_hw_state(il->hw->wiphy, true);
1991 1991
1992 il_enable_interrupts(priv); 1992 il_enable_interrupts(il);
1993 IL_WARN(priv, "Radio disabled by HW RF Kill switch\n"); 1993 IL_WARN(il, "Radio disabled by HW RF Kill switch\n");
1994 return 0; 1994 return 0;
1995 } 1995 }
1996 1996
1997 il_write32(priv, CSR_INT, 0xFFFFFFFF); 1997 il_write32(il, CSR_INT, 0xFFFFFFFF);
1998 1998
1999 /* must be initialised before il_hw_nic_init */ 1999 /* must be initialised before il_hw_nic_init */
2000 priv->cmd_queue = IL_DEFAULT_CMD_QUEUE_NUM; 2000 il->cmd_queue = IL_DEFAULT_CMD_QUEUE_NUM;
2001 2001
2002 ret = il4965_hw_nic_init(priv); 2002 ret = il4965_hw_nic_init(il);
2003 if (ret) { 2003 if (ret) {
2004 IL_ERR(priv, "Unable to init nic\n"); 2004 IL_ERR(il, "Unable to init nic\n");
2005 return ret; 2005 return ret;
2006 } 2006 }
2007 2007
2008 /* make sure rfkill handshake bits are cleared */ 2008 /* make sure rfkill handshake bits are cleared */
2009 il_write32(priv, CSR_UCODE_DRV_GP1_CLR, CSR_UCODE_SW_BIT_RFKILL); 2009 il_write32(il, CSR_UCODE_DRV_GP1_CLR, CSR_UCODE_SW_BIT_RFKILL);
2010 il_write32(priv, CSR_UCODE_DRV_GP1_CLR, 2010 il_write32(il, CSR_UCODE_DRV_GP1_CLR,
2011 CSR_UCODE_DRV_GP1_BIT_CMD_BLOCKED); 2011 CSR_UCODE_DRV_GP1_BIT_CMD_BLOCKED);
2012 2012
2013 /* clear (again), then enable host interrupts */ 2013 /* clear (again), then enable host interrupts */
2014 il_write32(priv, CSR_INT, 0xFFFFFFFF); 2014 il_write32(il, CSR_INT, 0xFFFFFFFF);
2015 il_enable_interrupts(priv); 2015 il_enable_interrupts(il);
2016 2016
2017 /* really make sure rfkill handshake bits are cleared */ 2017 /* really make sure rfkill handshake bits are cleared */
2018 il_write32(priv, CSR_UCODE_DRV_GP1_CLR, CSR_UCODE_SW_BIT_RFKILL); 2018 il_write32(il, CSR_UCODE_DRV_GP1_CLR, CSR_UCODE_SW_BIT_RFKILL);
2019 il_write32(priv, CSR_UCODE_DRV_GP1_CLR, CSR_UCODE_SW_BIT_RFKILL); 2019 il_write32(il, CSR_UCODE_DRV_GP1_CLR, CSR_UCODE_SW_BIT_RFKILL);
2020 2020
2021 /* Copy original ucode data image from disk into backup cache. 2021 /* Copy original ucode data image from disk into backup cache.
2022 * This will be used to initialize the on-board processor's 2022 * This will be used to initialize the on-board processor's
2023 * data SRAM for a clean start when the runtime program first loads. */ 2023 * data SRAM for a clean start when the runtime program first loads. */
2024 memcpy(priv->ucode_data_backup.v_addr, priv->ucode_data.v_addr, 2024 memcpy(il->ucode_data_backup.v_addr, il->ucode_data.v_addr,
2025 priv->ucode_data.len); 2025 il->ucode_data.len);
2026 2026
2027 for (i = 0; i < MAX_HW_RESTARTS; i++) { 2027 for (i = 0; i < MAX_HW_RESTARTS; i++) {
2028 2028
2029 /* load bootstrap state machine, 2029 /* load bootstrap state machine,
2030 * load bootstrap program into processor's memory, 2030 * load bootstrap program into processor's memory,
2031 * prepare to load the "initialize" uCode */ 2031 * prepare to load the "initialize" uCode */
2032 ret = priv->cfg->ops->lib->load_ucode(priv); 2032 ret = il->cfg->ops->lib->load_ucode(il);
2033 2033
2034 if (ret) { 2034 if (ret) {
2035 IL_ERR(priv, "Unable to set up bootstrap uCode: %d\n", 2035 IL_ERR(il, "Unable to set up bootstrap uCode: %d\n",
2036 ret); 2036 ret);
2037 continue; 2037 continue;
2038 } 2038 }
2039 2039
2040 /* start card; "initialize" will load runtime ucode */ 2040 /* start card; "initialize" will load runtime ucode */
2041 il4965_nic_start(priv); 2041 il4965_nic_start(il);
2042 2042
2043 IL_DEBUG_INFO(priv, DRV_NAME " is coming up\n"); 2043 IL_DEBUG_INFO(il, DRV_NAME " is coming up\n");
2044 2044
2045 return 0; 2045 return 0;
2046 } 2046 }
2047 2047
2048 set_bit(STATUS_EXIT_PENDING, &priv->status); 2048 set_bit(STATUS_EXIT_PENDING, &il->status);
2049 __il4965_down(priv); 2049 __il4965_down(il);
2050 clear_bit(STATUS_EXIT_PENDING, &priv->status); 2050 clear_bit(STATUS_EXIT_PENDING, &il->status);
2051 2051
2052 /* tried to restart and config the device for as long as our 2052 /* tried to restart and config the device for as long as our
2053 * patience could withstand */ 2053 * patience could withstand */
2054 IL_ERR(priv, "Unable to initialize device after %d attempts.\n", i); 2054 IL_ERR(il, "Unable to initialize device after %d attempts.\n", i);
2055 return -EIO; 2055 return -EIO;
2056} 2056}
2057 2057
@@ -2064,100 +2064,100 @@ static int __il4965_up(struct il_priv *priv)
2064 2064
2065static void il4965_bg_init_alive_start(struct work_struct *data) 2065static void il4965_bg_init_alive_start(struct work_struct *data)
2066{ 2066{
2067 struct il_priv *priv = 2067 struct il_priv *il =
2068 container_of(data, struct il_priv, init_alive_start.work); 2068 container_of(data, struct il_priv, init_alive_start.work);
2069 2069
2070 mutex_lock(&priv->mutex); 2070 mutex_lock(&il->mutex);
2071 if (test_bit(STATUS_EXIT_PENDING, &priv->status)) 2071 if (test_bit(STATUS_EXIT_PENDING, &il->status))
2072 goto out; 2072 goto out;
2073 2073
2074 priv->cfg->ops->lib->init_alive_start(priv); 2074 il->cfg->ops->lib->init_alive_start(il);
2075out: 2075out:
2076 mutex_unlock(&priv->mutex); 2076 mutex_unlock(&il->mutex);
2077} 2077}
2078 2078
2079static void il4965_bg_alive_start(struct work_struct *data) 2079static void il4965_bg_alive_start(struct work_struct *data)
2080{ 2080{
2081 struct il_priv *priv = 2081 struct il_priv *il =
2082 container_of(data, struct il_priv, alive_start.work); 2082 container_of(data, struct il_priv, alive_start.work);
2083 2083
2084 mutex_lock(&priv->mutex); 2084 mutex_lock(&il->mutex);
2085 if (test_bit(STATUS_EXIT_PENDING, &priv->status)) 2085 if (test_bit(STATUS_EXIT_PENDING, &il->status))
2086 goto out; 2086 goto out;
2087 2087
2088 il4965_alive_start(priv); 2088 il4965_alive_start(il);
2089out: 2089out:
2090 mutex_unlock(&priv->mutex); 2090 mutex_unlock(&il->mutex);
2091} 2091}
2092 2092
2093static void il4965_bg_run_time_calib_work(struct work_struct *work) 2093static void il4965_bg_run_time_calib_work(struct work_struct *work)
2094{ 2094{
2095 struct il_priv *priv = container_of(work, struct il_priv, 2095 struct il_priv *il = container_of(work, struct il_priv,
2096 run_time_calib_work); 2096 run_time_calib_work);
2097 2097
2098 mutex_lock(&priv->mutex); 2098 mutex_lock(&il->mutex);
2099 2099
2100 if (test_bit(STATUS_EXIT_PENDING, &priv->status) || 2100 if (test_bit(STATUS_EXIT_PENDING, &il->status) ||
2101 test_bit(STATUS_SCANNING, &priv->status)) { 2101 test_bit(STATUS_SCANNING, &il->status)) {
2102 mutex_unlock(&priv->mutex); 2102 mutex_unlock(&il->mutex);
2103 return; 2103 return;
2104 } 2104 }
2105 2105
2106 if (priv->start_calib) { 2106 if (il->start_calib) {
2107 il4965_chain_noise_calibration(priv, 2107 il4965_chain_noise_calibration(il,
2108 (void *)&priv->_4965.statistics); 2108 (void *)&il->_4965.statistics);
2109 il4965_sensitivity_calibration(priv, 2109 il4965_sensitivity_calibration(il,
2110 (void *)&priv->_4965.statistics); 2110 (void *)&il->_4965.statistics);
2111 } 2111 }
2112 2112
2113 mutex_unlock(&priv->mutex); 2113 mutex_unlock(&il->mutex);
2114} 2114}
2115 2115
2116static void il4965_bg_restart(struct work_struct *data) 2116static void il4965_bg_restart(struct work_struct *data)
2117{ 2117{
2118 struct il_priv *priv = container_of(data, struct il_priv, restart); 2118 struct il_priv *il = container_of(data, struct il_priv, restart);
2119 2119
2120 if (test_bit(STATUS_EXIT_PENDING, &priv->status)) 2120 if (test_bit(STATUS_EXIT_PENDING, &il->status))
2121 return; 2121 return;
2122 2122
2123 if (test_and_clear_bit(STATUS_FW_ERROR, &priv->status)) { 2123 if (test_and_clear_bit(STATUS_FW_ERROR, &il->status)) {
2124 struct il_rxon_context *ctx; 2124 struct il_rxon_context *ctx;
2125 2125
2126 mutex_lock(&priv->mutex); 2126 mutex_lock(&il->mutex);
2127 for_each_context(priv, ctx) 2127 for_each_context(il, ctx)
2128 ctx->vif = NULL; 2128 ctx->vif = NULL;
2129 priv->is_open = 0; 2129 il->is_open = 0;
2130 2130
2131 __il4965_down(priv); 2131 __il4965_down(il);
2132 2132
2133 mutex_unlock(&priv->mutex); 2133 mutex_unlock(&il->mutex);
2134 il4965_cancel_deferred_work(priv); 2134 il4965_cancel_deferred_work(il);
2135 ieee80211_restart_hw(priv->hw); 2135 ieee80211_restart_hw(il->hw);
2136 } else { 2136 } else {
2137 il4965_down(priv); 2137 il4965_down(il);
2138 2138
2139 mutex_lock(&priv->mutex); 2139 mutex_lock(&il->mutex);
2140 if (test_bit(STATUS_EXIT_PENDING, &priv->status)) { 2140 if (test_bit(STATUS_EXIT_PENDING, &il->status)) {
2141 mutex_unlock(&priv->mutex); 2141 mutex_unlock(&il->mutex);
2142 return; 2142 return;
2143 } 2143 }
2144 2144
2145 __il4965_up(priv); 2145 __il4965_up(il);
2146 mutex_unlock(&priv->mutex); 2146 mutex_unlock(&il->mutex);
2147 } 2147 }
2148} 2148}
2149 2149
2150static void il4965_bg_rx_replenish(struct work_struct *data) 2150static void il4965_bg_rx_replenish(struct work_struct *data)
2151{ 2151{
2152 struct il_priv *priv = 2152 struct il_priv *il =
2153 container_of(data, struct il_priv, rx_replenish); 2153 container_of(data, struct il_priv, rx_replenish);
2154 2154
2155 if (test_bit(STATUS_EXIT_PENDING, &priv->status)) 2155 if (test_bit(STATUS_EXIT_PENDING, &il->status))
2156 return; 2156 return;
2157 2157
2158 mutex_lock(&priv->mutex); 2158 mutex_lock(&il->mutex);
2159 il4965_rx_replenish(priv); 2159 il4965_rx_replenish(il);
2160 mutex_unlock(&priv->mutex); 2160 mutex_unlock(&il->mutex);
2161} 2161}
2162 2162
2163/***************************************************************************** 2163/*****************************************************************************
@@ -2172,11 +2172,11 @@ static void il4965_bg_rx_replenish(struct work_struct *data)
2172 * Not a mac80211 entry point function, but it fits in with all the 2172 * Not a mac80211 entry point function, but it fits in with all the
2173 * other mac80211 functions grouped here. 2173 * other mac80211 functions grouped here.
2174 */ 2174 */
2175static int il4965_mac_setup_register(struct il_priv *priv, 2175static int il4965_mac_setup_register(struct il_priv *il,
2176 u32 max_probe_length) 2176 u32 max_probe_length)
2177{ 2177{
2178 int ret; 2178 int ret;
2179 struct ieee80211_hw *hw = priv->hw; 2179 struct ieee80211_hw *hw = il->hw;
2180 struct il_rxon_context *ctx; 2180 struct il_rxon_context *ctx;
2181 2181
2182 hw->rate_control_algorithm = "iwl-4965-rs"; 2182 hw->rate_control_algorithm = "iwl-4965-rs";
@@ -2188,14 +2188,14 @@ static int il4965_mac_setup_register(struct il_priv *priv,
2188 IEEE80211_HW_SPECTRUM_MGMT | 2188 IEEE80211_HW_SPECTRUM_MGMT |
2189 IEEE80211_HW_REPORTS_TX_ACK_STATUS; 2189 IEEE80211_HW_REPORTS_TX_ACK_STATUS;
2190 2190
2191 if (priv->cfg->sku & IL_SKU_N) 2191 if (il->cfg->sku & IL_SKU_N)
2192 hw->flags |= IEEE80211_HW_SUPPORTS_DYNAMIC_SMPS | 2192 hw->flags |= IEEE80211_HW_SUPPORTS_DYNAMIC_SMPS |
2193 IEEE80211_HW_SUPPORTS_STATIC_SMPS; 2193 IEEE80211_HW_SUPPORTS_STATIC_SMPS;
2194 2194
2195 hw->sta_data_size = sizeof(struct il_station_priv); 2195 hw->sta_data_size = sizeof(struct il_station_priv);
2196 hw->vif_data_size = sizeof(struct il_vif_priv); 2196 hw->vif_data_size = sizeof(struct il_vif_priv);
2197 2197
2198 for_each_context(priv, ctx) { 2198 for_each_context(il, ctx) {
2199 hw->wiphy->interface_modes |= ctx->interface_modes; 2199 hw->wiphy->interface_modes |= ctx->interface_modes;
2200 hw->wiphy->interface_modes |= ctx->exclusive_interface_modes; 2200 hw->wiphy->interface_modes |= ctx->exclusive_interface_modes;
2201 } 2201 }
@@ -2218,21 +2218,21 @@ static int il4965_mac_setup_register(struct il_priv *priv,
2218 2218
2219 hw->max_listen_interval = IL_CONN_MAX_LISTEN_INTERVAL; 2219 hw->max_listen_interval = IL_CONN_MAX_LISTEN_INTERVAL;
2220 2220
2221 if (priv->bands[IEEE80211_BAND_2GHZ].n_channels) 2221 if (il->bands[IEEE80211_BAND_2GHZ].n_channels)
2222 priv->hw->wiphy->bands[IEEE80211_BAND_2GHZ] = 2222 il->hw->wiphy->bands[IEEE80211_BAND_2GHZ] =
2223 &priv->bands[IEEE80211_BAND_2GHZ]; 2223 &il->bands[IEEE80211_BAND_2GHZ];
2224 if (priv->bands[IEEE80211_BAND_5GHZ].n_channels) 2224 if (il->bands[IEEE80211_BAND_5GHZ].n_channels)
2225 priv->hw->wiphy->bands[IEEE80211_BAND_5GHZ] = 2225 il->hw->wiphy->bands[IEEE80211_BAND_5GHZ] =
2226 &priv->bands[IEEE80211_BAND_5GHZ]; 2226 &il->bands[IEEE80211_BAND_5GHZ];
2227 2227
2228 il_leds_init(priv); 2228 il_leds_init(il);
2229 2229
2230 ret = ieee80211_register_hw(priv->hw); 2230 ret = ieee80211_register_hw(il->hw);
2231 if (ret) { 2231 if (ret) {
2232 IL_ERR(priv, "Failed to register hw (error %d)\n", ret); 2232 IL_ERR(il, "Failed to register hw (error %d)\n", ret);
2233 return ret; 2233 return ret;
2234 } 2234 }
2235 priv->mac80211_registered = 1; 2235 il->mac80211_registered = 1;
2236 2236
2237 return 0; 2237 return 0;
2238} 2238}
@@ -2240,81 +2240,81 @@ static int il4965_mac_setup_register(struct il_priv *priv,
2240 2240
2241int il4965_mac_start(struct ieee80211_hw *hw) 2241int il4965_mac_start(struct ieee80211_hw *hw)
2242{ 2242{
2243 struct il_priv *priv = hw->priv; 2243 struct il_priv *il = hw->priv;
2244 int ret; 2244 int ret;
2245 2245
2246 IL_DEBUG_MAC80211(priv, "enter\n"); 2246 IL_DEBUG_MAC80211(il, "enter\n");
2247 2247
2248 /* we should be verifying the device is ready to be opened */ 2248 /* we should be verifying the device is ready to be opened */
2249 mutex_lock(&priv->mutex); 2249 mutex_lock(&il->mutex);
2250 ret = __il4965_up(priv); 2250 ret = __il4965_up(il);
2251 mutex_unlock(&priv->mutex); 2251 mutex_unlock(&il->mutex);
2252 2252
2253 if (ret) 2253 if (ret)
2254 return ret; 2254 return ret;
2255 2255
2256 if (il_is_rfkill(priv)) 2256 if (il_is_rfkill(il))
2257 goto out; 2257 goto out;
2258 2258
2259 IL_DEBUG_INFO(priv, "Start UP work done.\n"); 2259 IL_DEBUG_INFO(il, "Start UP work done.\n");
2260 2260
2261 /* Wait for START_ALIVE from Run Time ucode. Otherwise callbacks from 2261 /* Wait for START_ALIVE from Run Time ucode. Otherwise callbacks from
2262 * mac80211 will not be run successfully. */ 2262 * mac80211 will not be run successfully. */
2263 ret = wait_event_timeout(priv->wait_command_queue, 2263 ret = wait_event_timeout(il->wait_command_queue,
2264 test_bit(STATUS_READY, &priv->status), 2264 test_bit(STATUS_READY, &il->status),
2265 UCODE_READY_TIMEOUT); 2265 UCODE_READY_TIMEOUT);
2266 if (!ret) { 2266 if (!ret) {
2267 if (!test_bit(STATUS_READY, &priv->status)) { 2267 if (!test_bit(STATUS_READY, &il->status)) {
2268 IL_ERR(priv, "START_ALIVE timeout after %dms.\n", 2268 IL_ERR(il, "START_ALIVE timeout after %dms.\n",
2269 jiffies_to_msecs(UCODE_READY_TIMEOUT)); 2269 jiffies_to_msecs(UCODE_READY_TIMEOUT));
2270 return -ETIMEDOUT; 2270 return -ETIMEDOUT;
2271 } 2271 }
2272 } 2272 }
2273 2273
2274 il4965_led_enable(priv); 2274 il4965_led_enable(il);
2275 2275
2276out: 2276out:
2277 priv->is_open = 1; 2277 il->is_open = 1;
2278 IL_DEBUG_MAC80211(priv, "leave\n"); 2278 IL_DEBUG_MAC80211(il, "leave\n");
2279 return 0; 2279 return 0;
2280} 2280}
2281 2281
2282void il4965_mac_stop(struct ieee80211_hw *hw) 2282void il4965_mac_stop(struct ieee80211_hw *hw)
2283{ 2283{
2284 struct il_priv *priv = hw->priv; 2284 struct il_priv *il = hw->priv;
2285 2285
2286 IL_DEBUG_MAC80211(priv, "enter\n"); 2286 IL_DEBUG_MAC80211(il, "enter\n");
2287 2287
2288 if (!priv->is_open) 2288 if (!il->is_open)
2289 return; 2289 return;
2290 2290
2291 priv->is_open = 0; 2291 il->is_open = 0;
2292 2292
2293 il4965_down(priv); 2293 il4965_down(il);
2294 2294
2295 flush_workqueue(priv->workqueue); 2295 flush_workqueue(il->workqueue);
2296 2296
2297 /* User space software may expect getting rfkill changes 2297 /* User space software may expect getting rfkill changes
2298 * even if interface is down */ 2298 * even if interface is down */
2299 il_write32(priv, CSR_INT, 0xFFFFFFFF); 2299 il_write32(il, CSR_INT, 0xFFFFFFFF);
2300 il_enable_rfkill_int(priv); 2300 il_enable_rfkill_int(il);
2301 2301
2302 IL_DEBUG_MAC80211(priv, "leave\n"); 2302 IL_DEBUG_MAC80211(il, "leave\n");
2303} 2303}
2304 2304
2305void il4965_mac_tx(struct ieee80211_hw *hw, struct sk_buff *skb) 2305void il4965_mac_tx(struct ieee80211_hw *hw, struct sk_buff *skb)
2306{ 2306{
2307 struct il_priv *priv = hw->priv; 2307 struct il_priv *il = hw->priv;
2308 2308
2309 IL_DEBUG_MACDUMP(priv, "enter\n"); 2309 IL_DEBUG_MACDUMP(il, "enter\n");
2310 2310
2311 IL_DEBUG_TX(priv, "dev->xmit(%d bytes) at rate 0x%02x\n", skb->len, 2311 IL_DEBUG_TX(il, "dev->xmit(%d bytes) at rate 0x%02x\n", skb->len,
2312 ieee80211_get_tx_rate(hw, IEEE80211_SKB_CB(skb))->bitrate); 2312 ieee80211_get_tx_rate(hw, IEEE80211_SKB_CB(skb))->bitrate);
2313 2313
2314 if (il4965_tx_skb(priv, skb)) 2314 if (il4965_tx_skb(il, skb))
2315 dev_kfree_skb_any(skb); 2315 dev_kfree_skb_any(skb);
2316 2316
2317 IL_DEBUG_MACDUMP(priv, "leave\n"); 2317 IL_DEBUG_MACDUMP(il, "leave\n");
2318} 2318}
2319 2319
2320void il4965_mac_update_tkip_key(struct ieee80211_hw *hw, 2320void il4965_mac_update_tkip_key(struct ieee80211_hw *hw,
@@ -2323,41 +2323,41 @@ void il4965_mac_update_tkip_key(struct ieee80211_hw *hw,
2323 struct ieee80211_sta *sta, 2323 struct ieee80211_sta *sta,
2324 u32 iv32, u16 *phase1key) 2324 u32 iv32, u16 *phase1key)
2325{ 2325{
2326 struct il_priv *priv = hw->priv; 2326 struct il_priv *il = hw->priv;
2327 struct il_vif_priv *vif_priv = (void *)vif->drv_priv; 2327 struct il_vif_priv *vif_priv = (void *)vif->drv_priv;
2328 2328
2329 IL_DEBUG_MAC80211(priv, "enter\n"); 2329 IL_DEBUG_MAC80211(il, "enter\n");
2330 2330
2331 il4965_update_tkip_key(priv, vif_priv->ctx, keyconf, sta, 2331 il4965_update_tkip_key(il, vif_priv->ctx, keyconf, sta,
2332 iv32, phase1key); 2332 iv32, phase1key);
2333 2333
2334 IL_DEBUG_MAC80211(priv, "leave\n"); 2334 IL_DEBUG_MAC80211(il, "leave\n");
2335} 2335}
2336 2336
2337int il4965_mac_set_key(struct ieee80211_hw *hw, enum set_key_cmd cmd, 2337int il4965_mac_set_key(struct ieee80211_hw *hw, enum set_key_cmd cmd,
2338 struct ieee80211_vif *vif, struct ieee80211_sta *sta, 2338 struct ieee80211_vif *vif, struct ieee80211_sta *sta,
2339 struct ieee80211_key_conf *key) 2339 struct ieee80211_key_conf *key)
2340{ 2340{
2341 struct il_priv *priv = hw->priv; 2341 struct il_priv *il = hw->priv;
2342 struct il_vif_priv *vif_priv = (void *)vif->drv_priv; 2342 struct il_vif_priv *vif_priv = (void *)vif->drv_priv;
2343 struct il_rxon_context *ctx = vif_priv->ctx; 2343 struct il_rxon_context *ctx = vif_priv->ctx;
2344 int ret; 2344 int ret;
2345 u8 sta_id; 2345 u8 sta_id;
2346 bool is_default_wep_key = false; 2346 bool is_default_wep_key = false;
2347 2347
2348 IL_DEBUG_MAC80211(priv, "enter\n"); 2348 IL_DEBUG_MAC80211(il, "enter\n");
2349 2349
2350 if (priv->cfg->mod_params->sw_crypto) { 2350 if (il->cfg->mod_params->sw_crypto) {
2351 IL_DEBUG_MAC80211(priv, "leave - hwcrypto disabled\n"); 2351 IL_DEBUG_MAC80211(il, "leave - hwcrypto disabled\n");
2352 return -EOPNOTSUPP; 2352 return -EOPNOTSUPP;
2353 } 2353 }
2354 2354
2355 sta_id = il_sta_id_or_broadcast(priv, vif_priv->ctx, sta); 2355 sta_id = il_sta_id_or_broadcast(il, vif_priv->ctx, sta);
2356 if (sta_id == IL_INVALID_STATION) 2356 if (sta_id == IL_INVALID_STATION)
2357 return -EINVAL; 2357 return -EINVAL;
2358 2358
2359 mutex_lock(&priv->mutex); 2359 mutex_lock(&il->mutex);
2360 il_scan_cancel_timeout(priv, 100); 2360 il_scan_cancel_timeout(il, 100);
2361 2361
2362 /* 2362 /*
2363 * If we are getting WEP group key and we didn't receive any key mapping 2363 * If we are getting WEP group key and we didn't receive any key mapping
@@ -2378,29 +2378,29 @@ int il4965_mac_set_key(struct ieee80211_hw *hw, enum set_key_cmd cmd,
2378 switch (cmd) { 2378 switch (cmd) {
2379 case SET_KEY: 2379 case SET_KEY:
2380 if (is_default_wep_key) 2380 if (is_default_wep_key)
2381 ret = il4965_set_default_wep_key(priv, 2381 ret = il4965_set_default_wep_key(il,
2382 vif_priv->ctx, key); 2382 vif_priv->ctx, key);
2383 else 2383 else
2384 ret = il4965_set_dynamic_key(priv, vif_priv->ctx, 2384 ret = il4965_set_dynamic_key(il, vif_priv->ctx,
2385 key, sta_id); 2385 key, sta_id);
2386 2386
2387 IL_DEBUG_MAC80211(priv, "enable hwcrypto key\n"); 2387 IL_DEBUG_MAC80211(il, "enable hwcrypto key\n");
2388 break; 2388 break;
2389 case DISABLE_KEY: 2389 case DISABLE_KEY:
2390 if (is_default_wep_key) 2390 if (is_default_wep_key)
2391 ret = il4965_remove_default_wep_key(priv, ctx, key); 2391 ret = il4965_remove_default_wep_key(il, ctx, key);
2392 else 2392 else
2393 ret = il4965_remove_dynamic_key(priv, ctx, 2393 ret = il4965_remove_dynamic_key(il, ctx,
2394 key, sta_id); 2394 key, sta_id);
2395 2395
2396 IL_DEBUG_MAC80211(priv, "disable hwcrypto key\n"); 2396 IL_DEBUG_MAC80211(il, "disable hwcrypto key\n");
2397 break; 2397 break;
2398 default: 2398 default:
2399 ret = -EINVAL; 2399 ret = -EINVAL;
2400 } 2400 }
2401 2401
2402 mutex_unlock(&priv->mutex); 2402 mutex_unlock(&il->mutex);
2403 IL_DEBUG_MAC80211(priv, "leave\n"); 2403 IL_DEBUG_MAC80211(il, "leave\n");
2404 2404
2405 return ret; 2405 return ret;
2406} 2406}
@@ -2411,43 +2411,43 @@ int il4965_mac_ampdu_action(struct ieee80211_hw *hw,
2411 struct ieee80211_sta *sta, u16 tid, u16 *ssn, 2411 struct ieee80211_sta *sta, u16 tid, u16 *ssn,
2412 u8 buf_size) 2412 u8 buf_size)
2413{ 2413{
2414 struct il_priv *priv = hw->priv; 2414 struct il_priv *il = hw->priv;
2415 int ret = -EINVAL; 2415 int ret = -EINVAL;
2416 2416
2417 IL_DEBUG_HT(priv, "A-MPDU action on addr %pM tid %d\n", 2417 IL_DEBUG_HT(il, "A-MPDU action on addr %pM tid %d\n",
2418 sta->addr, tid); 2418 sta->addr, tid);
2419 2419
2420 if (!(priv->cfg->sku & IL_SKU_N)) 2420 if (!(il->cfg->sku & IL_SKU_N))
2421 return -EACCES; 2421 return -EACCES;
2422 2422
2423 mutex_lock(&priv->mutex); 2423 mutex_lock(&il->mutex);
2424 2424
2425 switch (action) { 2425 switch (action) {
2426 case IEEE80211_AMPDU_RX_START: 2426 case IEEE80211_AMPDU_RX_START:
2427 IL_DEBUG_HT(priv, "start Rx\n"); 2427 IL_DEBUG_HT(il, "start Rx\n");
2428 ret = il4965_sta_rx_agg_start(priv, sta, tid, *ssn); 2428 ret = il4965_sta_rx_agg_start(il, sta, tid, *ssn);
2429 break; 2429 break;
2430 case IEEE80211_AMPDU_RX_STOP: 2430 case IEEE80211_AMPDU_RX_STOP:
2431 IL_DEBUG_HT(priv, "stop Rx\n"); 2431 IL_DEBUG_HT(il, "stop Rx\n");
2432 ret = il4965_sta_rx_agg_stop(priv, sta, tid); 2432 ret = il4965_sta_rx_agg_stop(il, sta, tid);
2433 if (test_bit(STATUS_EXIT_PENDING, &priv->status)) 2433 if (test_bit(STATUS_EXIT_PENDING, &il->status))
2434 ret = 0; 2434 ret = 0;
2435 break; 2435 break;
2436 case IEEE80211_AMPDU_TX_START: 2436 case IEEE80211_AMPDU_TX_START:
2437 IL_DEBUG_HT(priv, "start Tx\n"); 2437 IL_DEBUG_HT(il, "start Tx\n");
2438 ret = il4965_tx_agg_start(priv, vif, sta, tid, ssn); 2438 ret = il4965_tx_agg_start(il, vif, sta, tid, ssn);
2439 break; 2439 break;
2440 case IEEE80211_AMPDU_TX_STOP: 2440 case IEEE80211_AMPDU_TX_STOP:
2441 IL_DEBUG_HT(priv, "stop Tx\n"); 2441 IL_DEBUG_HT(il, "stop Tx\n");
2442 ret = il4965_tx_agg_stop(priv, vif, sta, tid); 2442 ret = il4965_tx_agg_stop(il, vif, sta, tid);
2443 if (test_bit(STATUS_EXIT_PENDING, &priv->status)) 2443 if (test_bit(STATUS_EXIT_PENDING, &il->status))
2444 ret = 0; 2444 ret = 0;
2445 break; 2445 break;
2446 case IEEE80211_AMPDU_TX_OPERATIONAL: 2446 case IEEE80211_AMPDU_TX_OPERATIONAL:
2447 ret = 0; 2447 ret = 0;
2448 break; 2448 break;
2449 } 2449 }
2450 mutex_unlock(&priv->mutex); 2450 mutex_unlock(&il->mutex);
2451 2451
2452 return ret; 2452 return ret;
2453} 2453}
@@ -2456,39 +2456,39 @@ int il4965_mac_sta_add(struct ieee80211_hw *hw,
2456 struct ieee80211_vif *vif, 2456 struct ieee80211_vif *vif,
2457 struct ieee80211_sta *sta) 2457 struct ieee80211_sta *sta)
2458{ 2458{
2459 struct il_priv *priv = hw->priv; 2459 struct il_priv *il = hw->priv;
2460 struct il_station_priv *sta_priv = (void *)sta->drv_priv; 2460 struct il_station_priv *sta_priv = (void *)sta->drv_priv;
2461 struct il_vif_priv *vif_priv = (void *)vif->drv_priv; 2461 struct il_vif_priv *vif_priv = (void *)vif->drv_priv;
2462 bool is_ap = vif->type == NL80211_IFTYPE_STATION; 2462 bool is_ap = vif->type == NL80211_IFTYPE_STATION;
2463 int ret; 2463 int ret;
2464 u8 sta_id; 2464 u8 sta_id;
2465 2465
2466 IL_DEBUG_INFO(priv, "received request to add station %pM\n", 2466 IL_DEBUG_INFO(il, "received request to add station %pM\n",
2467 sta->addr); 2467 sta->addr);
2468 mutex_lock(&priv->mutex); 2468 mutex_lock(&il->mutex);
2469 IL_DEBUG_INFO(priv, "proceeding to add station %pM\n", 2469 IL_DEBUG_INFO(il, "proceeding to add station %pM\n",
2470 sta->addr); 2470 sta->addr);
2471 sta_priv->common.sta_id = IL_INVALID_STATION; 2471 sta_priv->common.sta_id = IL_INVALID_STATION;
2472 2472
2473 atomic_set(&sta_priv->pending_frames, 0); 2473 atomic_set(&sta_priv->pending_frames, 0);
2474 2474
2475 ret = il_add_station_common(priv, vif_priv->ctx, sta->addr, 2475 ret = il_add_station_common(il, vif_priv->ctx, sta->addr,
2476 is_ap, sta, &sta_id); 2476 is_ap, sta, &sta_id);
2477 if (ret) { 2477 if (ret) {
2478 IL_ERR(priv, "Unable to add station %pM (%d)\n", 2478 IL_ERR(il, "Unable to add station %pM (%d)\n",
2479 sta->addr, ret); 2479 sta->addr, ret);
2480 /* Should we return success if return code is EEXIST ? */ 2480 /* Should we return success if return code is EEXIST ? */
2481 mutex_unlock(&priv->mutex); 2481 mutex_unlock(&il->mutex);
2482 return ret; 2482 return ret;
2483 } 2483 }
2484 2484
2485 sta_priv->common.sta_id = sta_id; 2485 sta_priv->common.sta_id = sta_id;
2486 2486
2487 /* Initialize rate scaling */ 2487 /* Initialize rate scaling */
2488 IL_DEBUG_INFO(priv, "Initializing rate scaling for station %pM\n", 2488 IL_DEBUG_INFO(il, "Initializing rate scaling for station %pM\n",
2489 sta->addr); 2489 sta->addr);
2490 il4965_rs_rate_init(priv, sta, sta_id); 2490 il4965_rs_rate_init(il, sta, sta_id);
2491 mutex_unlock(&priv->mutex); 2491 mutex_unlock(&il->mutex);
2492 2492
2493 return 0; 2493 return 0;
2494} 2494}
@@ -2496,46 +2496,46 @@ int il4965_mac_sta_add(struct ieee80211_hw *hw,
2496void il4965_mac_channel_switch(struct ieee80211_hw *hw, 2496void il4965_mac_channel_switch(struct ieee80211_hw *hw,
2497 struct ieee80211_channel_switch *ch_switch) 2497 struct ieee80211_channel_switch *ch_switch)
2498{ 2498{
2499 struct il_priv *priv = hw->priv; 2499 struct il_priv *il = hw->priv;
2500 const struct il_channel_info *ch_info; 2500 const struct il_channel_info *ch_info;
2501 struct ieee80211_conf *conf = &hw->conf; 2501 struct ieee80211_conf *conf = &hw->conf;
2502 struct ieee80211_channel *channel = ch_switch->channel; 2502 struct ieee80211_channel *channel = ch_switch->channel;
2503 struct il_ht_config *ht_conf = &priv->current_ht_config; 2503 struct il_ht_config *ht_conf = &il->current_ht_config;
2504 2504
2505 struct il_rxon_context *ctx = &priv->contexts[IL_RXON_CTX_BSS]; 2505 struct il_rxon_context *ctx = &il->contexts[IL_RXON_CTX_BSS];
2506 u16 ch; 2506 u16 ch;
2507 2507
2508 IL_DEBUG_MAC80211(priv, "enter\n"); 2508 IL_DEBUG_MAC80211(il, "enter\n");
2509 2509
2510 mutex_lock(&priv->mutex); 2510 mutex_lock(&il->mutex);
2511 2511
2512 if (il_is_rfkill(priv)) 2512 if (il_is_rfkill(il))
2513 goto out; 2513 goto out;
2514 2514
2515 if (test_bit(STATUS_EXIT_PENDING, &priv->status) || 2515 if (test_bit(STATUS_EXIT_PENDING, &il->status) ||
2516 test_bit(STATUS_SCANNING, &priv->status) || 2516 test_bit(STATUS_SCANNING, &il->status) ||
2517 test_bit(STATUS_CHANNEL_SWITCH_PENDING, &priv->status)) 2517 test_bit(STATUS_CHANNEL_SWITCH_PENDING, &il->status))
2518 goto out; 2518 goto out;
2519 2519
2520 if (!il_is_associated_ctx(ctx)) 2520 if (!il_is_associated_ctx(ctx))
2521 goto out; 2521 goto out;
2522 2522
2523 if (!priv->cfg->ops->lib->set_channel_switch) 2523 if (!il->cfg->ops->lib->set_channel_switch)
2524 goto out; 2524 goto out;
2525 2525
2526 ch = channel->hw_value; 2526 ch = channel->hw_value;
2527 if (le16_to_cpu(ctx->active.channel) == ch) 2527 if (le16_to_cpu(ctx->active.channel) == ch)
2528 goto out; 2528 goto out;
2529 2529
2530 ch_info = il_get_channel_info(priv, channel->band, ch); 2530 ch_info = il_get_channel_info(il, channel->band, ch);
2531 if (!il_is_channel_valid(ch_info)) { 2531 if (!il_is_channel_valid(ch_info)) {
2532 IL_DEBUG_MAC80211(priv, "invalid channel\n"); 2532 IL_DEBUG_MAC80211(il, "invalid channel\n");
2533 goto out; 2533 goto out;
2534 } 2534 }
2535 2535
2536 spin_lock_irq(&priv->lock); 2536 spin_lock_irq(&il->lock);
2537 2537
2538 priv->current_ht_config.smps = conf->smps_mode; 2538 il->current_ht_config.smps = conf->smps_mode;
2539 2539
2540 /* Configure HT40 channels */ 2540 /* Configure HT40 channels */
2541 ctx->ht.enabled = conf_is_ht(conf); 2541 ctx->ht.enabled = conf_is_ht(conf);
@@ -2559,28 +2559,28 @@ void il4965_mac_channel_switch(struct ieee80211_hw *hw,
2559 if ((le16_to_cpu(ctx->staging.channel) != ch)) 2559 if ((le16_to_cpu(ctx->staging.channel) != ch))
2560 ctx->staging.flags = 0; 2560 ctx->staging.flags = 0;
2561 2561
2562 il_set_rxon_channel(priv, channel, ctx); 2562 il_set_rxon_channel(il, channel, ctx);
2563 il_set_rxon_ht(priv, ht_conf); 2563 il_set_rxon_ht(il, ht_conf);
2564 il_set_flags_for_band(priv, ctx, channel->band, ctx->vif); 2564 il_set_flags_for_band(il, ctx, channel->band, ctx->vif);
2565 2565
2566 spin_unlock_irq(&priv->lock); 2566 spin_unlock_irq(&il->lock);
2567 2567
2568 il_set_rate(priv); 2568 il_set_rate(il);
2569 /* 2569 /*
2570 * at this point, staging_rxon has the 2570 * at this point, staging_rxon has the
2571 * configuration for channel switch 2571 * configuration for channel switch
2572 */ 2572 */
2573 set_bit(STATUS_CHANNEL_SWITCH_PENDING, &priv->status); 2573 set_bit(STATUS_CHANNEL_SWITCH_PENDING, &il->status);
2574 priv->switch_channel = cpu_to_le16(ch); 2574 il->switch_channel = cpu_to_le16(ch);
2575 if (priv->cfg->ops->lib->set_channel_switch(priv, ch_switch)) { 2575 if (il->cfg->ops->lib->set_channel_switch(il, ch_switch)) {
2576 clear_bit(STATUS_CHANNEL_SWITCH_PENDING, &priv->status); 2576 clear_bit(STATUS_CHANNEL_SWITCH_PENDING, &il->status);
2577 priv->switch_channel = 0; 2577 il->switch_channel = 0;
2578 ieee80211_chswitch_done(ctx->vif, false); 2578 ieee80211_chswitch_done(ctx->vif, false);
2579 } 2579 }
2580 2580
2581out: 2581out:
2582 mutex_unlock(&priv->mutex); 2582 mutex_unlock(&il->mutex);
2583 IL_DEBUG_MAC80211(priv, "leave\n"); 2583 IL_DEBUG_MAC80211(il, "leave\n");
2584} 2584}
2585 2585
2586void il4965_configure_filter(struct ieee80211_hw *hw, 2586void il4965_configure_filter(struct ieee80211_hw *hw,
@@ -2588,7 +2588,7 @@ void il4965_configure_filter(struct ieee80211_hw *hw,
2588 unsigned int *total_flags, 2588 unsigned int *total_flags,
2589 u64 multicast) 2589 u64 multicast)
2590{ 2590{
2591 struct il_priv *priv = hw->priv; 2591 struct il_priv *il = hw->priv;
2592 __le32 filter_or = 0, filter_nand = 0; 2592 __le32 filter_or = 0, filter_nand = 0;
2593 struct il_rxon_context *ctx; 2593 struct il_rxon_context *ctx;
2594 2594
@@ -2599,7 +2599,7 @@ void il4965_configure_filter(struct ieee80211_hw *hw,
2599 filter_nand |= (flag); \ 2599 filter_nand |= (flag); \
2600 } while (0) 2600 } while (0)
2601 2601
2602 IL_DEBUG_MAC80211(priv, "Enter: changed: 0x%x, total: 0x%x\n", 2602 IL_DEBUG_MAC80211(il, "Enter: changed: 0x%x, total: 0x%x\n",
2603 changed_flags, *total_flags); 2603 changed_flags, *total_flags);
2604 2604
2605 CHK(FIF_OTHER_BSS | FIF_PROMISC_IN_BSS, RXON_FILTER_PROMISC_MSK); 2605 CHK(FIF_OTHER_BSS | FIF_PROMISC_IN_BSS, RXON_FILTER_PROMISC_MSK);
@@ -2609,9 +2609,9 @@ void il4965_configure_filter(struct ieee80211_hw *hw,
2609 2609
2610#undef CHK 2610#undef CHK
2611 2611
2612 mutex_lock(&priv->mutex); 2612 mutex_lock(&il->mutex);
2613 2613
2614 for_each_context(priv, ctx) { 2614 for_each_context(il, ctx) {
2615 ctx->staging.filter_flags &= ~filter_nand; 2615 ctx->staging.filter_flags &= ~filter_nand;
2616 ctx->staging.filter_flags |= filter_or; 2616 ctx->staging.filter_flags |= filter_or;
2617 2617
@@ -2621,7 +2621,7 @@ void il4965_configure_filter(struct ieee80211_hw *hw,
2621 */ 2621 */
2622 } 2622 }
2623 2623
2624 mutex_unlock(&priv->mutex); 2624 mutex_unlock(&il->mutex);
2625 2625
2626 /* 2626 /*
2627 * Receiving all multicast frames is always enabled by the 2627 * Receiving all multicast frames is always enabled by the
@@ -2641,72 +2641,72 @@ void il4965_configure_filter(struct ieee80211_hw *hw,
2641 2641
2642static void il4965_bg_txpower_work(struct work_struct *work) 2642static void il4965_bg_txpower_work(struct work_struct *work)
2643{ 2643{
2644 struct il_priv *priv = container_of(work, struct il_priv, 2644 struct il_priv *il = container_of(work, struct il_priv,
2645 txpower_work); 2645 txpower_work);
2646 2646
2647 mutex_lock(&priv->mutex); 2647 mutex_lock(&il->mutex);
2648 2648
2649 /* If a scan happened to start before we got here 2649 /* If a scan happened to start before we got here
2650 * then just return; the statistics notification will 2650 * then just return; the statistics notification will
2651 * kick off another scheduled work to compensate for 2651 * kick off another scheduled work to compensate for
2652 * any temperature delta we missed here. */ 2652 * any temperature delta we missed here. */
2653 if (test_bit(STATUS_EXIT_PENDING, &priv->status) || 2653 if (test_bit(STATUS_EXIT_PENDING, &il->status) ||
2654 test_bit(STATUS_SCANNING, &priv->status)) 2654 test_bit(STATUS_SCANNING, &il->status))
2655 goto out; 2655 goto out;
2656 2656
2657 /* Regardless of if we are associated, we must reconfigure the 2657 /* Regardless of if we are associated, we must reconfigure the
2658 * TX power since frames can be sent on non-radar channels while 2658 * TX power since frames can be sent on non-radar channels while
2659 * not associated */ 2659 * not associated */
2660 priv->cfg->ops->lib->send_tx_power(priv); 2660 il->cfg->ops->lib->send_tx_power(il);
2661 2661
2662 /* Update last_temperature to keep is_calib_needed from running 2662 /* Update last_temperature to keep is_calib_needed from running
2663 * when it isn't needed... */ 2663 * when it isn't needed... */
2664 priv->last_temperature = priv->temperature; 2664 il->last_temperature = il->temperature;
2665out: 2665out:
2666 mutex_unlock(&priv->mutex); 2666 mutex_unlock(&il->mutex);
2667} 2667}
2668 2668
2669static void il4965_setup_deferred_work(struct il_priv *priv) 2669static void il4965_setup_deferred_work(struct il_priv *il)
2670{ 2670{
2671 priv->workqueue = create_singlethread_workqueue(DRV_NAME); 2671 il->workqueue = create_singlethread_workqueue(DRV_NAME);
2672 2672
2673 init_waitqueue_head(&priv->wait_command_queue); 2673 init_waitqueue_head(&il->wait_command_queue);
2674 2674
2675 INIT_WORK(&priv->restart, il4965_bg_restart); 2675 INIT_WORK(&il->restart, il4965_bg_restart);
2676 INIT_WORK(&priv->rx_replenish, il4965_bg_rx_replenish); 2676 INIT_WORK(&il->rx_replenish, il4965_bg_rx_replenish);
2677 INIT_WORK(&priv->run_time_calib_work, il4965_bg_run_time_calib_work); 2677 INIT_WORK(&il->run_time_calib_work, il4965_bg_run_time_calib_work);
2678 INIT_DELAYED_WORK(&priv->init_alive_start, il4965_bg_init_alive_start); 2678 INIT_DELAYED_WORK(&il->init_alive_start, il4965_bg_init_alive_start);
2679 INIT_DELAYED_WORK(&priv->alive_start, il4965_bg_alive_start); 2679 INIT_DELAYED_WORK(&il->alive_start, il4965_bg_alive_start);
2680 2680
2681 il_setup_scan_deferred_work(priv); 2681 il_setup_scan_deferred_work(il);
2682 2682
2683 INIT_WORK(&priv->txpower_work, il4965_bg_txpower_work); 2683 INIT_WORK(&il->txpower_work, il4965_bg_txpower_work);
2684 2684
2685 init_timer(&priv->statistics_periodic); 2685 init_timer(&il->statistics_periodic);
2686 priv->statistics_periodic.data = (unsigned long)priv; 2686 il->statistics_periodic.data = (unsigned long)il;
2687 priv->statistics_periodic.function = il4965_bg_statistics_periodic; 2687 il->statistics_periodic.function = il4965_bg_statistics_periodic;
2688 2688
2689 init_timer(&priv->watchdog); 2689 init_timer(&il->watchdog);
2690 priv->watchdog.data = (unsigned long)priv; 2690 il->watchdog.data = (unsigned long)il;
2691 priv->watchdog.function = il_bg_watchdog; 2691 il->watchdog.function = il_bg_watchdog;
2692 2692
2693 tasklet_init(&priv->irq_tasklet, (void (*)(unsigned long)) 2693 tasklet_init(&il->irq_tasklet, (void (*)(unsigned long))
2694 il4965_irq_tasklet, (unsigned long)priv); 2694 il4965_irq_tasklet, (unsigned long)il);
2695} 2695}
2696 2696
2697static void il4965_cancel_deferred_work(struct il_priv *priv) 2697static void il4965_cancel_deferred_work(struct il_priv *il)
2698{ 2698{
2699 cancel_work_sync(&priv->txpower_work); 2699 cancel_work_sync(&il->txpower_work);
2700 cancel_delayed_work_sync(&priv->init_alive_start); 2700 cancel_delayed_work_sync(&il->init_alive_start);
2701 cancel_delayed_work(&priv->alive_start); 2701 cancel_delayed_work(&il->alive_start);
2702 cancel_work_sync(&priv->run_time_calib_work); 2702 cancel_work_sync(&il->run_time_calib_work);
2703 2703
2704 il_cancel_scan_deferred_work(priv); 2704 il_cancel_scan_deferred_work(il);
2705 2705
2706 del_timer_sync(&priv->statistics_periodic); 2706 del_timer_sync(&il->statistics_periodic);
2707} 2707}
2708 2708
2709static void il4965_init_hw_rates(struct il_priv *priv, 2709static void il4965_init_hw_rates(struct il_priv *il,
2710 struct ieee80211_rate *rates) 2710 struct ieee80211_rate *rates)
2711{ 2711{
2712 int i; 2712 int i;
@@ -2727,26 +2727,26 @@ static void il4965_init_hw_rates(struct il_priv *priv,
2727 } 2727 }
2728} 2728}
2729/* 2729/*
2730 * Acquire priv->lock before calling this function ! 2730 * Acquire il->lock before calling this function !
2731 */ 2731 */
2732void il4965_set_wr_ptrs(struct il_priv *priv, int txq_id, u32 index) 2732void il4965_set_wr_ptrs(struct il_priv *il, int txq_id, u32 index)
2733{ 2733{
2734 il_write_direct32(priv, HBUS_TARG_WRPTR, 2734 il_write_direct32(il, HBUS_TARG_WRPTR,
2735 (index & 0xff) | (txq_id << 8)); 2735 (index & 0xff) | (txq_id << 8));
2736 il_write_prph(priv, IWL49_SCD_QUEUE_RDPTR(txq_id), index); 2736 il_write_prph(il, IWL49_SCD_QUEUE_RDPTR(txq_id), index);
2737} 2737}
2738 2738
2739void il4965_tx_queue_set_status(struct il_priv *priv, 2739void il4965_tx_queue_set_status(struct il_priv *il,
2740 struct il_tx_queue *txq, 2740 struct il_tx_queue *txq,
2741 int tx_fifo_id, int scd_retry) 2741 int tx_fifo_id, int scd_retry)
2742{ 2742{
2743 int txq_id = txq->q.id; 2743 int txq_id = txq->q.id;
2744 2744
2745 /* Find out whether to activate Tx queue */ 2745 /* Find out whether to activate Tx queue */
2746 int active = test_bit(txq_id, &priv->txq_ctx_active_msk) ? 1 : 0; 2746 int active = test_bit(txq_id, &il->txq_ctx_active_msk) ? 1 : 0;
2747 2747
2748 /* Set up and activate */ 2748 /* Set up and activate */
2749 il_write_prph(priv, IWL49_SCD_QUEUE_STATUS_BITS(txq_id), 2749 il_write_prph(il, IWL49_SCD_QUEUE_STATUS_BITS(txq_id),
2750 (active << IWL49_SCD_QUEUE_STTS_REG_POS_ACTIVE) | 2750 (active << IWL49_SCD_QUEUE_STTS_REG_POS_ACTIVE) |
2751 (tx_fifo_id << IWL49_SCD_QUEUE_STTS_REG_POS_TXF) | 2751 (tx_fifo_id << IWL49_SCD_QUEUE_STTS_REG_POS_TXF) |
2752 (scd_retry << IWL49_SCD_QUEUE_STTS_REG_POS_WSL) | 2752 (scd_retry << IWL49_SCD_QUEUE_STTS_REG_POS_WSL) |
@@ -2755,94 +2755,94 @@ void il4965_tx_queue_set_status(struct il_priv *priv,
2755 2755
2756 txq->sched_retry = scd_retry; 2756 txq->sched_retry = scd_retry;
2757 2757
2758 IL_DEBUG_INFO(priv, "%s %s Queue %d on AC %d\n", 2758 IL_DEBUG_INFO(il, "%s %s Queue %d on AC %d\n",
2759 active ? "Activate" : "Deactivate", 2759 active ? "Activate" : "Deactivate",
2760 scd_retry ? "BA" : "AC", txq_id, tx_fifo_id); 2760 scd_retry ? "BA" : "AC", txq_id, tx_fifo_id);
2761} 2761}
2762 2762
2763 2763
2764static int il4965_init_drv(struct il_priv *priv) 2764static int il4965_init_drv(struct il_priv *il)
2765{ 2765{
2766 int ret; 2766 int ret;
2767 2767
2768 spin_lock_init(&priv->sta_lock); 2768 spin_lock_init(&il->sta_lock);
2769 spin_lock_init(&priv->hcmd_lock); 2769 spin_lock_init(&il->hcmd_lock);
2770 2770
2771 INIT_LIST_HEAD(&priv->free_frames); 2771 INIT_LIST_HEAD(&il->free_frames);
2772 2772
2773 mutex_init(&priv->mutex); 2773 mutex_init(&il->mutex);
2774 2774
2775 priv->ieee_channels = NULL; 2775 il->ieee_channels = NULL;
2776 priv->ieee_rates = NULL; 2776 il->ieee_rates = NULL;
2777 priv->band = IEEE80211_BAND_2GHZ; 2777 il->band = IEEE80211_BAND_2GHZ;
2778 2778
2779 priv->iw_mode = NL80211_IFTYPE_STATION; 2779 il->iw_mode = NL80211_IFTYPE_STATION;
2780 priv->current_ht_config.smps = IEEE80211_SMPS_STATIC; 2780 il->current_ht_config.smps = IEEE80211_SMPS_STATIC;
2781 priv->missed_beacon_threshold = IL_MISSED_BEACON_THRESHOLD_DEF; 2781 il->missed_beacon_threshold = IL_MISSED_BEACON_THRESHOLD_DEF;
2782 2782
2783 /* initialize force reset */ 2783 /* initialize force reset */
2784 priv->force_reset.reset_duration = IL_DELAY_NEXT_FORCE_FW_RELOAD; 2784 il->force_reset.reset_duration = IL_DELAY_NEXT_FORCE_FW_RELOAD;
2785 2785
2786 /* Choose which receivers/antennas to use */ 2786 /* Choose which receivers/antennas to use */
2787 if (priv->cfg->ops->hcmd->set_rxon_chain) 2787 if (il->cfg->ops->hcmd->set_rxon_chain)
2788 priv->cfg->ops->hcmd->set_rxon_chain(priv, 2788 il->cfg->ops->hcmd->set_rxon_chain(il,
2789 &priv->contexts[IL_RXON_CTX_BSS]); 2789 &il->contexts[IL_RXON_CTX_BSS]);
2790 2790
2791 il_init_scan_params(priv); 2791 il_init_scan_params(il);
2792 2792
2793 ret = il_init_channel_map(priv); 2793 ret = il_init_channel_map(il);
2794 if (ret) { 2794 if (ret) {
2795 IL_ERR(priv, "initializing regulatory failed: %d\n", ret); 2795 IL_ERR(il, "initializing regulatory failed: %d\n", ret);
2796 goto err; 2796 goto err;
2797 } 2797 }
2798 2798
2799 ret = il_init_geos(priv); 2799 ret = il_init_geos(il);
2800 if (ret) { 2800 if (ret) {
2801 IL_ERR(priv, "initializing geos failed: %d\n", ret); 2801 IL_ERR(il, "initializing geos failed: %d\n", ret);
2802 goto err_free_channel_map; 2802 goto err_free_channel_map;
2803 } 2803 }
2804 il4965_init_hw_rates(priv, priv->ieee_rates); 2804 il4965_init_hw_rates(il, il->ieee_rates);
2805 2805
2806 return 0; 2806 return 0;
2807 2807
2808err_free_channel_map: 2808err_free_channel_map:
2809 il_free_channel_map(priv); 2809 il_free_channel_map(il);
2810err: 2810err:
2811 return ret; 2811 return ret;
2812} 2812}
2813 2813
2814static void il4965_uninit_drv(struct il_priv *priv) 2814static void il4965_uninit_drv(struct il_priv *il)
2815{ 2815{
2816 il4965_calib_free_results(priv); 2816 il4965_calib_free_results(il);
2817 il_free_geos(priv); 2817 il_free_geos(il);
2818 il_free_channel_map(priv); 2818 il_free_channel_map(il);
2819 kfree(priv->scan_cmd); 2819 kfree(il->scan_cmd);
2820} 2820}
2821 2821
2822static void il4965_hw_detect(struct il_priv *priv) 2822static void il4965_hw_detect(struct il_priv *il)
2823{ 2823{
2824 priv->hw_rev = _il_read32(priv, CSR_HW_REV); 2824 il->hw_rev = _il_read32(il, CSR_HW_REV);
2825 priv->hw_wa_rev = _il_read32(priv, CSR_HW_REV_WA_REG); 2825 il->hw_wa_rev = _il_read32(il, CSR_HW_REV_WA_REG);
2826 priv->rev_id = priv->pci_dev->revision; 2826 il->rev_id = il->pci_dev->revision;
2827 IL_DEBUG_INFO(priv, "HW Revision ID = 0x%X\n", priv->rev_id); 2827 IL_DEBUG_INFO(il, "HW Revision ID = 0x%X\n", il->rev_id);
2828} 2828}
2829 2829
2830static int il4965_set_hw_params(struct il_priv *priv) 2830static int il4965_set_hw_params(struct il_priv *il)
2831{ 2831{
2832 priv->hw_params.max_rxq_size = RX_QUEUE_SIZE; 2832 il->hw_params.max_rxq_size = RX_QUEUE_SIZE;
2833 priv->hw_params.max_rxq_log = RX_QUEUE_SIZE_LOG; 2833 il->hw_params.max_rxq_log = RX_QUEUE_SIZE_LOG;
2834 if (priv->cfg->mod_params->amsdu_size_8K) 2834 if (il->cfg->mod_params->amsdu_size_8K)
2835 priv->hw_params.rx_page_order = get_order(IL_RX_BUF_SIZE_8K); 2835 il->hw_params.rx_page_order = get_order(IL_RX_BUF_SIZE_8K);
2836 else 2836 else
2837 priv->hw_params.rx_page_order = get_order(IL_RX_BUF_SIZE_4K); 2837 il->hw_params.rx_page_order = get_order(IL_RX_BUF_SIZE_4K);
2838 2838
2839 priv->hw_params.max_beacon_itrvl = IL_MAX_UCODE_BEACON_INTERVAL; 2839 il->hw_params.max_beacon_itrvl = IL_MAX_UCODE_BEACON_INTERVAL;
2840 2840
2841 if (priv->cfg->mod_params->disable_11n) 2841 if (il->cfg->mod_params->disable_11n)
2842 priv->cfg->sku &= ~IL_SKU_N; 2842 il->cfg->sku &= ~IL_SKU_N;
2843 2843
2844 /* Device-specific setup */ 2844 /* Device-specific setup */
2845 return priv->cfg->ops->lib->set_hw_params(priv); 2845 return il->cfg->ops->lib->set_hw_params(il);
2846} 2846}
2847 2847
2848static const u8 il4965_bss_ac_to_fifo[] = { 2848static const u8 il4965_bss_ac_to_fifo[] = {
@@ -2860,7 +2860,7 @@ static int
2860il4965_pci_probe(struct pci_dev *pdev, const struct pci_device_id *ent) 2860il4965_pci_probe(struct pci_dev *pdev, const struct pci_device_id *ent)
2861{ 2861{
2862 int err = 0, i; 2862 int err = 0, i;
2863 struct il_priv *priv; 2863 struct il_priv *il;
2864 struct ieee80211_hw *hw; 2864 struct ieee80211_hw *hw;
2865 struct il_cfg *cfg = (struct il_cfg *)(ent->driver_data); 2865 struct il_cfg *cfg = (struct il_cfg *)(ent->driver_data);
2866 unsigned long flags; 2866 unsigned long flags;
@@ -2875,49 +2875,49 @@ il4965_pci_probe(struct pci_dev *pdev, const struct pci_device_id *ent)
2875 err = -ENOMEM; 2875 err = -ENOMEM;
2876 goto out; 2876 goto out;
2877 } 2877 }
2878 priv = hw->priv; 2878 il = hw->priv;
2879 /* At this point both hw and priv are allocated. */ 2879 /* At this point both hw and il are allocated. */
2880 2880
2881 /* 2881 /*
2882 * The default context is always valid, 2882 * The default context is always valid,
2883 * more may be discovered when firmware 2883 * more may be discovered when firmware
2884 * is loaded. 2884 * is loaded.
2885 */ 2885 */
2886 priv->valid_contexts = BIT(IL_RXON_CTX_BSS); 2886 il->valid_contexts = BIT(IL_RXON_CTX_BSS);
2887 2887
2888 for (i = 0; i < NUM_IL_RXON_CTX; i++) 2888 for (i = 0; i < NUM_IL_RXON_CTX; i++)
2889 priv->contexts[i].ctxid = i; 2889 il->contexts[i].ctxid = i;
2890 2890
2891 priv->contexts[IL_RXON_CTX_BSS].always_active = true; 2891 il->contexts[IL_RXON_CTX_BSS].always_active = true;
2892 priv->contexts[IL_RXON_CTX_BSS].is_active = true; 2892 il->contexts[IL_RXON_CTX_BSS].is_active = true;
2893 priv->contexts[IL_RXON_CTX_BSS].rxon_cmd = REPLY_RXON; 2893 il->contexts[IL_RXON_CTX_BSS].rxon_cmd = REPLY_RXON;
2894 priv->contexts[IL_RXON_CTX_BSS].rxon_timing_cmd = REPLY_RXON_TIMING; 2894 il->contexts[IL_RXON_CTX_BSS].rxon_timing_cmd = REPLY_RXON_TIMING;
2895 priv->contexts[IL_RXON_CTX_BSS].rxon_assoc_cmd = REPLY_RXON_ASSOC; 2895 il->contexts[IL_RXON_CTX_BSS].rxon_assoc_cmd = REPLY_RXON_ASSOC;
2896 priv->contexts[IL_RXON_CTX_BSS].qos_cmd = REPLY_QOS_PARAM; 2896 il->contexts[IL_RXON_CTX_BSS].qos_cmd = REPLY_QOS_PARAM;
2897 priv->contexts[IL_RXON_CTX_BSS].ap_sta_id = IL_AP_ID; 2897 il->contexts[IL_RXON_CTX_BSS].ap_sta_id = IL_AP_ID;
2898 priv->contexts[IL_RXON_CTX_BSS].wep_key_cmd = REPLY_WEPKEY; 2898 il->contexts[IL_RXON_CTX_BSS].wep_key_cmd = REPLY_WEPKEY;
2899 priv->contexts[IL_RXON_CTX_BSS].ac_to_fifo = il4965_bss_ac_to_fifo; 2899 il->contexts[IL_RXON_CTX_BSS].ac_to_fifo = il4965_bss_ac_to_fifo;
2900 priv->contexts[IL_RXON_CTX_BSS].ac_to_queue = il4965_bss_ac_to_queue; 2900 il->contexts[IL_RXON_CTX_BSS].ac_to_queue = il4965_bss_ac_to_queue;
2901 priv->contexts[IL_RXON_CTX_BSS].exclusive_interface_modes = 2901 il->contexts[IL_RXON_CTX_BSS].exclusive_interface_modes =
2902 BIT(NL80211_IFTYPE_ADHOC); 2902 BIT(NL80211_IFTYPE_ADHOC);
2903 priv->contexts[IL_RXON_CTX_BSS].interface_modes = 2903 il->contexts[IL_RXON_CTX_BSS].interface_modes =
2904 BIT(NL80211_IFTYPE_STATION); 2904 BIT(NL80211_IFTYPE_STATION);
2905 priv->contexts[IL_RXON_CTX_BSS].ap_devtype = RXON_DEV_TYPE_AP; 2905 il->contexts[IL_RXON_CTX_BSS].ap_devtype = RXON_DEV_TYPE_AP;
2906 priv->contexts[IL_RXON_CTX_BSS].ibss_devtype = RXON_DEV_TYPE_IBSS; 2906 il->contexts[IL_RXON_CTX_BSS].ibss_devtype = RXON_DEV_TYPE_IBSS;
2907 priv->contexts[IL_RXON_CTX_BSS].station_devtype = RXON_DEV_TYPE_ESS; 2907 il->contexts[IL_RXON_CTX_BSS].station_devtype = RXON_DEV_TYPE_ESS;
2908 priv->contexts[IL_RXON_CTX_BSS].unused_devtype = RXON_DEV_TYPE_ESS; 2908 il->contexts[IL_RXON_CTX_BSS].unused_devtype = RXON_DEV_TYPE_ESS;
2909 2909
2910 BUILD_BUG_ON(NUM_IL_RXON_CTX != 1); 2910 BUILD_BUG_ON(NUM_IL_RXON_CTX != 1);
2911 2911
2912 SET_IEEE80211_DEV(hw, &pdev->dev); 2912 SET_IEEE80211_DEV(hw, &pdev->dev);
2913 2913
2914 IL_DEBUG_INFO(priv, "*** LOAD DRIVER ***\n"); 2914 IL_DEBUG_INFO(il, "*** LOAD DRIVER ***\n");
2915 priv->cfg = cfg; 2915 il->cfg = cfg;
2916 priv->pci_dev = pdev; 2916 il->pci_dev = pdev;
2917 priv->inta_mask = CSR_INI_SET_MASK; 2917 il->inta_mask = CSR_INI_SET_MASK;
2918 2918
2919 if (il_alloc_traffic_mem(priv)) 2919 if (il_alloc_traffic_mem(il))
2920 IL_ERR(priv, "Not enough memory to generate traffic log\n"); 2920 IL_ERR(il, "Not enough memory to generate traffic log\n");
2921 2921
2922 /************************** 2922 /**************************
2923 * 2. Initializing PCI bus 2923 * 2. Initializing PCI bus
@@ -2942,7 +2942,7 @@ il4965_pci_probe(struct pci_dev *pdev, const struct pci_device_id *ent)
2942 DMA_BIT_MASK(32)); 2942 DMA_BIT_MASK(32));
2943 /* both attempts failed: */ 2943 /* both attempts failed: */
2944 if (err) { 2944 if (err) {
2945 IL_WARN(priv, "No suitable DMA available.\n"); 2945 IL_WARN(il, "No suitable DMA available.\n");
2946 goto out_pci_disable_device; 2946 goto out_pci_disable_device;
2947 } 2947 }
2948 } 2948 }
@@ -2951,46 +2951,46 @@ il4965_pci_probe(struct pci_dev *pdev, const struct pci_device_id *ent)
2951 if (err) 2951 if (err)
2952 goto out_pci_disable_device; 2952 goto out_pci_disable_device;
2953 2953
2954 pci_set_drvdata(pdev, priv); 2954 pci_set_drvdata(pdev, il);
2955 2955
2956 2956
2957 /*********************** 2957 /***********************
2958 * 3. Read REV register 2958 * 3. Read REV register
2959 ***********************/ 2959 ***********************/
2960 priv->hw_base = pci_iomap(pdev, 0, 0); 2960 il->hw_base = pci_iomap(pdev, 0, 0);
2961 if (!priv->hw_base) { 2961 if (!il->hw_base) {
2962 err = -ENODEV; 2962 err = -ENODEV;
2963 goto out_pci_release_regions; 2963 goto out_pci_release_regions;
2964 } 2964 }
2965 2965
2966 IL_DEBUG_INFO(priv, "pci_resource_len = 0x%08llx\n", 2966 IL_DEBUG_INFO(il, "pci_resource_len = 0x%08llx\n",
2967 (unsigned long long) pci_resource_len(pdev, 0)); 2967 (unsigned long long) pci_resource_len(pdev, 0));
2968 IL_DEBUG_INFO(priv, "pci_resource_base = %p\n", priv->hw_base); 2968 IL_DEBUG_INFO(il, "pci_resource_base = %p\n", il->hw_base);
2969 2969
2970 /* these spin locks will be used in apm_ops.init and EEPROM access 2970 /* these spin locks will be used in apm_ops.init and EEPROM access
2971 * we should init now 2971 * we should init now
2972 */ 2972 */
2973 spin_lock_init(&priv->reg_lock); 2973 spin_lock_init(&il->reg_lock);
2974 spin_lock_init(&priv->lock); 2974 spin_lock_init(&il->lock);
2975 2975
2976 /* 2976 /*
2977 * stop and reset the on-board processor just in case it is in a 2977 * stop and reset the on-board processor just in case it is in a
2978 * strange state ... like being left stranded by a primary kernel 2978 * strange state ... like being left stranded by a primary kernel
2979 * and this is now the kdump kernel trying to start up 2979 * and this is now the kdump kernel trying to start up
2980 */ 2980 */
2981 il_write32(priv, CSR_RESET, CSR_RESET_REG_FLAG_NEVO_RESET); 2981 il_write32(il, CSR_RESET, CSR_RESET_REG_FLAG_NEVO_RESET);
2982 2982
2983 il4965_hw_detect(priv); 2983 il4965_hw_detect(il);
2984 IL_INFO(priv, "Detected %s, REV=0x%X\n", 2984 IL_INFO(il, "Detected %s, REV=0x%X\n",
2985 priv->cfg->name, priv->hw_rev); 2985 il->cfg->name, il->hw_rev);
2986 2986
2987 /* We disable the RETRY_TIMEOUT register (0x41) to keep 2987 /* We disable the RETRY_TIMEOUT register (0x41) to keep
2988 * PCI Tx retries from interfering with C3 CPU state */ 2988 * PCI Tx retries from interfering with C3 CPU state */
2989 pci_write_config_byte(pdev, PCI_CFG_RETRY_TIMEOUT, 0x00); 2989 pci_write_config_byte(pdev, PCI_CFG_RETRY_TIMEOUT, 0x00);
2990 2990
2991 il4965_prepare_card_hw(priv); 2991 il4965_prepare_card_hw(il);
2992 if (!priv->hw_ready) { 2992 if (!il->hw_ready) {
2993 IL_WARN(priv, "Failed, HW not ready\n"); 2993 IL_WARN(il, "Failed, HW not ready\n");
2994 goto out_iounmap; 2994 goto out_iounmap;
2995 } 2995 }
2996 2996
@@ -2998,12 +2998,12 @@ il4965_pci_probe(struct pci_dev *pdev, const struct pci_device_id *ent)
2998 * 4. Read EEPROM 2998 * 4. Read EEPROM
2999 *****************/ 2999 *****************/
3000 /* Read the EEPROM */ 3000 /* Read the EEPROM */
3001 err = il_eeprom_init(priv); 3001 err = il_eeprom_init(il);
3002 if (err) { 3002 if (err) {
3003 IL_ERR(priv, "Unable to init EEPROM\n"); 3003 IL_ERR(il, "Unable to init EEPROM\n");
3004 goto out_iounmap; 3004 goto out_iounmap;
3005 } 3005 }
3006 err = il4965_eeprom_check_version(priv); 3006 err = il4965_eeprom_check_version(il);
3007 if (err) 3007 if (err)
3008 goto out_free_eeprom; 3008 goto out_free_eeprom;
3009 3009
@@ -3011,131 +3011,131 @@ il4965_pci_probe(struct pci_dev *pdev, const struct pci_device_id *ent)
3011 goto out_free_eeprom; 3011 goto out_free_eeprom;
3012 3012
3013 /* extract MAC Address */ 3013 /* extract MAC Address */
3014 il4965_eeprom_get_mac(priv, priv->addresses[0].addr); 3014 il4965_eeprom_get_mac(il, il->addresses[0].addr);
3015 IL_DEBUG_INFO(priv, "MAC address: %pM\n", priv->addresses[0].addr); 3015 IL_DEBUG_INFO(il, "MAC address: %pM\n", il->addresses[0].addr);
3016 priv->hw->wiphy->addresses = priv->addresses; 3016 il->hw->wiphy->addresses = il->addresses;
3017 priv->hw->wiphy->n_addresses = 1; 3017 il->hw->wiphy->n_addresses = 1;
3018 3018
3019 /************************ 3019 /************************
3020 * 5. Setup HW constants 3020 * 5. Setup HW constants
3021 ************************/ 3021 ************************/
3022 if (il4965_set_hw_params(priv)) { 3022 if (il4965_set_hw_params(il)) {
3023 IL_ERR(priv, "failed to set hw parameters\n"); 3023 IL_ERR(il, "failed to set hw parameters\n");
3024 goto out_free_eeprom; 3024 goto out_free_eeprom;
3025 } 3025 }
3026 3026
3027 /******************* 3027 /*******************
3028 * 6. Setup priv 3028 * 6. Setup il
3029 *******************/ 3029 *******************/
3030 3030
3031 err = il4965_init_drv(priv); 3031 err = il4965_init_drv(il);
3032 if (err) 3032 if (err)
3033 goto out_free_eeprom; 3033 goto out_free_eeprom;
3034 /* At this point both hw and priv are initialized. */ 3034 /* At this point both hw and il are initialized. */
3035 3035
3036 /******************** 3036 /********************
3037 * 7. Setup services 3037 * 7. Setup services
3038 ********************/ 3038 ********************/
3039 spin_lock_irqsave(&priv->lock, flags); 3039 spin_lock_irqsave(&il->lock, flags);
3040 il_disable_interrupts(priv); 3040 il_disable_interrupts(il);
3041 spin_unlock_irqrestore(&priv->lock, flags); 3041 spin_unlock_irqrestore(&il->lock, flags);
3042 3042
3043 pci_enable_msi(priv->pci_dev); 3043 pci_enable_msi(il->pci_dev);
3044 3044
3045 err = request_irq(priv->pci_dev->irq, il_isr, 3045 err = request_irq(il->pci_dev->irq, il_isr,
3046 IRQF_SHARED, DRV_NAME, priv); 3046 IRQF_SHARED, DRV_NAME, il);
3047 if (err) { 3047 if (err) {
3048 IL_ERR(priv, "Error allocating IRQ %d\n", priv->pci_dev->irq); 3048 IL_ERR(il, "Error allocating IRQ %d\n", il->pci_dev->irq);
3049 goto out_disable_msi; 3049 goto out_disable_msi;
3050 } 3050 }
3051 3051
3052 il4965_setup_deferred_work(priv); 3052 il4965_setup_deferred_work(il);
3053 il4965_setup_rx_handlers(priv); 3053 il4965_setup_rx_handlers(il);
3054 3054
3055 /********************************************* 3055 /*********************************************
3056 * 8. Enable interrupts and read RFKILL state 3056 * 8. Enable interrupts and read RFKILL state
3057 *********************************************/ 3057 *********************************************/
3058 3058
3059 /* enable rfkill interrupt: hw bug w/a */ 3059 /* enable rfkill interrupt: hw bug w/a */
3060 pci_read_config_word(priv->pci_dev, PCI_COMMAND, &pci_cmd); 3060 pci_read_config_word(il->pci_dev, PCI_COMMAND, &pci_cmd);
3061 if (pci_cmd & PCI_COMMAND_INTX_DISABLE) { 3061 if (pci_cmd & PCI_COMMAND_INTX_DISABLE) {
3062 pci_cmd &= ~PCI_COMMAND_INTX_DISABLE; 3062 pci_cmd &= ~PCI_COMMAND_INTX_DISABLE;
3063 pci_write_config_word(priv->pci_dev, PCI_COMMAND, pci_cmd); 3063 pci_write_config_word(il->pci_dev, PCI_COMMAND, pci_cmd);
3064 } 3064 }
3065 3065
3066 il_enable_rfkill_int(priv); 3066 il_enable_rfkill_int(il);
3067 3067
3068 /* If platform's RF_KILL switch is NOT set to KILL */ 3068 /* If platform's RF_KILL switch is NOT set to KILL */
3069 if (il_read32(priv, CSR_GP_CNTRL) & 3069 if (il_read32(il, CSR_GP_CNTRL) &
3070 CSR_GP_CNTRL_REG_FLAG_HW_RF_KILL_SW) 3070 CSR_GP_CNTRL_REG_FLAG_HW_RF_KILL_SW)
3071 clear_bit(STATUS_RF_KILL_HW, &priv->status); 3071 clear_bit(STATUS_RF_KILL_HW, &il->status);
3072 else 3072 else
3073 set_bit(STATUS_RF_KILL_HW, &priv->status); 3073 set_bit(STATUS_RF_KILL_HW, &il->status);
3074 3074
3075 wiphy_rfkill_set_hw_state(priv->hw->wiphy, 3075 wiphy_rfkill_set_hw_state(il->hw->wiphy,
3076 test_bit(STATUS_RF_KILL_HW, &priv->status)); 3076 test_bit(STATUS_RF_KILL_HW, &il->status));
3077 3077
3078 il_power_initialize(priv); 3078 il_power_initialize(il);
3079 3079
3080 init_completion(&priv->_4965.firmware_loading_complete); 3080 init_completion(&il->_4965.firmware_loading_complete);
3081 3081
3082 err = il4965_request_firmware(priv, true); 3082 err = il4965_request_firmware(il, true);
3083 if (err) 3083 if (err)
3084 goto out_destroy_workqueue; 3084 goto out_destroy_workqueue;
3085 3085
3086 return 0; 3086 return 0;
3087 3087
3088 out_destroy_workqueue: 3088 out_destroy_workqueue:
3089 destroy_workqueue(priv->workqueue); 3089 destroy_workqueue(il->workqueue);
3090 priv->workqueue = NULL; 3090 il->workqueue = NULL;
3091 free_irq(priv->pci_dev->irq, priv); 3091 free_irq(il->pci_dev->irq, il);
3092 out_disable_msi: 3092 out_disable_msi:
3093 pci_disable_msi(priv->pci_dev); 3093 pci_disable_msi(il->pci_dev);
3094 il4965_uninit_drv(priv); 3094 il4965_uninit_drv(il);
3095 out_free_eeprom: 3095 out_free_eeprom:
3096 il_eeprom_free(priv); 3096 il_eeprom_free(il);
3097 out_iounmap: 3097 out_iounmap:
3098 pci_iounmap(pdev, priv->hw_base); 3098 pci_iounmap(pdev, il->hw_base);
3099 out_pci_release_regions: 3099 out_pci_release_regions:
3100 pci_set_drvdata(pdev, NULL); 3100 pci_set_drvdata(pdev, NULL);
3101 pci_release_regions(pdev); 3101 pci_release_regions(pdev);
3102 out_pci_disable_device: 3102 out_pci_disable_device:
3103 pci_disable_device(pdev); 3103 pci_disable_device(pdev);
3104 out_ieee80211_free_hw: 3104 out_ieee80211_free_hw:
3105 il_free_traffic_mem(priv); 3105 il_free_traffic_mem(il);
3106 ieee80211_free_hw(priv->hw); 3106 ieee80211_free_hw(il->hw);
3107 out: 3107 out:
3108 return err; 3108 return err;
3109} 3109}
3110 3110
3111static void __devexit il4965_pci_remove(struct pci_dev *pdev) 3111static void __devexit il4965_pci_remove(struct pci_dev *pdev)
3112{ 3112{
3113 struct il_priv *priv = pci_get_drvdata(pdev); 3113 struct il_priv *il = pci_get_drvdata(pdev);
3114 unsigned long flags; 3114 unsigned long flags;
3115 3115
3116 if (!priv) 3116 if (!il)
3117 return; 3117 return;
3118 3118
3119 wait_for_completion(&priv->_4965.firmware_loading_complete); 3119 wait_for_completion(&il->_4965.firmware_loading_complete);
3120 3120
3121 IL_DEBUG_INFO(priv, "*** UNLOAD DRIVER ***\n"); 3121 IL_DEBUG_INFO(il, "*** UNLOAD DRIVER ***\n");
3122 3122
3123 il_dbgfs_unregister(priv); 3123 il_dbgfs_unregister(il);
3124 sysfs_remove_group(&pdev->dev.kobj, &il_attribute_group); 3124 sysfs_remove_group(&pdev->dev.kobj, &il_attribute_group);
3125 3125
3126 /* ieee80211_unregister_hw call wil cause il_mac_stop to 3126 /* ieee80211_unregister_hw call wil cause il_mac_stop to
3127 * to be called and il4965_down since we are removing the device 3127 * to be called and il4965_down since we are removing the device
3128 * we need to set STATUS_EXIT_PENDING bit. 3128 * we need to set STATUS_EXIT_PENDING bit.
3129 */ 3129 */
3130 set_bit(STATUS_EXIT_PENDING, &priv->status); 3130 set_bit(STATUS_EXIT_PENDING, &il->status);
3131 3131
3132 il_leds_exit(priv); 3132 il_leds_exit(il);
3133 3133
3134 if (priv->mac80211_registered) { 3134 if (il->mac80211_registered) {
3135 ieee80211_unregister_hw(priv->hw); 3135 ieee80211_unregister_hw(il->hw);
3136 priv->mac80211_registered = 0; 3136 il->mac80211_registered = 0;
3137 } else { 3137 } else {
3138 il4965_down(priv); 3138 il4965_down(il);
3139 } 3139 }
3140 3140
3141 /* 3141 /*
@@ -3145,57 +3145,57 @@ static void __devexit il4965_pci_remove(struct pci_dev *pdev)
3145 * paths to avoid running il4965_down() at all before leaving driver. 3145 * paths to avoid running il4965_down() at all before leaving driver.
3146 * This (inexpensive) call *makes sure* device is reset. 3146 * This (inexpensive) call *makes sure* device is reset.
3147 */ 3147 */
3148 il_apm_stop(priv); 3148 il_apm_stop(il);
3149 3149
3150 /* make sure we flush any pending irq or 3150 /* make sure we flush any pending irq or
3151 * tasklet for the driver 3151 * tasklet for the driver
3152 */ 3152 */
3153 spin_lock_irqsave(&priv->lock, flags); 3153 spin_lock_irqsave(&il->lock, flags);
3154 il_disable_interrupts(priv); 3154 il_disable_interrupts(il);
3155 spin_unlock_irqrestore(&priv->lock, flags); 3155 spin_unlock_irqrestore(&il->lock, flags);
3156 3156
3157 il4965_synchronize_irq(priv); 3157 il4965_synchronize_irq(il);
3158 3158
3159 il4965_dealloc_ucode_pci(priv); 3159 il4965_dealloc_ucode_pci(il);
3160 3160
3161 if (priv->rxq.bd) 3161 if (il->rxq.bd)
3162 il4965_rx_queue_free(priv, &priv->rxq); 3162 il4965_rx_queue_free(il, &il->rxq);
3163 il4965_hw_txq_ctx_free(priv); 3163 il4965_hw_txq_ctx_free(il);
3164 3164
3165 il_eeprom_free(priv); 3165 il_eeprom_free(il);
3166 3166
3167 3167
3168 /*netif_stop_queue(dev); */ 3168 /*netif_stop_queue(dev); */
3169 flush_workqueue(priv->workqueue); 3169 flush_workqueue(il->workqueue);
3170 3170
3171 /* ieee80211_unregister_hw calls il_mac_stop, which flushes 3171 /* ieee80211_unregister_hw calls il_mac_stop, which flushes
3172 * priv->workqueue... so we can't take down the workqueue 3172 * il->workqueue... so we can't take down the workqueue
3173 * until now... */ 3173 * until now... */
3174 destroy_workqueue(priv->workqueue); 3174 destroy_workqueue(il->workqueue);
3175 priv->workqueue = NULL; 3175 il->workqueue = NULL;
3176 il_free_traffic_mem(priv); 3176 il_free_traffic_mem(il);
3177 3177
3178 free_irq(priv->pci_dev->irq, priv); 3178 free_irq(il->pci_dev->irq, il);
3179 pci_disable_msi(priv->pci_dev); 3179 pci_disable_msi(il->pci_dev);
3180 pci_iounmap(pdev, priv->hw_base); 3180 pci_iounmap(pdev, il->hw_base);
3181 pci_release_regions(pdev); 3181 pci_release_regions(pdev);
3182 pci_disable_device(pdev); 3182 pci_disable_device(pdev);
3183 pci_set_drvdata(pdev, NULL); 3183 pci_set_drvdata(pdev, NULL);
3184 3184
3185 il4965_uninit_drv(priv); 3185 il4965_uninit_drv(il);
3186 3186
3187 dev_kfree_skb(priv->beacon_skb); 3187 dev_kfree_skb(il->beacon_skb);
3188 3188
3189 ieee80211_free_hw(priv->hw); 3189 ieee80211_free_hw(il->hw);
3190} 3190}
3191 3191
3192/* 3192/*
3193 * Activate/Deactivate Tx DMA/FIFO channels according tx fifos mask 3193 * Activate/Deactivate Tx DMA/FIFO channels according tx fifos mask
3194 * must be called under priv->lock and mac access 3194 * must be called under il->lock and mac access
3195 */ 3195 */
3196void il4965_txq_set_sched(struct il_priv *priv, u32 mask) 3196void il4965_txq_set_sched(struct il_priv *il, u32 mask)
3197{ 3197{
3198 il_write_prph(priv, IWL49_SCD_TXFACT, mask); 3198 il_write_prph(il, IWL49_SCD_TXFACT, mask);
3199} 3199}
3200 3200
3201/***************************************************************************** 3201/*****************************************************************************