u8 fmt;
 
        if (!scsi_sglist(scmnd) || scmnd->sc_data_direction == DMA_NONE)
-               return sizeof (struct srp_cmd);
+               return sizeof(struct srp_cmd) + cmd->add_cdb_len;
 
        if (scmnd->sc_data_direction != DMA_FROM_DEVICE &&
            scmnd->sc_data_direction != DMA_TO_DEVICE) {
                return -EIO;
 
        fmt = SRP_DATA_DESC_DIRECT;
-       len = sizeof (struct srp_cmd) + sizeof (struct srp_direct_buf);
+       len = sizeof(struct srp_cmd) + cmd->add_cdb_len +
+               sizeof(struct srp_direct_buf);
 
        if (count == 1 && target->global_rkey) {
                /*
                 * single entry.  So a direct descriptor along with
                 * the DMA MR suffices.
                 */
-               struct srp_direct_buf *buf = (void *) cmd->add_data;
+               struct srp_direct_buf *buf;
 
+               buf = (void *)cmd->add_data + cmd->add_cdb_len;
                buf->va  = cpu_to_be64(ib_sg_dma_address(ibdev, scat));
                buf->key = cpu_to_be32(target->global_rkey);
                buf->len = cpu_to_be32(ib_sg_dma_len(ibdev, scat));
         * We have more than one scatter/gather entry, so build our indirect
         * descriptor table, trying to merge as many entries as we can.
         */
-       indirect_hdr = (void *) cmd->add_data;
+       indirect_hdr = (void *)cmd->add_data + cmd->add_cdb_len;
 
        ib_dma_sync_single_for_cpu(ibdev, req->indirect_dma_addr,
                                   target->indirect_size, DMA_TO_DEVICE);
                 * Memory registration collapsed the sg-list into one entry,
                 * so use a direct descriptor.
                 */
-               struct srp_direct_buf *buf = (void *) cmd->add_data;
+               struct srp_direct_buf *buf;
 
+               buf = (void *)cmd->add_data + cmd->add_cdb_len;
                *buf = req->indirect_desc[0];
                goto map_complete;
        }
        idb_len = sizeof(struct srp_indirect_buf) + table_len;
 
        fmt = SRP_DATA_DESC_INDIRECT;
-       len = sizeof(struct srp_cmd) + sizeof (struct srp_indirect_buf);
+       len = sizeof(struct srp_cmd) + cmd->add_cdb_len +
+               sizeof(struct srp_indirect_buf);
        len += count * sizeof (struct srp_direct_buf);
 
        memcpy(indirect_hdr->desc_list, req->indirect_desc,
        int_to_scsilun(scmnd->device->lun, &cmd->lun);
        cmd->tag    = tag;
        memcpy(cmd->cdb, scmnd->cmnd, scmnd->cmd_len);
+       if (unlikely(scmnd->cmd_len > sizeof(cmd->cdb))) {
+               cmd->add_cdb_len = round_up(scmnd->cmd_len - sizeof(cmd->cdb),
+                                           4);
+               if (WARN_ON_ONCE(cmd->add_cdb_len > SRP_MAX_ADD_CDB_LEN))
+                       goto err_iu;
+       }
 
        req->scmnd    = scmnd;
        req->cmd      = iu;
        target->indirect_size = target->sg_tablesize *
                                sizeof (struct srp_direct_buf);
        target->max_iu_len = sizeof (struct srp_cmd) +
+                            SRP_MAX_ADD_CDB_LEN +
                             sizeof (struct srp_indirect_buf) +
                             target->cmd_sg_cnt * sizeof (struct srp_direct_buf);