diff options
author | Johannes Berg <johannes.berg@intel.com> | 2013-10-21 06:37:53 -0400 |
---|---|---|
committer | Emmanuel Grumbach <emmanuel.grumbach@intel.com> | 2013-10-29 09:52:25 -0400 |
commit | fb8b8ee10e1bff6531d588525d6b6c3440e71e11 (patch) | |
tree | 6acae73f224abff273d74b87e26e5653b96ed406 /drivers | |
parent | bcbb8c9c7d42e012d8f73dfcccfcc56d5c8da431 (diff) |
iwlwifi: mvm: capture the FCS in monitor mode
This can be useful when using the device as a sniffer.
Signed-off-by: Johannes Berg <johannes.berg@intel.com>
Signed-off-by: Emmanuel Grumbach <emmanuel.grumbach@intel.com>
Diffstat (limited to 'drivers')
-rw-r--r-- | drivers/net/wireless/iwlwifi/mvm/mac-ctxt.c | 8 | ||||
-rw-r--r-- | drivers/net/wireless/iwlwifi/mvm/rx.c | 6 |
2 files changed, 12 insertions, 2 deletions
diff --git a/drivers/net/wireless/iwlwifi/mvm/mac-ctxt.c b/drivers/net/wireless/iwlwifi/mvm/mac-ctxt.c index ab5a7ac90dcd..f41f9b079831 100644 --- a/drivers/net/wireless/iwlwifi/mvm/mac-ctxt.c +++ b/drivers/net/wireless/iwlwifi/mvm/mac-ctxt.c | |||
@@ -719,7 +719,9 @@ static int iwl_mvm_mac_ctxt_cmd_listener(struct iwl_mvm *mvm, | |||
719 | cmd.filter_flags = cpu_to_le32(MAC_FILTER_IN_PROMISC | | 719 | cmd.filter_flags = cpu_to_le32(MAC_FILTER_IN_PROMISC | |
720 | MAC_FILTER_IN_CONTROL_AND_MGMT | | 720 | MAC_FILTER_IN_CONTROL_AND_MGMT | |
721 | MAC_FILTER_IN_BEACON | | 721 | MAC_FILTER_IN_BEACON | |
722 | MAC_FILTER_IN_PROBE_REQUEST); | 722 | MAC_FILTER_IN_PROBE_REQUEST | |
723 | MAC_FILTER_IN_CRC32); | ||
724 | mvm->hw->flags |= IEEE80211_HW_RX_INCLUDES_FCS; | ||
723 | 725 | ||
724 | return iwl_mvm_mac_ctxt_send_cmd(mvm, &cmd); | 726 | return iwl_mvm_mac_ctxt_send_cmd(mvm, &cmd); |
725 | } | 727 | } |
@@ -1122,6 +1124,10 @@ int iwl_mvm_mac_ctxt_remove(struct iwl_mvm *mvm, struct ieee80211_vif *vif) | |||
1122 | } | 1124 | } |
1123 | 1125 | ||
1124 | mvmvif->uploaded = false; | 1126 | mvmvif->uploaded = false; |
1127 | |||
1128 | if (vif->type == NL80211_IFTYPE_MONITOR) | ||
1129 | mvm->hw->flags &= ~IEEE80211_HW_RX_INCLUDES_FCS; | ||
1130 | |||
1125 | return 0; | 1131 | return 0; |
1126 | } | 1132 | } |
1127 | 1133 | ||
diff --git a/drivers/net/wireless/iwlwifi/mvm/rx.c b/drivers/net/wireless/iwlwifi/mvm/rx.c index a4af5019a496..3a1f3982109d 100644 --- a/drivers/net/wireless/iwlwifi/mvm/rx.c +++ b/drivers/net/wireless/iwlwifi/mvm/rx.c | |||
@@ -300,10 +300,14 @@ int iwl_mvm_rx_rx_mpdu(struct iwl_mvm *mvm, struct iwl_rx_cmd_buffer *rxb, | |||
300 | return 0; | 300 | return 0; |
301 | } | 301 | } |
302 | 302 | ||
303 | /* | ||
304 | * Keep packets with CRC errors (and with overrun) for monitor mode | ||
305 | * (otherwise the firmware discards them) but mark them as bad. | ||
306 | */ | ||
303 | if (!(rx_pkt_status & RX_MPDU_RES_STATUS_CRC_OK) || | 307 | if (!(rx_pkt_status & RX_MPDU_RES_STATUS_CRC_OK) || |
304 | !(rx_pkt_status & RX_MPDU_RES_STATUS_OVERRUN_OK)) { | 308 | !(rx_pkt_status & RX_MPDU_RES_STATUS_OVERRUN_OK)) { |
305 | IWL_DEBUG_RX(mvm, "Bad CRC or FIFO: 0x%08X.\n", rx_pkt_status); | 309 | IWL_DEBUG_RX(mvm, "Bad CRC or FIFO: 0x%08X.\n", rx_pkt_status); |
306 | return 0; | 310 | rx_status.flag |= RX_FLAG_FAILED_FCS_CRC; |
307 | } | 311 | } |
308 | 312 | ||
309 | /* This will be used in several places later */ | 313 | /* This will be used in several places later */ |