blob: bc7c809e16fbe7f6ede7717c2edfd2c01eb536ff [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001#ifndef __ASM_SH_SCATTERLIST_H
2#define __ASM_SH_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 Axboe18dabf42007-10-22 19:57:20 +02007 unsigned long page_link;
Linus Torvalds1da177e2005-04-16 15:20:36 -07008 unsigned int offset;/* for highmem, page offset */
9 dma_addr_t dma_address;
10 unsigned int length;
11};
12
13#define ISA_DMA_THRESHOLD (0x1fffffff)
14
Paul Mundt634bf4f2006-09-27 14:48:09 +090015/* These macros should be used after a pci_map_sg call has been done
16 * to get bus addresses of each of the SG entries and their lengths.
17 * You should only work with the number of sg entries pci_map_sg
18 * returns, or alternatively stop on the first sg_dma_len(sg) which
19 * is 0.
20 */
21#define sg_dma_address(sg) ((sg)->dma_address)
22#define sg_dma_len(sg) ((sg)->length)
23
Linus Torvalds1da177e2005-04-16 15:20:36 -070024#endif /* !(__ASM_SH_SCATTERLIST_H) */