mirror of
				https://git.kernel.org/pub/scm/linux/kernel/git/chenhuacai/linux-loongson
				synced 2025-10-26 22:38:34 +00:00 
			
		
		
		
	 b5ee900258
			
		
	
	
		b5ee900258
		
	
	
	
	
		
			
			Let's provide an overridable default instead of having every machine class define __virt_to_bus and __bus_to_virt to the same thing. What most platforms are using is bus_addr == phys_addr so such is the default. One exception is ebsa110 which has no DMA what so ever, so the actual definition is not important except only for proper compilation. Also added a comment about the special footbridge bus translation. Let's also remove comments alluding to set_dma_addr which is not (and should not) be commonly used. Signed-off-by: Nicolas Pitre <nico@marvell.com> Signed-off-by: Russell King <rmk+kernel@arm.linux.org.uk>
		
			
				
	
	
		
			79 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			79 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  *  arch/arm/mach-clps711x/include/mach/memory.h
 | |
|  *
 | |
|  *  Copyright (C) 1999 ARM Limited
 | |
|  *
 | |
|  * This program is free software; you can redistribute it and/or modify
 | |
|  * it under the terms of the GNU General Public License as published by
 | |
|  * the Free Software Foundation; either version 2 of the License, or
 | |
|  * (at your option) any later version.
 | |
|  *
 | |
|  * This program is distributed in the hope that it will be useful,
 | |
|  * but WITHOUT ANY WARRANTY; without even the implied warranty of
 | |
|  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | |
|  * GNU General Public License for more details.
 | |
|  *
 | |
|  * You should have received a copy of the GNU General Public License
 | |
|  * along with this program; if not, write to the Free Software
 | |
|  * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
 | |
|  */
 | |
| #ifndef __ASM_ARCH_MEMORY_H
 | |
| #define __ASM_ARCH_MEMORY_H
 | |
| 
 | |
| 
 | |
| /*
 | |
|  * Physical DRAM offset.
 | |
|  */
 | |
| #define PHYS_OFFSET	UL(0xc0000000)
 | |
| 
 | |
| #if !defined(CONFIG_ARCH_CDB89712) && !defined (CONFIG_ARCH_AUTCPU12)
 | |
| 
 | |
| #define __virt_to_bus(x)	((x) - PAGE_OFFSET)
 | |
| #define __bus_to_virt(x)	((x) + PAGE_OFFSET)
 | |
| 
 | |
| #endif
 | |
| 
 | |
| 
 | |
| /*
 | |
|  * Like the SA1100, the EDB7211 has a large gap between physical RAM
 | |
|  * banks.  In 2.2, the Psion (CL-PS7110) port added custom support for
 | |
|  * discontiguous physical memory.  In 2.4, we can use the standard
 | |
|  * Linux NUMA support.
 | |
|  *
 | |
|  * This is not necessary for EP7211 implementations with only one used
 | |
|  * memory bank.  For those systems, simply undefine CONFIG_DISCONTIGMEM.
 | |
|  */
 | |
| 
 | |
| /*
 | |
|  * The PS7211 allows up to 256MB max per DRAM bank, but the EDB7211
 | |
|  * uses only one of the two banks (bank #1).  However, even within
 | |
|  * bank #1, memory is discontiguous.
 | |
|  *
 | |
|  * The EDB7211 has two 8MB DRAM areas with 8MB of empty space between
 | |
|  * them, so we use 24 for the node max shift to get 16MB node sizes.
 | |
|  */
 | |
| 
 | |
| /*
 | |
|  * Because of the wide memory address space between physical RAM banks on the 
 | |
|  * SA1100, it's much more convenient to use Linux's NUMA support to implement
 | |
|  * our memory map representation.  Assuming all memory nodes have equal access 
 | |
|  * characteristics, we then have generic discontiguous memory support.
 | |
|  *
 | |
|  * Of course, all this isn't mandatory for SA1100 implementations with only
 | |
|  * one used memory bank.  For those, simply undefine CONFIG_DISCONTIGMEM.
 | |
|  *
 | |
|  * The nodes are matched with the physical memory bank addresses which are 
 | |
|  * incidentally the same as virtual addresses.
 | |
|  * 
 | |
|  * 	node 0:  0xc0000000 - 0xc7ffffff
 | |
|  * 	node 1:  0xc8000000 - 0xcfffffff
 | |
|  * 	node 2:  0xd0000000 - 0xd7ffffff
 | |
|  * 	node 3:  0xd8000000 - 0xdfffffff
 | |
|  */
 | |
| #define NODE_MEM_SIZE_BITS	24
 | |
| #define SECTION_SIZE_BITS	24
 | |
| #define MAX_PHYSMEM_BITS	32
 | |
| 
 | |
| #endif
 | |
| 
 |