]> git.kernelconcepts.de Git - karo-tx-linux.git/commitdiff
staging: vt6656: implement power saving code.
authorMalcolm Priestley <tvboxspy@gmail.com>
Sun, 27 Sep 2015 08:17:41 +0000 (09:17 +0100)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Tue, 29 Sep 2015 02:19:53 +0000 (04:19 +0200)
The device should ready to listen to next beacon so on count down of
wake_up_count == 1.

schedule command WLAN_CMD_TBTT_WAKEUP which calls vnt_next_tbtt_wakeup which
wakes the device.

This restores this back to vendors code with a slight difference the
count down is in the interrupt handler.

Signed-off-by: Malcolm Priestley <tvboxspy@gmail.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/staging/vt6656/device.h
drivers/staging/vt6656/int.c
drivers/staging/vt6656/power.c

index 635d931de409084b98666a34057f6babfd925009..dec36f296f3d07f6b0d7a8e07dd9a6a2f9167eb9 100644 (file)
@@ -389,6 +389,8 @@ struct vnt_private {
        u8 bb_pre_ed_rssi;
        u8 bb_pre_ed_index;
 
+       u16 wake_up_count;
+
        /* command timer */
        struct delayed_work run_command_work;
 
index 2ef70e4701f69af603c3c55ad3bb8e1f7a542e60..14b8ebc6508d68acbad02d0ca4b3af642e940f36 100644 (file)
@@ -149,10 +149,18 @@ void vnt_int_process_data(struct vnt_private *priv)
                                priv->op_mode == NL80211_IFTYPE_AP)
                        vnt_schedule_command(priv, WLAN_CMD_BECON_SEND);
 
-               if (int_data->isr0 & ISR_TBTT) {
-                       if (priv->hw->conf.flags & IEEE80211_CONF_PS)
+               if (int_data->isr0 & ISR_TBTT &&
+                   priv->hw->conf.flags & IEEE80211_CONF_PS) {
+                       if (!priv->wake_up_count)
+                               priv->wake_up_count =
+                                       priv->hw->conf.listen_interval;
+
+                       --priv->wake_up_count;
+
+                       /* Turn on wake up to listen next beacon */
+                       if (priv->wake_up_count == 1)
                                vnt_schedule_command(priv,
-                                                       WLAN_CMD_TBTT_WAKEUP);
+                                                    WLAN_CMD_TBTT_WAKEUP);
                }
                priv->current_tsf = le64_to_cpu(int_data->tsf);
 
index 0ffbaed5d7744ccb119d9d3dfa4f12e5b0634ad3..d5912d23aa0d36552ab90c1c21540dce288e9a26 100644 (file)
@@ -134,7 +134,7 @@ int vnt_next_tbtt_wakeup(struct vnt_private *priv)
        struct ieee80211_conf *conf = &hw->conf;
        int wake_up = false;
 
-       if (conf->listen_interval == 1) {
+       if (conf->listen_interval > 1) {
                /* Turn on wake up to listen next beacon */
                vnt_mac_reg_bits_on(priv, MAC_REG_PSCTL, PSCTL_LNBCN);
                wake_up = true;