aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net/wireless/iwlwifi/iwl-agn-ucode.c
diff options
context:
space:
mode:
authorGrumbach, Emmanuel <emmanuel.grumbach@intel.com>2010-11-18 06:47:38 -0500
committerWey-Yi Guy <wey-yi.w.guy@intel.com>2010-12-02 11:35:02 -0500
commite7cad69cdab4d6f0caadbcdd58b54214243ba98a (patch)
tree693e9ee779a7cee5e3ba07b044ed1040d05b3051 /drivers/net/wireless/iwlwifi/iwl-agn-ucode.c
parent40b97c2fe96a476f1c228345f0c6a2d135a8b226 (diff)
iwlagn: Enable PCI L1 ACTIVE state after uCode has been loaded
PCI L1 Active needs to be disabled while loading the uCode so that the bus doesn't go to sleep. The enablement of L1 Active should be done after the uCode has sent the ALIVE response. The enablement of L1 Active was missing. Enabling L1 Active allows to save power if the BIOS / bus driver allows it. I measured the power consumption while not associated and idle/associated: L1 Active disabled: 39 mA = 130mW L1 Active enabled: 6 mA = 20 mW Signed-off-by: Emmanuel Grumbach <emmanuel.grumbach@intel.com> Signed-off-by: Wey-Yi Guy <wey-yi.w.guy@intel.com>
Diffstat (limited to 'drivers/net/wireless/iwlwifi/iwl-agn-ucode.c')
-rw-r--r--drivers/net/wireless/iwlwifi/iwl-agn-ucode.c4
1 files changed, 4 insertions, 0 deletions
diff --git a/drivers/net/wireless/iwlwifi/iwl-agn-ucode.c b/drivers/net/wireless/iwlwifi/iwl-agn-ucode.c
index 0bdd2bb0bbd3..24dabcd2a36c 100644
--- a/drivers/net/wireless/iwlwifi/iwl-agn-ucode.c
+++ b/drivers/net/wireless/iwlwifi/iwl-agn-ucode.c
@@ -531,6 +531,10 @@ int iwlagn_alive_notify(struct iwl_priv *priv)
531 531
532 spin_unlock_irqrestore(&priv->lock, flags); 532 spin_unlock_irqrestore(&priv->lock, flags);
533 533
534 /* Enable L1-Active */
535 iwl_clear_bits_prph(priv, APMG_PCIDEV_STT_REG,
536 APMG_PCIDEV_STT_VAL_L1_ACT_DIS);
537
534 iwlagn_send_wimax_coex(priv); 538 iwlagn_send_wimax_coex(priv);
535 539
536 iwlagn_set_Xtal_calib(priv); 540 iwlagn_set_Xtal_calib(priv);