ath11k: Send PPDU_STATS_CFG with proper pdev mask to firmware
[ Upstream commit 16a2c3d5406f95ef6139de52669c60a39443f5f7 ] HTT_PPDU_STATS_CFG_PDEV_ID bit mask for target FW PPDU stats request message was set as bit 8 to 15. Bit 8 is reserved for soc stats and pdev id starts from bit 9. Hence change the bitmask as bit 9 to 15 and fill the proper pdev id in the request message. In commit701e48a43e
("ath11k: add packet log support for QCA6390"), both HTT_PPDU_STATS_CFG_PDEV_ID and pdev_mask were changed, but this pdev_mask calculation is not valid for platforms which has multiple pdevs with 1 rxdma per pdev, as this is writing same value(i.e. 2) for all pdevs. Hence fixed it to consider pdev_idx as well, to make it compatible for both single and multi pd cases. Tested on: IPQ8074 hw2.0 AHB WLAN.HK.2.5.0.1-01092-QCAHKSWPL_SILICONZ-1 Tested on: IPQ6018 hw1.0 WLAN.HK.2.5.0.1-01067-QCAHKSWPL_SILICONZ-1 Fixes:701e48a43e
("ath11k: add packet log support for QCA6390") Co-developed-by: Sathishkumar Muruganandam <murugana@codeaurora.org> Signed-off-by: Sathishkumar Muruganandam <murugana@codeaurora.org> Signed-off-by: Rameshkumar Sundaram <ramess@codeaurora.org> Signed-off-by: Jouni Malinen <jouni@codeaurora.org> Signed-off-by: Kalle Valo <kvalo@codeaurora.org> Link: https://lore.kernel.org/r/20210721212029.142388-10-jouni@codeaurora.org Signed-off-by: Sasha Levin <sashal@kernel.org>
This commit is contained in:

committed by
Greg Kroah-Hartman

parent
2fe056d979
commit
9bfed11dcf
@@ -514,7 +514,8 @@ struct htt_ppdu_stats_cfg_cmd {
|
|||||||
} __packed;
|
} __packed;
|
||||||
|
|
||||||
#define HTT_PPDU_STATS_CFG_MSG_TYPE GENMASK(7, 0)
|
#define HTT_PPDU_STATS_CFG_MSG_TYPE GENMASK(7, 0)
|
||||||
#define HTT_PPDU_STATS_CFG_PDEV_ID GENMASK(15, 8)
|
#define HTT_PPDU_STATS_CFG_SOC_STATS BIT(8)
|
||||||
|
#define HTT_PPDU_STATS_CFG_PDEV_ID GENMASK(15, 9)
|
||||||
#define HTT_PPDU_STATS_CFG_TLV_TYPE_BITMASK GENMASK(31, 16)
|
#define HTT_PPDU_STATS_CFG_TLV_TYPE_BITMASK GENMASK(31, 16)
|
||||||
|
|
||||||
enum htt_ppdu_stats_tag_type {
|
enum htt_ppdu_stats_tag_type {
|
||||||
|
@@ -894,7 +894,7 @@ int ath11k_dp_tx_htt_h2t_ppdu_stats_req(struct ath11k *ar, u32 mask)
|
|||||||
cmd->msg = FIELD_PREP(HTT_PPDU_STATS_CFG_MSG_TYPE,
|
cmd->msg = FIELD_PREP(HTT_PPDU_STATS_CFG_MSG_TYPE,
|
||||||
HTT_H2T_MSG_TYPE_PPDU_STATS_CFG);
|
HTT_H2T_MSG_TYPE_PPDU_STATS_CFG);
|
||||||
|
|
||||||
pdev_mask = 1 << (i + 1);
|
pdev_mask = 1 << (ar->pdev_idx + i);
|
||||||
cmd->msg |= FIELD_PREP(HTT_PPDU_STATS_CFG_PDEV_ID, pdev_mask);
|
cmd->msg |= FIELD_PREP(HTT_PPDU_STATS_CFG_PDEV_ID, pdev_mask);
|
||||||
cmd->msg |= FIELD_PREP(HTT_PPDU_STATS_CFG_TLV_TYPE_BITMASK, mask);
|
cmd->msg |= FIELD_PREP(HTT_PPDU_STATS_CFG_TLV_TYPE_BITMASK, mask);
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user