|
@@ -1205,19 +1205,31 @@ int iwl_mvm_rx_beacon_notif(struct iwl_mvm *mvm,
|
|
|
struct iwl_device_cmd *cmd)
|
|
|
{
|
|
|
struct iwl_rx_packet *pkt = rxb_addr(rxb);
|
|
|
- struct iwl_beacon_notif *beacon = (void *)pkt->data;
|
|
|
- u16 status __maybe_unused =
|
|
|
- le16_to_cpu(beacon->beacon_notify_hdr.status.status);
|
|
|
- u32 rate __maybe_unused =
|
|
|
- le32_to_cpu(beacon->beacon_notify_hdr.initial_rate);
|
|
|
+ struct iwl_mvm_tx_resp *beacon_notify_hdr;
|
|
|
+ u64 tsf;
|
|
|
|
|
|
lockdep_assert_held(&mvm->mutex);
|
|
|
|
|
|
- IWL_DEBUG_RX(mvm, "beacon status %#x retries:%d tsf:0x%16llX rate:%d\n",
|
|
|
- status & TX_STATUS_MSK,
|
|
|
- beacon->beacon_notify_hdr.failure_frame,
|
|
|
- le64_to_cpu(beacon->tsf),
|
|
|
- rate);
|
|
|
+ if (mvm->fw->ucode_capa.api[0] & IWL_UCODE_TLV_CAPA_EXTENDED_BEACON) {
|
|
|
+ struct iwl_extended_beacon_notif *beacon = (void *)pkt->data;
|
|
|
+
|
|
|
+ beacon_notify_hdr = &beacon->beacon_notify_hdr;
|
|
|
+ tsf = le64_to_cpu(beacon->tsf);
|
|
|
+ mvm->ap_last_beacon_gp2 = le32_to_cpu(beacon->gp2);
|
|
|
+ } else {
|
|
|
+ struct iwl_beacon_notif *beacon = (void *)pkt->data;
|
|
|
+
|
|
|
+ beacon_notify_hdr = &beacon->beacon_notify_hdr;
|
|
|
+ tsf = le64_to_cpu(beacon->tsf);
|
|
|
+ }
|
|
|
+
|
|
|
+ IWL_DEBUG_RX(mvm,
|
|
|
+ "beacon status %#x retries:%d tsf:0x%16llX gp2:0x%X rate:%d\n",
|
|
|
+ le16_to_cpu(beacon_notify_hdr->status.status) &
|
|
|
+ TX_STATUS_MSK,
|
|
|
+ beacon_notify_hdr->failure_frame, tsf,
|
|
|
+ mvm->ap_last_beacon_gp2,
|
|
|
+ le32_to_cpu(beacon_notify_hdr->initial_rate));
|
|
|
|
|
|
if (unlikely(mvm->csa_vif && mvm->csa_vif->csa_active)) {
|
|
|
if (!ieee80211_csa_is_complete(mvm->csa_vif)) {
|