Blame view

drivers/scsi/scsi_lib_dma.c 1.16 KB
81f7e3824   Eric Lee   Initial Release, ...
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
  // SPDX-License-Identifier: GPL-2.0
  /*
   * SCSI library functions depending on DMA
   */
  
  #include <linux/blkdev.h>
  #include <linux/device.h>
  #include <linux/export.h>
  #include <linux/kernel.h>
  
  #include <scsi/scsi.h>
  #include <scsi/scsi_cmnd.h>
  #include <scsi/scsi_device.h>
  #include <scsi/scsi_host.h>
  
  /**
   * scsi_dma_map - perform DMA mapping against command's sg lists
   * @cmd:	scsi command
   *
   * Returns the number of sg lists actually used, zero if the sg lists
   * is NULL, or -ENOMEM if the mapping failed.
   */
  int scsi_dma_map(struct scsi_cmnd *cmd)
  {
  	int nseg = 0;
  
  	if (scsi_sg_count(cmd)) {
  		struct device *dev = cmd->device->host->dma_dev;
  
  		nseg = dma_map_sg(dev, scsi_sglist(cmd), scsi_sg_count(cmd),
  				  cmd->sc_data_direction);
  		if (unlikely(!nseg))
  			return -ENOMEM;
  	}
  	return nseg;
  }
  EXPORT_SYMBOL(scsi_dma_map);
  
  /**
   * scsi_dma_unmap - unmap command's sg lists mapped by scsi_dma_map
   * @cmd:	scsi command
   */
  void scsi_dma_unmap(struct scsi_cmnd *cmd)
  {
  	if (scsi_sg_count(cmd)) {
  		struct device *dev = cmd->device->host->dma_dev;
  
  		dma_unmap_sg(dev, scsi_sglist(cmd), scsi_sg_count(cmd),
  			     cmd->sc_data_direction);
  	}
  }
  EXPORT_SYMBOL(scsi_dma_unmap);