2013-09-12 13:58:33 +07:00
|
|
|
|
/**********************************************************************
|
|
|
|
|
* $Id: lpc43xx_emc.h 8765 2011-12-08 00:51:21Z nxp21346 $ lpc43xx_emc.h 2011-12-07
|
|
|
|
|
*//**
|
|
|
|
|
* @file lpc43xx_emc.h
|
|
|
|
|
* @brief Contains all functions support for Clock Generation and Control
|
|
|
|
|
* firmware library on lpc43xx
|
|
|
|
|
* @version 1.0
|
|
|
|
|
* @date 07. December. 2011
|
|
|
|
|
* @author NXP MCU SW Application Team
|
|
|
|
|
*
|
|
|
|
|
* Copyright(C) 2011, NXP Semiconductor
|
|
|
|
|
* All rights reserved.
|
|
|
|
|
*
|
|
|
|
|
***********************************************************************
|
|
|
|
|
* Software that is described herein is for illustrative purposes only
|
|
|
|
|
* which provides customers with programming information regarding the
|
|
|
|
|
* products. This software is supplied "AS IS" without any warranties.
|
|
|
|
|
* NXP Semiconductors assumes no responsibility or liability for the
|
|
|
|
|
* use of the software, conveys no license or title under any patent,
|
|
|
|
|
* copyright, or mask work right to the product. NXP Semiconductors
|
|
|
|
|
* reserves the right to make changes in the software without
|
|
|
|
|
* notification. NXP Semiconductors also make no representation or
|
|
|
|
|
* warranty that such application will be suitable for the specified
|
|
|
|
|
* use without further testing or modification.
|
|
|
|
|
* Permission to use, copy, modify, and distribute this software and its
|
|
|
|
|
* documentation is hereby granted, under NXP Semiconductors<EFBFBD>
|
|
|
|
|
* relevant copyright in the software, without fee, provided that it
|
|
|
|
|
* is used in conjunction with NXP Semiconductors microcontrollers. This
|
|
|
|
|
* copyright, permission, and disclaimer notice must appear in all copies of
|
|
|
|
|
* this code.
|
|
|
|
|
**********************************************************************/
|
|
|
|
|
|
|
|
|
|
#define __CRYSTAL (12000000UL) /* Crystal Oscillator frequency */
|
|
|
|
|
#define __PLLMULT (15)
|
|
|
|
|
#define __PLLOUTHZ (__CRYSTAL * __PLLMULT)
|
|
|
|
|
#define __EMCDIV (2)
|
|
|
|
|
#define __EMCHZ (__PLLOUTHZ / __EMCDIV)
|
|
|
|
|
|
|
|
|
|
void MemoryPinInit(void);
|
|
|
|
|
void EMCFlashInit(void);
|
|
|
|
|
|
|
|
|
|
/* SDRAM Address Base for DYCS0*/
|
|
|
|
|
#define SDRAM_BASE_ADDR 0x28000000
|
|
|
|
|
#define FLASH_BASE_ADDR 0x1C000000
|
|
|
|
|
|
|
|
|
|
#define EMC_SDRAM_WIDTH_8_BITS 0
|
|
|
|
|
#define EMC_SDRAM_WIDTH_16_BITS 1
|
|
|
|
|
#define EMC_SDRAM_WIDTH_32_BITS 2
|
|
|
|
|
|
|
|
|
|
#define EMC_SDRAM_SIZE_16_MBITS 0
|
|
|
|
|
#define EMC_SDRAM_SIZE_64_MBITS 1
|
|
|
|
|
#define EMC_SDRAM_SIZE_128_MBITS 2
|
|
|
|
|
#define EMC_SDRAM_SIZE_256_MBITS 3
|
|
|
|
|
#define EMC_SDRAM_SIZE_512_MBITS 4
|
|
|
|
|
|
|
|
|
|
#define EMC_SDRAM_DATA_BUS_16_BITS 0
|
|
|
|
|
#define EMC_SDRAM_DATA_BUS_32_BITS 1
|
|
|
|
|
|
|
|
|
|
#define EMC_B_ENABLE (1 << 19)
|
|
|
|
|
#define EMC_ENABLE (1 << 0)
|
|
|
|
|
#define EMC_CE_ENABLE (1 << 0)
|
|
|
|
|
#define EMC_CS_ENABLE (1 << 1)
|
|
|
|
|
#define EMC_CLOCK_DELAYED_STRATEGY (0 << 0)
|
|
|
|
|
#define EMC_COMMAND_DELAYED_STRATEGY (1 << 0)
|
|
|
|
|
#define EMC_COMMAND_DELAYED_STRATEGY2 (2 << 0)
|
|
|
|
|
#define EMC_COMMAND_DELAYED_STRATEGY3 (3 << 0)
|
|
|
|
|
#define EMC_INIT(i) ((i) << 7)
|
|
|
|
|
#define EMC_NORMAL (0)
|
|
|
|
|
#define EMC_MODE (1)
|
|
|
|
|
#define EMC_PRECHARGE_ALL (2)
|
|
|
|
|
#define EMC_NOP (3)
|
|
|
|
|
|
|
|
|
|
/* The Hitex LPC18xx Evaluation board contains a 64Mb SDRAM with a 16-bit data bus */
|
2013-09-12 14:06:59 +07:00
|
|
|
|
#if(PLATFORM == HITEX_BOARD)
|
|
|
|
|
|
|
|
|
|
#define SDRAM_SIZE_BYTES (1024UL * 1024UL * 8UL)
|
|
|
|
|
#define SDRAM_WIDTH EMC_SDRAM_WIDTH_16_BITS
|
|
|
|
|
#define SDRAM_SIZE_MBITS EMC_SDRAM_SIZE_64_MBITS
|
|
|
|
|
#define SDRAM_DATA_BUS_BITS EMC_SDRAM_DATA_BUS_16_BITS
|
|
|
|
|
#define SDRAM_COL_ADDR_BITS 8
|
|
|
|
|
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
#if(PLATFORM == KEIL_BOARD)
|
|
|
|
|
// TODO adapt these for the MCB4357 !!!!
|
2013-09-12 13:58:33 +07:00
|
|
|
|
#define SDRAM_SIZE_BYTES (1024UL * 1024UL * 8UL)
|
|
|
|
|
#define SDRAM_WIDTH EMC_SDRAM_WIDTH_16_BITS
|
|
|
|
|
#define SDRAM_SIZE_MBITS EMC_SDRAM_SIZE_64_MBITS
|
|
|
|
|
#define SDRAM_DATA_BUS_BITS EMC_SDRAM_DATA_BUS_16_BITS
|
|
|
|
|
#define SDRAM_COL_ADDR_BITS 8
|
2013-09-12 14:06:59 +07:00
|
|
|
|
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
// CLK0_DELAY needs to be tuned depending on the external memory bus speed.
|
|
|
|
|
// For operation at 102 MHz it should be 6 or 7
|
|
|
|
|
#define CLK0_DELAY 7
|
2013-09-12 13:58:33 +07:00
|
|
|
|
|
|
|
|
|
void vEMC_InitSRDRAM(uint32_t u32BaseAddr, uint32_t u32Width, uint32_t u32Size, uint32_t u32DataBus, uint32_t u32ColAddrBits);
|
|
|
|
|
void emc_WaitUS(volatile uint32_t us);
|
|
|
|
|
void emc_WaitMS(uint32_t ms);
|
|
|
|
|
|