blob: 1847c72befeb9aca69a3402c6a243c001b728c20 [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001#ifndef _X8664_SCATTERLIST_H
2#define _X8664_SCATTERLIST_H
3
Jean Delvarea9dfd282007-03-06 02:45:12 -08004#include <asm/types.h>
5
Linus Torvalds1da177e2005-04-16 15:20:36 -07006struct scatterlist {
Jens Axboed6ec0842007-10-22 20:01:06 +02007#ifdef CONFIG_DEBUG_SG
8 unsigned long sg_magic;
9#endif
Jens Axboe18dabf42007-10-22 19:57:20 +020010 unsigned long page_link;
Linus Torvalds1da177e2005-04-16 15:20:36 -070011 unsigned int offset;
12 unsigned int length;
13 dma_addr_t dma_address;
14 unsigned int dma_length;
15};
16
Jens Axboe46856af2007-05-10 11:59:55 +020017#define ARCH_HAS_SG_CHAIN
18
Linus Torvalds1da177e2005-04-16 15:20:36 -070019#define ISA_DMA_THRESHOLD (0x00ffffff)
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)
27#define sg_dma_len(sg) ((sg)->dma_length)
28
29#endif