diff options
author | Johannes Berg <johannes.berg@intel.com> | 2013-05-14 07:53:45 -0400 |
---|---|---|
committer | Johannes Berg <johannes.berg@intel.com> | 2013-05-29 15:56:57 -0400 |
commit | debff6184c32149bd08cfecfafbebb96201be37d (patch) | |
tree | 25feb83b8dd4cc4c119b00245cdebf36435d5698 /drivers/net/wireless/iwlwifi/pcie | |
parent | 774439518ac01049e9bf44f2fa4c604981f39dbf (diff) |
iwlwifi: mvm: implement D3 testing
For testing the D3 (WoWLAN) firmware, it is useful to be able
to run the firmware with instrumentation while the host isn't
sleeping and can poke at the firmware debug logging etc.
Implement this by a debugfs file. When the file is opened the
D3 firmware is loaded and all regular commands are blocked.
While the file is being read, poll the firmware's PME status
flag and report EOF once it changes to non-zero. When it is
closed, do (most of) the resume processing. This lets a user
just "cat" the file. Pressing Ctrl-C to kill the cat process
will resume the firwmare as though the platform resumed for
non-wireless reason and when the firmware wants to wake up
reading from the file automatically completes.
Unlike in real suspend, only disable interrupts and don't
reset the TX/RX hardware while in the test mode. This is a
workaround for some interrupt problems that happen only when
the PCIe link isn't fully reset (presumably by changing the
PCI config space registers which the core PCI code does.)
Note that while regular operations are blocked from sending
commands to the firmware, they could still be made and cause
strange mac80211 issues. Therefore, while using this testing
feature you need to be careful to not try to disconnect, roam
or similar, and will see warnings for such attempts.
Als note that this requires an upcoming firmware change to
tell the driver the location of the PME status flag in SRAM.
D3 test will fail if the firmware doesn't report the pointer.
Reviewed-by: Emmanuel Grumbach <emmanuel.grumbach@intel.com>
Signed-off-by: Johannes Berg <johannes.berg@intel.com>
Diffstat (limited to 'drivers/net/wireless/iwlwifi/pcie')
-rw-r--r-- | drivers/net/wireless/iwlwifi/pcie/trans.c | 19 |
1 files changed, 17 insertions, 2 deletions
diff --git a/drivers/net/wireless/iwlwifi/pcie/trans.c b/drivers/net/wireless/iwlwifi/pcie/trans.c index 0b021305eedf..197dbe0a868c 100644 --- a/drivers/net/wireless/iwlwifi/pcie/trans.c +++ b/drivers/net/wireless/iwlwifi/pcie/trans.c | |||
@@ -578,9 +578,17 @@ static void iwl_trans_pcie_stop_device(struct iwl_trans *trans) | |||
578 | clear_bit(STATUS_RFKILL, &trans_pcie->status); | 578 | clear_bit(STATUS_RFKILL, &trans_pcie->status); |
579 | } | 579 | } |
580 | 580 | ||
581 | static void iwl_trans_pcie_d3_suspend(struct iwl_trans *trans) | 581 | static void iwl_trans_pcie_d3_suspend(struct iwl_trans *trans, bool test) |
582 | { | 582 | { |
583 | iwl_disable_interrupts(trans); | 583 | iwl_disable_interrupts(trans); |
584 | |||
585 | /* | ||
586 | * in testing mode, the host stays awake and the | ||
587 | * hardware won't be reset (not even partially) | ||
588 | */ | ||
589 | if (test) | ||
590 | return; | ||
591 | |||
584 | iwl_pcie_disable_ict(trans); | 592 | iwl_pcie_disable_ict(trans); |
585 | 593 | ||
586 | iwl_clear_bit(trans, CSR_GP_CNTRL, | 594 | iwl_clear_bit(trans, CSR_GP_CNTRL, |
@@ -599,11 +607,18 @@ static void iwl_trans_pcie_d3_suspend(struct iwl_trans *trans) | |||
599 | } | 607 | } |
600 | 608 | ||
601 | static int iwl_trans_pcie_d3_resume(struct iwl_trans *trans, | 609 | static int iwl_trans_pcie_d3_resume(struct iwl_trans *trans, |
602 | enum iwl_d3_status *status) | 610 | enum iwl_d3_status *status, |
611 | bool test) | ||
603 | { | 612 | { |
604 | u32 val; | 613 | u32 val; |
605 | int ret; | 614 | int ret; |
606 | 615 | ||
616 | if (test) { | ||
617 | iwl_enable_interrupts(trans); | ||
618 | *status = IWL_D3_STATUS_ALIVE; | ||
619 | return 0; | ||
620 | } | ||
621 | |||
607 | iwl_pcie_set_pwr(trans, false); | 622 | iwl_pcie_set_pwr(trans, false); |
608 | 623 | ||
609 | val = iwl_read32(trans, CSR_RESET); | 624 | val = iwl_read32(trans, CSR_RESET); |