提交 4c688fc7 编写于 作者: F FUJITA Tomonori 提交者: James Bottomley

[SCSI] aic79xx: convert to use the data buffer accessors

- remove the unnecessary map_single path.

- convert to use the new accessors for the sg lists and the
parameters.
Signed-off-by: NFUJITA Tomonori <fujita.tomonori@lab.ntt.co.jp>
Signed-off-by: NJames Bottomley <James.Bottomley@SteelEye.com>
上级 3a57c4a5
...@@ -376,21 +376,10 @@ static __inline void ...@@ -376,21 +376,10 @@ static __inline void
ahd_linux_unmap_scb(struct ahd_softc *ahd, struct scb *scb) ahd_linux_unmap_scb(struct ahd_softc *ahd, struct scb *scb)
{ {
struct scsi_cmnd *cmd; struct scsi_cmnd *cmd;
int direction;
cmd = scb->io_ctx; cmd = scb->io_ctx;
direction = cmd->sc_data_direction;
ahd_sync_sglist(ahd, scb, BUS_DMASYNC_POSTWRITE); ahd_sync_sglist(ahd, scb, BUS_DMASYNC_POSTWRITE);
if (cmd->use_sg != 0) { scsi_dma_unmap(cmd);
struct scatterlist *sg;
sg = (struct scatterlist *)cmd->request_buffer;
pci_unmap_sg(ahd->dev_softc, sg, cmd->use_sg, direction);
} else if (cmd->request_bufflen != 0) {
pci_unmap_single(ahd->dev_softc,
scb->platform_data->buf_busaddr,
cmd->request_bufflen, direction);
}
} }
/******************************** Macros **************************************/ /******************************** Macros **************************************/
...@@ -1422,6 +1411,7 @@ ahd_linux_run_command(struct ahd_softc *ahd, struct ahd_linux_device *dev, ...@@ -1422,6 +1411,7 @@ ahd_linux_run_command(struct ahd_softc *ahd, struct ahd_linux_device *dev,
u_int col_idx; u_int col_idx;
uint16_t mask; uint16_t mask;
unsigned long flags; unsigned long flags;
int nseg;
ahd_lock(ahd, &flags); ahd_lock(ahd, &flags);
...@@ -1494,18 +1484,17 @@ ahd_linux_run_command(struct ahd_softc *ahd, struct ahd_linux_device *dev, ...@@ -1494,18 +1484,17 @@ ahd_linux_run_command(struct ahd_softc *ahd, struct ahd_linux_device *dev,
ahd_set_residual(scb, 0); ahd_set_residual(scb, 0);
ahd_set_sense_residual(scb, 0); ahd_set_sense_residual(scb, 0);
scb->sg_count = 0; scb->sg_count = 0;
if (cmd->use_sg != 0) {
void *sg; nseg = scsi_dma_map(cmd);
struct scatterlist *cur_seg; BUG_ON(nseg < 0);
u_int nseg; if (nseg > 0) {
int dir; void *sg = scb->sg_list;
struct scatterlist *cur_seg;
cur_seg = (struct scatterlist *)cmd->request_buffer; int i;
dir = cmd->sc_data_direction;
nseg = pci_map_sg(ahd->dev_softc, cur_seg,
cmd->use_sg, dir);
scb->platform_data->xfer_len = 0; scb->platform_data->xfer_len = 0;
for (sg = scb->sg_list; nseg > 0; nseg--, cur_seg++) {
scsi_for_each_sg(cmd, cur_seg, nseg, i) {
dma_addr_t addr; dma_addr_t addr;
bus_size_t len; bus_size_t len;
...@@ -1513,22 +1502,8 @@ ahd_linux_run_command(struct ahd_softc *ahd, struct ahd_linux_device *dev, ...@@ -1513,22 +1502,8 @@ ahd_linux_run_command(struct ahd_softc *ahd, struct ahd_linux_device *dev,
len = sg_dma_len(cur_seg); len = sg_dma_len(cur_seg);
scb->platform_data->xfer_len += len; scb->platform_data->xfer_len += len;
sg = ahd_sg_setup(ahd, scb, sg, addr, len, sg = ahd_sg_setup(ahd, scb, sg, addr, len,
/*last*/nseg == 1); i == (nseg - 1));
} }
} else if (cmd->request_bufflen != 0) {
void *sg;
dma_addr_t addr;
int dir;
sg = scb->sg_list;
dir = cmd->sc_data_direction;
addr = pci_map_single(ahd->dev_softc,
cmd->request_buffer,
cmd->request_bufflen, dir);
scb->platform_data->xfer_len = cmd->request_bufflen;
scb->platform_data->buf_busaddr = addr;
sg = ahd_sg_setup(ahd, scb, sg, addr,
cmd->request_bufflen, /*last*/TRUE);
} }
LIST_INSERT_HEAD(&ahd->pending_scbs, scb, pending_links); LIST_INSERT_HEAD(&ahd->pending_scbs, scb, pending_links);
......
...@@ -781,7 +781,7 @@ int ahd_get_transfer_dir(struct scb *scb) ...@@ -781,7 +781,7 @@ int ahd_get_transfer_dir(struct scb *scb)
static __inline static __inline
void ahd_set_residual(struct scb *scb, u_long resid) void ahd_set_residual(struct scb *scb, u_long resid)
{ {
scb->io_ctx->resid = resid; scsi_set_resid(scb->io_ctx, resid);
} }
static __inline static __inline
...@@ -793,7 +793,7 @@ void ahd_set_sense_residual(struct scb *scb, u_long resid) ...@@ -793,7 +793,7 @@ void ahd_set_sense_residual(struct scb *scb, u_long resid)
static __inline static __inline
u_long ahd_get_residual(struct scb *scb) u_long ahd_get_residual(struct scb *scb)
{ {
return (scb->io_ctx->resid); return scsi_get_resid(scb->io_ctx);
} }
static __inline static __inline
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册