• Hiral Patel's avatar
    [SCSI] fnic: fnic driver may hit BUG_ON on device reset · a0bf1ca2
    Hiral Patel authored
    The issue was observed when LUN Reset is issued through IOCTL or sg_reset
    utility.
    
    fnic driver issues LUN RESET to firmware. On successful completion of device
    reset, driver cleans up all the pending IOs that were issued prior to device
    reset. These pending IOs are expected to be in ABTS_PENDING state. This works
    fine, when the device reset operation resulted from midlayer, but not when
    device reset was triggered from IOCTL path as the pending IOs were not in
    ABTS_PENDING state. execution path hits panic if the pending IO is not in
    ABTS_PENDING state.
    
    Changes:
    The fix replaces BUG_ON check in fnic_clean_pending_aborts() with marking
    pending IOs as ABTS_PENDING if they were not in ABTS_PENDING state and skips
    if they were already in ABTS_PENDING state. An extra check is added to validate
    the abort status of the commands after a delay of 2 * E_D_TOV using a
    helper function. The helper function returns 1 if it finds any pending IO in
    ABTS_PENDING state, belong to the LUN on which device reset was issued else 0.
    With this, device reset operation returns success only if the helper funciton
    returns 0, otherwise it returns failure.
    
    Other changes:
    - Removed code in fnic_clean_pending_aborts() that returns failure if it finds
      io_req NULL, instead of returning failure added code to continue with next io
    - Added device reset flags for debugging in fnic_terminate_rport_io,
      fnic_rport_exch_reset, and fnic_clean_pending_aborts
    Signed-off-by: default avatarNarsimhulu Musini <nmusini@cisco.com>
    Signed-off-by: default avatarHiral Patel <hiralpat@cisco.com>
    Signed-off-by: default avatarJames Bottomley <JBottomley@Parallels.com>
    a0bf1ca2
fnic_scsi.c 60 KB