blob: 35ef9c30f0dec8338da7398edc3a716510fdbee0 [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001#ifndef __ASM_SH_SCATTERLIST_H
2#define __ASM_SH_SCATTERLIST_H
3
Stuart Menefyd02b08f2007-11-30 17:52:53 +09004#include <asm/pgtable.h>
Jean Delvarea9dfd282007-03-06 02:45:12 -08005#include <asm/types.h>
6
Linus Torvalds1da177e2005-04-16 15:20:36 -07007struct scatterlist {
Jens Axboed6ec0842007-10-22 20:01:06 +02008#ifdef CONFIG_DEBUG_SG
9 unsigned long sg_magic;
10#endif
Jens Axboe18dabf42007-10-22 19:57:20 +020011 unsigned long page_link;
Linus Torvalds1da177e2005-04-16 15:20:36 -070012 unsigned int offset;/* for highmem, page offset */
13 dma_addr_t dma_address;
14 unsigned int length;
15};
16
Stuart Menefyd02b08f2007-11-30 17:52:53 +090017#define ISA_DMA_THRESHOLD PHYS_ADDR_MASK
Linus Torvalds1da177e2005-04-16 15:20:36 -070018
Paul Mundt634bf4f2006-09-27 14:48:09 +090019/* These macros should be used after a pci_map_sg call has been done
20 * to get bus addresses of each of the SG entries and their lengths.
21 * You should only work with the number of sg entries pci_map_sg
22 * returns, or alternatively stop on the first sg_dma_len(sg) which
23 * is 0.
24 */
25#define sg_dma_address(sg) ((sg)->dma_address)
26#define sg_dma_len(sg) ((sg)->length)
27
Linus Torvalds1da177e2005-04-16 15:20:36 -070028#endif /* !(__ASM_SH_SCATTERLIST_H) */