Skip to content

Commit ba8a9ba

Browse files
Ranjan Kumarmartinkpetersen
authored andcommitted
scsi: mpi3mr: Return proper values for failures in firmware init path
Return proper non-zero return values for all the cases when the controller initialization and re-initialization fails. Signed-off-by: Ranjan Kumar <[email protected]> Signed-off-by: Sreekanth Reddy <[email protected]> Link: https://lore.kernel.org/r/[email protected] Signed-off-by: Martin K. Petersen <[email protected]>
1 parent 0a319f1 commit ba8a9ba

File tree

1 file changed

+9
-2
lines changed

1 file changed

+9
-2
lines changed

drivers/scsi/mpi3mr/mpi3mr_fw.c

Lines changed: 9 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -3840,8 +3840,10 @@ int mpi3mr_init_ioc(struct mpi3mr_ioc *mrioc)
38403840
dprint_init(mrioc, "allocating config page buffers\n");
38413841
mrioc->cfg_page = dma_alloc_coherent(&mrioc->pdev->dev,
38423842
MPI3MR_DEFAULT_CFG_PAGE_SZ, &mrioc->cfg_page_dma, GFP_KERNEL);
3843-
if (!mrioc->cfg_page)
3843+
if (!mrioc->cfg_page) {
3844+
retval = -1;
38443845
goto out_failed_noretry;
3846+
}
38453847

38463848
mrioc->cfg_page_sz = MPI3MR_DEFAULT_CFG_PAGE_SZ;
38473849

@@ -3903,8 +3905,10 @@ int mpi3mr_init_ioc(struct mpi3mr_ioc *mrioc)
39033905
dprint_init(mrioc, "allocating memory for throttle groups\n");
39043906
sz = sizeof(struct mpi3mr_throttle_group_info);
39053907
mrioc->throttle_groups = kcalloc(mrioc->num_io_throttle_group, sz, GFP_KERNEL);
3906-
if (!mrioc->throttle_groups)
3908+
if (!mrioc->throttle_groups) {
3909+
retval = -1;
39073910
goto out_failed_noretry;
3911+
}
39083912
}
39093913

39103914
retval = mpi3mr_enable_events(mrioc);
@@ -3924,6 +3928,7 @@ int mpi3mr_init_ioc(struct mpi3mr_ioc *mrioc)
39243928
mpi3mr_memset_buffers(mrioc);
39253929
goto retry_init;
39263930
}
3931+
retval = -1;
39273932
out_failed_noretry:
39283933
ioc_err(mrioc, "controller initialization failed\n");
39293934
mpi3mr_issue_reset(mrioc, MPI3_SYSIF_HOST_DIAG_RESET_ACTION_DIAG_FAULT,
@@ -4036,6 +4041,7 @@ int mpi3mr_reinit_ioc(struct mpi3mr_ioc *mrioc, u8 is_resume)
40364041
ioc_err(mrioc,
40374042
"cannot create minimum number of operational queues expected:%d created:%d\n",
40384043
mrioc->shost->nr_hw_queues, mrioc->num_op_reply_q);
4044+
retval = -1;
40394045
goto out_failed_noretry;
40404046
}
40414047

@@ -4102,6 +4108,7 @@ int mpi3mr_reinit_ioc(struct mpi3mr_ioc *mrioc, u8 is_resume)
41024108
mpi3mr_memset_buffers(mrioc);
41034109
goto retry_init;
41044110
}
4111+
retval = -1;
41054112
out_failed_noretry:
41064113
ioc_err(mrioc, "controller %s is failed\n",
41074114
(is_resume)?"resume":"re-initialization");

0 commit comments

Comments
 (0)