diff options
Diffstat (limited to 'drivers/net/wireless/iwlwifi/iwl-io.c')
-rw-r--r-- | drivers/net/wireless/iwlwifi/iwl-io.c | 36 |
1 files changed, 28 insertions, 8 deletions
diff --git a/drivers/net/wireless/iwlwifi/iwl-io.c b/drivers/net/wireless/iwlwifi/iwl-io.c index 51337416e4ca..aa4a90674452 100644 --- a/drivers/net/wireless/iwlwifi/iwl-io.c +++ b/drivers/net/wireless/iwlwifi/iwl-io.c | |||
@@ -73,10 +73,9 @@ int iwl_poll_bit(struct iwl_priv *priv, u32 addr, | |||
73 | return -ETIMEDOUT; | 73 | return -ETIMEDOUT; |
74 | } | 74 | } |
75 | 75 | ||
76 | int iwl_grab_nic_access(struct iwl_priv *priv) | 76 | int iwl_grab_nic_access_silent(struct iwl_priv *priv) |
77 | { | 77 | { |
78 | int ret; | 78 | int ret; |
79 | u32 val; | ||
80 | 79 | ||
81 | lockdep_assert_held(&priv->reg_lock); | 80 | lockdep_assert_held(&priv->reg_lock); |
82 | 81 | ||
@@ -107,9 +106,6 @@ int iwl_grab_nic_access(struct iwl_priv *priv) | |||
107 | (CSR_GP_CNTRL_REG_FLAG_MAC_CLOCK_READY | | 106 | (CSR_GP_CNTRL_REG_FLAG_MAC_CLOCK_READY | |
108 | CSR_GP_CNTRL_REG_FLAG_GOING_TO_SLEEP), 15000); | 107 | CSR_GP_CNTRL_REG_FLAG_GOING_TO_SLEEP), 15000); |
109 | if (ret < 0) { | 108 | if (ret < 0) { |
110 | val = iwl_read32(priv, CSR_GP_CNTRL); | ||
111 | IWL_ERR(priv, | ||
112 | "MAC is in deep sleep!. CSR_GP_CNTRL = 0x%08X\n", val); | ||
113 | iwl_write32(priv, CSR_RESET, CSR_RESET_REG_FLAG_FORCE_NMI); | 109 | iwl_write32(priv, CSR_RESET, CSR_RESET_REG_FLAG_FORCE_NMI); |
114 | return -EIO; | 110 | return -EIO; |
115 | } | 111 | } |
@@ -117,6 +113,18 @@ int iwl_grab_nic_access(struct iwl_priv *priv) | |||
117 | return 0; | 113 | return 0; |
118 | } | 114 | } |
119 | 115 | ||
116 | int iwl_grab_nic_access(struct iwl_priv *priv) | ||
117 | { | ||
118 | int ret = iwl_grab_nic_access_silent(priv); | ||
119 | if (ret) { | ||
120 | u32 val = iwl_read32(priv, CSR_GP_CNTRL); | ||
121 | IWL_ERR(priv, | ||
122 | "MAC is in deep sleep!. CSR_GP_CNTRL = 0x%08X\n", val); | ||
123 | } | ||
124 | |||
125 | return ret; | ||
126 | } | ||
127 | |||
120 | void iwl_release_nic_access(struct iwl_priv *priv) | 128 | void iwl_release_nic_access(struct iwl_priv *priv) |
121 | { | 129 | { |
122 | lockdep_assert_held(&priv->reg_lock); | 130 | lockdep_assert_held(&priv->reg_lock); |
@@ -242,20 +250,32 @@ void iwl_clear_bits_prph(struct iwl_priv *priv, u32 reg, u32 mask) | |||
242 | spin_unlock_irqrestore(&priv->reg_lock, flags); | 250 | spin_unlock_irqrestore(&priv->reg_lock, flags); |
243 | } | 251 | } |
244 | 252 | ||
245 | u32 iwl_read_targ_mem(struct iwl_priv *priv, u32 addr) | 253 | void _iwl_read_targ_mem_words(struct iwl_priv *priv, u32 addr, |
254 | void *buf, int words) | ||
246 | { | 255 | { |
247 | unsigned long flags; | 256 | unsigned long flags; |
248 | u32 value; | 257 | int offs; |
258 | u32 *vals = buf; | ||
249 | 259 | ||
250 | spin_lock_irqsave(&priv->reg_lock, flags); | 260 | spin_lock_irqsave(&priv->reg_lock, flags); |
251 | iwl_grab_nic_access(priv); | 261 | iwl_grab_nic_access(priv); |
252 | 262 | ||
253 | iwl_write32(priv, HBUS_TARG_MEM_RADDR, addr); | 263 | iwl_write32(priv, HBUS_TARG_MEM_RADDR, addr); |
254 | rmb(); | 264 | rmb(); |
255 | value = iwl_read32(priv, HBUS_TARG_MEM_RDAT); | 265 | |
266 | for (offs = 0; offs < words; offs++) | ||
267 | vals[offs] = iwl_read32(priv, HBUS_TARG_MEM_RDAT); | ||
256 | 268 | ||
257 | iwl_release_nic_access(priv); | 269 | iwl_release_nic_access(priv); |
258 | spin_unlock_irqrestore(&priv->reg_lock, flags); | 270 | spin_unlock_irqrestore(&priv->reg_lock, flags); |
271 | } | ||
272 | |||
273 | u32 iwl_read_targ_mem(struct iwl_priv *priv, u32 addr) | ||
274 | { | ||
275 | u32 value; | ||
276 | |||
277 | _iwl_read_targ_mem_words(priv, addr, &value, 1); | ||
278 | |||
259 | return value; | 279 | return value; |
260 | } | 280 | } |
261 | 281 | ||