diff options
author | Cornelia Huck <cornelia.huck@de.ibm.com> | 2007-07-09 14:59:59 -0400 |
---|---|---|
committer | James Bottomley <jejb@mulgrave.localdomain> | 2007-07-14 20:28:10 -0400 |
commit | 7689e82efdb636e8a076a1293b977bce313110c5 (patch) | |
tree | 3d8702ff24a205db7670ad5425e3a35fe45b0f00 /drivers/scsi/scsi_lib_dma.c | |
parent | 6d877688ef411313c94aa3c83c7473fbec6db32c (diff) |
[SCSI] don't build scsi_dma_{map,unmap} for !HAS_DMA
With
dma-mapping-prevent-dma-dependent-code-from-linking-on.patch
scsi fails to build on !HAS_DMA architectures:
drivers/built-in.o(.text+0x20af6): In function `scsi_dma_map':
: undefined reference to `dma_map_sg'
drivers/built-in.o(.text+0x20b5c): In function `scsi_dma_unmap':
: undefined reference to `dma_unmap_sg'
I split those functions out into a new file. Builds on s390 and i386.
Move scsi_dma_{map,unmap} into scsi_lib_dma.c which is only build if
HAS_DMA is set.
Signed-off-by: Cornelia Huck <cornelia.huck@de.ibm.com>
Cc: Martin Schwidefsky <schwidefsky@de.ibm.com>
Cc: Heiko Carstens <heiko.carstens@de.ibm.com>
Cc: James Bottomley <James.Bottomley@SteelEye.com>
Cc: Jeff Garzik <jeff@garzik.org>
Cc: Christoph Hellwig <hch@lst.de>
Cc: Dan Williams <dan.j.williams@intel.com>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: James Bottomley <James.Bottomley@SteelEye.com>
Diffstat (limited to 'drivers/scsi/scsi_lib_dma.c')
-rw-r--r-- | drivers/scsi/scsi_lib_dma.c | 50 |
1 files changed, 50 insertions, 0 deletions
diff --git a/drivers/scsi/scsi_lib_dma.c b/drivers/scsi/scsi_lib_dma.c new file mode 100644 index 000000000000..ac6855cd2657 --- /dev/null +++ b/drivers/scsi/scsi_lib_dma.c | |||
@@ -0,0 +1,50 @@ | |||
1 | /* | ||
2 | * SCSI library functions depending on DMA | ||
3 | */ | ||
4 | |||
5 | #include <linux/blkdev.h> | ||
6 | #include <linux/device.h> | ||
7 | #include <linux/kernel.h> | ||
8 | |||
9 | #include <scsi/scsi.h> | ||
10 | #include <scsi/scsi_cmnd.h> | ||
11 | #include <scsi/scsi_device.h> | ||
12 | #include <scsi/scsi_host.h> | ||
13 | |||
14 | /** | ||
15 | * scsi_dma_map - perform DMA mapping against command's sg lists | ||
16 | * @cmd: scsi command | ||
17 | * | ||
18 | * Returns the number of sg lists actually used, zero if the sg lists | ||
19 | * is NULL, or -ENOMEM if the mapping failed. | ||
20 | */ | ||
21 | int scsi_dma_map(struct scsi_cmnd *cmd) | ||
22 | { | ||
23 | int nseg = 0; | ||
24 | |||
25 | if (scsi_sg_count(cmd)) { | ||
26 | struct device *dev = cmd->device->host->shost_gendev.parent; | ||
27 | |||
28 | nseg = dma_map_sg(dev, scsi_sglist(cmd), scsi_sg_count(cmd), | ||
29 | cmd->sc_data_direction); | ||
30 | if (unlikely(!nseg)) | ||
31 | return -ENOMEM; | ||
32 | } | ||
33 | return nseg; | ||
34 | } | ||
35 | EXPORT_SYMBOL(scsi_dma_map); | ||
36 | |||
37 | /** | ||
38 | * scsi_dma_unmap - unmap command's sg lists mapped by scsi_dma_map | ||
39 | * @cmd: scsi command | ||
40 | */ | ||
41 | void scsi_dma_unmap(struct scsi_cmnd *cmd) | ||
42 | { | ||
43 | if (scsi_sg_count(cmd)) { | ||
44 | struct device *dev = cmd->device->host->shost_gendev.parent; | ||
45 | |||
46 | dma_unmap_sg(dev, scsi_sglist(cmd), scsi_sg_count(cmd), | ||
47 | cmd->sc_data_direction); | ||
48 | } | ||
49 | } | ||
50 | EXPORT_SYMBOL(scsi_dma_unmap); | ||