2005-04-16 15:20:36 -07:00
# ifndef _ASM_SCATTERLIST_H
# define _ASM_SCATTERLIST_H
2007-03-06 02:45:12 -08:00
# include <asm/types.h>
2005-04-16 15:20:36 -07:00
/*
2007-10-23 12:39:41 +02:00
* Drivers must set either - > address or ( preferred ) page and - > offset
2005-04-16 15:20:36 -07:00
* to indicate where data must be transferred to / from .
*
2007-10-23 12:39:41 +02:00
* Using page is recommended since it handles highmem data as well as
2005-04-16 15:20:36 -07:00
* low mem . - > address is restricted to data which has a virtual mapping , and
2007-10-23 12:39:41 +02:00
* it will go away in the future . Updating to page can be automated very
2005-04-16 15:20:36 -07:00
* easily - - something like
*
* sg - > address = some_ptr ;
*
* can be rewritten as
*
2007-10-24 11:20:47 +02:00
* sg_set_buf ( sg , some_ptr , length ) ;
2005-04-16 15:20:36 -07:00
*
* and that ' s it . There ' s no excuse for not highmem enabling YOUR driver . / jens
*/
struct scatterlist {
2007-10-22 20:01:06 +02:00
# ifdef CONFIG_DEBUG_SG
unsigned long sg_magic ;
# endif
2007-10-22 19:57:20 +02:00
unsigned long page_link ;
2005-04-16 15:20:36 -07:00
unsigned int offset ; /* for highmem, page offset */
dma_addr_t dma_address ;
unsigned int length ;
} ;
2008-02-04 22:29:54 -08:00
/*
* These macros should be used after a pci_map_sg call has been done
* to get bus addresses of each of the SG entries and their lengths .
* You should only work with the number of sg entries pci_map_sg
* returns , or alternatively stop on the first sg_dma_len ( sg ) which
* is 0.
*/
# define sg_dma_address(sg) ((sg)->dma_address)
# define sg_dma_len(sg) ((sg)->length)
2005-04-16 15:20:36 -07:00
# define ISA_DMA_THRESHOLD (0xffffffffUL)
# endif /* !_ASM_SCATTERLIST_H */