Browse Source

qcacld-3.0: Check rmf status only for required frames

rmf status is applicable only for action/deauth/disassoc frames,
so check rmf status only for those frames, this can reduce
overhead of checking rmf status for each and every management frame.

Change-Id: I4fccf921051d624d01e94ee6ef8d9a6b170c7675
CRs-Fixed: 2656967
Dundi Raviteja 5 years ago
parent
commit
259898237f
1 changed files with 117 additions and 53 deletions
  1. 117 53
      components/pkt_capture/core/src/wlan_pkt_capture_mgmt_txrx.c

+ 117 - 53
components/pkt_capture/core/src/wlan_pkt_capture_mgmt_txrx.c

@@ -166,39 +166,35 @@ pkt_capture_mgmtpkt_process(struct wlan_objmgr_psoc *psoc,
 	return QDF_STATUS_SUCCESS;
 }
 
-QDF_STATUS
-pkt_capture_process_mgmt_tx_data(struct wlan_objmgr_pdev *pdev,
-				 struct mgmt_offload_event_params *params,
-				 qdf_nbuf_t nbuf,
-				 uint8_t status)
+/**
+ * pkt_capture_is_rmf_enabled - API to check if rmf is enabled or not
+ * @pdev: pointer to pdev object
+ * @psoc: pointer to psoc object
+ * @addr: mac address
+ */
+static bool
+pkt_capture_is_rmf_enabled(struct wlan_objmgr_pdev *pdev,
+			   struct wlan_objmgr_psoc *psoc,
+			   uint8_t *addr)
 {
-	struct mon_rx_status txrx_status = {0};
 	struct pkt_psoc_priv *psoc_priv;
 	struct wlan_objmgr_vdev *vdev;
-	struct wlan_objmgr_psoc *psoc;
-	uint16_t channel_flags = 0;
-	tpSirMacFrameCtl pfc = (tpSirMacFrameCtl) (qdf_nbuf_data(nbuf));
-	struct ieee80211_frame *wh;
-	uint8_t mgt_type, vdev_id;
+	uint8_t vdev_id;
 	int rmf_enabled;
 
-	psoc = wlan_pdev_get_psoc(pdev);
-	if (!psoc)
-		return QDF_STATUS_E_FAILURE;
-
 	psoc_priv = pkt_capture_psoc_get_priv(psoc);
 	if (!psoc_priv) {
 		pkt_capture_err("psoc priv is NULL");
-		return QDF_STATUS_E_FAILURE;
+		return false;
 	}
 
-	wh = (struct ieee80211_frame *)qdf_nbuf_data(nbuf);
-
 	vdev = wlan_objmgr_get_vdev_by_macaddr_from_pdev(pdev,
-							 wh->i_addr2,
+							 addr,
 							 WLAN_PKT_CAPTURE_ID);
-	if (!vdev)
-		return QDF_STATUS_E_FAILURE;
+	if (!vdev) {
+		pkt_capture_err("vdev is NULL");
+		return false;
+	}
 
 	vdev_id = wlan_vdev_get_id(vdev);
 	wlan_objmgr_vdev_release_ref(vdev, WLAN_PKT_CAPTURE_ID);
@@ -206,45 +202,91 @@ pkt_capture_process_mgmt_tx_data(struct wlan_objmgr_pdev *pdev,
 	rmf_enabled = psoc_priv->cb_obj.get_rmf_status(vdev_id);
 	if (rmf_enabled < 0) {
 		pkt_capture_err("unable to get rmf status");
+		return false;
+	}
+
+	return true;
+}
+
+/**
+ * pkt_capture_process_rmf_frame - process rmf frame
+ * @pdev: pointer to pdev object
+ * @psoc: pointer to psoc object
+ * @nbuf: netbuf
+ */
+static QDF_STATUS
+pkt_capture_process_rmf_frame(struct wlan_objmgr_pdev *pdev,
+			      struct wlan_objmgr_psoc *psoc,
+			      qdf_nbuf_t nbuf)
+{
+	tpSirMacFrameCtl pfc = (tpSirMacFrameCtl)(qdf_nbuf_data(nbuf));
+	uint8_t mic_len, hdr_len, pdev_id;
+	struct ieee80211_frame *wh;
+	uint8_t *orig_hdr;
+
+	wh = (struct ieee80211_frame *)qdf_nbuf_data(nbuf);
+
+	if (!QDF_IS_ADDR_BROADCAST(wh->i_addr1) &&
+	    !IEEE80211_IS_MULTICAST(wh->i_addr1)) {
+		if (pfc->wep) {
+			QDF_STATUS status;
+
+			orig_hdr = (uint8_t *)qdf_nbuf_data(nbuf);
+			pdev_id = wlan_objmgr_pdev_get_pdev_id(pdev);
+			status = mlme_get_peer_mic_len(psoc, pdev_id,
+						       wh->i_addr1,
+						       &mic_len,
+						       &hdr_len);
+			if (QDF_IS_STATUS_ERROR(status)) {
+				pkt_capture_err("Failed to get mic hdr");
+				return QDF_STATUS_E_FAILURE;
+			}
+
+			/* Strip privacy headers (and trailer)
+			 * for a received frame
+			 */
+			qdf_mem_move(orig_hdr + hdr_len, wh, sizeof(*wh));
+			qdf_nbuf_pull_head(nbuf, hdr_len);
+			qdf_nbuf_trim_tail(nbuf, mic_len);
+		}
+	} else {
+		qdf_nbuf_trim_tail(nbuf, IEEE80211_MMIE_LEN);
+	}
+
+	return QDF_STATUS_SUCCESS;
+}
+
+QDF_STATUS
+pkt_capture_process_mgmt_tx_data(struct wlan_objmgr_pdev *pdev,
+				 struct mgmt_offload_event_params *params,
+				 qdf_nbuf_t nbuf,
+				 uint8_t status)
+{
+	struct mon_rx_status txrx_status = {0};
+	struct wlan_objmgr_psoc *psoc;
+	uint16_t channel_flags = 0;
+	tpSirMacFrameCtl pfc = (tpSirMacFrameCtl)(qdf_nbuf_data(nbuf));
+	struct ieee80211_frame *wh;
+
+	psoc = wlan_pdev_get_psoc(pdev);
+	if (!psoc) {
+		pkt_capture_err("psoc is NULL");
 		return QDF_STATUS_E_FAILURE;
 	}
 
-	mgt_type = (wh)->i_fc[0] & IEEE80211_FC0_TYPE_MASK;
+	wh = (struct ieee80211_frame *)qdf_nbuf_data(nbuf);
 
-	if (rmf_enabled &&
-	    (mgt_type == IEEE80211_FC0_TYPE_MGT) &&
+	if ((pfc->type == IEEE80211_FC0_TYPE_MGT) &&
 	    (pfc->subType == SIR_MAC_MGMT_DISASSOC ||
 	     pfc->subType == SIR_MAC_MGMT_DEAUTH ||
 	     pfc->subType == SIR_MAC_MGMT_ACTION)) {
-		uint8_t *orig_hdr;
-		uint8_t mic_len, hdr_len, pdev_id;
-
-		if (!QDF_IS_ADDR_BROADCAST(wh->i_addr1) &&
-		    !IEEE80211_IS_MULTICAST(wh->i_addr1)) {
-			if (pfc->wep) {
-				orig_hdr = (uint8_t *)qdf_nbuf_data(nbuf);
-				pdev_id = wlan_objmgr_pdev_get_pdev_id(pdev);
-				status = mlme_get_peer_mic_len(psoc, pdev_id,
-							       wh->i_addr1,
-							       &mic_len,
-							       &hdr_len);
-				if (QDF_IS_STATUS_ERROR(status)) {
-					pkt_capture_err("Failed to get mic hdr");
-					return QDF_STATUS_E_FAILURE;
-				}
-
-				/* Strip privacy headers (and trailer)
-				 * for a received frame
-				 */
-				qdf_mem_move(orig_hdr +
-					     hdr_len, wh,
-					     sizeof(*wh));
-				qdf_nbuf_pull_head(nbuf,
-						   hdr_len);
-				qdf_nbuf_trim_tail(nbuf, mic_len);
-			}
-		} else {
-			qdf_nbuf_trim_tail(nbuf, IEEE80211_MMIE_LEN);
+		if (pkt_capture_is_rmf_enabled(pdev, psoc, wh->i_addr2)) {
+			QDF_STATUS status;
+
+			status = pkt_capture_process_rmf_frame(pdev, psoc,
+							       nbuf);
+			if (QDF_IS_STATUS_ERROR(status))
+				return status;
 		}
 	}
 
@@ -388,6 +430,7 @@ pkt_capture_mgmt_rx_data_cb(struct wlan_objmgr_psoc *psoc,
 	struct mon_rx_status txrx_status = {0};
 	uint16_t channel_flags = 0;
 	struct ieee80211_frame *wh;
+	tpSirMacFrameCtl pfc;
 	qdf_nbuf_t nbuf;
 	int buf_len;
 
@@ -404,6 +447,27 @@ pkt_capture_mgmt_rx_data_cb(struct wlan_objmgr_psoc *psoc,
 	qdf_nbuf_put_tail(nbuf, buf_len);
 	qdf_mem_copy(qdf_nbuf_data(nbuf), qdf_nbuf_data(wbuf), buf_len);
 
+	pfc = (tpSirMacFrameCtl)(qdf_nbuf_data(nbuf));
+	wh = (struct ieee80211_frame *)qdf_nbuf_data(nbuf);
+
+	if ((pfc->type == IEEE80211_FC0_TYPE_MGT) &&
+	    (pfc->subType == SIR_MAC_MGMT_DISASSOC ||
+	     pfc->subType == SIR_MAC_MGMT_DEAUTH ||
+	     pfc->subType == SIR_MAC_MGMT_ACTION)) {
+		struct wlan_objmgr_pdev *pdev;
+
+		pdev = wlan_vdev_get_pdev(peer->peer_objmgr.vdev);
+		if (pkt_capture_is_rmf_enabled(pdev, psoc, wh->i_addr2)) {
+			QDF_STATUS status;
+
+			status = pkt_capture_process_rmf_frame(pdev, psoc,
+							       nbuf);
+			if (QDF_IS_STATUS_ERROR(status))
+				return status;
+		}
+	}
+
+
 	txrx_status.tsft = (u_int64_t)rx_params->tsf_delta;
 	txrx_status.chan_num = rx_params->channel;
 	txrx_status.chan_freq = wlan_chan_to_freq(txrx_status.chan_num);