mirror of
https://github.com/torvalds/linux.git
synced 2024-12-27 13:22:23 +00:00
octeontx2-af: Initialize maps.
kmalloc_array() without __GFP_ZERO flag does not initialize
memory to zero. This causes issues. Use kcalloc() for maps and
bitmap_zalloc() for bitmaps.
Fixes: dd78428786
("octeontx2-af: Add new devlink param to configure maximum usable NIX block LFs")
Signed-off-by: Ratheesh Kannoth <rkannoth@marvell.com>
Reviewed-by: Brett Creeley <bcreeley@amd.com>
Reviewed-by: Simon Horman <horms@kernel.org>
Link: https://lore.kernel.org/r/20240206024000.1070260-1-rkannoth@marvell.com
Signed-off-by: Paolo Abeni <pabeni@redhat.com>
This commit is contained in:
parent
03fa49a386
commit
db010ff670
@ -1850,8 +1850,8 @@ void npc_mcam_rsrcs_deinit(struct rvu *rvu)
|
||||
{
|
||||
struct npc_mcam *mcam = &rvu->hw->mcam;
|
||||
|
||||
kfree(mcam->bmap);
|
||||
kfree(mcam->bmap_reverse);
|
||||
bitmap_free(mcam->bmap);
|
||||
bitmap_free(mcam->bmap_reverse);
|
||||
kfree(mcam->entry2pfvf_map);
|
||||
kfree(mcam->cntr2pfvf_map);
|
||||
kfree(mcam->entry2cntr_map);
|
||||
@ -1904,21 +1904,20 @@ int npc_mcam_rsrcs_init(struct rvu *rvu, int blkaddr)
|
||||
mcam->pf_offset = mcam->nixlf_offset + nixlf_count;
|
||||
|
||||
/* Allocate bitmaps for managing MCAM entries */
|
||||
mcam->bmap = kmalloc_array(BITS_TO_LONGS(mcam->bmap_entries),
|
||||
sizeof(long), GFP_KERNEL);
|
||||
mcam->bmap = bitmap_zalloc(mcam->bmap_entries, GFP_KERNEL);
|
||||
if (!mcam->bmap)
|
||||
return -ENOMEM;
|
||||
|
||||
mcam->bmap_reverse = kmalloc_array(BITS_TO_LONGS(mcam->bmap_entries),
|
||||
sizeof(long), GFP_KERNEL);
|
||||
mcam->bmap_reverse = bitmap_zalloc(mcam->bmap_entries, GFP_KERNEL);
|
||||
if (!mcam->bmap_reverse)
|
||||
goto free_bmap;
|
||||
|
||||
mcam->bmap_fcnt = mcam->bmap_entries;
|
||||
|
||||
/* Alloc memory for saving entry to RVU PFFUNC allocation mapping */
|
||||
mcam->entry2pfvf_map = kmalloc_array(mcam->bmap_entries,
|
||||
sizeof(u16), GFP_KERNEL);
|
||||
mcam->entry2pfvf_map = kcalloc(mcam->bmap_entries, sizeof(u16),
|
||||
GFP_KERNEL);
|
||||
|
||||
if (!mcam->entry2pfvf_map)
|
||||
goto free_bmap_reverse;
|
||||
|
||||
@ -1941,21 +1940,21 @@ int npc_mcam_rsrcs_init(struct rvu *rvu, int blkaddr)
|
||||
if (err)
|
||||
goto free_entry_map;
|
||||
|
||||
mcam->cntr2pfvf_map = kmalloc_array(mcam->counters.max,
|
||||
sizeof(u16), GFP_KERNEL);
|
||||
mcam->cntr2pfvf_map = kcalloc(mcam->counters.max, sizeof(u16),
|
||||
GFP_KERNEL);
|
||||
if (!mcam->cntr2pfvf_map)
|
||||
goto free_cntr_bmap;
|
||||
|
||||
/* Alloc memory for MCAM entry to counter mapping and for tracking
|
||||
* counter's reference count.
|
||||
*/
|
||||
mcam->entry2cntr_map = kmalloc_array(mcam->bmap_entries,
|
||||
sizeof(u16), GFP_KERNEL);
|
||||
mcam->entry2cntr_map = kcalloc(mcam->bmap_entries, sizeof(u16),
|
||||
GFP_KERNEL);
|
||||
if (!mcam->entry2cntr_map)
|
||||
goto free_cntr_map;
|
||||
|
||||
mcam->cntr_refcnt = kmalloc_array(mcam->counters.max,
|
||||
sizeof(u16), GFP_KERNEL);
|
||||
mcam->cntr_refcnt = kcalloc(mcam->counters.max, sizeof(u16),
|
||||
GFP_KERNEL);
|
||||
if (!mcam->cntr_refcnt)
|
||||
goto free_entry_cntr_map;
|
||||
|
||||
@ -1988,9 +1987,9 @@ free_cntr_bmap:
|
||||
free_entry_map:
|
||||
kfree(mcam->entry2pfvf_map);
|
||||
free_bmap_reverse:
|
||||
kfree(mcam->bmap_reverse);
|
||||
bitmap_free(mcam->bmap_reverse);
|
||||
free_bmap:
|
||||
kfree(mcam->bmap);
|
||||
bitmap_free(mcam->bmap);
|
||||
|
||||
return -ENOMEM;
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user