forked from Imagelibrary/rtems
bsp/lpc24xx: Simplify EMC configuration
This commit is contained in:
@@ -34,6 +34,20 @@
|
||||
extern "C" {
|
||||
#endif /* __cplusplus */
|
||||
|
||||
/**
|
||||
* @brief Pico seconds @a ps to clock ticks for clock frequency @a f.
|
||||
*/
|
||||
#define LPC24XX_PS_TO_CLK(ps, f) \
|
||||
(((((uint64_t) (ps)) * ((uint64_t) (f))) + 1000000000000ULL - 1ULL) \
|
||||
/ 1000000000000ULL)
|
||||
|
||||
/**
|
||||
* @brief Pico seconds @a ps to EMCCLK clock ticks adjusted by @a m.
|
||||
*/
|
||||
#define LPC24XX_PS_TO_EMCCLK(ps, m) \
|
||||
(LPC24XX_PS_TO_CLK(ps, LPC24XX_EMCCLK) > (m) ? \
|
||||
LPC24XX_PS_TO_CLK(ps, LPC24XX_EMCCLK) - (m) : 0)
|
||||
|
||||
typedef struct {
|
||||
uint32_t refresh;
|
||||
uint32_t readconfig;
|
||||
|
||||
@@ -7,7 +7,7 @@
|
||||
*/
|
||||
|
||||
/*
|
||||
* Copyright (c) 2011 embedded brains GmbH. All rights reserved.
|
||||
* Copyright (c) 2011-2012 embedded brains GmbH. All rights reserved.
|
||||
*
|
||||
* embedded brains GmbH
|
||||
* Obere Lagerstr. 30
|
||||
@@ -28,8 +28,8 @@ BSP_START_DATA_SECTION const lpc24xx_emc_dynamic_config
|
||||
#if defined(LPC24XX_EMC_MT48LC4M16A2)
|
||||
/* Dynamic Memory 0: Micron M T48LC 4M16 A2 P 75 IT */
|
||||
{
|
||||
/* Auto-refresh command every 15.6 us */
|
||||
.refresh = 0x46,
|
||||
/* 15.6 us */
|
||||
.refresh = LPC24XX_PS_TO_EMCCLK(15600000, 0) / 16,
|
||||
|
||||
/* Use command delayed strategy */
|
||||
.readconfig = 1,
|
||||
@@ -68,82 +68,82 @@ BSP_START_DATA_SECTION const lpc24xx_emc_dynamic_config
|
||||
.tmrd = 1
|
||||
}
|
||||
#elif defined(LPC24XX_EMC_IS42S32800D7)
|
||||
/* Dynamic Memory 0: ISSI IS42S32800D7 at 51612800Hz (tCK = 19.4ns) */
|
||||
/* Dynamic Memory 0: ISSI IS42S32800D7 */
|
||||
{
|
||||
/* (n * 16) clock cycles -> 15.5us <= 15.6 us */
|
||||
.refresh = 50,
|
||||
/* 15.6 us */
|
||||
.refresh = LPC24XX_PS_TO_EMCCLK(15600000, 0) / 16,
|
||||
|
||||
/* Use command delayed strategy */
|
||||
.readconfig = 1,
|
||||
|
||||
/* (n + 1) clock cycles -> 38.8ns >= 20ns */
|
||||
.trp = 1,
|
||||
/* 20ns */
|
||||
.trp = LPC24XX_PS_TO_EMCCLK(20000, 1),
|
||||
|
||||
/* (n + 1) clock cycles -> 58.1ns >= 45ns */
|
||||
.tras = 2,
|
||||
/* 45ns */
|
||||
.tras = LPC24XX_PS_TO_EMCCLK(45000, 1),
|
||||
|
||||
/* (n + 1) clock cycles -> 77.5ns >= 70ns (tXSR) */
|
||||
.tsrex = 3,
|
||||
/* 70ns (tXSR) */
|
||||
.tsrex = LPC24XX_PS_TO_EMCCLK(70000, 1),
|
||||
|
||||
/* (n + 1) clock cycles -> 38.8ns >= 20ns (tRCD) */
|
||||
.tapr = 1,
|
||||
/* 20ns (tRCD) */
|
||||
.tapr = LPC24XX_PS_TO_EMCCLK(20000, 1),
|
||||
|
||||
/* n clock cycles -> 38.8ns >= 35ns */
|
||||
.tdal = 2,
|
||||
.tdal = LPC24XX_PS_TO_EMCCLK(35000, 0),
|
||||
|
||||
/* (n + 1) clock cycles = 19.4ns >= 14ns (tDPL) */
|
||||
.twr = 0,
|
||||
/* 14ns (tDPL) */
|
||||
.twr = LPC24XX_PS_TO_EMCCLK(14000, 1),
|
||||
|
||||
/* (n + 1) clock cycles = 77.5ns >= 67.5ns */
|
||||
.trc = 3,
|
||||
/* 67.5ns */
|
||||
.trc = LPC24XX_PS_TO_EMCCLK(67500, 1),
|
||||
|
||||
/* (n + 1) clock cycles = 77.5ns >= 67.5ns (tRC) */
|
||||
.trfc = 3,
|
||||
/* 67.5ns (tRC) */
|
||||
.trfc = LPC24XX_PS_TO_EMCCLK(67500, 1),
|
||||
|
||||
/* (n + 1) clock cycles = 77.5ns >= 70ns */
|
||||
.txsr = 3,
|
||||
/* 70ns */
|
||||
.txsr = LPC24XX_PS_TO_EMCCLK(70000, 1),
|
||||
|
||||
/* (n + 1) clock cycles = 19.4ns >= 14ns */
|
||||
.trrd = 0,
|
||||
/* 14ns */
|
||||
.trrd = LPC24XX_PS_TO_EMCCLK(14000, 1),
|
||||
|
||||
/* (n + 1) clock cycles = 19.4ns >= 14ns */
|
||||
.tmrd = 0
|
||||
/* 14ns */
|
||||
.tmrd = LPC24XX_PS_TO_EMCCLK(14000, 1)
|
||||
}
|
||||
#elif defined(LPC24XX_EMC_W9825G2JB75I)
|
||||
/* Dynamic Memory 0: Winbond W9825G2JB75I at 51612800Hz (tCK = 19.4ns) */
|
||||
/* Dynamic Memory 0: Winbond W9825G2JB75I */
|
||||
{
|
||||
/* (n * 16) clock cycles -> 15.5us <= 15.6 us */
|
||||
.refresh = 50,
|
||||
/* 15.6 us */
|
||||
.refresh = LPC24XX_PS_TO_EMCCLK(15600000, 0) / 16,
|
||||
|
||||
/* Use command delayed strategy */
|
||||
.readconfig = 1,
|
||||
|
||||
/* (n + 1) clock cycles -> 38.8ns >= 20ns */
|
||||
.trp = 1,
|
||||
/* 20ns */
|
||||
.trp = LPC24XX_PS_TO_EMCCLK(20000, 1),
|
||||
|
||||
/* (n + 1) clock cycles -> 58.1ns >= 45ns */
|
||||
.tras = 2,
|
||||
/* 45ns */
|
||||
.tras = LPC24XX_PS_TO_EMCCLK(45000, 1),
|
||||
|
||||
/* (n + 1) clock cycles -> 77.5ns >= 75ns (tXSR) */
|
||||
.tsrex = 3,
|
||||
/* 75ns (tXSR) */
|
||||
.tsrex = LPC24XX_PS_TO_EMCCLK(75000, 1),
|
||||
|
||||
/* (n + 1) clock cycles -> 38.8ns >= 20ns (tRCD) */
|
||||
.tapr = 1,
|
||||
/* 20ns (tRCD) */
|
||||
.tapr = LPC24XX_PS_TO_EMCCLK(20000, 1),
|
||||
|
||||
/* n clock cycles -> 77.5ns >= tWR + tRP -> 2 * tCK + 20ns */
|
||||
.tdal = 4,
|
||||
/* tWR + tRP -> 2 * tCK + 20ns */
|
||||
.tdal = 2 + LPC24XX_PS_TO_EMCCLK(20000, 0),
|
||||
|
||||
/* (n + 1) clock cycles == 2 * tCK */
|
||||
.twr = 1,
|
||||
|
||||
/* (n + 1) clock cycles = 77.5ns >= 65ns */
|
||||
.trc = 3,
|
||||
/* 65ns */
|
||||
.trc = LPC24XX_PS_TO_EMCCLK(65000, 1),
|
||||
|
||||
/* (n + 1) clock cycles = 77.5ns >= 65ns (tRC) */
|
||||
.trfc = 3,
|
||||
/* 65ns (tRC) */
|
||||
.trfc = LPC24XX_PS_TO_EMCCLK(65000, 1),
|
||||
|
||||
/* (n + 1) clock cycles = 77.5ns >= 75ns */
|
||||
.txsr = 3,
|
||||
/* 75ns */
|
||||
.txsr = LPC24XX_PS_TO_EMCCLK(50000, 1),
|
||||
|
||||
/* (n + 1) clock cycles == 2 * tCK */
|
||||
.trrd = 1,
|
||||
@@ -168,71 +168,49 @@ BSP_START_DATA_SECTION const lpc24xx_emc_dynamic_config
|
||||
.tmrd = 2
|
||||
}
|
||||
#elif defined(LPC24XX_EMC_IS42S32800B)
|
||||
#if LPC24XX_EMCCLK == 72000000U
|
||||
{
|
||||
/* tCK = 13.888ns at 72MHz */
|
||||
{
|
||||
/* 15.6us */
|
||||
.refresh = LPC24XX_PS_TO_EMCCLK(15600000, 0) / 16,
|
||||
|
||||
/* (n * 16) clock cycles -> 15.556us <= 15.6us */
|
||||
.refresh = 70,
|
||||
/* Use command delayed strategy */
|
||||
.readconfig = 1,
|
||||
|
||||
.readconfig = 1,
|
||||
/* 20ns */
|
||||
.trp = LPC24XX_PS_TO_EMCCLK(20000, 1),
|
||||
|
||||
/* (n + 1) clock cycles -> 27.8ns >= 20ns */
|
||||
.trp = 1,
|
||||
/* 45ns */
|
||||
.tras = LPC24XX_PS_TO_EMCCLK(45000, 1),
|
||||
|
||||
/* (n + 1) clock cycles -> 55.5ns >= 45ns */
|
||||
.tras = 3,
|
||||
/* 70ns (tRC) */
|
||||
.tsrex = LPC24XX_PS_TO_EMCCLK(70000, 1),
|
||||
|
||||
/* (n + 1) clock cycles -> 69.4ns >= 70ns (tRC) */
|
||||
.tsrex = 5,
|
||||
/* FIXME */
|
||||
.tapr = LPC24XX_PS_TO_EMCCLK(40000, 1),
|
||||
|
||||
/* (n + 1) clock cycles -> 41.7ns >= FIXME */
|
||||
.tapr = 2,
|
||||
/* tWR + tRP -> 2 * tCK + 20ns */
|
||||
.tdal = 2 + LPC24XX_PS_TO_EMCCLK(20000, 0),
|
||||
|
||||
/* n clock cycles -> 55.5ns >= tWR + tRP = 47.8ns */
|
||||
.tdal = 4,
|
||||
/* (n + 1) clock cycles == 2 * tCK */
|
||||
.twr = 1,
|
||||
|
||||
/* (n + 1) clock cycles == 2 * tCK */
|
||||
.twr = 1,
|
||||
/* 70ns */
|
||||
.trc = LPC24XX_PS_TO_EMCCLK(70000, 1),
|
||||
|
||||
/* (n + 1) clock cycles -> 83.3ns >= 70ns */
|
||||
.trc = 5,
|
||||
/* 70ns */
|
||||
.trfc = LPC24XX_PS_TO_EMCCLK(70000, 1),
|
||||
|
||||
/* (n + 1) clock cycles -> 83.3ns >= 70ns */
|
||||
.trfc = 5,
|
||||
/* 70ns (tRC) */
|
||||
.txsr = LPC24XX_PS_TO_EMCCLK(70000, 1),
|
||||
|
||||
/* (n + 1) clock cycles -> 69.4ns >= 70ns (tRC) */
|
||||
.txsr = 5,
|
||||
/* 14ns */
|
||||
.trrd = LPC24XX_PS_TO_EMCCLK(14000, 1),
|
||||
|
||||
/* (n + 1) clock cycles -> 27.8ns >= 14ns */
|
||||
.trrd = 1,
|
||||
/* (n + 1) clock cycles == 2 * tCK */
|
||||
.tmrd = 1,
|
||||
|
||||
/* (n + 1) clock cycles == 2 * tCK */
|
||||
.tmrd = 1,
|
||||
|
||||
/* FIXME */
|
||||
.emcdlyctl = 0x1112
|
||||
}
|
||||
#elif LPC24XX_EMCCLK == 60000000U
|
||||
{
|
||||
.refresh = 0x3a,
|
||||
.readconfig = 1,
|
||||
.trp = 1,
|
||||
.tras = 3,
|
||||
.tsrex = 5,
|
||||
.tapr = 2,
|
||||
.tdal = 3,
|
||||
.twr = 1,
|
||||
.trc = 4,
|
||||
.trfc = 4,
|
||||
.txsr = 5,
|
||||
.trrd = 1,
|
||||
.tmrd = 1,
|
||||
.emcdlyctl = 0x1112
|
||||
}
|
||||
#else
|
||||
#error "unexpected EMCCLK"
|
||||
#endif
|
||||
/* FIXME */
|
||||
.emcdlyctl = 0x1112
|
||||
}
|
||||
#endif
|
||||
};
|
||||
|
||||
|
||||
@@ -65,7 +65,7 @@ BSP_START_DATA_SECTION const lpc24xx_emc_static_chip_config
|
||||
}
|
||||
}
|
||||
#elif defined(LPC24XX_EMC_M29W320E70)
|
||||
/* Static Memory 0: M29W320E70 at 51612800Hz (tCK = 19.4ns) */
|
||||
/* Static Memory 0: M29W320E70 */
|
||||
{
|
||||
.chip_select = (volatile lpc_emc_static *) EMC_STA_BASE_0,
|
||||
.config = {
|
||||
@@ -75,27 +75,27 @@ BSP_START_DATA_SECTION const lpc24xx_emc_static_chip_config
|
||||
*/
|
||||
.config = 0x81,
|
||||
|
||||
/* (n + 1) clock cycles -> 38.8ns >= 30ns (tWHWL) */
|
||||
.waitwen = 1,
|
||||
/* 30ns (tWHWL) */
|
||||
.waitwen = LPC24XX_PS_TO_EMCCLK(30000, 1),
|
||||
|
||||
/* (n + 1) clock cycles -> 19.4ns >= 0ns */
|
||||
.waitoen = 0,
|
||||
/* 0ns */
|
||||
.waitoen = LPC24XX_PS_TO_EMCCLK(0, 1),
|
||||
|
||||
/* (n + 1) clock cycles -> 77.5ns >= 70ns (tAVQV, tELQV) */
|
||||
.waitrd = 3,
|
||||
/* 70ns (tAVQV, tELQV) */
|
||||
.waitrd = LPC24XX_PS_TO_EMCCLK(70000, 1),
|
||||
|
||||
/* (n + 1) clock cycles -> 77.5ns >= 70ns (tAVQV, tELQV) */
|
||||
.waitpage = 3,
|
||||
/* 70ns (tAVQV, tELQV) */
|
||||
.waitpage = LPC24XX_PS_TO_EMCCLK(70000, 1),
|
||||
|
||||
/* (n + 2) clock cycles -> 58.1ns >= 45ns (tWLWH) */
|
||||
.waitwr = 1,
|
||||
/* 45ns (tWLWH) */
|
||||
.waitwr = LPC24XX_PS_TO_EMCCLK(45000, 2),
|
||||
|
||||
/* (n + 1) clock cycles -> 38.8ns >= 25ns (tEHQZ) */
|
||||
.waitrun = 1
|
||||
/* 25ns (tEHQZ) */
|
||||
.waitrun = LPC24XX_PS_TO_EMCCLK(25000, 1)
|
||||
}
|
||||
}
|
||||
#elif defined(LPC24XX_EMC_SST39VF3201)
|
||||
/* Static Memory 0: SST39VF3201 at 51612800Hz (tCK = 19.4ns) */
|
||||
/* Static Memory 0: SST39VF3201 */
|
||||
{
|
||||
.chip_select = (volatile lpc_emc_static *) EMC_STA_BASE_0,
|
||||
.config = {
|
||||
@@ -105,23 +105,23 @@ BSP_START_DATA_SECTION const lpc24xx_emc_static_chip_config
|
||||
*/
|
||||
.config = 0x81,
|
||||
|
||||
/* (n + 1) clock cycles -> 19.4ns >= 0ns (tCS, tAS) */
|
||||
.waitwen = 0,
|
||||
/* 0ns (tCS, tAS) */
|
||||
.waitwen = LPC24XX_PS_TO_EMCCLK(0, 1),
|
||||
|
||||
/* (n + 1) clock cycles -> 19.4ns >= 0ns (tOES) */
|
||||
.waitoen = 0,
|
||||
/* 0ns (tOES) */
|
||||
.waitoen = LPC24XX_PS_TO_EMCCLK(0, 1),
|
||||
|
||||
/* (n + 1) clock cycles -> 77.5ns >= 70ns (tRC) */
|
||||
.waitrd = 2,
|
||||
/* 70ns (tRC) */
|
||||
.waitrd = LPC24XX_PS_TO_EMCCLK(70000, 1),
|
||||
|
||||
/* (n + 1) clock cycles -> 77.5ns >= 70ns (tRC) */
|
||||
.waitpage = 2,
|
||||
/* 70ns (tRC) */
|
||||
.waitpage = LPC24XX_PS_TO_EMCCLK(70000, 1),
|
||||
|
||||
/* (n + 2) clock cycles -> 38.8ns >= 20ns (tCHZ, TOHZ) */
|
||||
.waitwr = 0,
|
||||
/* 20ns (tCHZ, TOHZ) */
|
||||
.waitwr = LPC24XX_PS_TO_EMCCLK(20000, 2),
|
||||
|
||||
/* (n + 1) clock cycles -> 38.8ns >= 20ns (tCHZ, TOHZ) */
|
||||
.waitrun = 1
|
||||
/* 20ns (tCHZ, TOHZ) */
|
||||
.waitrun = LPC24XX_PS_TO_EMCCLK(20000, 1)
|
||||
}
|
||||
}
|
||||
#endif
|
||||
|
||||
Reference in New Issue
Block a user