| /* |
| * Copyright (C) 2004, 2007-2010, 2011-2012 Synopsys, Inc. (www.synopsys.com) |
| * |
| * This program is free software; you can redistribute it and/or modify |
| * it under the terms of the GNU General Public License version 2 as |
| * published by the Free Software Foundation. |
| */ |
| |
| #ifndef _ARC_SCATTERLIST_H |
| #define _ARC_SCATTERLIST_H |
| |
| #include <asm/types.h> |
| |
| struct scatterlist { |
| #ifdef CONFIG_DEBUG_SG |
| unsigned long sg_magic; |
| #endif |
| unsigned long page_link; |
| unsigned int offset; /* buffer offset */ |
| dma_addr_t dma_address; /* dma address */ |
| unsigned int length; /* length */ |
| }; |
| |
| /* |
| * 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) |
| |
| #define ISA_DMA_THRESHOLD (0x00ffffffUL) |
| #endif /* _ARC_SCATTERLIST_H */ |