aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/scsi/scsi_lib_dma.c
diff options
context:
space:
mode:
authorCornelia Huck <cornelia.huck@de.ibm.com>2007-07-09 14:59:59 -0400
committerJames Bottomley <jejb@mulgrave.localdomain>2007-07-14 20:28:10 -0400
commit7689e82efdb636e8a076a1293b977bce313110c5 (patch)
tree3d8702ff24a205db7670ad5425e3a35fe45b0f00 /drivers/scsi/scsi_lib_dma.c
parent6d877688ef411313c94aa3c83c7473fbec6db32c (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.c50
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 */
21int 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}
35EXPORT_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 */
41void 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}
50EXPORT_SYMBOL(scsi_dma_unmap);