host_status = DID_ERROR;
                        }
                }
-               cmnd->result = ScsiResult(host_status, scsi_status);
+               cmnd->result = host_status << 16 | scsi_status;
 
                break;
 
        case BFI_IOIM_STS_TIMEDOUT:
-               host_status = DID_TIME_OUT;
-               cmnd->result = ScsiResult(host_status, 0);
+               cmnd->result = DID_TIME_OUT << 16;
                break;
        case BFI_IOIM_STS_PATHTOV:
-               host_status = DID_TRANSPORT_DISRUPTED;
-               cmnd->result = ScsiResult(host_status, 0);
+               cmnd->result = DID_TRANSPORT_DISRUPTED << 16;
                break;
        default:
-               host_status = DID_ERROR;
-               cmnd->result = ScsiResult(host_status, 0);
+               cmnd->result = DID_ERROR << 16;
        }
 
        /* Unmap DMA, if host is NULL, it means a scsi passthru cmd */
        struct bfad_itnim_data_s *itnim_data;
        struct bfad_itnim_s *itnim;
 
-       cmnd->result = ScsiResult(DID_OK, SCSI_STATUS_GOOD);
+       cmnd->result = DID_OK << 16 | SCSI_STATUS_GOOD;
 
        /* Unmap DMA, if host is NULL, it means a scsi passthru cmd */
        if (cmnd->device->host != NULL)
        struct scsi_cmnd *cmnd = (struct scsi_cmnd *)dio;
        struct bfad_s         *bfad = drv;
 
-       cmnd->result = ScsiResult(DID_ERROR, 0);
+       cmnd->result = DID_ERROR << 16;
 
        /* Unmap DMA, if host is NULL, it means a scsi passthru cmd */
        if (cmnd->device->host != NULL)
                printk(KERN_WARNING
                        "bfad%d, queuecommand %p %x failed, BFA stopped\n",
                       bfad->inst_no, cmnd, cmnd->cmnd[0]);
-               cmnd->result = ScsiResult(DID_NO_CONNECT, 0);
+               cmnd->result = DID_NO_CONNECT << 16;
                goto out_fail_cmd;
        }
 
 
        itnim = itnim_data->itnim;
        if (!itnim) {
-               cmnd->result = ScsiResult(DID_IMM_RETRY, 0);
+               cmnd->result = DID_IMM_RETRY << 16;
                goto out_fail_cmd;
        }