mirror of
				https://git.kernel.org/pub/scm/linux/kernel/git/chenhuacai/linux-loongson
				synced 2025-10-25 08:33:37 +00:00 
			
		
		
		
	 5b9eda3313
			
		
	
	
		5b9eda3313
		
	
	
	
	
		
			
			There are two 64 MB outbound memory windows at bus addresses 0x80000000..0x83ffffff and 0x84000000..0x87ffffff for PCI memory. Currently, on iop32x, only the lower window is available for allocations, limiting the available space to 64 MB. On iop33x the full 128 MB can be allocated, but the translation value is wrong for the upper window. The patch enables the full 128 MB space on iop32x and corrects the initialization of OMWTVR1. Redundant definitions are deleted. Tested using a Thecus N2100 board with a graphics adapter in the expansion slot. Both windows are in use: 00:05.0 VGA compatible controller: XGI Technology Inc. (eXtreme Graphics Innovation) Volari Z7 (prog-if 00 [VGA controller]) [...] Region 0: Memory at 80000000 (32-bit, prefetchable) [size=64M] Region 1: Memory at 84080000 (32-bit, non-prefetchable) [size=256K] Signed-off-by: Aaro Koskinen <aaro.koskinen@iki.fi> Cc: Lennert Buytenhek <kernel@wantstofly.org> Signed-off-by: Dan Williams <dan.j.williams@intel.com>
		
			
				
	
	
		
			36 lines
		
	
	
		
			1018 B
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			36 lines
		
	
	
		
			1018 B
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  * arch/arm/mach-iop32x/include/mach/iop32x.h
 | |
|  *
 | |
|  * Intel IOP32X Chip definitions
 | |
|  *
 | |
|  * Author: Rory Bolt <rorybolt@pacbell.net>
 | |
|  * Copyright (C) 2002 Rory Bolt
 | |
|  * Copyright (C) 2004 Intel Corp.
 | |
|  *
 | |
|  * 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 __IOP32X_H
 | |
| #define __IOP32X_H
 | |
| 
 | |
| /*
 | |
|  * Peripherals that are shared between the iop32x and iop33x but
 | |
|  * located at different addresses.
 | |
|  */
 | |
| #define IOP3XX_GPIO_REG(reg)	(IOP3XX_PERIPHERAL_VIRT_BASE + 0x07c4 + (reg))
 | |
| #define IOP3XX_TIMER_REG(reg)	(IOP3XX_PERIPHERAL_VIRT_BASE + 0x07e0 + (reg))
 | |
| 
 | |
| #include <asm/hardware/iop3xx.h>
 | |
| 
 | |
| /* ATU Parameters
 | |
|  * set up a 1:1 bus to physical ram relationship
 | |
|  * w/ physical ram on top of pci in the memory map
 | |
|  */
 | |
| #define IOP32X_MAX_RAM_SIZE            0x40000000UL
 | |
| #define IOP3XX_MAX_RAM_SIZE            IOP32X_MAX_RAM_SIZE
 | |
| #define IOP3XX_PCI_LOWER_MEM_BA        0x80000000
 | |
| 
 | |
| #endif
 |