| Vegard Nossum | 77ef50a | 2008-06-18 17:08:48 +0200 | [diff] [blame] | 1 | #ifndef ASM_X86__SCATTERLIST_H | 
 | 2 | #define ASM_X86__SCATTERLIST_H | 
| Thomas Gleixner | 3ebc51d | 2008-01-30 13:30:21 +0100 | [diff] [blame] | 3 |  | 
 | 4 | #include <asm/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; | 
| Thomas Gleixner | 3ebc51d | 2008-01-30 13:30:21 +0100 | [diff] [blame] | 14 | 	unsigned int	dma_length; | 
| Thomas Gleixner | 3ebc51d | 2008-01-30 13:30:21 +0100 | [diff] [blame] | 15 | }; | 
 | 16 |  | 
 | 17 | #define ARCH_HAS_SG_CHAIN | 
 | 18 | #define ISA_DMA_THRESHOLD (0x00ffffff) | 
 | 19 |  | 
 | 20 | /* | 
 | 21 |  * These macros should be used after a pci_map_sg call has been done | 
 | 22 |  * to get bus addresses of each of the SG entries and their lengths. | 
 | 23 |  * You should only work with the number of sg entries pci_map_sg | 
 | 24 |  * returns. | 
 | 25 |  */ | 
 | 26 | #define sg_dma_address(sg)	((sg)->dma_address) | 
| Thomas Gleixner | 96a388d | 2007-10-11 11:20:03 +0200 | [diff] [blame] | 27 | #ifdef CONFIG_X86_32 | 
| Thomas Gleixner | 3ebc51d | 2008-01-30 13:30:21 +0100 | [diff] [blame] | 28 | # define sg_dma_len(sg)		((sg)->length) | 
| Thomas Gleixner | 96a388d | 2007-10-11 11:20:03 +0200 | [diff] [blame] | 29 | #else | 
| Thomas Gleixner | 3ebc51d | 2008-01-30 13:30:21 +0100 | [diff] [blame] | 30 | # define sg_dma_len(sg)		((sg)->dma_length) | 
 | 31 | #endif | 
 | 32 |  | 
| Vegard Nossum | 77ef50a | 2008-06-18 17:08:48 +0200 | [diff] [blame] | 33 | #endif /* ASM_X86__SCATTERLIST_H */ |