mirror of
https://github.com/torvalds/linux.git
synced 2026-05-31 18:43:33 +02:00
bng_en: make bnge_alloc_ring() self-unwind on failure
Ensure bnge_alloc_ring() frees any intermediate allocations when it fails. This enables later patches to rely on this self-unwinding behavior. Signed-off-by: Bhargava Marreddy <bhargava.marreddy@broadcom.com> Reviewed-by: Vikas Gupta <vikas.gupta@broadcom.com> Reviewed-by: Rajashekar Hudumula <rajashekar.hudumula@broadcom.com> Link: https://patch.msgid.link/20250919174742.24969-2-bhargava.marreddy@broadcom.com Signed-off-by: Jakub Kicinski <kuba@kernel.org>
This commit is contained in:
parent
c5aaf0225a
commit
9ee5994418
|
|
@ -95,7 +95,7 @@ int bnge_alloc_ring(struct bnge_dev *bd, struct bnge_ring_mem_info *rmem)
|
|||
&rmem->dma_arr[i],
|
||||
GFP_KERNEL);
|
||||
if (!rmem->pg_arr[i])
|
||||
return -ENOMEM;
|
||||
goto err_free_ring;
|
||||
|
||||
if (rmem->ctx_mem)
|
||||
bnge_init_ctx_mem(rmem->ctx_mem, rmem->pg_arr[i],
|
||||
|
|
@ -116,10 +116,13 @@ int bnge_alloc_ring(struct bnge_dev *bd, struct bnge_ring_mem_info *rmem)
|
|||
if (rmem->vmem_size) {
|
||||
*rmem->vmem = vzalloc(rmem->vmem_size);
|
||||
if (!(*rmem->vmem))
|
||||
return -ENOMEM;
|
||||
goto err_free_ring;
|
||||
}
|
||||
|
||||
return 0;
|
||||
|
||||
err_free_ring:
|
||||
bnge_free_ring(bd, rmem);
|
||||
return -ENOMEM;
|
||||
}
|
||||
|
||||
static int bnge_alloc_ctx_one_lvl(struct bnge_dev *bd,
|
||||
|
|
|
|||
Loading…
Reference in New Issue
Block a user