| Thomas Gleixner | 3ebc51d | 2008-01-30 13:30:21 +0100 | [diff] [blame] | 1 | #ifndef _ASM_X86_SCATTERLIST_H | 
|  | 2 | #define _ASM_X86_SCATTERLIST_H | 
|  | 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 |  | 
| Thomas Gleixner | 96a388d | 2007-10-11 11:20:03 +0200 | [diff] [blame] | 33 | #endif |