ath9k_htc: Use power save wrappers when accessing HW
authorSujith Manoharan <Sujith.Manoharan@atheros.com>
Wed, 20 Apr 2011 05:31:10 +0000 (11:01 +0530)
committerJohn W. Linville <linville@tuxdriver.com>
Mon, 25 Apr 2011 18:50:14 +0000 (14:50 -0400)
Signed-off-by: Sujith Manoharan <Sujith.Manoharan@atheros.com>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
drivers/net/wireless/ath/ath9k/htc_drv_debug.c
drivers/net/wireless/ath/ath9k/htc_drv_main.c

index eca7774..894e5ef 100644 (file)
@@ -33,9 +33,15 @@ static ssize_t read_file_tgt_int_stats(struct file *file, char __user *user_buf,
 
        memset(&cmd_rsp, 0, sizeof(cmd_rsp));
 
+       ath9k_htc_ps_wakeup(priv);
+
        WMI_CMD(WMI_INT_STATS_CMDID);
-       if (ret)
+       if (ret) {
+               ath9k_htc_ps_restore(priv);
                return -EINVAL;
+       }
+
+       ath9k_htc_ps_restore(priv);
 
        len += snprintf(buf + len, sizeof(buf) - len,
                        "%20s : %10u\n", "RX",
@@ -85,9 +91,15 @@ static ssize_t read_file_tgt_tx_stats(struct file *file, char __user *user_buf,
 
        memset(&cmd_rsp, 0, sizeof(cmd_rsp));
 
+       ath9k_htc_ps_wakeup(priv);
+
        WMI_CMD(WMI_TX_STATS_CMDID);
-       if (ret)
+       if (ret) {
+               ath9k_htc_ps_restore(priv);
                return -EINVAL;
+       }
+
+       ath9k_htc_ps_restore(priv);
 
        len += snprintf(buf + len, sizeof(buf) - len,
                        "%20s : %10u\n", "Xretries",
@@ -149,9 +161,15 @@ static ssize_t read_file_tgt_rx_stats(struct file *file, char __user *user_buf,
 
        memset(&cmd_rsp, 0, sizeof(cmd_rsp));
 
+       ath9k_htc_ps_wakeup(priv);
+
        WMI_CMD(WMI_RX_STATS_CMDID);
-       if (ret)
+       if (ret) {
+               ath9k_htc_ps_restore(priv);
                return -EINVAL;
+       }
+
+       ath9k_htc_ps_restore(priv);
 
        len += snprintf(buf + len, sizeof(buf) - len,
                        "%20s : %10u\n", "NoBuf",
index fbc238a..c8577d5 100644 (file)
@@ -1582,6 +1582,7 @@ static int ath9k_htc_ampdu_action(struct ieee80211_hw *hw,
        int ret = 0;
 
        mutex_lock(&priv->mutex);
+       ath9k_htc_ps_wakeup(priv);
 
        switch (action) {
        case IEEE80211_AMPDU_RX_START:
@@ -1607,6 +1608,7 @@ static int ath9k_htc_ampdu_action(struct ieee80211_hw *hw,
                ath_err(ath9k_hw_common(priv->ah), "Unknown AMPDU action\n");
        }
 
+       ath9k_htc_ps_restore(priv);
        mutex_unlock(&priv->mutex);
 
        return ret;