extern void zfcp_fc_wka_ports_force_offline(struct zfcp_fc_wka_ports *);
 extern int zfcp_fc_gs_setup(struct zfcp_adapter *);
 extern void zfcp_fc_gs_destroy(struct zfcp_adapter *);
-extern int zfcp_fc_exec_bsg_job(struct fc_bsg_job *);
-extern int zfcp_fc_timeout_bsg_job(struct fc_bsg_job *);
+extern int zfcp_fc_exec_bsg_job(struct bsg_job *);
+extern int zfcp_fc_timeout_bsg_job(struct bsg_job *);
 extern void zfcp_fc_sym_name_update(struct work_struct *);
 extern unsigned int zfcp_fc_port_scan_backoff(void);
 extern void zfcp_fc_conditional_port_scan(struct zfcp_adapter *);
 
 #include <linux/slab.h>
 #include <linux/utsname.h>
 #include <linux/random.h>
+#include <linux/bsg-lib.h>
 #include <scsi/fc/fc_els.h>
 #include <scsi/libfc.h>
 #include "zfcp_ext.h"
 
 static void zfcp_fc_ct_els_job_handler(void *data)
 {
-       struct fc_bsg_job *job = data;
+       struct bsg_job *job = data;
        struct zfcp_fsf_ct_els *zfcp_ct_els = job->dd_data;
        struct fc_bsg_reply *jr = job->reply;
 
        fc_bsg_jobdone(job, jr->result, jr->reply_payload_rcv_len);
 }
 
-static struct zfcp_fc_wka_port *zfcp_fc_job_wka_port(struct fc_bsg_job *job)
+static struct zfcp_fc_wka_port *zfcp_fc_job_wka_port(struct bsg_job *job)
 {
        u32 preamble_word1;
        u8 gs_type;
 
 static void zfcp_fc_ct_job_handler(void *data)
 {
-       struct fc_bsg_job *job = data;
+       struct bsg_job *job = data;
        struct zfcp_fc_wka_port *wka_port;
 
        wka_port = zfcp_fc_job_wka_port(job);
        zfcp_fc_ct_els_job_handler(data);
 }
 
-static int zfcp_fc_exec_els_job(struct fc_bsg_job *job,
+static int zfcp_fc_exec_els_job(struct bsg_job *job,
                                struct zfcp_adapter *adapter)
 {
        struct zfcp_fsf_ct_els *els = job->dd_data;
        return zfcp_fsf_send_els(adapter, d_id, els, job->req->timeout / HZ);
 }
 
-static int zfcp_fc_exec_ct_job(struct fc_bsg_job *job,
+static int zfcp_fc_exec_ct_job(struct bsg_job *job,
                               struct zfcp_adapter *adapter)
 {
        int ret;
        return ret;
 }
 
-int zfcp_fc_exec_bsg_job(struct fc_bsg_job *job)
+int zfcp_fc_exec_bsg_job(struct bsg_job *job)
 {
        struct Scsi_Host *shost;
        struct zfcp_adapter *adapter;
        }
 }
 
-int zfcp_fc_timeout_bsg_job(struct fc_bsg_job *job)
+int zfcp_fc_timeout_bsg_job(struct bsg_job *job)
 {
        /* hardware tracks timeout, reset bsg timeout to not interfere */
        return -EAGAIN;
 
 }
 
 static int
-bfad_im_bsg_vendor_request(struct fc_bsg_job *job)
+bfad_im_bsg_vendor_request(struct bsg_job *job)
 {
        struct fc_bsg_request *bsg_request = job->request;
        struct fc_bsg_reply *bsg_reply = job->reply;
 }
 
 int
-bfad_fcxp_bsg_send(struct fc_bsg_job *job, struct bfad_fcxp *drv_fcxp,
+bfad_fcxp_bsg_send(struct bsg_job *job, struct bfad_fcxp *drv_fcxp,
                   bfa_bsg_fcpt_t *bsg_fcpt)
 {
        struct bfa_fcxp_s *hal_fcxp;
 }
 
 int
-bfad_im_bsg_els_ct_request(struct fc_bsg_job *job)
+bfad_im_bsg_els_ct_request(struct bsg_job *job)
 {
        struct bfa_bsg_data *bsg_data;
        struct bfad_im_port_s *im_port = shost_priv(fc_bsg_to_shost(job));
 }
 
 int
-bfad_im_bsg_request(struct fc_bsg_job *job)
+bfad_im_bsg_request(struct bsg_job *job)
 {
        struct fc_bsg_request *bsg_request = job->request;
        struct fc_bsg_reply *bsg_reply = job->reply;
 }
 
 int
-bfad_im_bsg_timeout(struct fc_bsg_job *job)
+bfad_im_bsg_timeout(struct bsg_job *job)
 {
        /* Don't complete the BSG job request - return -EAGAIN
         * to reset bsg job timeout : for ELS/CT pass thru we
 
 
 irqreturn_t bfad_intx(int irq, void *dev_id);
 
-int bfad_im_bsg_request(struct fc_bsg_job *job);
-int bfad_im_bsg_timeout(struct fc_bsg_job *job);
+int bfad_im_bsg_request(struct bsg_job *job);
+int bfad_im_bsg_timeout(struct bsg_job *job);
 
 /*
  * Macro to set the SCSI device sdev_bflags - sdev_bflags are used by the
 
 #include <linux/of.h>
 #include <linux/pm.h>
 #include <linux/stringify.h>
+#include <linux/bsg-lib.h>
 #include <asm/firmware.h>
 #include <asm/irq.h>
 #include <asm/vio.h>
 
 /**
  * ibmvfc_bsg_timeout - Handle a BSG timeout
- * @job:       struct fc_bsg_job that timed out
+ * @job:       struct bsg_job that timed out
  *
  * Returns:
  *     0 on success / other on failure
  **/
-static int ibmvfc_bsg_timeout(struct fc_bsg_job *job)
+static int ibmvfc_bsg_timeout(struct bsg_job *job)
 {
        struct ibmvfc_host *vhost = shost_priv(fc_bsg_to_shost(job));
        unsigned long port_id = (unsigned long)job->dd_data;
 
 /**
  * ibmvfc_bsg_request - Handle a BSG request
- * @job:       struct fc_bsg_job to be executed
+ * @job:       struct bsg_job to be executed
  *
  * Returns:
  *     0 on success / other on failure
  **/
-static int ibmvfc_bsg_request(struct fc_bsg_job *job)
+static int ibmvfc_bsg_request(struct bsg_job *job)
 {
        struct ibmvfc_host *vhost = shost_priv(fc_bsg_to_shost(job));
        struct fc_rport *rport = fc_bsg_to_rport(job);
 
  * @offset:   The offset into the response data
  */
 struct fc_bsg_info {
-       struct fc_bsg_job *job;
+       struct bsg_job *job;
        struct fc_lport *lport;
        u16 rsp_code;
        struct scatterlist *sg;
                              void *info_arg)
 {
        struct fc_bsg_info *info = info_arg;
-       struct fc_bsg_job *job = info->job;
+       struct bsg_job *job = info->job;
        struct fc_bsg_reply *bsg_reply = job->reply;
        struct fc_lport *lport = info->lport;
        struct fc_frame_header *fh;
  * Locking Note: The lport lock is expected to be held before calling
  * this routine.
  */
-static int fc_lport_els_request(struct fc_bsg_job *job,
+static int fc_lport_els_request(struct bsg_job *job,
                                struct fc_lport *lport,
                                u32 did, u32 tov)
 {
  * Locking Note: The lport lock is expected to be held before calling
  * this routine.
  */
-static int fc_lport_ct_request(struct fc_bsg_job *job,
+static int fc_lport_ct_request(struct bsg_job *job,
                               struct fc_lport *lport, u32 did, u32 tov)
 {
        struct fc_bsg_info *info;
  *                         FC Passthrough requests
  * @job: The BSG passthrough job
  */
-int fc_lport_bsg_request(struct fc_bsg_job *job)
+int fc_lport_bsg_request(struct bsg_job *job)
 {
        struct fc_bsg_request *bsg_request = job->request;
        struct fc_bsg_reply *bsg_reply = job->reply;
 
 #define TYPE_MENLO     4
 struct bsg_job_data {
        uint32_t type;
-       struct fc_bsg_job *set_job; /* job waiting for this iocb to finish */
+       struct bsg_job *set_job; /* job waiting for this iocb to finish */
        union {
                struct lpfc_bsg_event *evt;
                struct lpfc_bsg_iocb iocb;
                        struct lpfc_iocbq *rspiocbq)
 {
        struct bsg_job_data *dd_data;
-       struct fc_bsg_job *job;
+       struct bsg_job *job;
        struct fc_bsg_reply *bsg_reply;
        IOCB_t *rsp;
        struct lpfc_dmabuf *bmp, *cmp, *rmp;
  * @job: fc_bsg_job to handle
  **/
 static int
-lpfc_bsg_send_mgmt_cmd(struct fc_bsg_job *job)
+lpfc_bsg_send_mgmt_cmd(struct bsg_job *job)
 {
        struct lpfc_vport *vport = shost_priv(fc_bsg_to_shost(job));
        struct lpfc_hba *phba = vport->phba;
                        struct lpfc_iocbq *rspiocbq)
 {
        struct bsg_job_data *dd_data;
-       struct fc_bsg_job *job;
+       struct bsg_job *job;
        struct fc_bsg_reply *bsg_reply;
        IOCB_t *rsp;
        struct lpfc_nodelist *ndlp;
  * @job: fc_bsg_job to handle
  **/
 static int
-lpfc_bsg_rport_els(struct fc_bsg_job *job)
+lpfc_bsg_rport_els(struct bsg_job *job)
 {
        struct lpfc_vport *vport = shost_priv(fc_bsg_to_shost(job));
        struct lpfc_hba *phba = vport->phba;
        struct lpfc_dmabuf *bdeBuf2 = piocbq->context3;
        struct lpfc_hbq_entry *hbqe;
        struct lpfc_sli_ct_request *ct_req;
-       struct fc_bsg_job *job = NULL;
+       struct bsg_job *job = NULL;
        struct fc_bsg_reply *bsg_reply;
        struct bsg_job_data *dd_data = NULL;
        unsigned long flags;
  * @job: SET_EVENT fc_bsg_job
  **/
 static int
-lpfc_bsg_hba_set_event(struct fc_bsg_job *job)
+lpfc_bsg_hba_set_event(struct bsg_job *job)
 {
        struct lpfc_vport *vport = shost_priv(fc_bsg_to_shost(job));
        struct lpfc_hba *phba = vport->phba;
  * @job: GET_EVENT fc_bsg_job
  **/
 static int
-lpfc_bsg_hba_get_event(struct fc_bsg_job *job)
+lpfc_bsg_hba_get_event(struct bsg_job *job)
 {
        struct lpfc_vport *vport = shost_priv(fc_bsg_to_shost(job));
        struct lpfc_hba *phba = vport->phba;
                        struct lpfc_iocbq *rspiocbq)
 {
        struct bsg_job_data *dd_data;
-       struct fc_bsg_job *job;
+       struct bsg_job *job;
        struct fc_bsg_reply *bsg_reply;
        IOCB_t *rsp;
        struct lpfc_dmabuf *bmp, *cmp;
  * @num_entry: Number of enties in the bde.
  **/
 static int
-lpfc_issue_ct_rsp(struct lpfc_hba *phba, struct fc_bsg_job *job, uint32_t tag,
+lpfc_issue_ct_rsp(struct lpfc_hba *phba, struct bsg_job *job, uint32_t tag,
                  struct lpfc_dmabuf *cmp, struct lpfc_dmabuf *bmp,
                  int num_entry)
 {
  * @job: SEND_MGMT_RESP fc_bsg_job
  **/
 static int
-lpfc_bsg_send_mgmt_rsp(struct fc_bsg_job *job)
+lpfc_bsg_send_mgmt_rsp(struct bsg_job *job)
 {
        struct lpfc_vport *vport = shost_priv(fc_bsg_to_shost(job));
        struct lpfc_hba *phba = vport->phba;
  * All of this is done in-line.
  */
 static int
-lpfc_sli3_bsg_diag_loopback_mode(struct lpfc_hba *phba, struct fc_bsg_job *job)
+lpfc_sli3_bsg_diag_loopback_mode(struct lpfc_hba *phba, struct bsg_job *job)
 {
        struct fc_bsg_request *bsg_request = job->request;
        struct fc_bsg_reply *bsg_reply = job->reply;
  * loopback mode in order to perform a diagnostic loopback test.
  */
 static int
-lpfc_sli4_bsg_diag_loopback_mode(struct lpfc_hba *phba, struct fc_bsg_job *job)
+lpfc_sli4_bsg_diag_loopback_mode(struct lpfc_hba *phba, struct bsg_job *job)
 {
        struct fc_bsg_request *bsg_request = job->request;
        struct fc_bsg_reply *bsg_reply = job->reply;
  * command from the user to proper driver action routines.
  */
 static int
-lpfc_bsg_diag_loopback_mode(struct fc_bsg_job *job)
+lpfc_bsg_diag_loopback_mode(struct bsg_job *job)
 {
        struct Scsi_Host *shost;
        struct lpfc_vport *vport;
  * command from the user to proper driver action routines.
  */
 static int
-lpfc_sli4_bsg_diag_mode_end(struct fc_bsg_job *job)
+lpfc_sli4_bsg_diag_mode_end(struct bsg_job *job)
 {
        struct fc_bsg_request *bsg_request = job->request;
        struct fc_bsg_reply *bsg_reply = job->reply;
  * applicaiton.
  */
 static int
-lpfc_sli4_bsg_link_diag_test(struct fc_bsg_job *job)
+lpfc_sli4_bsg_link_diag_test(struct bsg_job *job)
 {
        struct fc_bsg_request *bsg_request = job->request;
        struct fc_bsg_reply *bsg_reply = job->reply;
  * of loopback mode.
  **/
 static int
-lpfc_bsg_diag_loopback_run(struct fc_bsg_job *job)
+lpfc_bsg_diag_loopback_run(struct bsg_job *job)
 {
        struct lpfc_vport *vport = shost_priv(fc_bsg_to_shost(job));
        struct fc_bsg_reply *bsg_reply = job->reply;
  * @job: GET_DFC_REV fc_bsg_job
  **/
 static int
-lpfc_bsg_get_dfc_rev(struct fc_bsg_job *job)
+lpfc_bsg_get_dfc_rev(struct bsg_job *job)
 {
        struct lpfc_vport *vport = shost_priv(fc_bsg_to_shost(job));
        struct fc_bsg_reply *bsg_reply = job->reply;
 {
        struct bsg_job_data *dd_data;
        struct fc_bsg_reply *bsg_reply;
-       struct fc_bsg_job *job;
+       struct bsg_job *job;
        uint32_t size;
        unsigned long flags;
        uint8_t *pmb, *pmb_buf;
  * This is routine handles BSG job for mailbox commands completions with
  * multiple external buffers.
  **/
-static struct fc_bsg_job *
+static struct bsg_job *
 lpfc_bsg_issue_mbox_ext_handle_job(struct lpfc_hba *phba, LPFC_MBOXQ_t *pmboxq)
 {
        struct bsg_job_data *dd_data;
-       struct fc_bsg_job *job;
+       struct bsg_job *job;
        struct fc_bsg_reply *bsg_reply;
        uint8_t *pmb, *pmb_buf;
        unsigned long flags;
 static void
 lpfc_bsg_issue_read_mbox_ext_cmpl(struct lpfc_hba *phba, LPFC_MBOXQ_t *pmboxq)
 {
-       struct fc_bsg_job *job;
+       struct bsg_job *job;
        struct fc_bsg_reply *bsg_reply;
 
        job = lpfc_bsg_issue_mbox_ext_handle_job(phba, pmboxq);
 static void
 lpfc_bsg_issue_write_mbox_ext_cmpl(struct lpfc_hba *phba, LPFC_MBOXQ_t *pmboxq)
 {
-       struct fc_bsg_job *job;
+       struct bsg_job *job;
        struct fc_bsg_reply *bsg_reply;
 
        job = lpfc_bsg_issue_mbox_ext_handle_job(phba, pmboxq);
  * non-embedded external bufffers.
  **/
 static int
-lpfc_bsg_sli_cfg_read_cmd_ext(struct lpfc_hba *phba, struct fc_bsg_job *job,
+lpfc_bsg_sli_cfg_read_cmd_ext(struct lpfc_hba *phba, struct bsg_job *job,
                              enum nemb_type nemb_tp,
                              struct lpfc_dmabuf *dmabuf)
 {
  * non-embedded external bufffers.
  **/
 static int
-lpfc_bsg_sli_cfg_write_cmd_ext(struct lpfc_hba *phba, struct fc_bsg_job *job,
+lpfc_bsg_sli_cfg_write_cmd_ext(struct lpfc_hba *phba, struct bsg_job *job,
                               enum nemb_type nemb_tp,
                               struct lpfc_dmabuf *dmabuf)
 {
  * with embedded sussystem 0x1 and opcodes with external HBDs.
  **/
 static int
-lpfc_bsg_handle_sli_cfg_mbox(struct lpfc_hba *phba, struct fc_bsg_job *job,
+lpfc_bsg_handle_sli_cfg_mbox(struct lpfc_hba *phba, struct bsg_job *job,
                             struct lpfc_dmabuf *dmabuf)
 {
        struct lpfc_sli_config_mbox *sli_cfg_mbx;
  * user space through BSG.
  **/
 static int
-lpfc_bsg_read_ebuf_get(struct lpfc_hba *phba, struct fc_bsg_job *job)
+lpfc_bsg_read_ebuf_get(struct lpfc_hba *phba, struct bsg_job *job)
 {
        struct fc_bsg_reply *bsg_reply = job->reply;
        struct lpfc_sli_config_mbox *sli_cfg_mbx;
  * from user space through BSG.
  **/
 static int
-lpfc_bsg_write_ebuf_set(struct lpfc_hba *phba, struct fc_bsg_job *job,
+lpfc_bsg_write_ebuf_set(struct lpfc_hba *phba, struct bsg_job *job,
                        struct lpfc_dmabuf *dmabuf)
 {
        struct fc_bsg_reply *bsg_reply = job->reply;
  * command with multiple non-embedded external buffers.
  **/
 static int
-lpfc_bsg_handle_sli_cfg_ebuf(struct lpfc_hba *phba, struct fc_bsg_job *job,
+lpfc_bsg_handle_sli_cfg_ebuf(struct lpfc_hba *phba, struct bsg_job *job,
                             struct lpfc_dmabuf *dmabuf)
 {
        int rc;
  * (0x9B) mailbox commands and external buffers.
  **/
 static int
-lpfc_bsg_handle_sli_cfg_ext(struct lpfc_hba *phba, struct fc_bsg_job *job,
+lpfc_bsg_handle_sli_cfg_ext(struct lpfc_hba *phba, struct bsg_job *job,
                            struct lpfc_dmabuf *dmabuf)
 {
        struct fc_bsg_request *bsg_request = job->request;
  * let our completion handler finish the command.
  **/
 static int
-lpfc_bsg_issue_mbox(struct lpfc_hba *phba, struct fc_bsg_job *job,
+lpfc_bsg_issue_mbox(struct lpfc_hba *phba, struct bsg_job *job,
        struct lpfc_vport *vport)
 {
        struct fc_bsg_request *bsg_request = job->request;
  * @job: MBOX fc_bsg_job for LPFC_BSG_VENDOR_MBOX.
  **/
 static int
-lpfc_bsg_mbox_cmd(struct fc_bsg_job *job)
+lpfc_bsg_mbox_cmd(struct bsg_job *job)
 {
        struct lpfc_vport *vport = shost_priv(fc_bsg_to_shost(job));
        struct fc_bsg_request *bsg_request = job->request;
                        struct lpfc_iocbq *rspiocbq)
 {
        struct bsg_job_data *dd_data;
-       struct fc_bsg_job *job;
+       struct bsg_job *job;
        struct fc_bsg_reply *bsg_reply;
        IOCB_t *rsp;
        struct lpfc_dmabuf *bmp, *cmp, *rmp;
  * supplied in the menlo request header xri field.
  **/
 static int
-lpfc_menlo_cmd(struct fc_bsg_job *job)
+lpfc_menlo_cmd(struct bsg_job *job)
 {
        struct lpfc_vport *vport = shost_priv(fc_bsg_to_shost(job));
        struct fc_bsg_request *bsg_request = job->request;
 }
 
 static int
-lpfc_forced_link_speed(struct fc_bsg_job *job)
+lpfc_forced_link_speed(struct bsg_job *job)
 {
        struct Scsi_Host *shost = fc_bsg_to_shost(job);
        struct lpfc_vport *vport = shost_priv(shost);
  * @job: fc_bsg_job to handle
  **/
 static int
-lpfc_bsg_hst_vendor(struct fc_bsg_job *job)
+lpfc_bsg_hst_vendor(struct bsg_job *job)
 {
        struct fc_bsg_request *bsg_request = job->request;
        struct fc_bsg_reply *bsg_reply = job->reply;
  * @job: fc_bsg_job to handle
  **/
 int
-lpfc_bsg_request(struct fc_bsg_job *job)
+lpfc_bsg_request(struct bsg_job *job)
 {
        struct fc_bsg_request *bsg_request = job->request;
        struct fc_bsg_reply *bsg_reply = job->reply;
  * the waiting function which will handle passing the error back to userspace
  **/
 int
-lpfc_bsg_timeout(struct fc_bsg_job *job)
+lpfc_bsg_timeout(struct bsg_job *job)
 {
        struct lpfc_vport *vport = shost_priv(fc_bsg_to_shost(job));
        struct lpfc_hba *phba = vport->phba;
 
 #define HBA_EVENT_LINK_DOWN              3
 
 /* functions to support SGIOv4/bsg interface */
-int lpfc_bsg_request(struct fc_bsg_job *);
-int lpfc_bsg_timeout(struct fc_bsg_job *);
+int lpfc_bsg_request(struct bsg_job *);
+int lpfc_bsg_timeout(struct bsg_job *);
 int lpfc_bsg_ct_unsol_event(struct lpfc_hba *, struct lpfc_sli_ring *,
                             struct lpfc_iocbq *);
 int lpfc_bsg_ct_unsol_abort(struct lpfc_hba *, struct hbq_dmabuf *);
 
 #include <linux/kthread.h>
 #include <linux/vmalloc.h>
 #include <linux/delay.h>
+#include <linux/bsg-lib.h>
 
 /* BSG support for ELS/CT pass through */
 void
 {
        srb_t *sp = (srb_t *)ptr;
        struct scsi_qla_host *vha = (scsi_qla_host_t *)data;
-       struct fc_bsg_job *bsg_job = sp->u.bsg_job;
+       struct bsg_job *bsg_job = sp->u.bsg_job;
        struct fc_bsg_reply *bsg_reply = bsg_job->reply;
 
        bsg_reply->result = res;
 {
        srb_t *sp = (srb_t *)ptr;
        struct scsi_qla_host *vha = sp->fcport->vha;
-       struct fc_bsg_job *bsg_job = sp->u.bsg_job;
+       struct bsg_job *bsg_job = sp->u.bsg_job;
        struct fc_bsg_request *bsg_request = bsg_job->request;
 
        struct qla_hw_data *ha = vha->hw;
 }
 
 static int
-qla24xx_proc_fcp_prio_cfg_cmd(struct fc_bsg_job *bsg_job)
+qla24xx_proc_fcp_prio_cfg_cmd(struct bsg_job *bsg_job)
 {
        struct Scsi_Host *host = fc_bsg_to_shost(bsg_job);
        struct fc_bsg_request *bsg_request = bsg_job->request;
 }
 
 static int
-qla2x00_process_els(struct fc_bsg_job *bsg_job)
+qla2x00_process_els(struct bsg_job *bsg_job)
 {
        struct fc_bsg_request *bsg_request = bsg_job->request;
        struct fc_rport *rport;
 }
 
 static int
-qla2x00_process_ct(struct fc_bsg_job *bsg_job)
+qla2x00_process_ct(struct bsg_job *bsg_job)
 {
        srb_t *sp;
        struct fc_bsg_request *bsg_request = bsg_job->request;
 }
 
 static int
-qla2x00_process_loopback(struct fc_bsg_job *bsg_job)
+qla2x00_process_loopback(struct bsg_job *bsg_job)
 {
        struct fc_bsg_request *bsg_request = bsg_job->request;
        struct fc_bsg_reply *bsg_reply = bsg_job->reply;
 }
 
 static int
-qla84xx_reset(struct fc_bsg_job *bsg_job)
+qla84xx_reset(struct bsg_job *bsg_job)
 {
        struct fc_bsg_request *bsg_request = bsg_job->request;
        struct Scsi_Host *host = fc_bsg_to_shost(bsg_job);
 }
 
 static int
-qla84xx_updatefw(struct fc_bsg_job *bsg_job)
+qla84xx_updatefw(struct bsg_job *bsg_job)
 {
        struct fc_bsg_request *bsg_request = bsg_job->request;
        struct fc_bsg_reply *bsg_reply = bsg_job->reply;
 }
 
 static int
-qla84xx_mgmt_cmd(struct fc_bsg_job *bsg_job)
+qla84xx_mgmt_cmd(struct bsg_job *bsg_job)
 {
        struct fc_bsg_request *bsg_request = bsg_job->request;
        struct fc_bsg_reply *bsg_reply = bsg_job->reply;
 }
 
 static int
-qla24xx_iidma(struct fc_bsg_job *bsg_job)
+qla24xx_iidma(struct bsg_job *bsg_job)
 {
        struct fc_bsg_request *bsg_request = bsg_job->request;
        struct fc_bsg_reply *bsg_reply = bsg_job->reply;
 }
 
 static int
-qla2x00_optrom_setup(struct fc_bsg_job *bsg_job, scsi_qla_host_t *vha,
+qla2x00_optrom_setup(struct bsg_job *bsg_job, scsi_qla_host_t *vha,
        uint8_t is_update)
 {
        struct fc_bsg_request *bsg_request = bsg_job->request;
 }
 
 static int
-qla2x00_read_optrom(struct fc_bsg_job *bsg_job)
+qla2x00_read_optrom(struct bsg_job *bsg_job)
 {
        struct fc_bsg_reply *bsg_reply = bsg_job->reply;
        struct Scsi_Host *host = fc_bsg_to_shost(bsg_job);
 }
 
 static int
-qla2x00_update_optrom(struct fc_bsg_job *bsg_job)
+qla2x00_update_optrom(struct bsg_job *bsg_job)
 {
        struct fc_bsg_reply *bsg_reply = bsg_job->reply;
        struct Scsi_Host *host = fc_bsg_to_shost(bsg_job);
 }
 
 static int
-qla2x00_update_fru_versions(struct fc_bsg_job *bsg_job)
+qla2x00_update_fru_versions(struct bsg_job *bsg_job)
 {
        struct fc_bsg_reply *bsg_reply = bsg_job->reply;
        struct Scsi_Host *host = fc_bsg_to_shost(bsg_job);
 }
 
 static int
-qla2x00_read_fru_status(struct fc_bsg_job *bsg_job)
+qla2x00_read_fru_status(struct bsg_job *bsg_job)
 {
        struct fc_bsg_reply *bsg_reply = bsg_job->reply;
        struct Scsi_Host *host = fc_bsg_to_shost(bsg_job);
 }
 
 static int
-qla2x00_write_fru_status(struct fc_bsg_job *bsg_job)
+qla2x00_write_fru_status(struct bsg_job *bsg_job)
 {
        struct fc_bsg_reply *bsg_reply = bsg_job->reply;
        struct Scsi_Host *host = fc_bsg_to_shost(bsg_job);
 }
 
 static int
-qla2x00_write_i2c(struct fc_bsg_job *bsg_job)
+qla2x00_write_i2c(struct bsg_job *bsg_job)
 {
        struct fc_bsg_reply *bsg_reply = bsg_job->reply;
        struct Scsi_Host *host = fc_bsg_to_shost(bsg_job);
 }
 
 static int
-qla2x00_read_i2c(struct fc_bsg_job *bsg_job)
+qla2x00_read_i2c(struct bsg_job *bsg_job)
 {
        struct fc_bsg_reply *bsg_reply = bsg_job->reply;
        struct Scsi_Host *host = fc_bsg_to_shost(bsg_job);
 }
 
 static int
-qla24xx_process_bidir_cmd(struct fc_bsg_job *bsg_job)
+qla24xx_process_bidir_cmd(struct bsg_job *bsg_job)
 {
        struct fc_bsg_reply *bsg_reply = bsg_job->reply;
        struct Scsi_Host *host = fc_bsg_to_shost(bsg_job);
 }
 
 static int
-qlafx00_mgmt_cmd(struct fc_bsg_job *bsg_job)
+qlafx00_mgmt_cmd(struct bsg_job *bsg_job)
 {
        struct fc_bsg_request *bsg_request = bsg_job->request;
        struct Scsi_Host *host = fc_bsg_to_shost(bsg_job);
 }
 
 static int
-qla26xx_serdes_op(struct fc_bsg_job *bsg_job)
+qla26xx_serdes_op(struct bsg_job *bsg_job)
 {
        struct fc_bsg_reply *bsg_reply = bsg_job->reply;
        struct Scsi_Host *host = fc_bsg_to_shost(bsg_job);
 }
 
 static int
-qla8044_serdes_op(struct fc_bsg_job *bsg_job)
+qla8044_serdes_op(struct bsg_job *bsg_job)
 {
        struct fc_bsg_reply *bsg_reply = bsg_job->reply;
        struct Scsi_Host *host = fc_bsg_to_shost(bsg_job);
 }
 
 static int
-qla27xx_get_flash_upd_cap(struct fc_bsg_job *bsg_job)
+qla27xx_get_flash_upd_cap(struct bsg_job *bsg_job)
 {
        struct fc_bsg_reply *bsg_reply = bsg_job->reply;
        struct Scsi_Host *host = fc_bsg_to_shost(bsg_job);
 }
 
 static int
-qla27xx_set_flash_upd_cap(struct fc_bsg_job *bsg_job)
+qla27xx_set_flash_upd_cap(struct bsg_job *bsg_job)
 {
        struct fc_bsg_reply *bsg_reply = bsg_job->reply;
        struct Scsi_Host *host = fc_bsg_to_shost(bsg_job);
 }
 
 static int
-qla27xx_get_bbcr_data(struct fc_bsg_job *bsg_job)
+qla27xx_get_bbcr_data(struct bsg_job *bsg_job)
 {
        struct fc_bsg_reply *bsg_reply = bsg_job->reply;
        struct Scsi_Host *host = fc_bsg_to_shost(bsg_job);
 }
 
 static int
-qla2x00_get_priv_stats(struct fc_bsg_job *bsg_job)
+qla2x00_get_priv_stats(struct bsg_job *bsg_job)
 {
        struct fc_bsg_request *bsg_request = bsg_job->request;
        struct fc_bsg_reply *bsg_reply = bsg_job->reply;
 }
 
 static int
-qla2x00_do_dport_diagnostics(struct fc_bsg_job *bsg_job)
+qla2x00_do_dport_diagnostics(struct bsg_job *bsg_job)
 {
        struct fc_bsg_reply *bsg_reply = bsg_job->reply;
        struct Scsi_Host *host = fc_bsg_to_shost(bsg_job);
 }
 
 static int
-qla2x00_process_vendor_specific(struct fc_bsg_job *bsg_job)
+qla2x00_process_vendor_specific(struct bsg_job *bsg_job)
 {
        struct fc_bsg_request *bsg_request = bsg_job->request;
 
 }
 
 int
-qla24xx_bsg_request(struct fc_bsg_job *bsg_job)
+qla24xx_bsg_request(struct bsg_job *bsg_job)
 {
        struct fc_bsg_request *bsg_request = bsg_job->request;
        struct fc_bsg_reply *bsg_reply = bsg_job->reply;
 }
 
 int
-qla24xx_bsg_timeout(struct fc_bsg_job *bsg_job)
+qla24xx_bsg_timeout(struct bsg_job *bsg_job)
 {
        struct fc_bsg_reply *bsg_reply = bsg_job->reply;
        scsi_qla_host_t *vha = shost_priv(fc_bsg_to_shost(bsg_job));
 
        int iocbs;
        union {
                struct srb_iocb iocb_cmd;
-               struct fc_bsg_job *bsg_job;
+               struct bsg_job *bsg_job;
                struct srb_cmd scmd;
        } u;
        void (*done)(void *, void *, int);
 
 extern int qla8044_read_temperature(scsi_qla_host_t *);
 
 /* BSG related functions */
-extern int qla24xx_bsg_request(struct fc_bsg_job *);
-extern int qla24xx_bsg_timeout(struct fc_bsg_job *);
+extern int qla24xx_bsg_request(struct bsg_job *);
+extern int qla24xx_bsg_timeout(struct bsg_job *);
 extern int qla84xx_reset_chip(scsi_qla_host_t *, uint16_t);
 extern int qla2x00_issue_iocb_timeout(scsi_qla_host_t *, void *,
        dma_addr_t, size_t, uint32_t);
 
 static void
 qla24xx_els_iocb(srb_t *sp, struct els_entry_24xx *els_iocb)
 {
-       struct fc_bsg_job *bsg_job = sp->u.bsg_job;
+       struct bsg_job *bsg_job = sp->u.bsg_job;
        struct fc_bsg_request *bsg_request = bsg_job->request;
 
         els_iocb->entry_type = ELS_IOCB_TYPE;
        uint16_t tot_dsds;
        scsi_qla_host_t *vha = sp->fcport->vha;
        struct qla_hw_data *ha = vha->hw;
-       struct fc_bsg_job *bsg_job = sp->u.bsg_job;
+       struct bsg_job *bsg_job = sp->u.bsg_job;
        int loop_iterartion = 0;
        int entry_count = 1;
 
        uint16_t tot_dsds;
         scsi_qla_host_t *vha = sp->fcport->vha;
        struct qla_hw_data *ha = vha->hw;
-       struct fc_bsg_job *bsg_job = sp->u.bsg_job;
+       struct bsg_job *bsg_job = sp->u.bsg_job;
        int loop_iterartion = 0;
        int entry_count = 1;
 
        struct scatterlist *sg;
        int index;
        int entry_count = 1;
-       struct fc_bsg_job *bsg_job = sp->u.bsg_job;
+       struct bsg_job *bsg_job = sp->u.bsg_job;
 
        /*Update entry type to indicate bidir command */
        *((uint32_t *)(&cmd_pkt->entry_type)) =
 
        const char func[] = "CT_IOCB";
        const char *type;
        srb_t *sp;
-       struct fc_bsg_job *bsg_job;
+       struct bsg_job *bsg_job;
        struct fc_bsg_reply *bsg_reply;
        uint16_t comp_status;
        int res;
        const char func[] = "ELS_CT_IOCB";
        const char *type;
        srb_t *sp;
-       struct fc_bsg_job *bsg_job;
+       struct bsg_job *bsg_job;
        struct fc_bsg_reply *bsg_reply;
        uint16_t comp_status;
        uint32_t fw_status[3];
        uint16_t        scsi_status;
        uint16_t thread_id;
        uint32_t rval = EXT_STATUS_OK;
-       struct fc_bsg_job *bsg_job = NULL;
+       struct bsg_job *bsg_job = NULL;
        struct fc_bsg_request *bsg_request;
        struct fc_bsg_reply *bsg_reply;
        sts_entry_t *sts;
 
 #include <linux/pci.h>
 #include <linux/ratelimit.h>
 #include <linux/vmalloc.h>
+#include <linux/bsg-lib.h>
 #include <scsi/scsi_tcq.h>
 #include <linux/utsname.h>
 
 {
        const char func[] = "IOSB_IOCB";
        srb_t *sp;
-       struct fc_bsg_job *bsg_job;
+       struct bsg_job *bsg_job;
        struct fc_bsg_reply *bsg_reply;
        struct srb_iocb *iocb_job;
        int res;
 {
        struct srb_iocb *fxio = &sp->u.iocb_cmd;
        struct qla_mt_iocb_rqst_fx00 *piocb_rqst;
-       struct fc_bsg_job *bsg_job;
+       struct bsg_job *bsg_job;
        struct fc_bsg_request *bsg_request;
        struct fxdisc_entry_fx00 fx_iocb;
        uint8_t entry_cnt = 1;
 
 static void
 fc_destroy_bsgjob(struct kref *kref)
 {
-       struct fc_bsg_job *job = container_of(kref, struct fc_bsg_job, kref);
+       struct bsg_job *job = container_of(kref, struct bsg_job, kref);
        struct request *rq = job->req;
 
        blk_end_request_all(rq, rq->errors);
  * @result:    job reply result
  * @reply_payload_rcv_len: length of payload received
  */
-void fc_bsg_jobdone(struct fc_bsg_job *job, int result,
+void fc_bsg_jobdone(struct bsg_job *job, int result,
                    unsigned int reply_payload_rcv_len)
 {
        struct request *req = job->req;
  */
 static void fc_bsg_softirq_done(struct request *rq)
 {
-       struct fc_bsg_job *job = rq->special;
+       struct bsg_job *job = rq->special;
 
        kref_put(&job->kref, fc_destroy_bsgjob);
 }
 static enum blk_eh_timer_return
 fc_bsg_job_timeout(struct request *req)
 {
-       struct fc_bsg_job *job = (void *) req->special;
+       struct bsg_job *job = (void *) req->special;
        struct Scsi_Host *shost = fc_bsg_to_shost(job);
        struct fc_rport *rport = fc_bsg_to_rport(job);
        struct fc_internal *i = to_fc_internal(shost->transportt);
 {
        struct fc_internal *i = to_fc_internal(shost->transportt);
        struct request *rsp = req->next_rq;
-       struct fc_bsg_job *job;
+       struct bsg_job *job;
        int ret;
 
        BUG_ON(req->special);
 
-       job = kzalloc(sizeof(struct fc_bsg_job) + i->f->dd_bsg_size,
+       job = kzalloc(sizeof(struct bsg_job) + i->f->dd_bsg_size,
                        GFP_KERNEL);
        if (!job)
                return -ENOMEM;
         */
 
        req->special = job;
-       job->shost = shost;
-       job->rport = rport;
        job->req = req;
        if (i->f->dd_bsg_size)
                job->dd_data = (void *)&job[1];
  */
 static enum fc_dispatch_result
 fc_bsg_host_dispatch(struct request_queue *q, struct Scsi_Host *shost,
-                        struct fc_bsg_job *job)
+                        struct bsg_job *job)
 {
        struct fc_internal *i = to_fc_internal(shost->transportt);
        struct fc_bsg_request *bsg_request = job->request;
  */
 static enum fc_dispatch_result
 fc_bsg_rport_dispatch(struct request_queue *q, struct Scsi_Host *shost,
-                        struct fc_rport *rport, struct fc_bsg_job *job)
+                        struct fc_rport *rport, struct bsg_job *job)
 {
        struct fc_internal *i = to_fc_internal(shost->transportt);
        struct fc_bsg_request *bsg_request = job->request;
                       struct fc_rport *rport, struct device *dev)
 {
        struct request *req;
-       struct fc_bsg_job *job;
+       struct bsg_job *job;
        enum fc_dispatch_result ret;
        struct fc_bsg_reply *bsg_reply;
 
 
 int fc_set_mfs(struct fc_lport *, u32 mfs);
 struct fc_lport *libfc_vport_create(struct fc_vport *, int privsize);
 struct fc_lport *fc_vport_id_lookup(struct fc_lport *, u32 port_id);
-int fc_lport_bsg_request(struct fc_bsg_job *);
+int fc_lport_bsg_request(struct bsg_job *);
 void fc_lport_set_local_id(struct fc_lport *, u32 port_id);
 void fc_lport_iterate(void (*func)(struct fc_lport *, void *), void *);
 
 
 #include <asm/unaligned.h>
 #include <scsi/scsi.h>
 #include <scsi/scsi_netlink.h>
+#include <scsi/scsi_host.h>
 
 struct scsi_transport_template;
 
 #define fc_host_dev_loss_tmo(x) \
        (((struct fc_host_attrs *)(x)->shost_data)->dev_loss_tmo)
 
-/* Values for fc_bsg_job->state_flags (bitflags) */
-#define FC_RQST_STATE_INPROGRESS       0
-#define FC_RQST_STATE_DONE             1
-
-struct fc_bsg_job {
-       struct Scsi_Host *shost;
-       struct fc_rport *rport;
-       struct device *dev;
-       struct request *req;
-       struct kref kref;
-
-       struct fc_bsg_request *request;
-       struct fc_bsg_reply *reply;
-       unsigned int request_len;
-       unsigned int reply_len;
-       /*
-        * On entry : reply_len indicates the buffer size allocated for
-        * the reply.
-        *
-        * Upon completion : the message handler must set reply_len
-        *  to indicates the size of the reply to be returned to the
-        *  caller.
-        */
-
-       /* DMA payloads for the request/response */
-       struct bsg_buffer request_payload;
-       struct bsg_buffer reply_payload;
-
-       void *dd_data;                  /* Used for driver-specific storage */
-};
-
-
 /* The functions by which the transport class and the driver communicate */
 struct fc_function_template {
        void    (*get_rport_dev_loss_tmo)(struct fc_rport *);
        int     (* it_nexus_response)(struct Scsi_Host *, u64, int);
 
        /* bsg support */
-       int     (*bsg_request)(struct fc_bsg_job *);
-       int     (*bsg_timeout)(struct fc_bsg_job *);
+       int     (*bsg_request)(struct bsg_job *);
+       int     (*bsg_timeout)(struct bsg_job *);
 
        /* allocation lengths for host-specific data */
        u32                             dd_fcrport_size;
        vport->vport_state = new_state;
 }
 
-static inline struct Scsi_Host *fc_bsg_to_shost(struct fc_bsg_job *job)
-{
-       return job->shost;
-}
-
-static inline struct fc_rport *fc_bsg_to_rport(struct fc_bsg_job *job)
-{
-       return job->rport;
-}
-
 struct scsi_transport_template *fc_attach_transport(
                        struct fc_function_template *);
 void fc_release_transport(struct scsi_transport_template *);
                struct fc_vport_identifiers *);
 int fc_vport_terminate(struct fc_vport *vport);
 int fc_block_scsi_eh(struct scsi_cmnd *cmnd);
-void fc_bsg_jobdone(struct fc_bsg_job *job, int result,
+void fc_bsg_jobdone(struct bsg_job *job, int result,
                    unsigned int reply_payload_rcv_len);
 
+static inline struct Scsi_Host *fc_bsg_to_shost(struct bsg_job *job)
+{
+       if (scsi_is_host_device(job->dev))
+               return dev_to_shost(job->dev);
+       return rport_to_shost(dev_to_rport(job->dev));
+}
+
+static inline struct fc_rport *fc_bsg_to_rport(struct bsg_job *job)
+{
+       if (scsi_is_fc_rport(job->dev))
+               return dev_to_rport(job->dev);
+       return NULL;
+}
+
 #endif /* SCSI_TRANSPORT_FC_H */