qcacmn: Disable monitor mode for QCA6390
Setup monitor mode rings and allocate descriptors only if QCA6390_MONITOR_MODE is defined. Change-Id: I9c9bdc1e325eda822a326d64d6445a7112083420 CRs-Fixed: 2271998
このコミットが含まれているのは:
@@ -2559,7 +2559,6 @@ static void dp_cleanup_ipa_rx_refill_buf_ring(struct dp_soc *soc,
|
||||
}
|
||||
|
||||
#else
|
||||
|
||||
static int dp_setup_ipa_rx_refill_buf_ring(struct dp_soc *soc,
|
||||
struct dp_pdev *pdev)
|
||||
{
|
||||
@@ -2570,7 +2569,57 @@ static void dp_cleanup_ipa_rx_refill_buf_ring(struct dp_soc *soc,
|
||||
struct dp_pdev *pdev)
|
||||
{
|
||||
}
|
||||
#endif
|
||||
|
||||
#ifndef QCA_WIFI_QCA6390
|
||||
static
|
||||
QDF_STATUS dp_mon_rings_setup(struct dp_soc *soc, struct dp_pdev *pdev)
|
||||
{
|
||||
int mac_id = 0;
|
||||
int pdev_id = pdev->pdev_id;
|
||||
|
||||
for (mac_id = 0; mac_id < NUM_RXDMA_RINGS_PER_PDEV; mac_id++) {
|
||||
int mac_for_pdev = dp_get_mac_id_for_pdev(mac_id, pdev_id);
|
||||
|
||||
if (dp_srng_setup(soc, &pdev->rxdma_mon_buf_ring[mac_id],
|
||||
RXDMA_MONITOR_BUF, 0, mac_for_pdev,
|
||||
RXDMA_MONITOR_BUF_RING_SIZE)) {
|
||||
QDF_TRACE(QDF_MODULE_ID_DP, QDF_TRACE_LEVEL_ERROR,
|
||||
FL("Srng setup failed for rxdma_mon_buf_ring"));
|
||||
return QDF_STATUS_E_NOMEM;
|
||||
}
|
||||
|
||||
if (dp_srng_setup(soc, &pdev->rxdma_mon_dst_ring[mac_id],
|
||||
RXDMA_MONITOR_DST, 0, mac_for_pdev,
|
||||
RXDMA_MONITOR_DST_RING_SIZE)) {
|
||||
QDF_TRACE(QDF_MODULE_ID_DP, QDF_TRACE_LEVEL_ERROR,
|
||||
FL("Srng setup failed for rxdma_mon_dst_ring"));
|
||||
return QDF_STATUS_E_NOMEM;
|
||||
}
|
||||
|
||||
if (dp_srng_setup(soc, &pdev->rxdma_mon_status_ring[mac_id],
|
||||
RXDMA_MONITOR_STATUS, 0, mac_for_pdev,
|
||||
RXDMA_MONITOR_STATUS_RING_SIZE)) {
|
||||
QDF_TRACE(QDF_MODULE_ID_DP, QDF_TRACE_LEVEL_ERROR,
|
||||
FL("Srng setup failed for rxdma_mon_status_ring"));
|
||||
return QDF_STATUS_E_NOMEM;
|
||||
}
|
||||
|
||||
if (dp_srng_setup(soc, &pdev->rxdma_mon_desc_ring[mac_id],
|
||||
RXDMA_MONITOR_DESC, 0, mac_for_pdev,
|
||||
RXDMA_MONITOR_DESC_RING_SIZE)) {
|
||||
QDF_TRACE(QDF_MODULE_ID_DP, QDF_TRACE_LEVEL_ERROR,
|
||||
"Srng setup failed for rxdma_mon_desc_ring\n");
|
||||
return QDF_STATUS_E_NOMEM;
|
||||
}
|
||||
}
|
||||
return QDF_STATUS_SUCCESS;
|
||||
}
|
||||
#else
|
||||
static QDF_STATUS dp_mon_rings_setup(struct dp_soc *soc, struct dp_pdev *pdev)
|
||||
{
|
||||
return QDF_STATUS_SUCCESS;
|
||||
}
|
||||
#endif
|
||||
|
||||
/*
|
||||
@@ -2592,7 +2641,6 @@ static struct cdp_pdev *dp_pdev_attach_wifi3(struct cdp_soc_t *txrx_soc,
|
||||
|
||||
struct dp_soc *soc = (struct dp_soc *)txrx_soc;
|
||||
struct dp_pdev *pdev = qdf_mem_malloc(sizeof(*pdev));
|
||||
int mac_id;
|
||||
|
||||
if (!pdev) {
|
||||
QDF_TRACE(QDF_MODULE_ID_DP, QDF_TRACE_LEVEL_ERROR,
|
||||
@@ -2689,43 +2737,12 @@ static struct cdp_pdev *dp_pdev_attach_wifi3(struct cdp_soc_t *txrx_soc,
|
||||
goto fail1;
|
||||
}
|
||||
|
||||
for (mac_id = 0; mac_id < NUM_RXDMA_RINGS_PER_PDEV; mac_id++) {
|
||||
int mac_for_pdev = dp_get_mac_id_for_pdev(mac_id, pdev_id);
|
||||
|
||||
if (dp_srng_setup(soc, &pdev->rxdma_mon_buf_ring[mac_id],
|
||||
RXDMA_MONITOR_BUF, 0, mac_for_pdev,
|
||||
RXDMA_MONITOR_BUF_RING_SIZE)) {
|
||||
if (dp_mon_rings_setup(soc, pdev)) {
|
||||
QDF_TRACE(QDF_MODULE_ID_DP, QDF_TRACE_LEVEL_ERROR,
|
||||
FL("dp_srng_setup failed for rxdma_mon_buf_ring"));
|
||||
FL("MONITOR rings setup failed"));
|
||||
goto fail1;
|
||||
}
|
||||
|
||||
if (dp_srng_setup(soc, &pdev->rxdma_mon_dst_ring[mac_id],
|
||||
RXDMA_MONITOR_DST, 0, mac_for_pdev,
|
||||
RXDMA_MONITOR_DST_RING_SIZE)) {
|
||||
QDF_TRACE(QDF_MODULE_ID_DP, QDF_TRACE_LEVEL_ERROR,
|
||||
FL("dp_srng_setup failed for rxdma_mon_dst_ring"));
|
||||
goto fail1;
|
||||
}
|
||||
|
||||
|
||||
if (dp_srng_setup(soc, &pdev->rxdma_mon_status_ring[mac_id],
|
||||
RXDMA_MONITOR_STATUS, 0, mac_for_pdev,
|
||||
RXDMA_MONITOR_STATUS_RING_SIZE)) {
|
||||
QDF_TRACE(QDF_MODULE_ID_DP, QDF_TRACE_LEVEL_ERROR,
|
||||
FL("dp_srng_setup failed for rxdma_mon_status_ring"));
|
||||
goto fail1;
|
||||
}
|
||||
|
||||
if (dp_srng_setup(soc, &pdev->rxdma_mon_desc_ring[mac_id],
|
||||
RXDMA_MONITOR_DESC, 0, mac_for_pdev,
|
||||
RXDMA_MONITOR_DESC_RING_SIZE)) {
|
||||
QDF_TRACE(QDF_MODULE_ID_DP, QDF_TRACE_LEVEL_ERROR,
|
||||
"dp_srng_setup failed for rxdma_mon_desc_ring\n");
|
||||
goto fail1;
|
||||
}
|
||||
}
|
||||
|
||||
if (wlan_cfg_per_pdev_lmac_ring(soc->wlan_cfg_ctx)) {
|
||||
if (dp_srng_setup(soc, &pdev->rxdma_err_dst_ring[0], RXDMA_DST,
|
||||
0, pdev_id, RXDMA_ERR_DST_RING_SIZE)) {
|
||||
@@ -2872,6 +2889,31 @@ static void dp_htt_ppdu_stats_detach(struct dp_pdev *pdev)
|
||||
}
|
||||
}
|
||||
|
||||
#ifndef QCA_WIFI_QCA6390
|
||||
static
|
||||
void dp_mon_ring_deinit(struct dp_soc *soc, struct dp_pdev *pdev,
|
||||
int mac_id)
|
||||
{
|
||||
dp_srng_cleanup(soc, &pdev->rxdma_mon_buf_ring[mac_id],
|
||||
RXDMA_MONITOR_BUF, 0);
|
||||
dp_srng_cleanup(soc, &pdev->rxdma_mon_dst_ring[mac_id],
|
||||
RXDMA_MONITOR_DST, 0);
|
||||
|
||||
dp_srng_cleanup(soc, &pdev->rxdma_mon_status_ring[mac_id],
|
||||
RXDMA_MONITOR_STATUS, 0);
|
||||
|
||||
dp_srng_cleanup(soc, &pdev->rxdma_mon_desc_ring[mac_id],
|
||||
RXDMA_MONITOR_DESC, 0);
|
||||
dp_srng_cleanup(soc, &pdev->rxdma_err_dst_ring[mac_id],
|
||||
RXDMA_DST, 0);
|
||||
}
|
||||
#else
|
||||
static void dp_mon_ring_deinit(struct dp_soc *soc, struct dp_pdev *pdev,
|
||||
int mac_id)
|
||||
{
|
||||
}
|
||||
#endif
|
||||
|
||||
/*
|
||||
* dp_pdev_detach_wifi3() - detach txrx pdev
|
||||
* @txrx_pdev: Datapath PDEV handle
|
||||
@@ -2899,9 +2941,7 @@ static void dp_pdev_detach_wifi3(struct cdp_pdev *txrx_pdev, int force)
|
||||
dp_pktlogmod_exit(pdev);
|
||||
|
||||
dp_rx_pdev_detach(pdev);
|
||||
|
||||
dp_rx_pdev_mon_detach(pdev);
|
||||
|
||||
dp_neighbour_peers_detach(pdev);
|
||||
qdf_spinlock_destroy(&pdev->tx_mutex);
|
||||
qdf_spinlock_destroy(&pdev->vdev_list_lock);
|
||||
@@ -2921,18 +2961,7 @@ static void dp_pdev_detach_wifi3(struct cdp_pdev *txrx_pdev, int force)
|
||||
dp_rxdma_ring_cleanup(soc, pdev);
|
||||
|
||||
for (mac_id = 0; mac_id < NUM_RXDMA_RINGS_PER_PDEV; mac_id++) {
|
||||
dp_srng_cleanup(soc, &pdev->rxdma_mon_buf_ring[mac_id],
|
||||
RXDMA_MONITOR_BUF, 0);
|
||||
|
||||
dp_srng_cleanup(soc, &pdev->rxdma_mon_dst_ring[mac_id],
|
||||
RXDMA_MONITOR_DST, 0);
|
||||
|
||||
dp_srng_cleanup(soc, &pdev->rxdma_mon_status_ring[mac_id],
|
||||
RXDMA_MONITOR_STATUS, 0);
|
||||
|
||||
dp_srng_cleanup(soc, &pdev->rxdma_mon_desc_ring[mac_id],
|
||||
RXDMA_MONITOR_DESC, 0);
|
||||
|
||||
dp_mon_ring_deinit(soc, pdev, mac_id);
|
||||
dp_srng_cleanup(soc, &pdev->rxdma_err_dst_ring[mac_id],
|
||||
RXDMA_DST, 0);
|
||||
}
|
||||
@@ -3076,6 +3105,36 @@ static void dp_soc_detach_wifi3(void *txrx_soc)
|
||||
qdf_mem_free(soc);
|
||||
}
|
||||
|
||||
#ifndef QCA_WIFI_QCA6390
|
||||
static void dp_mon_htt_srng_setup(struct dp_soc *soc,
|
||||
struct dp_pdev *pdev,
|
||||
int mac_id,
|
||||
int mac_for_pdev)
|
||||
{
|
||||
htt_srng_setup(soc->htt_handle, mac_for_pdev,
|
||||
pdev->rxdma_mon_buf_ring[mac_id].hal_srng,
|
||||
RXDMA_MONITOR_BUF);
|
||||
|
||||
htt_srng_setup(soc->htt_handle, mac_for_pdev,
|
||||
pdev->rxdma_mon_dst_ring[mac_id].hal_srng,
|
||||
RXDMA_MONITOR_DST);
|
||||
|
||||
htt_srng_setup(soc->htt_handle, mac_for_pdev,
|
||||
pdev->rxdma_mon_status_ring[mac_id].hal_srng,
|
||||
RXDMA_MONITOR_STATUS);
|
||||
|
||||
htt_srng_setup(soc->htt_handle, mac_for_pdev,
|
||||
pdev->rxdma_mon_desc_ring[mac_id].hal_srng,
|
||||
RXDMA_MONITOR_DESC);
|
||||
}
|
||||
#else
|
||||
static void dp_mon_htt_srng_setup(struct dp_soc *soc,
|
||||
struct dp_pdev *pdev,
|
||||
int mac_id,
|
||||
int mac_for_pdev)
|
||||
{
|
||||
}
|
||||
#endif
|
||||
/*
|
||||
* dp_rxdma_ring_config() - configure the RX DMA rings
|
||||
*
|
||||
@@ -3152,21 +3211,9 @@ static void dp_rxdma_ring_config(struct dp_soc *soc)
|
||||
RXDMA_DST);
|
||||
|
||||
/* Configure monitor mode rings */
|
||||
htt_srng_setup(soc->htt_handle, mac_for_pdev,
|
||||
pdev->rxdma_mon_buf_ring[mac_id].hal_srng,
|
||||
RXDMA_MONITOR_BUF);
|
||||
dp_mon_htt_srng_setup(soc, pdev, mac_id,
|
||||
mac_for_pdev);
|
||||
|
||||
htt_srng_setup(soc->htt_handle, mac_for_pdev,
|
||||
pdev->rxdma_mon_dst_ring[mac_id].hal_srng,
|
||||
RXDMA_MONITOR_DST);
|
||||
|
||||
htt_srng_setup(soc->htt_handle, mac_for_pdev,
|
||||
pdev->rxdma_mon_status_ring[mac_id].hal_srng,
|
||||
RXDMA_MONITOR_STATUS);
|
||||
|
||||
htt_srng_setup(soc->htt_handle, mac_for_pdev,
|
||||
pdev->rxdma_mon_desc_ring[mac_id].hal_srng,
|
||||
RXDMA_MONITOR_DESC);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@@ -38,11 +38,37 @@
|
||||
void dp_rx_mon_dest_process(struct dp_soc *soc, uint32_t mac_id,
|
||||
uint32_t quota);
|
||||
|
||||
#ifndef QCA_WIFI_QCA6390
|
||||
QDF_STATUS dp_rx_pdev_mon_attach(struct dp_pdev *pdev);
|
||||
QDF_STATUS dp_rx_pdev_mon_detach(struct dp_pdev *pdev);
|
||||
|
||||
QDF_STATUS dp_rx_pdev_mon_status_attach(struct dp_pdev *pdev, int mac_id);
|
||||
QDF_STATUS dp_rx_pdev_mon_status_detach(struct dp_pdev *pdev, int mac_id);
|
||||
#else
|
||||
static inline
|
||||
QDF_STATUS dp_rx_pdev_mon_attach(struct dp_pdev *pdev)
|
||||
{
|
||||
return QDF_STATUS_SUCCESS;
|
||||
}
|
||||
|
||||
static inline
|
||||
QDF_STATUS dp_rx_pdev_mon_detach(struct dp_pdev *pdev)
|
||||
{
|
||||
return QDF_STATUS_SUCCESS;
|
||||
}
|
||||
|
||||
static inline
|
||||
QDF_STATUS dp_rx_pdev_mon_status_attach(struct dp_pdev *pdev, int mac_id)
|
||||
{
|
||||
return QDF_STATUS_SUCCESS;
|
||||
}
|
||||
|
||||
static inline
|
||||
QDF_STATUS dp_rx_pdev_mon_status_detach(struct dp_pdev *pdev, int mac_id)
|
||||
{
|
||||
return QDF_STATUS_SUCCESS;
|
||||
}
|
||||
#endif
|
||||
|
||||
|
||||
uint32_t dp_mon_process(struct dp_soc *soc, uint32_t mac_id, uint32_t quota);
|
||||
QDF_STATUS dp_rx_mon_deliver(struct dp_soc *soc, uint32_t mac_id,
|
||||
|
@@ -829,6 +829,7 @@ void dp_rx_mon_dest_process(struct dp_soc *soc, uint32_t mac_id, uint32_t quota)
|
||||
}
|
||||
}
|
||||
|
||||
#ifndef QCA_WIFI_QCA6390
|
||||
static QDF_STATUS
|
||||
dp_rx_pdev_mon_buf_attach(struct dp_pdev *pdev, int mac_id) {
|
||||
uint8_t pdev_id = pdev->pdev_id;
|
||||
@@ -898,7 +899,8 @@ dp_rx_pdev_mon_buf_detach(struct dp_pdev *pdev, int mac_id)
|
||||
* Allocate and setup link descriptor pool that will be used by HW for
|
||||
* various link and queue descriptors and managed by WBM
|
||||
*/
|
||||
static int dp_mon_link_desc_pool_setup(struct dp_soc *soc, uint32_t mac_id)
|
||||
static
|
||||
QDF_STATUS dp_mon_link_desc_pool_setup(struct dp_soc *soc, uint32_t mac_id)
|
||||
{
|
||||
struct dp_pdev *dp_pdev = dp_get_pdev_for_mac_id(soc, mac_id);
|
||||
int mac_for_pdev = dp_get_mac_id_for_mac(soc, mac_id);
|
||||
@@ -1077,7 +1079,7 @@ static int dp_mon_link_desc_pool_setup(struct dp_soc *soc, uint32_t mac_id)
|
||||
"%s: successfully replenished %d buffer\n",
|
||||
__func__, num_replenish_buf);
|
||||
|
||||
return 0;
|
||||
return QDF_STATUS_SUCCESS;
|
||||
|
||||
fail:
|
||||
for (i = 0; i < MAX_MON_LINK_DESC_BANKS; i++) {
|
||||
@@ -1099,7 +1101,8 @@ fail:
|
||||
/*
|
||||
* Free link descriptor pool that was setup HW
|
||||
*/
|
||||
static void dp_mon_link_desc_pool_cleanup(struct dp_soc *soc, uint32_t mac_id)
|
||||
static
|
||||
void dp_mon_link_desc_pool_cleanup(struct dp_soc *soc, uint32_t mac_id)
|
||||
{
|
||||
struct dp_pdev *dp_pdev = dp_get_pdev_for_mac_id(soc, mac_id);
|
||||
int mac_for_pdev = dp_get_mac_id_for_mac(soc, mac_id);
|
||||
@@ -1131,7 +1134,6 @@ static void dp_mon_link_desc_pool_cleanup(struct dp_soc *soc, uint32_t mac_id)
|
||||
* Return: QDF_STATUS_SUCCESS: success
|
||||
* QDF_STATUS_E_RESOURCES: Error return
|
||||
*/
|
||||
|
||||
QDF_STATUS
|
||||
dp_rx_pdev_mon_attach(struct dp_pdev *pdev) {
|
||||
struct dp_soc *soc = pdev->soc;
|
||||
@@ -1172,6 +1174,7 @@ dp_rx_pdev_mon_attach(struct dp_pdev *pdev) {
|
||||
qdf_spinlock_create(&pdev->mon_lock);
|
||||
return QDF_STATUS_SUCCESS;
|
||||
}
|
||||
|
||||
/**
|
||||
* dp_rx_pdev_mon_detach() - detach dp rx for monitor mode
|
||||
* @pdev: core txrx pdev context
|
||||
@@ -1200,3 +1203,4 @@ dp_rx_pdev_mon_detach(struct dp_pdev *pdev) {
|
||||
|
||||
return QDF_STATUS_SUCCESS;
|
||||
}
|
||||
#endif
|
||||
|
@@ -615,6 +615,7 @@ dp_mon_process(struct dp_soc *soc, uint32_t mac_id, uint32_t quota) {
|
||||
* Return: QDF_STATUS_SUCCESS: success
|
||||
* QDF_STATUS_E_RESOURCES: Error return
|
||||
*/
|
||||
#ifndef QCA_WIFI_QCA6390
|
||||
QDF_STATUS
|
||||
dp_rx_pdev_mon_status_detach(struct dp_pdev *pdev, int mac_id)
|
||||
{
|
||||
@@ -627,6 +628,7 @@ dp_rx_pdev_mon_status_detach(struct dp_pdev *pdev, int mac_id)
|
||||
|
||||
return QDF_STATUS_SUCCESS;
|
||||
}
|
||||
#endif
|
||||
|
||||
/*
|
||||
* dp_rx_buffers_replenish() - replenish monitor status ring with
|
||||
@@ -795,6 +797,7 @@ QDF_STATUS dp_rx_mon_status_buffers_replenish(struct dp_soc *dp_soc,
|
||||
* Return: QDF_STATUS_SUCCESS: success
|
||||
* QDF_STATUS_E_RESOURCES: Error return
|
||||
*/
|
||||
#ifndef QCA_WIFI_QCA6390
|
||||
QDF_STATUS
|
||||
dp_rx_pdev_mon_status_attach(struct dp_pdev *pdev, int ring_id) {
|
||||
struct dp_soc *soc = pdev->soc;
|
||||
@@ -854,3 +857,4 @@ dp_rx_pdev_mon_status_attach(struct dp_pdev *pdev, int ring_id) {
|
||||
|
||||
return QDF_STATUS_SUCCESS;
|
||||
}
|
||||
#endif
|
||||
|
新しいイシューから参照
ユーザーをブロックする