bsg_job->reply_len = sizeof(struct fc_bsg_reply) +
            sizeof(response) + sizeof(uint8_t);
-       fw_sts_ptr = ((uint8_t *)scsi_req(bsg_job->req)->sense) +
-           sizeof(struct fc_bsg_reply);
-       memcpy(fw_sts_ptr, response, sizeof(response));
+       fw_sts_ptr = bsg_job->reply + sizeof(struct fc_bsg_reply);
+       memcpy(bsg_job->reply + sizeof(struct fc_bsg_reply), response,
+                       sizeof(response));
        fw_sts_ptr += sizeof(response);
        *fw_sts_ptr = command_sent;
 
                                                ql_log(ql_log_warn, vha, 0x7089,
                                                    "mbx abort_command "
                                                    "failed.\n");
-                                               scsi_req(bsg_job->req)->result =
                                                bsg_reply->result = -EIO;
                                        } else {
                                                ql_dbg(ql_dbg_user, vha, 0x708a,
                                                    "mbx abort_command "
                                                    "success.\n");
-                                               scsi_req(bsg_job->req)->result =
                                                bsg_reply->result = 0;
                                        }
                                        spin_lock_irqsave(&ha->hardware_lock, flags);
        }
        spin_unlock_irqrestore(&ha->hardware_lock, flags);
        ql_log(ql_log_info, vha, 0x708b, "SRB not found to abort.\n");
-       scsi_req(bsg_job->req)->result = bsg_reply->result = -ENXIO;
+       bsg_reply->result = -ENXIO;
        return 0;
 
 done:
 
        struct fc_bsg_reply *bsg_reply;
        uint16_t comp_status;
        uint32_t fw_status[3];
-       uint8_t* fw_sts_ptr;
        int res;
        struct srb_iocb *els;
 
                            type, sp->handle, comp_status, fw_status[1], fw_status[2],
                            le16_to_cpu(((struct els_sts_entry_24xx *)
                                pkt)->total_byte_count));
-                       fw_sts_ptr = ((uint8_t*)scsi_req(bsg_job->req)->sense) +
-                               sizeof(struct fc_bsg_reply);
-                       memcpy( fw_sts_ptr, fw_status, sizeof(fw_status));
-               }
-               else {
+               } else {
                        ql_dbg(ql_dbg_user, vha, 0x5040,
                            "ELS-CT pass-through-%s error hdl=%x comp_status-status=0x%x "
                            "error subcode 1=0x%x error subcode 2=0x%x.\n",
                                    pkt)->error_subcode_2));
                        res = DID_ERROR << 16;
                        bsg_reply->reply_payload_rcv_len = 0;
-                       fw_sts_ptr = ((uint8_t*)scsi_req(bsg_job->req)->sense) +
-                                       sizeof(struct fc_bsg_reply);
-                       memcpy( fw_sts_ptr, fw_status, sizeof(fw_status));
                }
+               memcpy(bsg_job->reply + sizeof(struct fc_bsg_reply),
+                      fw_status, sizeof(fw_status));
                ql_dump_buffer(ql_dbg_user + ql_dbg_buffer, vha, 0x5056,
                                (uint8_t *)pkt, sizeof(*pkt));
        }
 
                memcpy(fstatus.reserved_3,
                    pkt->reserved_2, 20 * sizeof(uint8_t));
 
-               fw_sts_ptr = ((uint8_t *)scsi_req(bsg_job->req)->sense) +
-                   sizeof(struct fc_bsg_reply);
+               fw_sts_ptr = bsg_job->reply + sizeof(struct fc_bsg_reply);
 
                memcpy(fw_sts_ptr, (uint8_t *)&fstatus,
                    sizeof(struct qla_mt_iocb_rsp_fx00));