mirror of
				https://github.com/smaeul/u-boot.git
				synced 2025-10-22 16:48:14 +01:00 
			
		
		
		
	There was a mix of UTF-8 and ISO-8859 files in the U-Boot source tree, which could cause issues with the patchwork review system. This commit converts all ISO-8859 files to UTF-8. Signed-off-by: Albert ARIBAUD <albert.u.boot@aribaud.net>
		
			
				
	
	
		
			1391 lines
		
	
	
		
			49 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			1391 lines
		
	
	
		
			49 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  * Copyright - Galileo technology.
 | |
|  *
 | |
|  * See file CREDITS for list of people who contributed to this
 | |
|  * project.
 | |
|  *
 | |
|  * 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
 | |
|  */
 | |
| 
 | |
| /*
 | |
|  *
 | |
|  * written or collected and sometimes rewritten by
 | |
|  * Ingo Assmus <ingo.assmus@keymile.com>
 | |
|  *
 | |
|  */
 | |
| 
 | |
| 
 | |
| #include <common.h>
 | |
| #include "../include/core.h"
 | |
| #include "../include/memory.h"
 | |
| 
 | |
| /*******************************************************************************
 | |
| * memoryGetBankBaseAddress - Returns the base address of a memory bank.
 | |
| * DESCRIPTION:
 | |
| *       This function returns the base address of one of the SDRAM's memory
 | |
| *       banks. There are 4 memory banks and each one represents one DIMM side.
 | |
| * INPUT:
 | |
| *       MEMORY_BANK bank - Selects one of the four banks as defined in Memory.h.
 | |
| * OUTPUT:
 | |
| *       None.
 | |
| * RETURN:
 | |
| *       32 bit Memory bank base address.
 | |
| *******************************************************************************/
 | |
| static unsigned long memoryGetBankRegOffset (MEMORY_BANK bank)
 | |
| {
 | |
| 	switch (bank) {
 | |
| 	case BANK0:
 | |
| 		return SCS_0_LOW_DECODE_ADDRESS;
 | |
| 	case BANK1:
 | |
| 		return SCS_1_LOW_DECODE_ADDRESS;
 | |
| 	case BANK2:
 | |
| 		return SCS_2_LOW_DECODE_ADDRESS;
 | |
| 	case BANK3:
 | |
| 		return SCS_3_LOW_DECODE_ADDRESS;
 | |
| 
 | |
| 	}
 | |
| 	return SCS_0_LOW_DECODE_ADDRESS;	/* default value */
 | |
| }
 | |
| 
 | |
| unsigned int memoryGetBankBaseAddress (MEMORY_BANK bank)
 | |
| {
 | |
| 	unsigned int base;
 | |
| 	unsigned int regOffset = memoryGetBankRegOffset (bank);
 | |
| 
 | |
| 	GT_REG_READ (regOffset, &base);
 | |
| 	base = base << 16;	/* MV6436x */
 | |
| 	return base;
 | |
| }
 | |
| 
 | |
| /*******************************************************************************
 | |
| * memoryGetDeviceBaseAddress - Returns the base address of a device.
 | |
| * DESCRIPTION:
 | |
| *       This function returns the base address of a device on the system. There
 | |
| *       are 5 possible devices (0 - 4 and one boot device) as defined in
 | |
| *       gtMemory.h. Each of the device parameters is maped to one of the CS
 | |
| *       (Devices chip selects) base address register.
 | |
| * INPUT:
 | |
| *       device - Selects one of the five devices as defined in Memory.h.
 | |
| * OUTPUT:
 | |
| *       None.
 | |
| * RETURN:
 | |
| *       32 bit Device base address.
 | |
| *
 | |
| *******************************************************************************/
 | |
| static unsigned int memoryGetDeviceRegOffset (DEVICE device)
 | |
| {
 | |
| 	switch (device) {
 | |
| 	case DEVICE0:
 | |
| 		return CS_0_LOW_DECODE_ADDRESS;
 | |
| 	case DEVICE1:
 | |
| 		return CS_1_LOW_DECODE_ADDRESS;
 | |
| 	case DEVICE2:
 | |
| 		return CS_2_LOW_DECODE_ADDRESS;
 | |
| 	case DEVICE3:
 | |
| 		return CS_3_LOW_DECODE_ADDRESS;
 | |
| 	case BOOT_DEVICE:
 | |
| 		return BOOTCS_LOW_DECODE_ADDRESS;
 | |
| 	}
 | |
| 	return CS_0_LOW_DECODE_ADDRESS;	/* default value */
 | |
| }
 | |
| 
 | |
| unsigned int memoryGetDeviceBaseAddress (DEVICE device)
 | |
| {
 | |
| 	unsigned int regBase;
 | |
| 	unsigned int regOffset = memoryGetDeviceRegOffset (device);
 | |
| 
 | |
| 	GT_REG_READ (regOffset, ®Base);
 | |
| 
 | |
| 	regBase = regBase << 16;	/* MV6436x */
 | |
| 	return regBase;
 | |
| }
 | |
| 
 | |
| /*******************************************************************************
 | |
| * MemoryGetPciBaseAddr - Returns the base address of a PCI window.
 | |
| * DESCRIPTION:
 | |
| *       This function returns the base address of a PCI window. There are 5
 | |
| *       possible PCI windows (memory 0 - 3 and one for I/O) for each PCI
 | |
| *       interface as defined in gtMemory.h, used by the CPU's address decoding
 | |
| *       mechanism.
 | |
| *	New in MV6436x
 | |
| * INPUT:
 | |
| *       pciWindow - Selects one of the PCI windows as defined in Memory.h.
 | |
| * OUTPUT:
 | |
| *       None.
 | |
| * RETURN:
 | |
| *       32 bit PCI window base address.
 | |
| *******************************************************************************/
 | |
| unsigned int MemoryGetPciBaseAddr (PCI_MEM_WINDOW pciWindow)
 | |
| {
 | |
| 	unsigned int baseAddrReg, base;
 | |
| 
 | |
| 	switch (pciWindow) {
 | |
| 	case PCI_0_IO:
 | |
| 		baseAddrReg = PCI_0I_O_LOW_DECODE_ADDRESS;	/*PCI_0_IO_BASE_ADDR;  */
 | |
| 		break;
 | |
| 	case PCI_0_MEM0:
 | |
| 		baseAddrReg = PCI_0MEMORY0_LOW_DECODE_ADDRESS;	/*PCI_0_MEMORY0_BASE_ADDR; */
 | |
| 		break;
 | |
| 	case PCI_0_MEM1:
 | |
| 		baseAddrReg = PCI_0MEMORY1_LOW_DECODE_ADDRESS;	/*PCI_0_MEMORY1_BASE_ADDR; */
 | |
| 		break;
 | |
| 	case PCI_0_MEM2:
 | |
| 		baseAddrReg = PCI_0MEMORY2_LOW_DECODE_ADDRESS;	/*PCI_0_MEMORY2_BASE_ADDR;  */
 | |
| 		break;
 | |
| 	case PCI_0_MEM3:
 | |
| 		baseAddrReg = PCI_0MEMORY3_LOW_DECODE_ADDRESS;	/*PCI_0_MEMORY3_BASE_ADDR;  */
 | |
| 		break;
 | |
| #ifdef INCLUDE_PCI_1
 | |
| 	case PCI_1_IO:
 | |
| 		baseAddrReg = PCI_1I_O_LOW_DECODE_ADDRESS;	/*PCI_1_IO_BASE_ADDR;  */
 | |
| 		break;
 | |
| 	case PCI_1_MEM0:
 | |
| 		baseAddrReg = PCI_1MEMORY0_LOW_DECODE_ADDRESS;	/*PCI_1_MEMORY0_BASE_ADDR; */
 | |
| 		break;
 | |
| 	case PCI_1_MEM1:
 | |
| 		baseAddrReg = PCI_1MEMORY1_LOW_DECODE_ADDRESS;	/*PCI_1_MEMORY1_BASE_ADDR;  */
 | |
| 		break;
 | |
| 	case PCI_1_MEM2:
 | |
| 		baseAddrReg = PCI_1MEMORY2_LOW_DECODE_ADDRESS;	/*PCI_1_MEMORY2_BASE_ADDR;  */
 | |
| 		break;
 | |
| 	case PCI_1_MEM3:
 | |
| 		baseAddrReg = PCI_1MEMORY3_LOW_DECODE_ADDRESS;	/*PCI_1_MEMORY3_BASE_ADDR; */
 | |
| 		break;
 | |
| #endif /* INCLUDE_PCI_1 */
 | |
| 	default:
 | |
| 		return 0xffffffff;
 | |
| 	}
 | |
| 	GT_REG_READ (baseAddrReg, &base);
 | |
| 	return (base << 16);
 | |
| }
 | |
| 
 | |
| /*******************************************************************************
 | |
| * memoryGetBankSize - Returns the size of a memory bank.
 | |
| * DESCRIPTION:
 | |
| *       This function returns the size of memory bank as described in
 | |
| *       'gtMemoryGetBankBaseAddress' function.
 | |
| * INPUT:
 | |
| *       bank - Selects one of the four banks as defined in Memory.h.
 | |
| * OUTPUT:
 | |
| *       None.
 | |
| * RETURN:
 | |
| *       32 bit size memory bank size or 0 for a closed or non populated bank.
 | |
| *
 | |
| *******************************************************************************/
 | |
| unsigned int memoryGetBankSize (MEMORY_BANK bank)
 | |
| {
 | |
| 	unsigned int sizeReg, size;
 | |
| 	MEMORY_WINDOW window;
 | |
| 
 | |
| 	switch (bank) {
 | |
| 	case BANK0:
 | |
| 		sizeReg = SCS_0_HIGH_DECODE_ADDRESS;	/* CS_0_SIZE; */
 | |
| 		window = CS_0_WINDOW;
 | |
| 		break;
 | |
| 	case BANK1:
 | |
| 		sizeReg = SCS_1_HIGH_DECODE_ADDRESS;	/* CS_1_SIZE; */
 | |
| 		window = CS_1_WINDOW;
 | |
| 		break;
 | |
| 	case BANK2:
 | |
| 		sizeReg = SCS_2_HIGH_DECODE_ADDRESS;	/* CS_2_SIZE; */
 | |
| 		window = CS_2_WINDOW;
 | |
| 		break;
 | |
| 	case BANK3:
 | |
| 		sizeReg = SCS_3_HIGH_DECODE_ADDRESS;	/* CS_3_SIZE; */
 | |
| 		window = CS_3_WINDOW;
 | |
| 		break;
 | |
| 	default:
 | |
| 		return 0;
 | |
| 		break;
 | |
| 	}
 | |
| 	/* If the window is closed, a size of 0 is returned */
 | |
| 	if (MemoryGetMemWindowStatus (window) != MEM_WINDOW_ENABLED)
 | |
| 		return 0;
 | |
| 	GT_REG_READ (sizeReg, &size);
 | |
| 	size = ((size << 16) | 0xffff) + 1;
 | |
| 	return size;
 | |
| }
 | |
| 
 | |
| /*******************************************************************************
 | |
| * memoryGetDeviceSize - Returns the size of a device memory space.
 | |
| * DESCRIPTION:
 | |
| *       This function returns the memory space size of a given device.
 | |
| * INPUT:
 | |
| *       device - Selects one of the five devices as defined in Memory.h.
 | |
| * OUTPUT:
 | |
| *       None.
 | |
| * RETURN:
 | |
| *       32 bit size of a device memory space.
 | |
| *******************************************************************************/
 | |
| unsigned int memoryGetDeviceSize (DEVICE device)
 | |
| {
 | |
| 	unsigned int sizeReg, size;
 | |
| 	MEMORY_WINDOW window;
 | |
| 
 | |
| 	switch (device) {
 | |
| 	case DEVICE0:
 | |
| 		sizeReg = CS_0_HIGH_DECODE_ADDRESS;	/*DEV_CS0_SIZE; */
 | |
| 		window = DEVCS_0_WINDOW;
 | |
| 		break;
 | |
| 	case DEVICE1:
 | |
| 		sizeReg = CS_1_HIGH_DECODE_ADDRESS;	/*DEV_CS1_SIZE; */
 | |
| 		window = DEVCS_1_WINDOW;
 | |
| 		break;
 | |
| 	case DEVICE2:
 | |
| 		sizeReg = CS_2_HIGH_DECODE_ADDRESS;	/*DEV_CS2_SIZE; */
 | |
| 		window = DEVCS_2_WINDOW;
 | |
| 		break;
 | |
| 	case DEVICE3:
 | |
| 		sizeReg = CS_3_HIGH_DECODE_ADDRESS;	/*DEV_CS3_SIZE; */
 | |
| 		window = DEVCS_3_WINDOW;
 | |
| 		break;
 | |
| 	case BOOT_DEVICE:
 | |
| 		sizeReg = BOOTCS_HIGH_DECODE_ADDRESS;	/*BOOTCS_SIZE; */
 | |
| 		window = BOOT_CS_WINDOW;
 | |
| 		break;
 | |
| 	default:
 | |
| 		return 0;
 | |
| 		break;
 | |
| 	}
 | |
| 	/* If the window is closed, a size of 0 is returned */
 | |
| 	if (MemoryGetMemWindowStatus (window) != MEM_WINDOW_ENABLED)
 | |
| 		return 0;
 | |
| 	GT_REG_READ (sizeReg, &size);
 | |
| 	size = ((size << 16) | 0xffff) + 1;
 | |
| 	return size;
 | |
| }
 | |
| 
 | |
| /*******************************************************************************
 | |
| * MemoryGetPciWindowSize - Returns the size of a PCI memory window.
 | |
| * DESCRIPTION:
 | |
| *       This function returns the size of a PCI window.
 | |
| * INPUT:
 | |
| *       pciWindow - Selects one of the PCI memory windows as defined in
 | |
| *       Memory.h.
 | |
| * OUTPUT:
 | |
| *       None.
 | |
| * RETURN:
 | |
| *       32 bit size of a PCI memory window.
 | |
| *******************************************************************************/
 | |
| unsigned int MemoryGetPciWindowSize (PCI_MEM_WINDOW pciWindow)
 | |
| {
 | |
| 	unsigned int sizeReg, size;
 | |
| 
 | |
| 	switch (pciWindow) {
 | |
| 	case PCI_0_IO:
 | |
| 		sizeReg = PCI_0I_O_HIGH_DECODE_ADDRESS;	/*PCI_0_IO_SIZE; */
 | |
| 		break;
 | |
| 	case PCI_0_MEM0:
 | |
| 		sizeReg = PCI_0MEMORY0_HIGH_DECODE_ADDRESS;	/*PCI_0_MEMORY0_SIZE; */
 | |
| 		break;
 | |
| 	case PCI_0_MEM1:
 | |
| 		sizeReg = PCI_0MEMORY1_HIGH_DECODE_ADDRESS;	/*PCI_0_MEMORY1_SIZE; */
 | |
| 		break;
 | |
| 	case PCI_0_MEM2:
 | |
| 		sizeReg = PCI_0MEMORY2_HIGH_DECODE_ADDRESS;	/*PCI_0_MEMORY2_SIZE; */
 | |
| 		break;
 | |
| 	case PCI_0_MEM3:
 | |
| 		sizeReg = PCI_0MEMORY3_HIGH_DECODE_ADDRESS;	/*PCI_0_MEMORY3_SIZE; */
 | |
| 		break;
 | |
| #ifdef INCLUDE_PCI_1
 | |
| 	case PCI_1_IO:
 | |
| 		sizeReg = PCI_1I_O_HIGH_DECODE_ADDRESS;	/*PCI_1_IO_SIZE; */
 | |
| 		break;
 | |
| 	case PCI_1_MEM0:
 | |
| 		sizeReg = PCI_1MEMORY0_HIGH_DECODE_ADDRESS;	/*PCI_1_MEMORY0_SIZE; */
 | |
| 		break;
 | |
| 	case PCI_1_MEM1:
 | |
| 		sizeReg = PCI_1MEMORY1_HIGH_DECODE_ADDRESS;	/*PCI_1_MEMORY1_SIZE;  */
 | |
| 		break;
 | |
| 	case PCI_1_MEM2:
 | |
| 		sizeReg = PCI_1MEMORY2_HIGH_DECODE_ADDRESS;	/*PCI_1_MEMORY2_SIZE;  */
 | |
| 		break;
 | |
| 	case PCI_1_MEM3:
 | |
| 		sizeReg = PCI_1MEMORY3_HIGH_DECODE_ADDRESS;	/*PCI_1_MEMORY3_SIZE; */
 | |
| 		break;
 | |
| #endif /* INCLUDE_PCI_1 */
 | |
| 	default:
 | |
| 		return 0x0;
 | |
| 	}
 | |
| 	/* If the memory window is disabled, retrun size = 0 */
 | |
| 	if (MemoryGetMemWindowStatus (PCI_0_IO_WINDOW << pciWindow)
 | |
| 	    == MEM_WINDOW_DISABLED)
 | |
| 		return 0;
 | |
| 	GT_REG_READ (sizeReg, &size);
 | |
| 	size = ((size << 16) | 0xffff) + 1;
 | |
| 	return size;
 | |
| }
 | |
| 
 | |
| /*******************************************************************************
 | |
| * memoryGetDeviceWidth - Returns the width of a given device.
 | |
| * DESCRIPTION:
 | |
| *       The MV's device interface supports up to 32 Bit wide devices. A device
 | |
| *       can have a  1, 2, 4 or 8 Bytes data width. This function returns the
 | |
| *       width of a device as defined by the user or the operating system.
 | |
| * INPUT:
 | |
| *       device - Selects one of the five devices as defined in Memory.h.
 | |
| * OUTPUT:
 | |
| *       None.
 | |
| * RETURN:
 | |
| *       Device width in Bytes (1,2,4 or 8), 0 if error had occurred.
 | |
| *******************************************************************************/
 | |
| unsigned int memoryGetDeviceWidth (DEVICE device)
 | |
| {
 | |
| 	unsigned int width;
 | |
| 	unsigned int regValue;
 | |
| 
 | |
| 	GT_REG_READ (DEVICE_BANK0PARAMETERS + device * 4, ®Value);
 | |
| 	width = (regValue & (BIT20 | BIT21)) >> 20;
 | |
| 	return (BIT0 << width);
 | |
| }
 | |
| 
 | |
| /*******************************************************************************
 | |
| * memoryMapBank - Set new base address and size for one of the memory
 | |
| *                         banks.
 | |
| *
 | |
| * DESCRIPTION:
 | |
| *       The CPU interface address decoding map consists of 21 address windows
 | |
| *       for the different devices (e.g. CS[3:0] ,PCI0 Mem 0/1/2/3...). Each
 | |
| *       window can have a minimum of 1Mbytes of address space, and up to 4Gbyte
 | |
| *       space. Each address window is defined by two registers - base and size.
 | |
| *       The CPU address is compared with the values in the various CPU windows
 | |
| *       until a match is found and the address is than targeted to that window.
 | |
| *       This function sets new base and size for one the memory banks
 | |
| *       (CS0 - CS3). It is the programmer`s responsibility to make sure that
 | |
| *       there are no conflicts with other memory spaces. When two memory spaces
 | |
| *       overlap, the MV's behavior is not defined .If a bank needs to be closed,
 | |
| *       set the 'bankLength' parameter size to 0x0.
 | |
| *
 | |
| * INPUT:
 | |
| *       bank      - One of the memory banks (CS0-CS3) as defined in gtMemory.h.
 | |
| *       bankBase  - The memory bank base address.
 | |
| *       bankLength  - The memory bank size. This function will decrement the
 | |
| *                   'bankLength' parameter by one and then check if the size is
 | |
| *                   valid. A valid size must be programed from LSB to MSB as
 | |
| *                   sequence of '1's followed by sequence of '0's.
 | |
| *                   To close a memory window simply set the size to 0.
 | |
| *      NOTE!!!
 | |
| *       The size must be in 64Kbyte granularity.
 | |
| *       The base address must be aligned to the size.
 | |
| * OUTPUT:
 | |
| *       None.
 | |
| * RETURN:
 | |
| *       False for invalid size, true otherwise.
 | |
| *
 | |
| * CAUTION: PCI_functions must be implemented later To_do !!!!!!!!!!!!!!!!!
 | |
| *
 | |
| *******************************************************************************/
 | |
| 
 | |
| bool memoryMapBank (MEMORY_BANK bank, unsigned int bankBase,
 | |
| 		    unsigned int bankLength)
 | |
| {
 | |
| 	unsigned int newBase, newSize, baseReg, sizeReg, temp, rShift;
 | |
| 
 | |
| /*    PCI_INTERNAL_BAR pciBAR; */
 | |
| 
 | |
| 	switch (bank) {
 | |
| 	case BANK0:
 | |
| 		baseReg = SCS_0_LOW_DECODE_ADDRESS;	/*CS_0_BASE_ADDR; */
 | |
| 		sizeReg = SCS_0_HIGH_DECODE_ADDRESS;	/*CS_0_SIZE; */
 | |
| /*        pciBAR = PCI_CS0_BAR; */
 | |
| 		break;
 | |
| 	case BANK1:
 | |
| 		baseReg = SCS_1_LOW_DECODE_ADDRESS;	/*CS_1_BASE_ADDR; */
 | |
| 		sizeReg = SCS_1_HIGH_DECODE_ADDRESS;	/*CS_1_SIZE; */
 | |
| 		/*        pciBAR = SCS_0_HIGH_DECODE_ADDRESS; */ /*PCI_CS1_BAR; */
 | |
| 		break;
 | |
| 	case BANK2:
 | |
| 		baseReg = SCS_2_LOW_DECODE_ADDRESS;	/*CS_2_BASE_ADDR; */
 | |
| 		sizeReg = SCS_2_HIGH_DECODE_ADDRESS;	/*CS_2_SIZE; */
 | |
| /*        pciBAR = PCI_CS2_BAR;*/
 | |
| 		break;
 | |
| 	case BANK3:
 | |
| 		baseReg = SCS_3_LOW_DECODE_ADDRESS;	/*CS_3_BASE_ADDR; */
 | |
| 		sizeReg = SCS_3_HIGH_DECODE_ADDRESS;	/*CS_3_SIZE; */
 | |
| /*        pciBAR = PCI_CS3_BAR; */
 | |
| 		break;
 | |
| 	default:
 | |
| 		return false;
 | |
| 	}
 | |
| 	/* If the size is 0, the window will be disabled */
 | |
| 	if (bankLength == 0) {
 | |
| 		MemoryDisableWindow (CS_0_WINDOW << bank);
 | |
| 		/* Disable the BAR from the PCI slave side */
 | |
| /*        gtPci0DisableInternalBAR(pciBAR); */
 | |
| /*        gtPci1DisableInternalBAR(pciBAR); */
 | |
| 		return true;
 | |
| 	}
 | |
| 	/* The base address must be aligned to the size */
 | |
| 	if ((bankBase % bankLength) != 0) {
 | |
| 		return false;
 | |
| 	}
 | |
| 	if (bankLength >= MINIMUM_MEM_BANK_SIZE) {
 | |
| 		newBase = bankBase >> 16;
 | |
| 		newSize = bankLength >> 16;
 | |
| 		/* Checking that the size is a sequence of '1' followed by a
 | |
| 		   sequence of '0' starting from LSB to MSB. */
 | |
| 		temp = newSize - 1;
 | |
| 		for (rShift = 0; rShift < 16; rShift++) {
 | |
| 			temp = temp >> rShift;
 | |
| 			if ((temp & 0x1) == 0) {	/* Either we got to the last '1' */
 | |
| 							/* or the size is not valid	 */
 | |
| 				if (temp > 0x0)
 | |
| 					return false;
 | |
| 				else
 | |
| 					break;
 | |
| 			}
 | |
| 		}
 | |
| #ifdef DEBUG
 | |
| 		{
 | |
| 			unsigned int oldBase, oldSize;
 | |
| 
 | |
| 			GT_REG_READ (baseReg, &oldBase);
 | |
| 			GT_REG_READ (sizeReg + 8, &oldSize);
 | |
| 
 | |
| 			printf ("b%d Base:%x Size:%x -> Base:%x Size:%x\n",
 | |
| 				bank, oldBase, oldSize, newBase, newSize);
 | |
| 		}
 | |
| #endif
 | |
| 		/* writing the new values */
 | |
| 		GT_REG_WRITE (baseReg, newBase);
 | |
| 		GT_REG_WRITE (sizeReg, newSize - 1);
 | |
| 		/* Enable back the window */
 | |
| 		MemoryEnableWindow (CS_0_WINDOW << bank);
 | |
| 		/* Enable the BAR from the PCI slave side */
 | |
| /*        gtPci0EnableInternalBAR(pciBAR); */
 | |
| /*        gtPci1EnableInternalBAR(pciBAR); */
 | |
| 		return true;
 | |
| 	}
 | |
| 	return false;
 | |
| }
 | |
| 
 | |
| 
 | |
| /*******************************************************************************
 | |
| * memoryMapDeviceSpace - Set new base address and size for one of the device
 | |
| *                           windows.
 | |
| *
 | |
| * DESCRIPTION:
 | |
| *       The CPU interface address decoding map consists of 21 address windows
 | |
| *       for the different devices (e.g. CS[3:0] ,PCI0 Mem 0/1/2/3...). Each
 | |
| *       window can have a minimum of 1Mbytes of address space, and up to 4Gbyte
 | |
| *       space. Each address window is defined by two registers - base and size.
 | |
| *       The CPU address is compared with the values in the various CPU windows
 | |
| *       until a match is found and the address is than targeted to that window.
 | |
| *       This function sets new base and size for one the device windows
 | |
| *       (DEV_CS0 - DEV_CS3). It is the programmer`s responsibility to make sure
 | |
| *       that there are no conflicts with other memory spaces. When two memory
 | |
| *       spaces overlap, the MV's behavior is not defined .If a device window
 | |
| *       needs to be closed, set the 'deviceLength' parameter size to 0x0.
 | |
| *
 | |
| * INPUT:
 | |
| *       device           - One of the device windows (DEV_CS0-DEV_CS3) as
 | |
| *                          defined in gtMemory.h.
 | |
| *       deviceBase - The device window base address.
 | |
| *       deviceLength - The device window size. This function will decrement
 | |
| *                          the 'deviceLength' parameter by one and then
 | |
| *                          check if the size is valid. A valid size must be
 | |
| *                          programed from LSB to MSB as sequence of '1's
 | |
| *                          followed by sequence of '0's.
 | |
| *                          To close a memory window simply set the size to 0.
 | |
| *
 | |
| *      NOTE!!!
 | |
| *       The size must be in 64Kbyte granularity.
 | |
| *       The base address must be aligned to the size.
 | |
| *
 | |
| * OUTPUT:
 | |
| *       None.
 | |
| *
 | |
| * RETURN:
 | |
| *       False for invalid size, true otherwise.
 | |
| *
 | |
| * CAUTION: PCI_functions must be implemented later To_do !!!!!!!!!!!!!!!!!
 | |
| *
 | |
| *******************************************************************************/
 | |
| 
 | |
| bool memoryMapDeviceSpace (DEVICE device, unsigned int deviceBase,
 | |
| 			   unsigned int deviceLength)
 | |
| {
 | |
| 	unsigned int newBase, newSize, baseReg, sizeReg, temp, rShift;
 | |
| 
 | |
| /*    PCI_INTERNAL_BAR pciBAR;*/
 | |
| 
 | |
| 	switch (device) {
 | |
| 	case DEVICE0:
 | |
| 		baseReg = CS_0_LOW_DECODE_ADDRESS;	/*DEV_CS0_BASE_ADDR; */
 | |
| 		sizeReg = CS_0_HIGH_DECODE_ADDRESS;	/*DEV_CS0_SIZE; */
 | |
| /*        pciBAR = PCI_DEV_CS0_BAR; */
 | |
| 		break;
 | |
| 	case DEVICE1:
 | |
| 		baseReg = CS_1_LOW_DECODE_ADDRESS;	/*DEV_CS1_BASE_ADDR; */
 | |
| 		sizeReg = CS_1_HIGH_DECODE_ADDRESS;	/*DEV_CS1_SIZE; */
 | |
| /*        pciBAR = PCI_DEV_CS1_BAR; */
 | |
| 		break;
 | |
| 	case DEVICE2:
 | |
| 		baseReg = CS_2_LOW_DECODE_ADDRESS;	/*DEV_CS2_BASE_ADDR; */
 | |
| 		sizeReg = CS_2_HIGH_DECODE_ADDRESS;	/*DEV_CS2_SIZE; */
 | |
| /*        pciBAR = PCI_DEV_CS2_BAR; */
 | |
| 		break;
 | |
| 	case DEVICE3:
 | |
| 		baseReg = CS_3_LOW_DECODE_ADDRESS;	/*DEV_CS3_BASE_ADDR; */
 | |
| 		sizeReg = CS_3_HIGH_DECODE_ADDRESS;	/*DEV_CS3_SIZE; */
 | |
| /*        pciBAR = PCI_DEV_CS3_BAR; */
 | |
| 		break;
 | |
| 	case BOOT_DEVICE:
 | |
| 		baseReg = BOOTCS_LOW_DECODE_ADDRESS;	/*BOOTCS_BASE_ADDR; */
 | |
| 		sizeReg = BOOTCS_HIGH_DECODE_ADDRESS;	/*BOOTCS_SIZE; */
 | |
| /*        pciBAR = PCI_BOOT_CS_BAR; */
 | |
| 		break;
 | |
| 	default:
 | |
| 		return false;
 | |
| 	}
 | |
| 	if (deviceLength == 0) {
 | |
| 		MemoryDisableWindow (DEVCS_0_WINDOW << device);
 | |
| 		/* Disable the BAR from the PCI slave side */
 | |
| /*        gtPci0DisableInternalBAR(pciBAR); */
 | |
| /*        gtPci1DisableInternalBAR(pciBAR); */
 | |
| 		return true;
 | |
| 	}
 | |
| 	/* The base address must be aligned to the size */
 | |
| 	if ((deviceBase % deviceLength) != 0) {
 | |
| 		return false;
 | |
| 	}
 | |
| 	if (deviceLength >= MINIMUM_DEVICE_WINDOW_SIZE) {
 | |
| 		newBase = deviceBase >> 16;
 | |
| 		newSize = deviceLength >> 16;
 | |
| 		/* Checking that the size is a sequence of '1' followed by a
 | |
| 		   sequence of '0' starting from LSB to MSB. */
 | |
| 		temp = newSize - 1;
 | |
| 		for (rShift = 0; rShift < 16; rShift++) {
 | |
| 			temp = temp >> rShift;
 | |
| 			if ((temp & 0x1) == 0) {	/* Either we got to the last '1' */
 | |
| 							/* or the size is not valid       */
 | |
| 				if (temp > 0x0)
 | |
| 					return false;
 | |
| 				else
 | |
| 					break;
 | |
| 			}
 | |
| 		}
 | |
| 		/* writing the new values */
 | |
| 		GT_REG_WRITE (baseReg, newBase);
 | |
| 		GT_REG_WRITE (sizeReg, newSize - 1);
 | |
| 		MemoryEnableWindow (DEVCS_0_WINDOW << device);
 | |
| 		/* Enable the BAR from the PCI slave side */
 | |
| /*        gtPci0EnableInternalBAR(pciBAR); */
 | |
| /*        gtPci1EnableInternalBAR(pciBAR); */
 | |
| 		return true;
 | |
| 	}
 | |
| 	return false;
 | |
| }
 | |
| 
 | |
| /*******************************************************************************
 | |
| * MemorySetPciWindow - Set new base address and size for one of the PCI
 | |
| *                        windows.
 | |
| *
 | |
| * DESCRIPTION:
 | |
| *       The CPU interface address decoding map consists of 21 address windows
 | |
| *       for the different devices (e.g. CS[3:0] ,PCI0 Mem 0/1/2/3...). Each
 | |
| *       window can have a minimum of 1Mbytes of address space, and up to 4Gbyte
 | |
| *       space. Each address window is defined by two registers - base and size.
 | |
| *       The CPU address is compared with the values in the various CPU windows
 | |
| *       until a match is found and the address is than targeted to that window.
 | |
| *       This function sets new base and size for one the PCI windows
 | |
| *       (PCI memory0/1/2..). It is the programmer`s responsibility to make sure
 | |
| *       that there are no conflicts with other memory spaces. When two memory
 | |
| *       spaces overlap, the MV's behavior is not defined. If a PCI window
 | |
| *       needs to be closed, set the 'pciWindowSize' parameter size to 0x0.
 | |
| *
 | |
| * INPUT:
 | |
| *       pciWindow     - One of the PCI windows as defined in gtMemory.h.
 | |
| *       pciWindowBase - The PCI window base address.
 | |
| *       pciWindowSize - The PCI window size. This function will decrement the
 | |
| *                       'pciWindowSize' parameter by one and then check if the
 | |
| *                       size is valid. A valid size must be programed from LSB
 | |
| *                       to MSB as sequence of '1's followed by sequence of '0's.
 | |
| *                       To close a memory window simply set the size to 0.
 | |
| *
 | |
| *      NOTE!!!
 | |
| *       The size must be in 64Kbyte granularity.
 | |
| *       The base address must be aligned to the size.
 | |
| *
 | |
| * OUTPUT:
 | |
| *       None.
 | |
| *
 | |
| * RETURN:
 | |
| *       False for invalid size, true otherwise.
 | |
| *
 | |
| *******************************************************************************/
 | |
| bool memorySetPciWindow (PCI_MEM_WINDOW pciWindow, unsigned int pciWindowBase,
 | |
| 			 unsigned int pciWindowSize)
 | |
| {
 | |
| 	unsigned int currentLow, baseAddrReg, sizeReg, temp, rShift;
 | |
| 
 | |
| 	switch (pciWindow) {
 | |
| 	case PCI_0_IO:
 | |
| 		baseAddrReg = PCI_1I_O_LOW_DECODE_ADDRESS;	/*PCI_0_IO_BASE_ADDR; */
 | |
| 		sizeReg = PCI_0I_O_HIGH_DECODE_ADDRESS;	/*PCI_0_IO_SIZE; */
 | |
| 		break;
 | |
| 	case PCI_0_MEM0:
 | |
| 		baseAddrReg = PCI_0MEMORY0_LOW_DECODE_ADDRESS;	/*PCI_0_MEMORY0_BASE_ADDR; */
 | |
| 		sizeReg = PCI_0MEMORY0_HIGH_DECODE_ADDRESS;	/*PCI_0_MEMORY0_SIZE; */
 | |
| 		break;
 | |
| 	case PCI_0_MEM1:
 | |
| 		baseAddrReg = PCI_0MEMORY1_LOW_DECODE_ADDRESS;	/*PCI_0_MEMORY1_BASE_ADDR; */
 | |
| 		sizeReg = PCI_0MEMORY1_HIGH_DECODE_ADDRESS;	/*PCI_0_MEMORY1_SIZE; */
 | |
| 		break;
 | |
| 	case PCI_0_MEM2:
 | |
| 		baseAddrReg = PCI_0MEMORY2_LOW_DECODE_ADDRESS;	/*PCI_0_MEMORY2_BASE_ADDR; */
 | |
| 		sizeReg = PCI_0MEMORY2_HIGH_DECODE_ADDRESS;	/*PCI_0_MEMORY2_SIZE; */
 | |
| 		break;
 | |
| 	case PCI_0_MEM3:
 | |
| 		baseAddrReg = PCI_0MEMORY3_LOW_DECODE_ADDRESS;	/*PCI_0_MEMORY3_BASE_ADDR; */
 | |
| 		sizeReg = PCI_0MEMORY3_HIGH_DECODE_ADDRESS;	/*PCI_0_MEMORY3_SIZE; */
 | |
| 		break;
 | |
| #ifdef INCLUDE_PCI_1
 | |
| 	case PCI_1_IO:
 | |
| 		baseAddrReg = PCI_1I_O_LOW_DECODE_ADDRESS;	/*PCI_1_IO_BASE_ADDR; */
 | |
| 		sizeReg = PCI_1I_O_HIGH_DECODE_ADDRESS;	/*PCI_1_IO_SIZE; */
 | |
| 		break;
 | |
| 	case PCI_1_MEM0:
 | |
| 		baseAddrReg = PCI_1MEMORY0_LOW_DECODE_ADDRESS;	/*PCI_1_MEMORY0_BASE_ADDR; */
 | |
| 		sizeReg = PCI_1MEMORY0_HIGH_DECODE_ADDRESS;	/*PCI_1_MEMORY0_SIZE; */
 | |
| 		break;
 | |
| 	case PCI_1_MEM1:
 | |
| 		baseAddrReg = PCI_1MEMORY1_LOW_DECODE_ADDRESS;	/*PCI_1_MEMORY1_BASE_ADDR;  */
 | |
| 		sizeReg = PCI_1MEMORY1_HIGH_DECODE_ADDRESS;	/*PCI_1_MEMORY1_SIZE; */
 | |
| 		break;
 | |
| 	case PCI_1_MEM2:
 | |
| 		baseAddrReg = PCI_1MEMORY2_LOW_DECODE_ADDRESS;	/*PCI_1_MEMORY2_BASE_ADDR;  */
 | |
| 		sizeReg = PCI_1MEMORY2_HIGH_DECODE_ADDRESS;	/*PCI_1_MEMORY2_SIZE; */
 | |
| 		break;
 | |
| 	case PCI_1_MEM3:
 | |
| 		baseAddrReg = PCI_1MEMORY3_LOW_DECODE_ADDRESS;	/*PCI_1_MEMORY3_BASE_ADDR; */
 | |
| 		sizeReg = PCI_1MEMORY3_HIGH_DECODE_ADDRESS;	/*PCI_1_MEMORY3_SIZE; */
 | |
| 		break;
 | |
| #endif /* INCLUDE_PCI_1 */
 | |
| 	default:
 | |
| 		return false;
 | |
| 	}
 | |
| 	if (pciWindowSize == 0) {
 | |
| 		MemoryDisableWindow (PCI_0_IO_WINDOW << pciWindow);
 | |
| 		return true;
 | |
| 	}
 | |
| 	/* The base address must be aligned to the size */
 | |
| 	if ((pciWindowBase % pciWindowSize) != 0) {
 | |
| 		return false;
 | |
| 	}
 | |
| 	if (pciWindowSize >= MINIMUM_PCI_WINDOW_SIZE) {
 | |
| 		pciWindowBase >>= 16;
 | |
| 		pciWindowSize >>= 16;
 | |
| 		/* Checking that the size is a sequence of '1' followed by a
 | |
| 		   sequence of '0' starting from LSB to MSB. */
 | |
| 		temp = pciWindowSize - 1;
 | |
| 		for (rShift = 0; rShift < 16; rShift++) {
 | |
| 			temp = temp >> rShift;
 | |
| 			if ((temp & 0x1) == 0) {	/* Either we got to the last '1' */
 | |
| 							/* or the size is not valid       */
 | |
| 				if (temp > 0x0)
 | |
| 					return false;
 | |
| 				else
 | |
| 					break;
 | |
| 			}
 | |
| 		}
 | |
| 		GT_REG_WRITE (sizeReg, pciWindowSize - 1);
 | |
| 		GT_REG_READ (baseAddrReg, ¤tLow);
 | |
| 		pciWindowBase =
 | |
| 			(pciWindowBase & 0xfffff) | (currentLow & 0xfff00000);
 | |
| 		GT_REG_WRITE (baseAddrReg, pciWindowBase);
 | |
| 		MemoryEnableWindow (PCI_0_IO_WINDOW << pciWindow);
 | |
| 		return true;
 | |
| 	}
 | |
| 	return false;
 | |
| }
 | |
| 
 | |
| /*******************************************************************************
 | |
| * memoryMapInternalRegistersSpace - Sets new base address for the internal
 | |
| *                                  registers memory space.
 | |
| *
 | |
| * DESCRIPTION:
 | |
| *       This function set new base address for the internal registers memory
 | |
| *       space (the size is fixed and cannot be modified). The function does not
 | |
| *       handle overlapping with other memory spaces, it is the programer's
 | |
| *       responsibility to ensure that overlapping does not occur.
 | |
| *       When two memory spaces overlap, the MV's behavior is not defined.
 | |
| *
 | |
| * INPUT:
 | |
| *       internalRegBase - new base address for the internal registers memory
 | |
| *                         space.
 | |
| *
 | |
| * OUTPUT:
 | |
| *       None.
 | |
| *
 | |
| * RETURN:
 | |
| *        true on success, false on failure
 | |
| *
 | |
| *******************************************************************************/
 | |
| /********************************************************************
 | |
| * memoryMapInternalRegistersSpace - Sets new base address for the internals
 | |
| *                                   registers.
 | |
| *
 | |
| * INPUTS:  unsigned int internalRegBase - The new base address.
 | |
| * RETURNS: true on success, false on failure
 | |
| *********************************************************************/
 | |
| bool memoryMapInternalRegistersSpace (unsigned int internalRegBase)
 | |
| {
 | |
| 	unsigned int currentValue;
 | |
| 	unsigned int internalValue = internalRegBase;
 | |
| 
 | |
| 	internalRegBase = (internalRegBase >> 16);
 | |
| 	GT_REG_READ (INTERNAL_SPACE_DECODE, ¤tValue);
 | |
| 	internalRegBase = (currentValue & 0xff000000) | internalRegBase;
 | |
| 	GT_REG_WRITE (INTERNAL_SPACE_DECODE, internalRegBase);
 | |
| 	/* initializing also the global variable 'internalRegBaseAddr' */
 | |
| /*    gtInternalRegBaseAddr = internalValue; */
 | |
| 	INTERNAL_REG_BASE_ADDR = internalValue;
 | |
| 	return true;
 | |
| }
 | |
| 
 | |
| /*******************************************************************************
 | |
| * memoryGetInternalRegistersSpace - Returns the internal registers Base
 | |
| *                                     address.
 | |
| *
 | |
| * DESCRIPTION:
 | |
| *       This function returns the base address of  the internal registers
 | |
| *       memory space .
 | |
| *
 | |
| * INPUT:
 | |
| *       None.
 | |
| *
 | |
| * OUTPUT:
 | |
| *       None.
 | |
| *
 | |
| * RETURN:
 | |
| *       32 bit base address of the internal registers memory space.
 | |
| *
 | |
| *******************************************************************************/
 | |
| unsigned int memoryGetInternalRegistersSpace (void)
 | |
| {
 | |
| 	unsigned int currentValue = 0;
 | |
| 
 | |
| 	GT_REG_READ (INTERNAL_SPACE_DECODE, ¤tValue);
 | |
| 	return ((currentValue & 0x000fffff) << 16);
 | |
| }
 | |
| 
 | |
| /*******************************************************************************
 | |
| * gtMemoryGetInternalSramBaseAddr - Returns the integrated SRAM base address.
 | |
| *
 | |
| * DESCRIPTION:
 | |
| *       The Atlantis incorporate integrated 2Mbit SRAM for general use. This
 | |
| *       funcnion return the SRAM's base address.
 | |
| * INPUT:
 | |
| *       None.
 | |
| * OUTPUT:
 | |
| *       None.
 | |
| * RETURN:
 | |
| *       32 bit SRAM's base address.
 | |
| *
 | |
| *******************************************************************************/
 | |
| unsigned int memoryGetInternalSramBaseAddr (void)
 | |
| {
 | |
| 	return ((GTREGREAD (INTEGRATED_SRAM_BASE_ADDR) & 0xfffff) << 16);
 | |
| }
 | |
| 
 | |
| /*******************************************************************************
 | |
| * gtMemorySetInternalSramBaseAddr - Set the integrated SRAM base address.
 | |
| *
 | |
| * DESCRIPTION:
 | |
| *       The Atlantis incorporate integrated 2Mbit SRAM for general use. This
 | |
| *       function sets a new base address to the SRAM .
 | |
| * INPUT:
 | |
| *       sramBaseAddress - The SRAM's base address.
 | |
| * OUTPUT:
 | |
| *       None.
 | |
| * RETURN:
 | |
| *       None.
 | |
| *
 | |
| *******************************************************************************/
 | |
| void gtMemorySetInternalSramBaseAddr (unsigned int sramBaseAddress)
 | |
| {
 | |
| 	GT_REG_WRITE (INTEGRATED_SRAM_BASE_ADDR, sramBaseAddress >> 16);
 | |
| }
 | |
| 
 | |
| /*******************************************************************************
 | |
| * memorySetProtectRegion - Set protection mode for one of the 8 regions.
 | |
| *
 | |
| * DESCRIPTION:
 | |
| *       The CPU interface supports configurable access protection. This includes
 | |
| *       up to eight address ranges defined to a different protection type :
 | |
| *       whether the address range is cacheable or not, whether it is writable or
 | |
| *       not , and whether it is accessible or not. A Low and High registers
 | |
| *       define each window while the minimum address range of each window is
 | |
| *       1Mbyte. An address driven by the CPU, in addition to the address
 | |
| *       decoding and remapping process, is compared against the eight Access
 | |
| *       Protection Low/High registers , if an address matches one of the windows
 | |
| *       , the MV device checks the transaction type against the protection bits
 | |
| *       defined in CPU Access Protection register, to determine if the access is
 | |
| *       allowed. This function set a protection mode to one of the 8 possible
 | |
| *       regions.
 | |
| *      NOTE:
 | |
| *       The CPU address windows are restricted to a size of  2 power n and the
 | |
| *       start address must be aligned to the window size. For example, if using
 | |
| *       a 16 MB window, the start address bits [23:0] must be 0.The MV's
 | |
| *       internal registers space is not protected, even if the access protection
 | |
| *       windows contain this space.
 | |
| *
 | |
| * INPUT:
 | |
| *       region - selects which region to be configured. The values defined in
 | |
| *                gtMemory.h:
 | |
| *
 | |
| *                 - MEM_REGION0
 | |
| *                 - MEM_REGION1
 | |
| *                 - etc.
 | |
| *
 | |
| *       memAccess - Allows or forbids access (read or write ) to the region. The
 | |
| *                   values defined in gtMemory.h:
 | |
| *
 | |
| *                    - MEM_ACCESS_ALLOWED
 | |
| *                    - MEM_ACCESS_FORBIDEN
 | |
| *
 | |
| *       memWrite - CPU write protection to the region. The values defined in
 | |
| *                  gtMemory.h:
 | |
| *
 | |
| *                   - MEM_WRITE_ALLOWED
 | |
| *                   - MEM_WRITE_FORBIDEN
 | |
| *
 | |
| *       cacheProtection - Defines whether caching the region is allowed or not.
 | |
| *                         The values defined in gtMemory.h:
 | |
| *
 | |
| *                          - MEM_CACHE_ALLOWED
 | |
| *                          - MEM_CACHE_FORBIDEN
 | |
| *
 | |
| *       baseAddress - the region's base Address.
 | |
| *       regionSize  - The region's size. This function will decrement the
 | |
| *                     'regionSize' parameter by one and then check if the size
 | |
| *                     is valid. A valid size must be programed from LSB to MSB
 | |
| *                     as sequence of '1's followed by sequence of '0's.
 | |
| *                     To close a memory window simply set the size to 0.
 | |
| *
 | |
| *      NOTE!!!
 | |
| *       The size must be in 64Kbyte granularity.
 | |
| *       The base address must be aligned to the size.
 | |
| *
 | |
| * OUTPUT:
 | |
| *       None.
 | |
| *
 | |
| * RETURN:
 | |
| *       False for invalid size, true otherwise.
 | |
| *
 | |
| *******************************************************************************/
 | |
| bool memorySetProtectRegion (MEMORY_PROTECT_WINDOW window,
 | |
| 			     MEMORY_ACCESS memAccess,
 | |
| 			     MEMORY_ACCESS_WRITE memWrite,
 | |
| 			     MEMORY_CACHE_PROTECT cacheProtection,
 | |
| 			     unsigned int baseAddress, unsigned int size)
 | |
| {
 | |
| 	unsigned int dataForReg, temp, rShift;
 | |
| 
 | |
| 	if (size == 0) {
 | |
| 		GT_REG_WRITE ((CPU_PROTECT_WINDOW_0_SIZE + 0x10 * window),
 | |
| 			      0x0);
 | |
| 		return true;
 | |
| 	}
 | |
| 	/* The base address must be aligned to the size.  */
 | |
| 	if (baseAddress % size != 0) {
 | |
| 		return false;
 | |
| 	}
 | |
| 	if (size >= MINIMUM_ACCESS_WIN_SIZE) {
 | |
| 		baseAddress = ((baseAddress >> 16) & 0xfffff);
 | |
| 		dataForReg = baseAddress | ((memAccess << 20) & BIT20) |
 | |
| 			((memWrite << 21) & BIT21) | ((cacheProtection << 22)
 | |
| 						      & BIT22) | BIT31;
 | |
| 		GT_REG_WRITE (CPU_PROTECT_WINDOW_0_BASE_ADDR + 0x10 * window,
 | |
| 			      dataForReg);
 | |
| 		size >>= 16;
 | |
| 		/* Checking that the size is a sequence of '1' followed by a
 | |
| 		   sequence of '0' starting from LSB to MSB. */
 | |
| 		temp = size - 1;
 | |
| 		for (rShift = 0; rShift < 16; rShift++) {
 | |
| 			temp = temp >> rShift;
 | |
| 			if ((temp & 0x1) == 0) {	/* Either we got to the last '1' */
 | |
| 							/* or the size is not valid       */
 | |
| 				if (temp > 0x0)
 | |
| 					return false;
 | |
| 				else
 | |
| 					break;
 | |
| 			}
 | |
| 		}
 | |
| 		GT_REG_WRITE ((CPU_PROTECT_WINDOW_0_SIZE + 0x10 * window),
 | |
| 			      size - 1);
 | |
| 		return true;
 | |
| 	}
 | |
| 	return false;
 | |
| }
 | |
| 
 | |
| /*******************************************************************************
 | |
| * gtMemoryDisableProtectRegion - Disable a protected window.
 | |
| *
 | |
| * DESCRIPTION:
 | |
| *       This function disable a protected window set by
 | |
| *       'gtMemorySetProtectRegion' function.
 | |
| *
 | |
| * INPUT:
 | |
| *       window - one of the 4 windows ( defined in gtMemory.h ).
 | |
| *
 | |
| * OUTPUT:
 | |
| *       None.
 | |
| *
 | |
| * RETURN:
 | |
| *       None.
 | |
| *
 | |
| *******************************************************************************/
 | |
| void memoryDisableProtectRegion (MEMORY_PROTECT_WINDOW window)
 | |
| {
 | |
| 	RESET_REG_BITS (((CPU_PROTECT_WINDOW_0_BASE_ADDR) + (0x10 * window)),
 | |
| 			BIT31);
 | |
| }
 | |
| 
 | |
| /*******************************************************************************
 | |
| * memorySetPciRemapValue - Set a remap value to a PCI memory space target.
 | |
| *
 | |
| * DESCRIPTION:
 | |
| *       In addition to the address decoding mechanism, the CPU has an address
 | |
| *       remapping mechanism to be used by every PCI decoding window. Each PCI
 | |
| *       window can be remaped to a desired address target according to the remap
 | |
| *       value within the remap register. The address remapping is useful when a
 | |
| *       CPU address range must be reallocated to a different location on the
 | |
| *       PCI bus. Also, it enables CPU access to a PCI agent located above the
 | |
| *       4Gbyte space. On system boot, each of the PCI memory spaces is maped to
 | |
| *       a defualt value (see CPU interface section in the MV spec for the
 | |
| *       default values). The remap mechanism does not always produce the desired
 | |
| *       address on the PCI bus because of the remap mechanism way of working
 | |
| *       (to fully understand why, please see the 'Address Remapping' section in
 | |
| *       the MV's spec). Therefor, this function sets a desired remap value to
 | |
| *       one of the PCI memory windows and return the effective address that
 | |
| *       should be used when exiting the PCI memory window. You should ALWAYS use
 | |
| *       the returned value by this function when remapping a PCI window and
 | |
| *       exiting it. If for example the base address of PCI0 memory 0 is
 | |
| *       0x90000000, the size is 0x03ffffff and the remap value is 0x11000000,
 | |
| *       the function will return the value of 0x91000000 that MUST
 | |
| *       be used to exit this memory window in order to achive the deisred
 | |
| *       remapping.
 | |
| *
 | |
| * INPUT:
 | |
| *       memoryWindow   - One of the PCI memory windows as defined in Memory.h
 | |
| *       remapValueLow  - The low remap value.
 | |
| *       remapValueHigh - The high remap value.
 | |
| * OUTPUT:
 | |
| *       None.
 | |
| *
 | |
| * RETURN:
 | |
| *       The effective base address to exit the PCI, or 0xffffffff if one of the
 | |
| *       parameters is erroneous or the effective base address is higher the top
 | |
| *       decode value.
 | |
| *
 | |
| *******************************************************************************/
 | |
| unsigned int memorySetPciRemapValue (PCI_MEM_WINDOW memoryWindow,
 | |
| 				     unsigned int remapValueHigh,
 | |
| 				     unsigned int remapValueLow)
 | |
| {
 | |
| 	unsigned int pciMemWindowBaseAddrReg = 0, baseAddrValue = 0;
 | |
| 	unsigned int pciMemWindowSizeReg = 0, windowSizeValue = 0;
 | |
| 	unsigned int effectiveBaseAddress, remapRegLow, remapRegHigh;
 | |
| 
 | |
| 	/* Initializing the base and size variables of the PCI
 | |
| 	   memory windows */
 | |
| 	switch (memoryWindow) {
 | |
| 	case PCI_0_IO:
 | |
| 		pciMemWindowBaseAddrReg = PCI_0_IO_BASE_ADDR;
 | |
| 		pciMemWindowSizeReg = PCI_0_IO_SIZE;
 | |
| 		remapRegLow = PCI_0_IO_ADDR_REMAP;
 | |
| 		remapRegHigh = PCI_0_IO_ADDR_REMAP;
 | |
| 		break;
 | |
| 	case PCI_0_MEM0:
 | |
| 		pciMemWindowBaseAddrReg = PCI_0_MEMORY0_BASE_ADDR;
 | |
| 		pciMemWindowSizeReg = PCI_0_MEMORY0_SIZE;
 | |
| 		remapRegLow = PCI_0_MEMORY0_LOW_ADDR_REMAP;
 | |
| 		remapRegHigh = PCI_0_MEMORY0_HIGH_ADDR_REMAP;
 | |
| 		break;
 | |
| 	case PCI_0_MEM1:
 | |
| 		pciMemWindowBaseAddrReg = PCI_0_MEMORY1_BASE_ADDR;
 | |
| 		pciMemWindowSizeReg = PCI_0_MEMORY1_SIZE;
 | |
| 		remapRegLow = PCI_0_MEMORY1_LOW_ADDR_REMAP;
 | |
| 		remapRegHigh = PCI_0_MEMORY1_HIGH_ADDR_REMAP;
 | |
| 		break;
 | |
| 	case PCI_0_MEM2:
 | |
| 		pciMemWindowBaseAddrReg = PCI_0_MEMORY2_BASE_ADDR;
 | |
| 		pciMemWindowSizeReg = PCI_0_MEMORY2_SIZE;
 | |
| 		remapRegLow = PCI_0_MEMORY2_LOW_ADDR_REMAP;
 | |
| 		remapRegHigh = PCI_0_MEMORY2_HIGH_ADDR_REMAP;
 | |
| 		break;
 | |
| 	case PCI_0_MEM3:
 | |
| 		pciMemWindowBaseAddrReg = PCI_0_MEMORY3_BASE_ADDR;
 | |
| 		pciMemWindowSizeReg = PCI_0_MEMORY3_SIZE;
 | |
| 		remapRegLow = PCI_0_MEMORY3_LOW_ADDR_REMAP;
 | |
| 		remapRegHigh = PCI_0_MEMORY3_HIGH_ADDR_REMAP;
 | |
| 		break;
 | |
| #ifdef INCLUDE_PCI_1
 | |
| 	case PCI_1_IO:
 | |
| 		pciMemWindowBaseAddrReg = PCI_1_IO_BASE_ADDR;
 | |
| 		pciMemWindowSizeReg = PCI_1_IO_SIZE;
 | |
| 		remapRegLow = PCI_1_IO_ADDR_REMAP;
 | |
| 		remapRegHigh = PCI_1_IO_ADDR_REMAP;
 | |
| 		break;
 | |
| 	case PCI_1_MEM0:
 | |
| 		pciMemWindowBaseAddrReg = PCI_1_MEMORY0_BASE_ADDR;
 | |
| 		pciMemWindowSizeReg = PCI_1_MEMORY0_SIZE;
 | |
| 		remapRegLow = PCI_1_MEMORY0_LOW_ADDR_REMAP;
 | |
| 		remapRegHigh = PCI_1_MEMORY0_HIGH_ADDR_REMAP;
 | |
| 		break;
 | |
| 	case PCI_1_MEM1:
 | |
| 		pciMemWindowBaseAddrReg = PCI_1_MEMORY1_BASE_ADDR;
 | |
| 		pciMemWindowSizeReg = PCI_1_MEMORY1_SIZE;
 | |
| 		remapRegLow = PCI_1_MEMORY1_LOW_ADDR_REMAP;
 | |
| 		remapRegHigh = PCI_1_MEMORY1_HIGH_ADDR_REMAP;
 | |
| 		break;
 | |
| 	case PCI_1_MEM2:
 | |
| 		pciMemWindowBaseAddrReg = PCI_1_MEMORY1_BASE_ADDR;
 | |
| 		pciMemWindowSizeReg = PCI_1_MEMORY1_SIZE;
 | |
| 		remapRegLow = PCI_1_MEMORY1_LOW_ADDR_REMAP;
 | |
| 		remapRegHigh = PCI_1_MEMORY1_HIGH_ADDR_REMAP;
 | |
| 		break;
 | |
| 	case PCI_1_MEM3:
 | |
| 		pciMemWindowBaseAddrReg = PCI_1_MEMORY3_BASE_ADDR;
 | |
| 		pciMemWindowSizeReg = PCI_1_MEMORY3_SIZE;
 | |
| 		remapRegLow = PCI_1_MEMORY3_LOW_ADDR_REMAP;
 | |
| 		remapRegHigh = PCI_1_MEMORY3_HIGH_ADDR_REMAP;
 | |
| 		break;
 | |
| #endif /* INCLUDE_PCI_1 */
 | |
| 	default:
 | |
| 		/* Retrun an invalid effective base address */
 | |
| 		return 0xffffffff;
 | |
| 	}
 | |
| 	/* Writing the remap value to the remap regisers */
 | |
| 	GT_REG_WRITE (remapRegHigh, remapValueHigh);
 | |
| 	GT_REG_WRITE (remapRegLow, remapValueLow >> 16);
 | |
| 	/* Reading the values from the base address and size registers */
 | |
| 	baseAddrValue = GTREGREAD (pciMemWindowBaseAddrReg) & 0xfffff;
 | |
| 	windowSizeValue = GTREGREAD (pciMemWindowSizeReg) & 0xffff;
 | |
| 	/* Start calculating the effective Base Address */
 | |
| 	effectiveBaseAddress = baseAddrValue << 16;
 | |
| 	/* The effective base address will be combined from the chopped (if any)
 | |
| 	   remap value (according to the size value and remap mechanism) and the
 | |
| 	   window's base address */
 | |
| 	effectiveBaseAddress |=
 | |
| 		(((windowSizeValue << 16) | 0xffff) & remapValueLow);
 | |
| 	/* If the effectiveBaseAddress exceed the window boundaries return an
 | |
| 	   invalid value. */
 | |
| 	if (effectiveBaseAddress >
 | |
| 	    ((baseAddrValue << 16) + ((windowSizeValue << 16) | 0xffff)))
 | |
| 		return 0xffffffff;
 | |
| 	return effectiveBaseAddress;
 | |
| }
 | |
| 
 | |
| /********************************************************************
 | |
| * memorySetRegionSnoopMode - This function modifys one of the 4 regions which
 | |
| *                            supports Cache Coherency.
 | |
| *
 | |
| *
 | |
| * Inputs: SNOOP_REGION region - One of the four regions.
 | |
| *         SNOOP_TYPE snoopType - There is four optional Types:
 | |
| *                               1. No Snoop.
 | |
| *                               2. Snoop to WT region.
 | |
| *                               3. Snoop to WB region.
 | |
| *                               4. Snoop & Invalidate to WB region.
 | |
| *         unsigned int baseAddress - Base Address of this region.
 | |
| *         unsigned int topAddress - Top Address of this region.
 | |
| * Returns: false if one of the parameters is wrong and true else
 | |
| *********************************************************************/
 | |
| /* evb6260 code */
 | |
| #if 0
 | |
| bool memorySetRegionSnoopMode(MEMORY_SNOOP_REGION region,
 | |
| 			      MEMORY_SNOOP_TYPE snoopType,
 | |
| 			      unsigned int baseAddress,
 | |
| 			      unsigned int regionLength)
 | |
| {
 | |
|     unsigned int snoopXbaseAddress;
 | |
|     unsigned int snoopXtopAddress;
 | |
|     unsigned int data;
 | |
|     unsigned int snoopHigh = baseAddress + regionLength;
 | |
| 
 | |
|     if( (region > MEM_SNOOP_REGION3) || (snoopType > MEM_SNOOP_WB) )
 | |
| 	return false;
 | |
|     snoopXbaseAddress = SNOOP_BASE_ADDRESS_0 + 0x10 * region;
 | |
|     snoopXtopAddress = SNOOP_TOP_ADDRESS_0 + 0x10 * region;
 | |
| 				 if(regionLength == 0) /* closing the region */
 | |
|     {
 | |
| 	GT_REG_WRITE(snoopXbaseAddress,0x0000ffff);
 | |
| 	GT_REG_WRITE(snoopXtopAddress,0);
 | |
| 	return true;
 | |
|     }
 | |
|     baseAddress = baseAddress & 0xffff0000;
 | |
|     data = (baseAddress >> 16) | snoopType << 16;
 | |
|     GT_REG_WRITE(snoopXbaseAddress,data);
 | |
|     snoopHigh = (snoopHigh & 0xfff00000) >> 20;
 | |
|     GT_REG_WRITE(snoopXtopAddress,snoopHigh - 1);
 | |
|     return true;
 | |
| }
 | |
| #endif
 | |
| 
 | |
| /********************************************************************
 | |
| * memoryRemapAddress - This fubction used for address remapping.
 | |
| *
 | |
| *
 | |
| * Inputs: regOffset: remap register
 | |
| *         remapValue :
 | |
| * Returns: false if one of the parameters is erroneous,true otherwise.
 | |
| *
 | |
| * Not needed function To_do !!!!
 | |
| *********************************************************************/
 | |
| bool memoryRemapAddress (unsigned int remapReg, unsigned int remapValue)
 | |
| {
 | |
| 	unsigned int valueForReg;
 | |
| 
 | |
| 	valueForReg = (remapValue & 0xfff00000) >> 20;
 | |
| 	GT_REG_WRITE (remapReg, valueForReg);
 | |
| 	return true;
 | |
| }
 | |
| 
 | |
| /*******************************************************************************
 | |
| * memoryGetDeviceParam - Extract the device parameters from the device bank
 | |
| *                          parameters register.
 | |
| *
 | |
| * DESCRIPTION:
 | |
| *       To allow interfacing with very slow devices and fast synchronous SRAMs,
 | |
| *       each device can be programed to different timing parameters. Each bank
 | |
| *       has its own parameters register. Bank width can be programmed to 8, 16,
 | |
| *       or 32-bits. Bank timing parameters can be programmed to support
 | |
| *       different device types (e.g. Sync Burst SRAM, Flash , ROM, I/O
 | |
| *       Controllers). The MV allows you to set timing parameters and width for
 | |
| *       each device through parameters register .
 | |
| *       This function extracts the parameters described from the Device Bank
 | |
| *       parameters register and fills the given 'deviceParam' (defined in
 | |
| *       gtMemory.h) structure with the read data.
 | |
| *
 | |
| * INPUT:
 | |
| *       deviceParam -  pointer to a structure DEVICE_PARAM (defined in
 | |
| *                      Memory.h).For details about each structure field please
 | |
| *                      see the device timing parameter section in the MV
 | |
| *                      datasheet.
 | |
| *       deviceNum  -   Select on of the five device banks (defined in
 | |
| *                      Memory.h) :
 | |
| *
 | |
| *                       - DEVICE0
 | |
| *                       - DEVICE1
 | |
| *                       - DEVICE2
 | |
| *                       - etc.
 | |
| *
 | |
| * OUTPUT:
 | |
| *       None.
 | |
| *
 | |
| * RETURN:
 | |
| *       false if one of the parameters is erroneous,true otherwise.
 | |
| *
 | |
| *******************************************************************************/
 | |
| /********************************************************************
 | |
| * memoryGetDeviceParam - This function used for getting device parameters from
 | |
| *                        DEVICE BANK PARAMETERS REGISTER
 | |
| *
 | |
| *
 | |
| * Inputs:        - deviceParam: STRUCT with paramiters for DEVICE BANK
 | |
| *                  PARAMETERS REGISTER
 | |
| *                - deviceNum : number of device
 | |
| * Returns: false if one of the parameters is erroneous,true otherwise.
 | |
| *********************************************************************/
 | |
| 
 | |
| bool memoryGetDeviceParam (DEVICE_PARAM * deviceParam, DEVICE deviceNum)
 | |
| {
 | |
| 	unsigned int valueOfReg;
 | |
| 	unsigned int calcData;
 | |
| 
 | |
| 	if (deviceNum > 4)
 | |
| 		return false;
 | |
| 	GT_REG_READ (DEVICE_BANK0PARAMETERS + 4 * deviceNum, &valueOfReg);
 | |
| 	calcData = (0x7 & valueOfReg) + ((BIT22 & valueOfReg) >> 19);
 | |
| 	deviceParam->turnOff = calcData;	/* Turn Off */
 | |
| 
 | |
| 	calcData = ((0x78 & valueOfReg) >> 3) + ((BIT23 & valueOfReg) >> 19);
 | |
| 	deviceParam->acc2First = calcData;	/* Access To First */
 | |
| 
 | |
| 	calcData = ((0x780 & valueOfReg) >> 7) + ((BIT24 & valueOfReg) >> 20);
 | |
| 	deviceParam->acc2Next = calcData;	/* Access To Next */
 | |
| 
 | |
| 	calcData =
 | |
| 		((0x3800 & valueOfReg) >> 11) + ((BIT25 & valueOfReg) >> 22);
 | |
| 	deviceParam->ale2Wr = calcData;	/* Ale To Write */
 | |
| 
 | |
| 	calcData = ((0x1c000 & valueOfReg) >> 14) +
 | |
| 		((BIT26 & valueOfReg) >> 23);
 | |
| 	deviceParam->wrLow = calcData;	/* Write Active */
 | |
| 
 | |
| 	calcData = ((0xe0000 & valueOfReg) >> 17) +
 | |
| 		((BIT27 & valueOfReg) >> 24);
 | |
| 	deviceParam->wrHigh = calcData;	/* Write High */
 | |
| 
 | |
| 	calcData = ((0x300000 & valueOfReg) >> 20);
 | |
| 	deviceParam->deviceWidth = (BIT0 << calcData);	/* In bytes */
 | |
| 	calcData = ((0x30000000 & valueOfReg) >> 28);
 | |
| 	deviceParam->badrSkew = calcData;	/* Cycles gap between BAdr
 | |
| 						   toggle to read data sample. */
 | |
| 	calcData = ((0x40000000 & valueOfReg) >> 30);
 | |
| 	deviceParam->DPEn = calcData;	/*  Data Parity enable  */
 | |
| 	return true;
 | |
| }
 | |
| 
 | |
| /*******************************************************************************
 | |
| * memorySetDeviceParam - Set new parameters for a device.
 | |
| *
 | |
| *
 | |
| * DESCRIPTION:
 | |
| *       To allow interfacing with very slow devices and fast synchronous SRAMs,
 | |
| *       each device can be programed to different timing parameters. Each bank
 | |
| *       has its own parameters register. Bank width can be programmed to 8, 16,
 | |
| *       or 32-bits. Bank timing parameters can be programmed to support
 | |
| *       different device types (e.g. Sync Burst SRAM, Flash , ROM, I/O
 | |
| *       Controllers). The MV allows you to set timing parameters and width for
 | |
| *       each device through parameters register. This function set new
 | |
| *       parameters to a device Bank from the delivered structure 'deviceParam'
 | |
| *       (defined in gtMemory.h). The structure must be initialized with data
 | |
| *       prior to the use of these function.
 | |
| *
 | |
| * INPUT:
 | |
| *       deviceParam -  pointer to a structure DEVICE_PARAM (defined in
 | |
| *                      Memory.h).For details about each structure field please
 | |
| *                      see the device timing parameter section in the MV
 | |
| *                      datasheet.
 | |
| *       deviceNum  -   Select on of the five device banks (defined in
 | |
| *                      Memory.h) :
 | |
| *
 | |
| *                       - DEVICE0
 | |
| *                       - DEVICE1
 | |
| *                       - DEVICE2
 | |
| *                       - etc.
 | |
| *
 | |
| * OUTPUT:
 | |
| *       None.
 | |
| *
 | |
| * RETURN:
 | |
| *       false if one of the parameters is erroneous,true otherwise.
 | |
| *
 | |
| *******************************************************************************/
 | |
| /********************************************************************
 | |
| * memorySetDeviceParam - This function used for setting device parameters to
 | |
| *                        DEVICE BANK PARAMETERS REGISTER
 | |
| *
 | |
| *
 | |
| * Inputs:        - deviceParam: STRUCT for store paramiters from DEVICE BANK
 | |
| *                  PARAMETERS REGISTER
 | |
| *                - deviceNum : number of device
 | |
| * Returns: false if one of the parameters is erroneous,true otherwise.
 | |
| *********************************************************************/
 | |
| bool memorySetDeviceParam (DEVICE_PARAM * deviceParam, DEVICE deviceNum)
 | |
| {
 | |
| 	unsigned int valueForReg;
 | |
| 
 | |
| 	if ((deviceParam->turnOff > 0x7) || (deviceParam->acc2First > 0xf) ||
 | |
| 	    (deviceParam->acc2Next > 0xf) || (deviceParam->ale2Wr > 0x7) ||
 | |
| 	    (deviceParam->wrLow > 0x7) || (deviceParam->wrHigh > 0x7) ||
 | |
| 	    (deviceParam->badrSkew > 0x2) || (deviceParam->DPEn > 0x1)) {
 | |
| 		return false;
 | |
| 	}
 | |
| 	valueForReg = (((deviceParam->turnOff) & 0x7) |
 | |
| 		       (((deviceParam->turnOff) & 0x8) << 19) |
 | |
| 		       (((deviceParam->acc2First) & 0xf) << 3) |
 | |
| 		       (((deviceParam->acc2First) & 0x10) << 19) |
 | |
| 		       (((deviceParam->acc2Next) & 0xf) << 7) |
 | |
| 		       (((deviceParam->acc2Next) & 0x10) << 20) |
 | |
| 		       (((deviceParam->ale2Wr) & 0x7) << 11) |
 | |
| 		       (((deviceParam->ale2Wr) & 0xf) << 22) |
 | |
| 		       (((deviceParam->wrLow) & 0x7) << 14) |
 | |
| 		       (((deviceParam->wrLow) & 0xf) << 23) |
 | |
| 		       (((deviceParam->wrHigh) & 0x7) << 17) |
 | |
| 		       (((deviceParam->wrHigh) & 0xf) << 24) |
 | |
| 		       (((deviceParam->badrSkew) & 0x3) << 28) |
 | |
| 		       (((deviceParam->DPEn) & 0x1) << 30));
 | |
| 
 | |
| 	/* insert the device width: */
 | |
| 	switch (deviceParam->deviceWidth) {
 | |
| 	case 1:
 | |
| 		valueForReg = valueForReg | _8BIT;
 | |
| 		break;
 | |
| 	case 2:
 | |
| 		valueForReg = valueForReg | _16BIT;
 | |
| 		break;
 | |
| 	case 4:
 | |
| 		valueForReg = valueForReg | _32BIT;
 | |
| 		break;
 | |
| 	default:
 | |
| 		valueForReg = valueForReg | _8BIT;
 | |
| 		break;
 | |
| 	}
 | |
| 	GT_REG_WRITE (DEVICE_BANK0PARAMETERS + 4 * deviceNum, valueForReg);
 | |
| 	return true;
 | |
| }
 | |
| 
 | |
| /*******************************************************************************
 | |
| * MemoryDisableWindow - Disable a memory space by the disable bit.
 | |
| * DESCRIPTION:
 | |
| *       This function disables one of the 21 availiable windows dedicated for
 | |
| *       the CPU decoding mechanism. Its possible to combine several windows with
 | |
| *       the OR command.
 | |
| * INPUT:
 | |
| *       window - One or more of the memory windows (defined in gtMemory.h).
 | |
| * OUTPUT:
 | |
| *       None.
 | |
| * RETURN:
 | |
| *       None.
 | |
| *******************************************************************************/
 | |
| void MemoryDisableWindow (MEMORY_WINDOW window)
 | |
| {
 | |
| 	SET_REG_BITS (BASE_ADDR_ENABLE, window);
 | |
| }
 | |
| 
 | |
| /*******************************************************************************
 | |
| * MemoryEnableWindow - Enable a memory space that was disabled by
 | |
| *                       'MemoryDisableWindow'.
 | |
| * DESCRIPTION:
 | |
| *       This function enables one of the 21 availiable windows dedicated for the
 | |
| *       CPU decoding mechanism. Its possible to combine several windows with the
 | |
| *       OR command.
 | |
| * INPUT:
 | |
| *       window - One or more of the memory windows (defined in gtMemory.h).
 | |
| * OUTPUT:
 | |
| *       None.
 | |
| * RETURN:
 | |
| *       None.
 | |
| *******************************************************************************/
 | |
| void MemoryEnableWindow (MEMORY_WINDOW window)
 | |
| {
 | |
| 	RESET_REG_BITS (BASE_ADDR_ENABLE, window);
 | |
| }
 | |
| 
 | |
| /*******************************************************************************
 | |
| * MemoryGetMemWindowStatus - This function check whether the memory window is
 | |
| *                              disabled or not.
 | |
| * DESCRIPTION:
 | |
| *       This function checks if the given memory window is closed .
 | |
| * INPUT:
 | |
| *       window - One or more of the memory windows (defined in gtMemory.h).
 | |
| * OUTPUT:
 | |
| *       None.
 | |
| * RETURN:
 | |
| *       True for a closed window, false otherwise .
 | |
| *******************************************************************************/
 | |
| MEMORY_WINDOW_STATUS MemoryGetMemWindowStatus (MEMORY_WINDOW window)
 | |
| {
 | |
| 	if (GTREGREAD (BASE_ADDR_ENABLE) & window)
 | |
| 		return MEM_WINDOW_DISABLED;
 | |
| 	return MEM_WINDOW_ENABLED;
 | |
| }
 |