2005-04-16 15:20:36 -07:00
# ifndef _ASM_DMA_MAPPING_H
# define _ASM_DMA_MAPPING_H
# include <asm/scatterlist.h>
# include <asm/cache.h>
void * dma_alloc_noncoherent ( struct device * dev , size_t size ,
2005-10-21 03:21:23 -04:00
dma_addr_t * dma_handle , gfp_t flag ) ;
2005-04-16 15:20:36 -07:00
void dma_free_noncoherent ( struct device * dev , size_t size ,
void * vaddr , dma_addr_t dma_handle ) ;
void * dma_alloc_coherent ( struct device * dev , size_t size ,
2005-10-21 03:21:23 -04:00
dma_addr_t * dma_handle , gfp_t flag ) ;
2005-04-16 15:20:36 -07:00
void dma_free_coherent ( struct device * dev , size_t size ,
void * vaddr , dma_addr_t dma_handle ) ;
extern dma_addr_t dma_map_single ( struct device * dev , void * ptr , size_t size ,
enum dma_data_direction direction ) ;
extern void dma_unmap_single ( struct device * dev , dma_addr_t dma_addr ,
size_t size , enum dma_data_direction direction ) ;
extern int dma_map_sg ( struct device * dev , struct scatterlist * sg , int nents ,
enum dma_data_direction direction ) ;
extern dma_addr_t dma_map_page ( struct device * dev , struct page * page ,
unsigned long offset , size_t size , enum dma_data_direction direction ) ;
extern void dma_unmap_page ( struct device * dev , dma_addr_t dma_address ,
size_t size , enum dma_data_direction direction ) ;
extern void dma_unmap_sg ( struct device * dev , struct scatterlist * sg ,
int nhwentries , enum dma_data_direction direction ) ;
extern void dma_sync_single_for_cpu ( struct device * dev , dma_addr_t dma_handle ,
size_t size , enum dma_data_direction direction ) ;
extern void dma_sync_single_for_device ( struct device * dev ,
dma_addr_t dma_handle , size_t size , enum dma_data_direction direction ) ;
extern void dma_sync_single_range_for_cpu ( struct device * dev ,
dma_addr_t dma_handle , unsigned long offset , size_t size ,
enum dma_data_direction direction ) ;
extern void dma_sync_single_range_for_device ( struct device * dev ,
dma_addr_t dma_handle , unsigned long offset , size_t size ,
enum dma_data_direction direction ) ;
extern void dma_sync_sg_for_cpu ( struct device * dev , struct scatterlist * sg ,
int nelems , enum dma_data_direction direction ) ;
extern void dma_sync_sg_for_device ( struct device * dev , struct scatterlist * sg ,
int nelems , enum dma_data_direction direction ) ;
extern int dma_mapping_error ( dma_addr_t dma_addr ) ;
extern int dma_supported ( struct device * dev , u64 mask ) ;
static inline int
dma_set_mask ( struct device * dev , u64 mask )
{
if ( ! dev - > dma_mask | | ! dma_supported ( dev , mask ) )
return - EIO ;
* dev - > dma_mask = mask ;
return 0 ;
}
static inline int
dma_get_cache_alignment ( void )
{
/* XXX Largest on any MIPS */
return 128 ;
}
2006-12-06 20:38:54 -08:00
extern int dma_is_consistent ( struct device * dev , dma_addr_t dma_addr ) ;
2005-04-16 15:20:36 -07:00
2006-12-06 20:38:56 -08:00
extern void dma_cache_sync ( struct device * dev , void * vaddr , size_t size ,
2005-04-16 15:20:36 -07:00
enum dma_data_direction direction ) ;
2007-02-12 22:22:53 +00:00
#if 0
2005-04-16 15:20:36 -07:00
# define ARCH_HAS_DMA_DECLARE_COHERENT_MEMORY
extern int dma_declare_coherent_memory ( struct device * dev , dma_addr_t bus_addr ,
dma_addr_t device_addr , size_t size , int flags ) ;
extern void dma_release_declared_memory ( struct device * dev ) ;
extern void * dma_mark_declared_memory_occupied ( struct device * dev ,
dma_addr_t device_addr , size_t size ) ;
2007-02-12 22:22:53 +00:00
# endif
2005-04-16 15:20:36 -07:00
# endif /* _ASM_DMA_MAPPING_H */