| Arnd Bergmann | aafe4db | 2009-05-13 22:56:33 +0000 | [diff] [blame] | 1 | #ifndef __ASM_GENERIC_SCATTERLIST_H | 
 | 2 | #define __ASM_GENERIC_SCATTERLIST_H | 
 | 3 |  | 
 | 4 | #include <linux/types.h> | 
 | 5 |  | 
 | 6 | struct scatterlist { | 
 | 7 | #ifdef CONFIG_DEBUG_SG | 
 | 8 | 	unsigned long	sg_magic; | 
 | 9 | #endif | 
 | 10 | 	unsigned long	page_link; | 
 | 11 | 	unsigned int	offset; | 
 | 12 | 	unsigned int	length; | 
 | 13 | 	dma_addr_t	dma_address; | 
 | 14 | 	unsigned int	dma_length; | 
 | 15 | }; | 
 | 16 |  | 
 | 17 | /* | 
 | 18 |  * These macros should be used after a dma_map_sg call has been done | 
 | 19 |  * to get bus addresses of each of the SG entries and their lengths. | 
 | 20 |  * You should only work with the number of sg entries pci_map_sg | 
 | 21 |  * returns, or alternatively stop on the first sg_dma_len(sg) which | 
 | 22 |  * is 0. | 
 | 23 |  */ | 
 | 24 | #define sg_dma_address(sg)	((sg)->dma_address) | 
 | 25 | #ifndef sg_dma_len | 
 | 26 | /* | 
 | 27 |  * Normally, you have an iommu on 64 bit machines, but not on 32 bit | 
 | 28 |  * machines. Architectures that are differnt should override this. | 
 | 29 |  */ | 
 | 30 | #if __BITS_PER_LONG == 64 | 
 | 31 | #define sg_dma_len(sg)		((sg)->dma_length) | 
 | 32 | #else | 
 | 33 | #define sg_dma_len(sg)		((sg)->length) | 
 | 34 | #endif /* 64 bit */ | 
 | 35 | #endif /* sg_dma_len */ | 
 | 36 |  | 
 | 37 | #ifndef ISA_DMA_THRESHOLD | 
 | 38 | #define ISA_DMA_THRESHOLD	(~0UL) | 
 | 39 | #endif | 
 | 40 |  | 
 | 41 | #define ARCH_HAS_SG_CHAIN | 
 | 42 |  | 
 | 43 | #endif /* __ASM_GENERIC_SCATTERLIST_H */ |