| 
									
										
										
										
											2005-07-27 11:44:40 -07:00
										 |  |  | /* DMA mapping. Nothing tricky here, just virt_to_phys */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | #ifndef _ASM_CRIS_DMA_MAPPING_H
 | 
					
						
							|  |  |  | #define _ASM_CRIS_DMA_MAPPING_H
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-07-27 11:44:40 -07:00
										 |  |  | #include <linux/mm.h>
 | 
					
						
							|  |  |  | #include <linux/kernel.h>
 | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-07-27 11:44:40 -07:00
										 |  |  | #include <asm/cache.h>
 | 
					
						
							|  |  |  | #include <asm/io.h>
 | 
					
						
							|  |  |  | #include <asm/scatterlist.h>
 | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-07-27 11:44:40 -07:00
										 |  |  | #define dma_alloc_noncoherent(d, s, h, f) dma_alloc_coherent(d, s, h, f)
 | 
					
						
							|  |  |  | #define dma_free_noncoherent(d, s, v, h) dma_free_coherent(d, s, v, h)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef CONFIG_PCI
 | 
					
						
							| 
									
										
										
										
											2008-07-20 15:00:32 +04:00
										 |  |  | #include <asm-generic/dma-coherent.h>
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-07-27 11:44:40 -07:00
										 |  |  | void *dma_alloc_coherent(struct device *dev, size_t size, | 
					
						
							| 
									
										
										
										
											2005-10-21 03:21:13 -04:00
										 |  |  | 			   dma_addr_t *dma_handle, gfp_t flag); | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-07-27 11:44:40 -07:00
										 |  |  | void dma_free_coherent(struct device *dev, size_t size, | 
					
						
							|  |  |  | 			 void *vaddr, dma_addr_t dma_handle); | 
					
						
							|  |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | static inline void * | 
					
						
							|  |  |  | dma_alloc_coherent(struct device *dev, size_t size, dma_addr_t *dma_handle, | 
					
						
							| 
									
										
										
										
											2005-10-21 03:21:13 -04:00
										 |  |  |                    gfp_t flag) | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2005-07-27 11:44:40 -07:00
										 |  |  |         BUG(); | 
					
						
							|  |  |  |         return NULL; | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static inline void | 
					
						
							|  |  |  | dma_free_coherent(struct device *dev, size_t size, void *cpu_addr, | 
					
						
							| 
									
										
										
										
											2005-07-27 11:44:40 -07:00
										 |  |  |                     dma_addr_t dma_handle) | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2005-07-27 11:44:40 -07:00
										 |  |  |         BUG(); | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2005-07-27 11:44:40 -07:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | static inline dma_addr_t | 
					
						
							| 
									
										
										
										
											2005-07-27 11:44:40 -07:00
										 |  |  | dma_map_single(struct device *dev, void *ptr, size_t size, | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 	       enum dma_data_direction direction) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2005-07-27 11:44:40 -07:00
										 |  |  | 	BUG_ON(direction == DMA_NONE); | 
					
						
							|  |  |  | 	return virt_to_phys(ptr); | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static inline void | 
					
						
							|  |  |  | dma_unmap_single(struct device *dev, dma_addr_t dma_addr, size_t size, | 
					
						
							|  |  |  | 		 enum dma_data_direction direction) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2005-07-27 11:44:40 -07:00
										 |  |  | 	BUG_ON(direction == DMA_NONE); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static inline int | 
					
						
							|  |  |  | dma_map_sg(struct device *dev, struct scatterlist *sg, int nents, | 
					
						
							|  |  |  | 	   enum dma_data_direction direction) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	printk("Map sg\n"); | 
					
						
							|  |  |  | 	return nents; | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static inline dma_addr_t | 
					
						
							| 
									
										
										
										
											2005-07-27 11:44:40 -07:00
										 |  |  | dma_map_page(struct device *dev, struct page *page, unsigned long offset, | 
					
						
							|  |  |  | 	     size_t size, enum dma_data_direction direction) | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2005-07-27 11:44:40 -07:00
										 |  |  | 	BUG_ON(direction == DMA_NONE); | 
					
						
							|  |  |  | 	return page_to_phys(page) + offset; | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static inline void | 
					
						
							|  |  |  | dma_unmap_page(struct device *dev, dma_addr_t dma_address, size_t size, | 
					
						
							|  |  |  | 	       enum dma_data_direction direction) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2005-07-27 11:44:40 -07:00
										 |  |  | 	BUG_ON(direction == DMA_NONE); | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static inline void | 
					
						
							|  |  |  | dma_unmap_sg(struct device *dev, struct scatterlist *sg, int nhwentries, | 
					
						
							|  |  |  | 	     enum dma_data_direction direction) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2005-07-27 11:44:40 -07:00
										 |  |  | 	BUG_ON(direction == DMA_NONE); | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static inline void | 
					
						
							| 
									
										
										
										
											2005-07-27 11:44:40 -07:00
										 |  |  | dma_sync_single_for_cpu(struct device *dev, dma_addr_t dma_handle, size_t size, | 
					
						
							|  |  |  | 			enum dma_data_direction direction) | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | { | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static inline void | 
					
						
							| 
									
										
										
										
											2005-07-27 11:44:40 -07:00
										 |  |  | dma_sync_single_for_device(struct device *dev, dma_addr_t dma_handle, size_t size, | 
					
						
							|  |  |  | 			enum dma_data_direction direction) | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | { | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-07-27 11:44:40 -07:00
										 |  |  | static inline 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) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-07-27 11:44:40 -07:00
										 |  |  | static inline 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) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-07-27 11:44:40 -07:00
										 |  |  | static inline void | 
					
						
							|  |  |  | dma_sync_sg_for_cpu(struct device *dev, struct scatterlist *sg, int nelems, | 
					
						
							|  |  |  | 		    enum dma_data_direction direction) | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | { | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static inline void | 
					
						
							| 
									
										
										
										
											2005-07-27 11:44:40 -07:00
										 |  |  | dma_sync_sg_for_device(struct device *dev, struct scatterlist *sg, int nelems, | 
					
						
							|  |  |  | 		    enum dma_data_direction direction) | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | { | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-07-27 11:44:40 -07:00
										 |  |  | static inline int | 
					
						
							| 
									
										
										
										
											2008-07-25 19:44:49 -07:00
										 |  |  | dma_mapping_error(struct device *dev, dma_addr_t dma_addr) | 
					
						
							| 
									
										
										
										
											2005-07-27 11:44:40 -07:00
										 |  |  | { | 
					
						
							|  |  |  | 	return 0; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static inline int | 
					
						
							|  |  |  | dma_supported(struct device *dev, u64 mask) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |         /*
 | 
					
						
							|  |  |  |          * we fall back to GFP_DMA when the mask isn't all 1s, | 
					
						
							|  |  |  |          * so we can't guarantee allocations that must be | 
					
						
							|  |  |  |          * within a tighter range than GFP_DMA.. | 
					
						
							|  |  |  |          */ | 
					
						
							|  |  |  |         if(mask < 0x00ffffff) | 
					
						
							|  |  |  |                 return 0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return 1; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 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; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | static inline void | 
					
						
							| 
									
										
										
										
											2006-12-06 20:38:56 -08:00
										 |  |  | dma_cache_sync(struct device *dev, void *vaddr, size_t size, | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 	       enum dma_data_direction direction) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-01-27 09:33:23 +00:00
										 |  |  | /* drivers/base/dma-mapping.c */ | 
					
						
							|  |  |  | extern int dma_common_mmap(struct device *dev, struct vm_area_struct *vma, | 
					
						
							|  |  |  | 			   void *cpu_addr, dma_addr_t dma_addr, size_t size); | 
					
						
							|  |  |  | extern int dma_common_get_sgtable(struct device *dev, struct sg_table *sgt, | 
					
						
							|  |  |  | 				  void *cpu_addr, dma_addr_t dma_addr, | 
					
						
							|  |  |  | 				  size_t size); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define dma_mmap_coherent(d, v, c, h, s) dma_common_mmap(d, v, c, h, s)
 | 
					
						
							|  |  |  | #define dma_get_sgtable(d, t, v, h, s) dma_common_get_sgtable(d, t, v, h, s)
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-07-27 11:44:40 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | #endif
 |