scsi: mpt3sas: Separate out mpt3sas_wait_for_ioc
No functional changes. This section of code "wait for IOC to be operational" is used in many places across the driver. Factor this code out into a new mpt3sas_wait_for_ioc(). Signed-off-by: Suganath Prabu <suganath-prabu.subramani@broadcom.com> Reviewed-by: Bjorn Helgaas <bhelgaas@google.com> Reviewed-by: Andy Shevchenko <andy.shevchenko@gmail.com> Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com>
This commit is contained in:

committed by
Martin K. Petersen

parent
02abcbc25a
commit
f4305749ca
@@ -5077,6 +5077,41 @@ _base_send_ioc_reset(struct MPT3SAS_ADAPTER *ioc, u8 reset_type, int timeout)
|
||||
return r;
|
||||
}
|
||||
|
||||
/**
|
||||
* mpt3sas_wait_for_ioc - IOC's operational state is checked here.
|
||||
* @ioc: per adapter object
|
||||
* @wait_count: timeout in seconds
|
||||
*
|
||||
* Return: Waits up to timeout seconds for the IOC to
|
||||
* become operational. Returns 0 if IOC is present
|
||||
* and operational; otherwise returns -EFAULT.
|
||||
*/
|
||||
|
||||
int
|
||||
mpt3sas_wait_for_ioc(struct MPT3SAS_ADAPTER *ioc, int timeout)
|
||||
{
|
||||
int wait_state_count = 0;
|
||||
u32 ioc_state;
|
||||
|
||||
ioc_state = mpt3sas_base_get_iocstate(ioc, 1);
|
||||
while (ioc_state != MPI2_IOC_STATE_OPERATIONAL) {
|
||||
|
||||
if (wait_state_count++ == timeout) {
|
||||
ioc_err(ioc, "%s: failed due to ioc not operational\n",
|
||||
__func__);
|
||||
return -EFAULT;
|
||||
}
|
||||
ssleep(1);
|
||||
ioc_state = mpt3sas_base_get_iocstate(ioc, 1);
|
||||
ioc_info(ioc, "%s: waiting for operational state(count=%d)\n",
|
||||
__func__, wait_state_count);
|
||||
}
|
||||
if (wait_state_count)
|
||||
ioc_info(ioc, "ioc is operational\n");
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
/**
|
||||
* _base_handshake_req_reply_wait - send request thru doorbell interface
|
||||
* @ioc: per adapter object
|
||||
@@ -5211,11 +5246,9 @@ mpt3sas_base_sas_iounit_control(struct MPT3SAS_ADAPTER *ioc,
|
||||
Mpi2SasIoUnitControlRequest_t *mpi_request)
|
||||
{
|
||||
u16 smid;
|
||||
u32 ioc_state;
|
||||
u8 issue_reset = 0;
|
||||
int rc;
|
||||
void *request;
|
||||
u16 wait_state_count;
|
||||
|
||||
dinitprintk(ioc, ioc_info(ioc, "%s\n", __func__));
|
||||
|
||||
@@ -5227,20 +5260,9 @@ mpt3sas_base_sas_iounit_control(struct MPT3SAS_ADAPTER *ioc,
|
||||
goto out;
|
||||
}
|
||||
|
||||
wait_state_count = 0;
|
||||
ioc_state = mpt3sas_base_get_iocstate(ioc, 1);
|
||||
while (ioc_state != MPI2_IOC_STATE_OPERATIONAL) {
|
||||
if (wait_state_count++ == IOC_OPERATIONAL_WAIT_COUNT) {
|
||||
ioc_err(ioc, "%s: failed due to ioc not operational\n",
|
||||
__func__);
|
||||
rc = -EFAULT;
|
||||
goto out;
|
||||
}
|
||||
ssleep(1);
|
||||
ioc_state = mpt3sas_base_get_iocstate(ioc, 1);
|
||||
ioc_info(ioc, "%s: waiting for operational state(count=%d)\n",
|
||||
__func__, wait_state_count);
|
||||
}
|
||||
rc = mpt3sas_wait_for_ioc(ioc, IOC_OPERATIONAL_WAIT_COUNT);
|
||||
if (rc)
|
||||
goto out;
|
||||
|
||||
smid = mpt3sas_base_get_smid(ioc, ioc->base_cb_idx);
|
||||
if (!smid) {
|
||||
@@ -5306,11 +5328,9 @@ mpt3sas_base_scsi_enclosure_processor(struct MPT3SAS_ADAPTER *ioc,
|
||||
Mpi2SepReply_t *mpi_reply, Mpi2SepRequest_t *mpi_request)
|
||||
{
|
||||
u16 smid;
|
||||
u32 ioc_state;
|
||||
u8 issue_reset = 0;
|
||||
int rc;
|
||||
void *request;
|
||||
u16 wait_state_count;
|
||||
|
||||
dinitprintk(ioc, ioc_info(ioc, "%s\n", __func__));
|
||||
|
||||
@@ -5322,20 +5342,9 @@ mpt3sas_base_scsi_enclosure_processor(struct MPT3SAS_ADAPTER *ioc,
|
||||
goto out;
|
||||
}
|
||||
|
||||
wait_state_count = 0;
|
||||
ioc_state = mpt3sas_base_get_iocstate(ioc, 1);
|
||||
while (ioc_state != MPI2_IOC_STATE_OPERATIONAL) {
|
||||
if (wait_state_count++ == IOC_OPERATIONAL_WAIT_COUNT) {
|
||||
ioc_err(ioc, "%s: failed due to ioc not operational\n",
|
||||
__func__);
|
||||
rc = -EFAULT;
|
||||
goto out;
|
||||
}
|
||||
ssleep(1);
|
||||
ioc_state = mpt3sas_base_get_iocstate(ioc, 1);
|
||||
ioc_info(ioc, "%s: waiting for operational state(count=%d)\n",
|
||||
__func__, wait_state_count);
|
||||
}
|
||||
rc = mpt3sas_wait_for_ioc(ioc, IOC_OPERATIONAL_WAIT_COUNT);
|
||||
if (rc)
|
||||
goto out;
|
||||
|
||||
smid = mpt3sas_base_get_smid(ioc, ioc->base_cb_idx);
|
||||
if (!smid) {
|
||||
|
Reference in New Issue
Block a user