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
This commit is contained in:

committed by
nshrivas

parent
59ec405e49
commit
30e442b026
@@ -2559,7 +2559,6 @@ static void dp_cleanup_ipa_rx_refill_buf_ring(struct dp_soc *soc,
|
|||||||
}
|
}
|
||||||
|
|
||||||
#else
|
#else
|
||||||
|
|
||||||
static int dp_setup_ipa_rx_refill_buf_ring(struct dp_soc *soc,
|
static int dp_setup_ipa_rx_refill_buf_ring(struct dp_soc *soc,
|
||||||
struct dp_pdev *pdev)
|
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)
|
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
|
#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_soc *soc = (struct dp_soc *)txrx_soc;
|
||||||
struct dp_pdev *pdev = qdf_mem_malloc(sizeof(*pdev));
|
struct dp_pdev *pdev = qdf_mem_malloc(sizeof(*pdev));
|
||||||
int mac_id;
|
|
||||||
|
|
||||||
if (!pdev) {
|
if (!pdev) {
|
||||||
QDF_TRACE(QDF_MODULE_ID_DP, QDF_TRACE_LEVEL_ERROR,
|
QDF_TRACE(QDF_MODULE_ID_DP, QDF_TRACE_LEVEL_ERROR,
|
||||||
@@ -2689,41 +2737,10 @@ static struct cdp_pdev *dp_pdev_attach_wifi3(struct cdp_soc_t *txrx_soc,
|
|||||||
goto fail1;
|
goto fail1;
|
||||||
}
|
}
|
||||||
|
|
||||||
for (mac_id = 0; mac_id < NUM_RXDMA_RINGS_PER_PDEV; mac_id++) {
|
if (dp_mon_rings_setup(soc, pdev)) {
|
||||||
int mac_for_pdev = dp_get_mac_id_for_pdev(mac_id, pdev_id);
|
QDF_TRACE(QDF_MODULE_ID_DP, QDF_TRACE_LEVEL_ERROR,
|
||||||
|
FL("MONITOR rings setup failed"));
|
||||||
if (dp_srng_setup(soc, &pdev->rxdma_mon_buf_ring[mac_id],
|
goto fail1;
|
||||||
RXDMA_MONITOR_BUF, 0, mac_for_pdev,
|
|
||||||
RXDMA_MONITOR_BUF_RING_SIZE)) {
|
|
||||||
QDF_TRACE(QDF_MODULE_ID_DP, QDF_TRACE_LEVEL_ERROR,
|
|
||||||
FL("dp_srng_setup failed for rxdma_mon_buf_ring"));
|
|
||||||
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 (wlan_cfg_per_pdev_lmac_ring(soc->wlan_cfg_ctx)) {
|
||||||
@@ -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
|
* dp_pdev_detach_wifi3() - detach txrx pdev
|
||||||
* @txrx_pdev: Datapath PDEV handle
|
* @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_pktlogmod_exit(pdev);
|
||||||
|
|
||||||
dp_rx_pdev_detach(pdev);
|
dp_rx_pdev_detach(pdev);
|
||||||
|
|
||||||
dp_rx_pdev_mon_detach(pdev);
|
dp_rx_pdev_mon_detach(pdev);
|
||||||
|
|
||||||
dp_neighbour_peers_detach(pdev);
|
dp_neighbour_peers_detach(pdev);
|
||||||
qdf_spinlock_destroy(&pdev->tx_mutex);
|
qdf_spinlock_destroy(&pdev->tx_mutex);
|
||||||
qdf_spinlock_destroy(&pdev->vdev_list_lock);
|
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);
|
dp_rxdma_ring_cleanup(soc, pdev);
|
||||||
|
|
||||||
for (mac_id = 0; mac_id < NUM_RXDMA_RINGS_PER_PDEV; mac_id++) {
|
for (mac_id = 0; mac_id < NUM_RXDMA_RINGS_PER_PDEV; mac_id++) {
|
||||||
dp_srng_cleanup(soc, &pdev->rxdma_mon_buf_ring[mac_id],
|
dp_mon_ring_deinit(soc, pdev, 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],
|
dp_srng_cleanup(soc, &pdev->rxdma_err_dst_ring[mac_id],
|
||||||
RXDMA_DST, 0);
|
RXDMA_DST, 0);
|
||||||
}
|
}
|
||||||
@@ -3076,6 +3105,36 @@ static void dp_soc_detach_wifi3(void *txrx_soc)
|
|||||||
qdf_mem_free(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
|
* 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);
|
RXDMA_DST);
|
||||||
|
|
||||||
/* Configure monitor mode rings */
|
/* Configure monitor mode rings */
|
||||||
htt_srng_setup(soc->htt_handle, mac_for_pdev,
|
dp_mon_htt_srng_setup(soc, pdev, mac_id,
|
||||||
pdev->rxdma_mon_buf_ring[mac_id].hal_srng,
|
mac_for_pdev);
|
||||||
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);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@@ -38,11 +38,37 @@
|
|||||||
void dp_rx_mon_dest_process(struct dp_soc *soc, uint32_t mac_id,
|
void dp_rx_mon_dest_process(struct dp_soc *soc, uint32_t mac_id,
|
||||||
uint32_t quota);
|
uint32_t quota);
|
||||||
|
|
||||||
|
#ifndef QCA_WIFI_QCA6390
|
||||||
QDF_STATUS dp_rx_pdev_mon_attach(struct dp_pdev *pdev);
|
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_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_attach(struct dp_pdev *pdev, int mac_id);
|
||||||
QDF_STATUS dp_rx_pdev_mon_status_detach(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);
|
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,
|
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
|
static QDF_STATUS
|
||||||
dp_rx_pdev_mon_buf_attach(struct dp_pdev *pdev, int mac_id) {
|
dp_rx_pdev_mon_buf_attach(struct dp_pdev *pdev, int mac_id) {
|
||||||
uint8_t pdev_id = pdev->pdev_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
|
* Allocate and setup link descriptor pool that will be used by HW for
|
||||||
* various link and queue descriptors and managed by WBM
|
* 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);
|
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);
|
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",
|
"%s: successfully replenished %d buffer\n",
|
||||||
__func__, num_replenish_buf);
|
__func__, num_replenish_buf);
|
||||||
|
|
||||||
return 0;
|
return QDF_STATUS_SUCCESS;
|
||||||
|
|
||||||
fail:
|
fail:
|
||||||
for (i = 0; i < MAX_MON_LINK_DESC_BANKS; i++) {
|
for (i = 0; i < MAX_MON_LINK_DESC_BANKS; i++) {
|
||||||
@@ -1099,7 +1101,8 @@ fail:
|
|||||||
/*
|
/*
|
||||||
* Free link descriptor pool that was setup HW
|
* 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);
|
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);
|
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
|
* Return: QDF_STATUS_SUCCESS: success
|
||||||
* QDF_STATUS_E_RESOURCES: Error return
|
* QDF_STATUS_E_RESOURCES: Error return
|
||||||
*/
|
*/
|
||||||
|
|
||||||
QDF_STATUS
|
QDF_STATUS
|
||||||
dp_rx_pdev_mon_attach(struct dp_pdev *pdev) {
|
dp_rx_pdev_mon_attach(struct dp_pdev *pdev) {
|
||||||
struct dp_soc *soc = pdev->soc;
|
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);
|
qdf_spinlock_create(&pdev->mon_lock);
|
||||||
return QDF_STATUS_SUCCESS;
|
return QDF_STATUS_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* dp_rx_pdev_mon_detach() - detach dp rx for monitor mode
|
* dp_rx_pdev_mon_detach() - detach dp rx for monitor mode
|
||||||
* @pdev: core txrx pdev context
|
* @pdev: core txrx pdev context
|
||||||
@@ -1200,3 +1203,4 @@ dp_rx_pdev_mon_detach(struct dp_pdev *pdev) {
|
|||||||
|
|
||||||
return QDF_STATUS_SUCCESS;
|
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
|
* Return: QDF_STATUS_SUCCESS: success
|
||||||
* QDF_STATUS_E_RESOURCES: Error return
|
* QDF_STATUS_E_RESOURCES: Error return
|
||||||
*/
|
*/
|
||||||
|
#ifndef QCA_WIFI_QCA6390
|
||||||
QDF_STATUS
|
QDF_STATUS
|
||||||
dp_rx_pdev_mon_status_detach(struct dp_pdev *pdev, int mac_id)
|
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;
|
return QDF_STATUS_SUCCESS;
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* dp_rx_buffers_replenish() - replenish monitor status ring with
|
* 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
|
* Return: QDF_STATUS_SUCCESS: success
|
||||||
* QDF_STATUS_E_RESOURCES: Error return
|
* QDF_STATUS_E_RESOURCES: Error return
|
||||||
*/
|
*/
|
||||||
|
#ifndef QCA_WIFI_QCA6390
|
||||||
QDF_STATUS
|
QDF_STATUS
|
||||||
dp_rx_pdev_mon_status_attach(struct dp_pdev *pdev, int ring_id) {
|
dp_rx_pdev_mon_status_attach(struct dp_pdev *pdev, int ring_id) {
|
||||||
struct dp_soc *soc = pdev->soc;
|
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;
|
return QDF_STATUS_SUCCESS;
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
Reference in New Issue
Block a user