IB/srpt: Introduce target_reverse_dma_direction()
Use the function target_reverse_dma_direction() instead of reimplementing it. Signed-off-by: Bart Van Assche <bart.vanassche@sandisk.com> Reviewed-by: Christoph Hellwig <hch@lst.de> Reviewed-by: Sagi Grimberg <sagig@mellanox.com> Cc: Alex Estrin <alex.estrin@intel.com> Signed-off-by: Doug Ledford <dledford@redhat.com>
This commit is contained in:
parent
33912d7348
commit
671ec1b2d3
|
@ -96,19 +96,6 @@ static int srpt_queue_status(struct se_cmd *cmd);
|
||||||
static void srpt_recv_done(struct ib_cq *cq, struct ib_wc *wc);
|
static void srpt_recv_done(struct ib_cq *cq, struct ib_wc *wc);
|
||||||
static void srpt_send_done(struct ib_cq *cq, struct ib_wc *wc);
|
static void srpt_send_done(struct ib_cq *cq, struct ib_wc *wc);
|
||||||
|
|
||||||
/**
|
|
||||||
* opposite_dma_dir() - Swap DMA_TO_DEVICE and DMA_FROM_DEVICE.
|
|
||||||
*/
|
|
||||||
static inline
|
|
||||||
enum dma_data_direction opposite_dma_dir(enum dma_data_direction dir)
|
|
||||||
{
|
|
||||||
switch (dir) {
|
|
||||||
case DMA_TO_DEVICE: return DMA_FROM_DEVICE;
|
|
||||||
case DMA_FROM_DEVICE: return DMA_TO_DEVICE;
|
|
||||||
default: return dir;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
static enum rdma_ch_state
|
static enum rdma_ch_state
|
||||||
srpt_set_ch_state(struct srpt_rdma_ch *ch, enum rdma_ch_state new_state)
|
srpt_set_ch_state(struct srpt_rdma_ch *ch, enum rdma_ch_state new_state)
|
||||||
{
|
{
|
||||||
|
@ -1049,7 +1036,7 @@ static void srpt_unmap_sg_to_ib_sge(struct srpt_rdma_ch *ch,
|
||||||
dir = ioctx->cmd.data_direction;
|
dir = ioctx->cmd.data_direction;
|
||||||
BUG_ON(dir == DMA_NONE);
|
BUG_ON(dir == DMA_NONE);
|
||||||
ib_dma_unmap_sg(ch->sport->sdev->device, sg, ioctx->sg_cnt,
|
ib_dma_unmap_sg(ch->sport->sdev->device, sg, ioctx->sg_cnt,
|
||||||
opposite_dma_dir(dir));
|
target_reverse_dma_direction(&ioctx->cmd));
|
||||||
ioctx->mapped_sg_count = 0;
|
ioctx->mapped_sg_count = 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1086,7 +1073,7 @@ static int srpt_map_sg_to_ib_sge(struct srpt_rdma_ch *ch,
|
||||||
ioctx->sg_cnt = sg_cnt = cmd->t_data_nents;
|
ioctx->sg_cnt = sg_cnt = cmd->t_data_nents;
|
||||||
|
|
||||||
count = ib_dma_map_sg(ch->sport->sdev->device, sg, sg_cnt,
|
count = ib_dma_map_sg(ch->sport->sdev->device, sg, sg_cnt,
|
||||||
opposite_dma_dir(dir));
|
target_reverse_dma_direction(cmd));
|
||||||
if (unlikely(!count))
|
if (unlikely(!count))
|
||||||
return -EAGAIN;
|
return -EAGAIN;
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue