dma_addr_t                      rspdma;
        struct scatterlist              *data_sg;
        int                             data_sg_cnt;
-       u32                             total_length;
        u32                             offset;
        enum nvmet_fcp_datadir          io_dir;
        bool                            active;
        u32 page_len, length;
        int i = 0;
 
-       length = fod->total_length;
+       length = fod->req.transfer_len;
        nent = DIV_ROUND_UP(length, PAGE_SIZE);
        sg = kmalloc_array(nent, sizeof(struct scatterlist), GFP_KERNEL);
        if (!sg)
        u32 rsn, rspcnt, xfr_length;
 
        if (fod->fcpreq->op == NVMET_FCOP_READDATA_RSP)
-               xfr_length = fod->total_length;
+               xfr_length = fod->req.transfer_len;
        else
                xfr_length = fod->offset;
 
        rspcnt = atomic_inc_return(&fod->queue->zrspcnt);
        if (!(rspcnt % fod->queue->ersp_ratio) ||
            sqe->opcode == nvme_fabrics_command ||
-           xfr_length != fod->total_length ||
+           xfr_length != fod->req.transfer_len ||
            (le16_to_cpu(cqe->status) & 0xFFFE) || cqewd[0] || cqewd[1] ||
            (sqe->flags & (NVME_CMD_FUSE_FIRST | NVME_CMD_FUSE_SECOND)) ||
            queue_90percent_full(fod->queue, le16_to_cpu(cqe->sq_head)))
        fcpreq->timeout = NVME_FC_TGTOP_TIMEOUT_SEC;
 
        tlen = min_t(u32, tgtport->max_sg_cnt * PAGE_SIZE,
-                       (fod->total_length - fod->offset));
+                       (fod->req.transfer_len - fod->offset));
        fcpreq->transfer_length = tlen;
        fcpreq->transferred_length = 0;
        fcpreq->fcp_error = 0;
         * combined xfr with response.
         */
        if ((op == NVMET_FCOP_READDATA) &&
-           ((fod->offset + fcpreq->transfer_length) == fod->total_length) &&
+           ((fod->offset + fcpreq->transfer_length) == fod->req.transfer_len) &&
            (tgtport->ops->target_features & NVMET_FCTGTFEAT_READDATA_RSP)) {
                fcpreq->op = NVMET_FCOP_READDATA_RSP;
                nvmet_fc_prep_fcp_rsp(tgtport, fod);
                }
 
                fod->offset += fcpreq->transferred_length;
-               if (fod->offset != fod->total_length) {
+               if (fod->offset != fod->req.transfer_len) {
                        spin_lock_irqsave(&fod->flock, flags);
                        fod->writedataactive = true;
                        spin_unlock_irqrestore(&fod->flock, flags);
                }
 
                /* data transfer complete, resume with nvmet layer */
-
-               fod->req.execute(&fod->req);
-
+               nvmet_req_execute(&fod->req);
                break;
 
        case NVMET_FCOP_READDATA:
                }
 
                fod->offset += fcpreq->transferred_length;
-               if (fod->offset != fod->total_length) {
+               if (fod->offset != fod->req.transfer_len) {
                        /* transfer the next chunk */
                        nvmet_fc_transfer_fcp_data(tgtport, fod,
                                                NVMET_FCOP_READDATA);
 
        fod->fcpreq->done = nvmet_fc_xmt_fcp_op_done;
 
-       fod->total_length = be32_to_cpu(cmdiu->data_len);
+       fod->req.transfer_len = be32_to_cpu(cmdiu->data_len);
        if (cmdiu->flags & FCNVME_CMD_FLAGS_WRITE) {
                fod->io_dir = NVMET_FCP_WRITE;
                if (!nvme_is_write(&cmdiu->sqe))
                        goto transport_error;
        } else {
                fod->io_dir = NVMET_FCP_NODATA;
-               if (fod->total_length)
+               if (fod->req.transfer_len)
                        goto transport_error;
        }
 
        fod->req.rsp = &fod->rspiubuf.cqe;
        fod->req.port = fod->queue->port;
 
-       /* ensure nvmet handlers will set cmd handler callback */
-       fod->req.execute = NULL;
-
        /* clear any response payload */
        memset(&fod->rspiubuf, 0, sizeof(fod->rspiubuf));
 
        /* keep a running counter of tail position */
        atomic_inc(&fod->queue->sqtail);
 
-       if (fod->total_length) {
+       if (fod->req.transfer_len) {
                ret = nvmet_fc_alloc_tgt_pgs(fod);
                if (ret) {
                        nvmet_req_complete(&fod->req, ret);
         * can invoke the nvmet_layer now. If read data, cmd completion will
         * push the data
         */
-
-       fod->req.execute(&fod->req);
-
+       nvmet_req_execute(&fod->req);
        return;
 
 transport_error:
 
 static inline bool nvmet_rdma_need_data_in(struct nvmet_rdma_rsp *rsp)
 {
        return nvme_is_write(rsp->req.cmd) &&
-               rsp->req.data_len &&
+               rsp->req.transfer_len &&
                !(rsp->flags & NVMET_RDMA_REQ_INLINE_DATA);
 }
 
 static inline bool nvmet_rdma_need_data_out(struct nvmet_rdma_rsp *rsp)
 {
        return !nvme_is_write(rsp->req.cmd) &&
-               rsp->req.data_len &&
+               rsp->req.transfer_len &&
                !rsp->req.rsp->status &&
                !(rsp->flags & NVMET_RDMA_REQ_INLINE_DATA);
 }
                return;
        }
 
-       rsp->req.execute(&rsp->req);
+       nvmet_req_execute(&rsp->req);
 }
 
 static void nvmet_rdma_use_inline_sg(struct nvmet_rdma_rsp *rsp, u32 len,
 
        nvmet_rdma_use_inline_sg(rsp, len, off);
        rsp->flags |= NVMET_RDMA_REQ_INLINE_DATA;
+       rsp->req.transfer_len += len;
        return 0;
 }
 
                        nvmet_data_dir(&rsp->req));
        if (ret < 0)
                return NVME_SC_INTERNAL;
+       rsp->req.transfer_len += len;
        rsp->n_rdma += ret;
 
        if (invalidate) {
                                queue->cm_id->port_num, &rsp->read_cqe, NULL))
                        nvmet_req_complete(&rsp->req, NVME_SC_DATA_XFER_ERROR);
        } else {
-               rsp->req.execute(&rsp->req);
+               nvmet_req_execute(&rsp->req);
        }
 
        return true;