diff options
author | Boaz Harrosh <bharrosh@panasas.com> | 2007-12-13 19:14:27 -0500 |
---|---|---|
committer | James Bottomley <James.Bottomley@HansenPartnership.com> | 2008-01-30 14:03:40 -0500 |
commit | bb52d82f45df3a2661d88befba7c79a7db8be496 (patch) | |
tree | 875af65ede88fe724fb350e43000fe99262fec9f /drivers/scsi/scsi_tgt_lib.c | |
parent | 03e7925d0737d99086acee6263424dafa34e45ae (diff) |
[SCSI] tgt: use scsi_init_io instead of scsi_alloc_sgtable
If we export scsi_init_io()/scsi_release_buffers() instead of
scsi_{alloc,free}_sgtable() from scsi_lib than tgt code is much more
insulated from scsi_lib changes. As a bonus it will also gain bidi
capability when it comes.
[jejb: rebase on to sg_table and fix up rejections]
Signed-off-by: Boaz Harrosh <bharrosh@panasas.com>
Acked-by: FUJITA Tomonori <fujita.tomonori@lab.ntt.co.jp>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: James Bottomley <James.Bottomley@HansenPartnership.com>
Diffstat (limited to 'drivers/scsi/scsi_tgt_lib.c')
-rw-r--r-- | drivers/scsi/scsi_tgt_lib.c | 28 |
1 files changed, 5 insertions, 23 deletions
diff --git a/drivers/scsi/scsi_tgt_lib.c b/drivers/scsi/scsi_tgt_lib.c index 01e03f3f6ffa..91630baea532 100644 --- a/drivers/scsi/scsi_tgt_lib.c +++ b/drivers/scsi/scsi_tgt_lib.c | |||
@@ -331,8 +331,7 @@ static void scsi_tgt_cmd_done(struct scsi_cmnd *cmd) | |||
331 | 331 | ||
332 | scsi_tgt_uspace_send_status(cmd, tcmd->itn_id, tcmd->tag); | 332 | scsi_tgt_uspace_send_status(cmd, tcmd->itn_id, tcmd->tag); |
333 | 333 | ||
334 | if (scsi_sglist(cmd)) | 334 | scsi_release_buffers(cmd); |
335 | scsi_free_sgtable(cmd); | ||
336 | 335 | ||
337 | queue_work(scsi_tgtd, &tcmd->work); | 336 | queue_work(scsi_tgtd, &tcmd->work); |
338 | } | 337 | } |
@@ -353,25 +352,6 @@ static int scsi_tgt_transfer_response(struct scsi_cmnd *cmd) | |||
353 | return 0; | 352 | return 0; |
354 | } | 353 | } |
355 | 354 | ||
356 | static int scsi_tgt_init_cmd(struct scsi_cmnd *cmd, gfp_t gfp_mask) | ||
357 | { | ||
358 | struct request *rq = cmd->request; | ||
359 | int count; | ||
360 | |||
361 | cmd->use_sg = rq->nr_phys_segments; | ||
362 | if (scsi_alloc_sgtable(cmd, gfp_mask)) | ||
363 | return -ENOMEM; | ||
364 | |||
365 | cmd->request_bufflen = rq->data_len; | ||
366 | |||
367 | dprintk("cmd %p cnt %d %lu\n", cmd, scsi_sg_count(cmd), | ||
368 | rq_data_dir(rq)); | ||
369 | count = blk_rq_map_sg(rq->q, rq, scsi_sglist(cmd)); | ||
370 | BUG_ON(count > cmd->use_sg); | ||
371 | cmd->use_sg = count; | ||
372 | return 0; | ||
373 | } | ||
374 | |||
375 | /* TODO: test this crap and replace bio_map_user with new interface maybe */ | 355 | /* TODO: test this crap and replace bio_map_user with new interface maybe */ |
376 | static int scsi_map_user_pages(struct scsi_tgt_cmd *tcmd, struct scsi_cmnd *cmd, | 356 | static int scsi_map_user_pages(struct scsi_tgt_cmd *tcmd, struct scsi_cmnd *cmd, |
377 | unsigned long uaddr, unsigned int len, int rw) | 357 | unsigned long uaddr, unsigned int len, int rw) |
@@ -397,9 +377,11 @@ static int scsi_map_user_pages(struct scsi_tgt_cmd *tcmd, struct scsi_cmnd *cmd, | |||
397 | } | 377 | } |
398 | 378 | ||
399 | tcmd->bio = rq->bio; | 379 | tcmd->bio = rq->bio; |
400 | err = scsi_tgt_init_cmd(cmd, GFP_KERNEL); | 380 | err = scsi_init_io(cmd, GFP_KERNEL); |
401 | if (err) | 381 | if (err) { |
382 | scsi_release_buffers(cmd); | ||
402 | goto unmap_rq; | 383 | goto unmap_rq; |
384 | } | ||
403 | 385 | ||
404 | return 0; | 386 | return 0; |
405 | 387 | ||