diff options
author | Christoph Hellwig <hch@infradead.org> | 2011-04-02 08:15:04 -0400 |
---|---|---|
committer | Dan Williams <dan.j.williams@intel.com> | 2011-07-03 07:00:37 -0400 |
commit | bc5c96748a5f2067193faa8131b2aa5f9775d309 (patch) | |
tree | 509dc1a4e1cd2859f9c521af6c41b0a955226bc2 /drivers/scsi/isci/host.h | |
parent | 524b5f723be8a1d966c1285d69810bc461f181c2 (diff) |
isci: simplify dma coherent allocation
Remove the insane infrastructure for preallocating coheren DMA regions,
and just allocate the memory where needed. This also gets rid of the
aligment adjustments given that Documentation/DMA-API-HOWTO.txt sais:
"The cpu return address and the DMA bus master address are both
guaranteed to be aligned to the smallest PAGE_SIZE order which
is greater than or equal to the requested size. This invariant
exists (for example) to guarantee that if you allocate a chunk
which is smaller than or equal to 64 kilobytes, the extent of the
buffer you receive will not cross a 64K boundary."
Signed-off-by: Christoph Hellwig <hch@lst.de>
[djbw: moved allocation from start to init, re-add memset]
Signed-off-by: Dan Williams <dan.j.williams@intel.com>
Diffstat (limited to 'drivers/scsi/isci/host.h')
-rw-r--r-- | drivers/scsi/isci/host.h | 9 |
1 files changed, 0 insertions, 9 deletions
diff --git a/drivers/scsi/isci/host.h b/drivers/scsi/isci/host.h index 8372094ef5ad..6e660744d8d4 100644 --- a/drivers/scsi/isci/host.h +++ b/drivers/scsi/isci/host.h | |||
@@ -75,14 +75,6 @@ | |||
75 | #define ISCI_CAN_QUEUE_VAL 250 /* < SCI_MAX_IO_REQUESTS ? */ | 75 | #define ISCI_CAN_QUEUE_VAL 250 /* < SCI_MAX_IO_REQUESTS ? */ |
76 | #define SCIC_CONTROLLER_STOP_TIMEOUT 5000 | 76 | #define SCIC_CONTROLLER_STOP_TIMEOUT 5000 |
77 | 77 | ||
78 | struct coherent_memory_info { | ||
79 | struct list_head node; | ||
80 | dma_addr_t dma_handle; | ||
81 | void *vaddr; | ||
82 | size_t size; | ||
83 | struct sci_physical_memory_descriptor *mde; | ||
84 | }; | ||
85 | |||
86 | struct isci_host { | 78 | struct isci_host { |
87 | struct scic_sds_controller *core_controller; | 79 | struct scic_sds_controller *core_controller; |
88 | union scic_oem_parameters oem_parameters; | 80 | union scic_oem_parameters oem_parameters; |
@@ -114,7 +106,6 @@ struct isci_host { | |||
114 | wait_queue_head_t eventq; | 106 | wait_queue_head_t eventq; |
115 | struct Scsi_Host *shost; | 107 | struct Scsi_Host *shost; |
116 | struct tasklet_struct completion_tasklet; | 108 | struct tasklet_struct completion_tasklet; |
117 | struct list_head mdl_struct_list; | ||
118 | struct list_head requests_to_complete; | 109 | struct list_head requests_to_complete; |
119 | struct list_head requests_to_errorback; | 110 | struct list_head requests_to_errorback; |
120 | spinlock_t scic_lock; | 111 | spinlock_t scic_lock; |