int aac_reset_adapter(struct aac_dev *aac, int forced, u8 reset_type)
 {
        unsigned long flagv = 0;
-       int retval;
+       int retval, unblock_retval;
        struct Scsi_Host *host = aac->scsi_host_ptr;
        int bled;
 
        retval = _aac_reset_adapter(aac, bled, reset_type);
        spin_unlock_irqrestore(host->host_lock, flagv);
 
-       retval = scsi_host_unblock(host, SDEV_RUNNING);
-
+       unblock_retval = scsi_host_unblock(host, SDEV_RUNNING);
+       if (!retval)
+               retval = unblock_retval;
        if ((forced < 2) && (retval == -ENODEV)) {
                /* Unwind aac_send_shutdown() IOP_RESET unsupported/disabled */
                struct fib * fibctx = aac_fib_alloc(aac);