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 <ranjan.kumar@broadcom.com> Signed-off-by: Sreekanth Reddy <sreekanth.reddy@broadcom.com> Link: https://lore.kernel.org/r/20230228140835.4075-5-ranjan.kumar@broadcom.com Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com>
This commit is contained in:
parent
0a319f1629
commit
ba8a9ba41f
@ -3840,8 +3840,10 @@ retry_init:
|
|||||||
dprint_init(mrioc, "allocating config page buffers\n");
|
dprint_init(mrioc, "allocating config page buffers\n");
|
||||||
mrioc->cfg_page = dma_alloc_coherent(&mrioc->pdev->dev,
|
mrioc->cfg_page = dma_alloc_coherent(&mrioc->pdev->dev,
|
||||||
MPI3MR_DEFAULT_CFG_PAGE_SZ, &mrioc->cfg_page_dma, GFP_KERNEL);
|
MPI3MR_DEFAULT_CFG_PAGE_SZ, &mrioc->cfg_page_dma, GFP_KERNEL);
|
||||||
if (!mrioc->cfg_page)
|
if (!mrioc->cfg_page) {
|
||||||
|
retval = -1;
|
||||||
goto out_failed_noretry;
|
goto out_failed_noretry;
|
||||||
|
}
|
||||||
|
|
||||||
mrioc->cfg_page_sz = MPI3MR_DEFAULT_CFG_PAGE_SZ;
|
mrioc->cfg_page_sz = MPI3MR_DEFAULT_CFG_PAGE_SZ;
|
||||||
|
|
||||||
@ -3903,8 +3905,10 @@ retry_init:
|
|||||||
dprint_init(mrioc, "allocating memory for throttle groups\n");
|
dprint_init(mrioc, "allocating memory for throttle groups\n");
|
||||||
sz = sizeof(struct mpi3mr_throttle_group_info);
|
sz = sizeof(struct mpi3mr_throttle_group_info);
|
||||||
mrioc->throttle_groups = kcalloc(mrioc->num_io_throttle_group, sz, GFP_KERNEL);
|
mrioc->throttle_groups = kcalloc(mrioc->num_io_throttle_group, sz, GFP_KERNEL);
|
||||||
if (!mrioc->throttle_groups)
|
if (!mrioc->throttle_groups) {
|
||||||
|
retval = -1;
|
||||||
goto out_failed_noretry;
|
goto out_failed_noretry;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
retval = mpi3mr_enable_events(mrioc);
|
retval = mpi3mr_enable_events(mrioc);
|
||||||
@ -3924,6 +3928,7 @@ out_failed:
|
|||||||
mpi3mr_memset_buffers(mrioc);
|
mpi3mr_memset_buffers(mrioc);
|
||||||
goto retry_init;
|
goto retry_init;
|
||||||
}
|
}
|
||||||
|
retval = -1;
|
||||||
out_failed_noretry:
|
out_failed_noretry:
|
||||||
ioc_err(mrioc, "controller initialization failed\n");
|
ioc_err(mrioc, "controller initialization failed\n");
|
||||||
mpi3mr_issue_reset(mrioc, MPI3_SYSIF_HOST_DIAG_RESET_ACTION_DIAG_FAULT,
|
mpi3mr_issue_reset(mrioc, MPI3_SYSIF_HOST_DIAG_RESET_ACTION_DIAG_FAULT,
|
||||||
@ -4036,6 +4041,7 @@ retry_init:
|
|||||||
ioc_err(mrioc,
|
ioc_err(mrioc,
|
||||||
"cannot create minimum number of operational queues expected:%d created:%d\n",
|
"cannot create minimum number of operational queues expected:%d created:%d\n",
|
||||||
mrioc->shost->nr_hw_queues, mrioc->num_op_reply_q);
|
mrioc->shost->nr_hw_queues, mrioc->num_op_reply_q);
|
||||||
|
retval = -1;
|
||||||
goto out_failed_noretry;
|
goto out_failed_noretry;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -4102,6 +4108,7 @@ out_failed:
|
|||||||
mpi3mr_memset_buffers(mrioc);
|
mpi3mr_memset_buffers(mrioc);
|
||||||
goto retry_init;
|
goto retry_init;
|
||||||
}
|
}
|
||||||
|
retval = -1;
|
||||||
out_failed_noretry:
|
out_failed_noretry:
|
||||||
ioc_err(mrioc, "controller %s is failed\n",
|
ioc_err(mrioc, "controller %s is failed\n",
|
||||||
(is_resume)?"resume":"re-initialization");
|
(is_resume)?"resume":"re-initialization");
|
||||||
|
Loading…
Reference in New Issue
Block a user