qcacmn: Add support to use pre-alloc mem
Add logic to pre-allocate DP consistent memory and reuse later on wifi on/off. This prevents memory fragmentation. Change-Id: I1e5eb0da39950a5d028dd46d38ff715f283e53ff CRs-Fixed: 2740889
This commit is contained in:
@@ -1096,8 +1096,20 @@ struct ol_if_ops {
|
|||||||
bool (*is_roam_inprogress)(uint32_t vdev_id);
|
bool (*is_roam_inprogress)(uint32_t vdev_id);
|
||||||
enum QDF_GLOBAL_MODE (*get_con_mode)(void);
|
enum QDF_GLOBAL_MODE (*get_con_mode)(void);
|
||||||
#ifdef QCA_PEER_MULTIQ_SUPPORT
|
#ifdef QCA_PEER_MULTIQ_SUPPORT
|
||||||
int (*peer_ast_flowid_map)(struct cdp_ctrl_objmgr_psoc *ol_soc_handle,
|
int (*peer_ast_flowid_map)(struct cdp_ctrl_objmgr_psoc *ol_soc_handle,
|
||||||
uint16_t peer_id, uint8_t vdev_id, uint8_t *peer_mac_addr);
|
uint16_t peer_id, uint8_t vdev_id,
|
||||||
|
uint8_t *peer_mac_addr);
|
||||||
|
#endif
|
||||||
|
#ifdef DP_MEM_PRE_ALLOC
|
||||||
|
void *(*dp_prealloc_get_consistent)(uint32_t *size,
|
||||||
|
void **base_vaddr_unaligned,
|
||||||
|
qdf_dma_addr_t *paddr_unaligned,
|
||||||
|
qdf_dma_addr_t *paddr_aligned,
|
||||||
|
uint32_t align,
|
||||||
|
uint32_t ring_type);
|
||||||
|
void (*dp_prealloc_put_consistent)(qdf_size_t size,
|
||||||
|
void *vaddr_unligned,
|
||||||
|
qdf_dma_addr_t paddr);
|
||||||
#endif
|
#endif
|
||||||
int (*get_soc_nss_cfg)(struct cdp_ctrl_objmgr_psoc *ol_soc_handle);
|
int (*get_soc_nss_cfg)(struct cdp_ctrl_objmgr_psoc *ol_soc_handle);
|
||||||
|
|
||||||
|
@@ -22,8 +22,12 @@
|
|||||||
#include "dp_types.h"
|
#include "dp_types.h"
|
||||||
|
|
||||||
#define RX_BUFFER_SIZE_PKTLOG_LITE 1024
|
#define RX_BUFFER_SIZE_PKTLOG_LITE 1024
|
||||||
|
|
||||||
#define DP_PEER_WDS_COUNT_INVALID UINT_MAX
|
#define DP_PEER_WDS_COUNT_INVALID UINT_MAX
|
||||||
|
|
||||||
|
/* Alignment for consistent memory for DP rings*/
|
||||||
|
#define DP_RING_BASE_ALIGN 32
|
||||||
|
|
||||||
#define DP_RSSI_INVAL 0x80
|
#define DP_RSSI_INVAL 0x80
|
||||||
#define DP_RSSI_AVG_WEIGHT 2
|
#define DP_RSSI_AVG_WEIGHT 2
|
||||||
/*
|
/*
|
||||||
|
@@ -1430,6 +1430,94 @@ dp_srng_configure_interrupt_thresholds(struct dp_soc *soc,
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifdef DP_MEM_PRE_ALLOC
|
||||||
|
static inline
|
||||||
|
void *dp_srng_aligned_mem_alloc_consistent(struct dp_soc *soc,
|
||||||
|
struct dp_srng *srng,
|
||||||
|
uint32_t ring_type)
|
||||||
|
{
|
||||||
|
void *mem;
|
||||||
|
|
||||||
|
qdf_assert(!srng->is_mem_prealloc);
|
||||||
|
|
||||||
|
if (!soc->cdp_soc.ol_ops->dp_prealloc_get_consistent) {
|
||||||
|
dp_warn("dp_prealloc_get_consistent is null!");
|
||||||
|
goto qdf;
|
||||||
|
}
|
||||||
|
|
||||||
|
mem =
|
||||||
|
soc->cdp_soc.ol_ops->dp_prealloc_get_consistent
|
||||||
|
(&srng->alloc_size,
|
||||||
|
&srng->base_vaddr_unaligned,
|
||||||
|
&srng->base_paddr_unaligned,
|
||||||
|
&srng->base_paddr_aligned,
|
||||||
|
DP_RING_BASE_ALIGN, ring_type);
|
||||||
|
|
||||||
|
if (mem) {
|
||||||
|
srng->is_mem_prealloc = true;
|
||||||
|
goto end;
|
||||||
|
}
|
||||||
|
qdf:
|
||||||
|
mem = qdf_aligned_mem_alloc_consistent(soc->osdev, &srng->alloc_size,
|
||||||
|
&srng->base_vaddr_unaligned,
|
||||||
|
&srng->base_paddr_unaligned,
|
||||||
|
&srng->base_paddr_aligned,
|
||||||
|
DP_RING_BASE_ALIGN);
|
||||||
|
end:
|
||||||
|
dp_info("%s memory %pK dp_srng %pK ring_type %d alloc_size %d num_entries %d",
|
||||||
|
srng->is_mem_prealloc ? "pre-alloc" : "dynamic-alloc", mem,
|
||||||
|
srng, ring_type, srng->alloc_size, srng->num_entries);
|
||||||
|
return mem;
|
||||||
|
}
|
||||||
|
|
||||||
|
static inline void dp_srng_mem_free_consistent(struct dp_soc *soc,
|
||||||
|
struct dp_srng *srng)
|
||||||
|
{
|
||||||
|
if (srng->is_mem_prealloc) {
|
||||||
|
if (!soc->cdp_soc.ol_ops->dp_prealloc_put_consistent) {
|
||||||
|
dp_warn("dp_prealloc_put_consistent is null!");
|
||||||
|
QDF_BUG(0);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
soc->cdp_soc.ol_ops->dp_prealloc_put_consistent
|
||||||
|
(srng->alloc_size,
|
||||||
|
srng->base_vaddr_unaligned,
|
||||||
|
srng->base_paddr_unaligned);
|
||||||
|
|
||||||
|
} else {
|
||||||
|
qdf_mem_free_consistent(soc->osdev, soc->osdev->dev,
|
||||||
|
srng->alloc_size,
|
||||||
|
srng->base_vaddr_unaligned,
|
||||||
|
srng->base_paddr_unaligned, 0);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#else
|
||||||
|
|
||||||
|
static inline
|
||||||
|
void *dp_srng_aligned_mem_alloc_consistent(struct dp_soc *soc,
|
||||||
|
struct dp_srng *srng,
|
||||||
|
uint32_t ring_type)
|
||||||
|
|
||||||
|
{
|
||||||
|
return qdf_aligned_mem_alloc_consistent(soc->osdev, &srng->alloc_size,
|
||||||
|
&srng->base_vaddr_unaligned,
|
||||||
|
&srng->base_paddr_unaligned,
|
||||||
|
&srng->base_paddr_aligned,
|
||||||
|
DP_RING_BASE_ALIGN);
|
||||||
|
}
|
||||||
|
|
||||||
|
static inline void dp_srng_mem_free_consistent(struct dp_soc *soc,
|
||||||
|
struct dp_srng *srng)
|
||||||
|
{
|
||||||
|
qdf_mem_free_consistent(soc->osdev, soc->osdev->dev,
|
||||||
|
srng->alloc_size,
|
||||||
|
srng->base_vaddr_unaligned,
|
||||||
|
srng->base_paddr_unaligned, 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif /* DP_MEM_PRE_ALLOC */
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* dp_srng_free() - Free SRNG memory
|
* dp_srng_free() - Free SRNG memory
|
||||||
* @soc : Data path soc handle
|
* @soc : Data path soc handle
|
||||||
@@ -1437,15 +1525,11 @@ dp_srng_configure_interrupt_thresholds(struct dp_soc *soc,
|
|||||||
*
|
*
|
||||||
* return: None
|
* return: None
|
||||||
*/
|
*/
|
||||||
|
|
||||||
static void dp_srng_free(struct dp_soc *soc, struct dp_srng *srng)
|
static void dp_srng_free(struct dp_soc *soc, struct dp_srng *srng)
|
||||||
{
|
{
|
||||||
if (srng->alloc_size && srng->base_vaddr_unaligned) {
|
if (srng->alloc_size && srng->base_vaddr_unaligned) {
|
||||||
if (!srng->cached) {
|
if (!srng->cached) {
|
||||||
qdf_mem_free_consistent(soc->osdev, soc->osdev->dev,
|
dp_srng_mem_free_consistent(soc, srng);
|
||||||
srng->alloc_size,
|
|
||||||
srng->base_vaddr_unaligned,
|
|
||||||
srng->base_paddr_unaligned, 0);
|
|
||||||
} else {
|
} else {
|
||||||
qdf_mem_free(srng->base_vaddr_unaligned);
|
qdf_mem_free(srng->base_vaddr_unaligned);
|
||||||
}
|
}
|
||||||
@@ -1487,11 +1571,11 @@ static QDF_STATUS dp_srng_init(struct dp_soc *soc, struct dp_srng *srng,
|
|||||||
|
|
||||||
ring_params.num_entries = srng->num_entries;
|
ring_params.num_entries = srng->num_entries;
|
||||||
|
|
||||||
dp_verbose_debug("Ring type: %d, num:%d vaddr %pK paddr %pK entries %u",
|
dp_info("Ring type: %d, num:%d vaddr %pK paddr %pK entries %u",
|
||||||
ring_type, ring_num,
|
ring_type, ring_num,
|
||||||
(void *)ring_params.ring_base_vaddr,
|
(void *)ring_params.ring_base_vaddr,
|
||||||
(void *)ring_params.ring_base_paddr,
|
(void *)ring_params.ring_base_paddr,
|
||||||
ring_params.num_entries);
|
ring_params.num_entries);
|
||||||
|
|
||||||
if (soc->intr_mode == DP_INTR_MSI) {
|
if (soc->intr_mode == DP_INTR_MSI) {
|
||||||
dp_srng_msi_setup(soc, &ring_params, ring_type, ring_num);
|
dp_srng_msi_setup(soc, &ring_params, ring_type, ring_num);
|
||||||
@@ -1539,7 +1623,6 @@ static QDF_STATUS dp_srng_alloc(struct dp_soc *soc, struct dp_srng *srng,
|
|||||||
{
|
{
|
||||||
hal_soc_handle_t hal_soc = soc->hal_soc;
|
hal_soc_handle_t hal_soc = soc->hal_soc;
|
||||||
uint32_t entry_size = hal_srng_get_entrysize(hal_soc, ring_type);
|
uint32_t entry_size = hal_srng_get_entrysize(hal_soc, ring_type);
|
||||||
uint32_t ring_base_align = 32;
|
|
||||||
uint32_t max_entries = hal_srng_max_entries(hal_soc, ring_type);
|
uint32_t max_entries = hal_srng_max_entries(hal_soc, ring_type);
|
||||||
|
|
||||||
if (srng->base_vaddr_unaligned) {
|
if (srng->base_vaddr_unaligned) {
|
||||||
@@ -1556,19 +1639,16 @@ static QDF_STATUS dp_srng_alloc(struct dp_soc *soc, struct dp_srng *srng,
|
|||||||
|
|
||||||
if (!cached) {
|
if (!cached) {
|
||||||
srng->base_vaddr_aligned =
|
srng->base_vaddr_aligned =
|
||||||
qdf_aligned_mem_alloc_consistent(
|
dp_srng_aligned_mem_alloc_consistent(soc,
|
||||||
soc->osdev, &srng->alloc_size,
|
srng,
|
||||||
&srng->base_vaddr_unaligned,
|
ring_type);
|
||||||
&srng->base_paddr_unaligned,
|
|
||||||
&srng->base_paddr_aligned,
|
|
||||||
ring_base_align);
|
|
||||||
} else {
|
} else {
|
||||||
srng->base_vaddr_aligned = qdf_aligned_malloc(
|
srng->base_vaddr_aligned = qdf_aligned_malloc(
|
||||||
&srng->alloc_size,
|
&srng->alloc_size,
|
||||||
&srng->base_vaddr_unaligned,
|
&srng->base_vaddr_unaligned,
|
||||||
&srng->base_paddr_unaligned,
|
&srng->base_paddr_unaligned,
|
||||||
&srng->base_paddr_aligned,
|
&srng->base_paddr_aligned,
|
||||||
ring_base_align);
|
DP_RING_BASE_ALIGN);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!srng->base_vaddr_aligned)
|
if (!srng->base_vaddr_aligned)
|
||||||
|
@@ -601,6 +601,9 @@ struct dp_srng {
|
|||||||
uint8_t cached;
|
uint8_t cached;
|
||||||
int irq;
|
int irq;
|
||||||
uint32_t num_entries;
|
uint32_t num_entries;
|
||||||
|
#ifdef DP_MEM_PRE_ALLOC
|
||||||
|
uint8_t is_mem_prealloc;
|
||||||
|
#endif
|
||||||
};
|
};
|
||||||
|
|
||||||
struct dp_rx_reorder_array_elem {
|
struct dp_rx_reorder_array_elem {
|
||||||
|
Reference in New Issue
Block a user