| 
									
										
										
										
											2006-11-16 02:56:12 +00:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  * This file is subject to the terms and conditions of the GNU General Public | 
					
						
							|  |  |  |  * License.  See the file "COPYING" in the main directory of this archive | 
					
						
							|  |  |  |  * for more details. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Copyright (C) 2006  Ralf Baechle <ralf@linux-mips.org> | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2007-05-25 02:26:47 -04:00
										 |  |  | #ifndef __ASM_MACH_IP32_DMA_COHERENCE_H
 | 
					
						
							|  |  |  | #define __ASM_MACH_IP32_DMA_COHERENCE_H
 | 
					
						
							| 
									
										
										
										
											2006-11-16 02:56:12 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #include <asm/ip32/crime.h>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | struct device; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |  * Few notes. | 
					
						
							|  |  |  |  * 1. CPU sees memory as two chunks: 0-256M@0x0, and the rest @0x40000000+256M | 
					
						
							|  |  |  |  * 2. PCI sees memory as one big chunk @0x0 (or we could use 0x40000000 for | 
					
						
							|  |  |  |  *    native-endian) | 
					
						
							|  |  |  |  * 3. All other devices see memory as one big chunk at 0x40000000 | 
					
						
							|  |  |  |  * 4. Non-PCI devices will pass NULL as struct device* | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Thus we translate differently, depending on device. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define RAM_OFFSET_MASK 0x3fffffffUL
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-03-10 03:26:56 +00:00
										 |  |  | static inline dma_addr_t plat_map_dma_mem(struct device *dev, void *addr, | 
					
						
							|  |  |  | 	size_t size) | 
					
						
							| 
									
										
										
										
											2006-11-16 02:56:12 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	dma_addr_t pa = virt_to_phys(addr) & RAM_OFFSET_MASK; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (dev == NULL) | 
					
						
							|  |  |  | 		pa += CRIME_HI_MEM_BASE; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return pa; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-10-01 13:27:32 -07:00
										 |  |  | static inline dma_addr_t plat_map_dma_mem_page(struct device *dev, | 
					
						
							|  |  |  | 	struct page *page) | 
					
						
							| 
									
										
										
										
											2006-11-16 02:56:12 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	dma_addr_t pa; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	pa = page_to_phys(page) & RAM_OFFSET_MASK; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (dev == NULL) | 
					
						
							|  |  |  | 		pa += CRIME_HI_MEM_BASE; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return pa; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-01-22 12:59:30 +01:00
										 |  |  | /* This is almost certainly wrong but it's what dma-ip32.c used to use	*/ | 
					
						
							| 
									
										
										
										
											2010-10-01 13:27:31 -07:00
										 |  |  | static inline unsigned long plat_dma_addr_to_phys(struct device *dev, | 
					
						
							| 
									
										
										
										
											2009-04-23 17:25:12 -07:00
										 |  |  | 	dma_addr_t dma_addr) | 
					
						
							| 
									
										
										
										
											2006-11-16 02:56:12 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	unsigned long addr = dma_addr & RAM_OFFSET_MASK; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (dma_addr >= 256*1024*1024) | 
					
						
							|  |  |  | 		addr += CRIME_HI_MEM_BASE; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return addr; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-04-23 17:03:43 -07:00
										 |  |  | static inline void plat_unmap_dma_mem(struct device *dev, dma_addr_t dma_addr, | 
					
						
							|  |  |  | 	size_t size, enum dma_data_direction direction) | 
					
						
							| 
									
										
										
										
											2006-11-16 02:56:12 +00:00
										 |  |  | { | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-11 15:33:36 -08:00
										 |  |  | static inline int plat_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 < DMA_BIT_MASK(24)) | 
					
						
							|  |  |  | 		return 0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return 1; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-11-16 02:56:12 +00:00
										 |  |  | static inline int plat_device_is_coherent(struct device *dev) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	return 0;		/* IP32 is non-cohernet */ | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-05-25 02:26:47 -04:00
										 |  |  | #endif /* __ASM_MACH_IP32_DMA_COHERENCE_H */
 |