123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521 |
- /*
- * Memory Setup stuff - taken from blob memsetup.S
- *
- * Copyright (C) 1999 2000 2001 Erik Mouw (J.A.K.Mouw@its.tudelft.nl) and
- * Jan-Derk Bakker (J.D.Bakker@its.tudelft.nl)
- *
- * Modified for MPL VCMA9 by
- * David Mueller, ELSOFT AG, <d.mueller@elsoft.ch>
- * (C) Copyright 2002, 2003, 2004, 2005
- *
- * 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
- */
- #include <config.h>
- #include <version.h>
- /* register definitions */
- #define PLD_BASE 0x28000000
- #define MISC_REG 0x103
- #define SDRAM_REG 0x106
- #define BWSCON 0x48000000
- #define CLKBASE 0x4C000000
- #define LOCKTIME 0x0
- #define MPLLCON 0x4
- #define UPLLCON 0x8
- #define GPIOBASE 0x56000000
- #define GSTATUS1 0xB0
- #define FASTCPU 0x02
- /* some parameters for the board */
- /* BWSCON */
- #define DW8 (0x0)
- #define DW16 (0x1)
- #define DW32 (0x2)
- #define WAIT (0x1<<2)
- #define UBLB (0x1<<3)
- /* BANKSIZE */
- #define BURST_EN (0x1<<7)
- /* BANK0CON 200 */
- #define B0_Tacs_200 0x0 /* 0clk (or 0x1 1clk) */
- #define B0_Tcos_200 0x1 /* 1clk (or 0x2 2clk) */
- #define B0_Tacc_200 0x5 /* 8clk (or 0x6 10clk) */
- #define B0_Tcoh_200 0x0 /* 0clk */
- #define B0_Tcah_200 0x3 /* 4clk (or0x01 1clk) */
- #define B0_Tacp_200 0x0 /* page mode is not used */
- #define B0_PMC_200 0x0 /* page mode disabled */
- /* BANK0CON 250 */
- #define B0_Tacs_250 0x0 /* 0clk (or 0x1 1clk) */
- #define B0_Tcos_250 0x1 /* 1clk (or 0x2 2clk) */
- #define B0_Tacc_250 0x5 /* 8clk (or 0x7 14clk) */
- #define B0_Tcoh_250 0x0 /* 0clk */
- #define B0_Tcah_250 0x3 /* 4clk (or 0x1 1clk) */
- #define B0_Tacp_250 0x0 /* page mode is not used */
- #define B0_PMC_250 0x0 /* page mode disabled */
- /* BANK0CON 266 */
- #define B0_Tacs_266 0x0 /* 0clk (or 0x1 1clk) */
- #define B0_Tcos_266 0x1 /* 1clk (or 0x2 2clk) */
- #define B0_Tacc_266 0x6 /* 10clk (or 0x7 14clk) */
- #define B0_Tcoh_266 0x0 /* 0clk */
- #define B0_Tcah_266 0x3 /* 4clk (or 0x1 1clk) */
- #define B0_Tacp_266 0x0 /* page mode is not used */
- #define B0_PMC_266 0x0 /* page mode disabled */
- /* BANK1CON 200 */
- #define B1_Tacs_200 0x0 /* 0clk (or 0x1 1clk) */
- #define B1_Tcos_200 0x1 /* 1clk (or 0x2 2clk) */
- #define B1_Tacc_200 0x5 /* 8clk (or 0x6 10clk) */
- #define B1_Tcoh_200 0x0 /* 0clk */
- #define B1_Tcah_200 0x3 /* 4clk (or 0x1 1clk) */
- #define B1_Tacp_200 0x0 /* page mode is not used */
- #define B1_PMC_200 0x0 /* page mode disabled */
- /* BANK1CON 250 */
- #define B1_Tacs_250 0x0 /* 0clk (or 0x1 1clk) */
- #define B1_Tcos_250 0x1 /* 1clk (or 0x2 2clk) */
- #define B1_Tacc_250 0x5 /* 8clk (or 0x7 14clk) */
- #define B1_Tcoh_250 0x0 /* 0clk */
- #define B1_Tcah_250 0x3 /* 4clk (or 0x1 1clk) */
- #define B1_Tacp_250 0x0 /* page mode is not used */
- #define B1_PMC_250 0x0 /* page mode disabled */
- /* BANK1CON 266 */
- #define B1_Tacs_266 0x0 /* 0clk (or 0x1 1clk) */
- #define B1_Tcos_266 0x1 /* 1clk (or 0x2 2clk) */
- #define B1_Tacc_266 0x6 /* 10clk (or 0x7 14clk) */
- #define B1_Tcoh_266 0x0 /* 0clk */
- #define B1_Tcah_266 0x3 /* 4clk (or 0x1 1clk) */
- #define B1_Tacp_266 0x0 /* page mode is not used */
- #define B1_PMC_266 0x0 /* page mode disabled */
- /* BANK2CON 200 + 250 + 266 */
- #define B2_Tacs 0x3 /* 4clk */
- #define B2_Tcos 0x3 /* 4clk */
- #define B2_Tacc 0x7 /* 14clk */
- #define B2_Tcoh 0x3 /* 4clk */
- #define B2_Tcah 0x3 /* 4clk */
- #define B2_Tacp 0x0 /* page mode is not used */
- #define B2_PMC 0x0 /* page mode disabled */
- /* BANK3CON 200 + 250 + 266 */
- #define B3_Tacs 0x3 /* 4clk */
- #define B3_Tcos 0x3 /* 4clk */
- #define B3_Tacc 0x7 /* 14clk */
- #define B3_Tcoh 0x3 /* 4clk */
- #define B3_Tcah 0x3 /* 4clk */
- #define B3_Tacp 0x0 /* page mode is not used */
- #define B3_PMC 0x0 /* page mode disabled */
- /* BANK4CON 200 */
- #define B4_Tacs_200 0x1 /* 1clk */
- #define B4_Tcos_200 0x3 /* 4clk */
- #define B4_Tacc_200 0x7 /* 14clk */
- #define B4_Tcoh_200 0x3 /* 4clk */
- #define B4_Tcah_200 0x2 /* 2clk */
- #define B4_Tacp_200 0x0 /* page mode is not used */
- #define B4_PMC_200 0x0 /* page mode disabled */
- /* BANK4CON 250 */
- #define B4_Tacs_250 0x1 /* 1clk */
- #define B4_Tcos_250 0x3 /* 4clk */
- #define B4_Tacc_250 0x7 /* 14clk */
- #define B4_Tcoh_250 0x3 /* 4clk */
- #define B4_Tcah_250 0x2 /* 2clk */
- #define B4_Tacp_250 0x0 /* page mode is not used */
- #define B4_PMC_250 0x0 /* page mode disabled */
- /* BANK4CON 266 */
- #define B4_Tacs_266 0x1 /* 1clk */
- #define B4_Tcos_266 0x3 /* 4clk */
- #define B4_Tacc_266 0x7 /* 14clk */
- #define B4_Tcoh_266 0x3 /* 4clk */
- #define B4_Tcah_266 0x2 /* 2clk */
- #define B4_Tacp_266 0x0 /* page mode is not used */
- #define B4_PMC_266 0x0 /* page mode disabled */
- /* BANK5CON 200 */
- #define B5_Tacs_200 0x0 /* 0clk */
- #define B5_Tcos_200 0x3 /* 4clk */
- #define B5_Tacc_200 0x4 /* 6clk */
- #define B5_Tcoh_200 0x3 /* 4clk */
- #define B5_Tcah_200 0x1 /* 1clk */
- #define B5_Tacp_200 0x0 /* page mode is not used */
- #define B5_PMC_200 0x0 /* page mode disabled */
- /* BANK5CON 250 */
- #define B5_Tacs_250 0x0 /* 0clk */
- #define B5_Tcos_250 0x3 /* 4clk */
- #define B5_Tacc_250 0x5 /* 8clk */
- #define B5_Tcoh_250 0x3 /* 4clk */
- #define B5_Tcah_250 0x1 /* 1clk */
- #define B5_Tacp_250 0x0 /* page mode is not used */
- #define B5_PMC_250 0x0 /* page mode disabled */
- /* BANK5CON 266 */
- #define B5_Tacs_266 0x0 /* 0clk */
- #define B5_Tcos_266 0x3 /* 4clk */
- #define B5_Tacc_266 0x5 /* 8clk */
- #define B5_Tcoh_266 0x3 /* 4clk */
- #define B5_Tcah_266 0x1 /* 1clk */
- #define B5_Tacp_266 0x0 /* page mode is not used */
- #define B5_PMC_266 0x0 /* page mode disabled */
- #define B6_MT 0x3 /* SDRAM */
- #define B6_Trcd_200 0x0 /* 2clk */
- #define B6_Trcd_250 0x1 /* 3clk */
- #define B6_Trcd_266 0x1 /* 3clk */
- #define B6_SCAN 0x2 /* 10bit */
- #define B7_MT 0x3 /* SDRAM */
- #define B7_Trcd_200 0x0 /* 2clk */
- #define B7_Trcd_250 0x1 /* 3clk */
- #define B7_Trcd_266 0x1 /* 3clk */
- #define B7_SCAN 0x2 /* 10bit */
- /* REFRESH parameter */
- #define REFEN 0x1 /* Refresh enable */
- #define TREFMD 0x0 /* CBR(CAS before RAS)/Auto refresh */
- #define Trp_200 0x0 /* 2clk */
- #define Trp_250 0x1 /* 3clk */
- #define Trp_266 0x1 /* 3clk */
- #define Tsrc_200 0x1 /* 5clk */
- #define Tsrc_250 0x2 /* 6clk */
- #define Tsrc_266 0x3 /* 7clk */
- /* period=15.6us, HCLK=100Mhz, (2048+1-15.6*100) */
- #define REFCNT_200 489
- /* period=15.6us, HCLK=125Mhz, (2048+1-15.6*125) */
- #define REFCNT_250 99
- /* period=15.6us, HCLK=133Mhz, (2048+1-15.6*133) */
- #define REFCNT_266 0
- /**************************************/
- _TEXT_BASE:
- .word CONFIG_SYS_TEXT_BASE
- .globl lowlevel_init
- lowlevel_init:
- /* use r0 to relocate DATA read/write to flash rather than memory ! */
- ldr r0, _TEXT_BASE
- ldr r13, =BWSCON
- /* enable minimal access to PLD */
- ldr r1, [r13] /* load default BWSCON */
- orr r1, r1, #(DW8 + UBLB) << 20 /* set necessary CS attrs */
- str r1, [r13] /* set BWSCON */
- ldr r1, =0x7FF0 /* select slowest timing */
- str r1, [r13, #0x18] /* set BANKCON5 */
- ldr r1, =PLD_BASE
- ldr r2, =SETUPDATA
- ldrb r1, [r1, #MISC_REG]
- sub r2, r2, r0
- tst r1, #FASTCPU /* FASTCPU available ? */
- addeq r2, r2, #SETUPENTRY_SIZE
- /* memory control configuration */
- /* r2 = pointer into timing table */
- /* r13 = pointer to MEM controller regs (starting with BWSCON) */
- add r3, r2, #CSDATA_OFFSET
- add r4, r3, #CSDATAENTRY_SIZE
- 0:
- ldr r1, [r3], #4
- str r1, [r13], #4
- cmp r3, r4
- bne 0b
- /* PLD access is now possible */
- /* r3 = SDRAMDATA
- /* r13 = pointer to MEM controller regs */
- ldr r1, =PLD_BASE
- mov r4, #SDRAMENTRY_SIZE
- ldrb r1, [r1, #SDRAM_REG]
- /* calculate start and end point */
- mla r3, r4, r1, r3
- add r4, r3, r4
- 0:
- ldr r1, [r3], #4
- str r1, [r13], #4
- cmp r3, r4
- bne 0b
- /* setup MPLL registers */
- ldr r1, =CLKBASE
- ldr r4, =0xFFFFFF
- add r3, r2, #4 /* r3 points to PLL values */
- str r4, [r1, #LOCKTIME]
- ldmia r3, {r4,r5}
- str r5, [r1, #UPLLCON] /* writing PLL register */
- /* !! order seems to be important !! */
- /* a little delay */
- ldr r3, =0x4000
- 0:
- subs r3, r3, #1
- bne 0b
- str r4, [r1, #MPLLCON] /* writing PLL register */
- /* !! order seems to be important !! */
- /* a little delay */
- ldr r3, =0x4000
- 0:
- subs r3, r3, #1
- bne 0b
- /* everything is fine now */
- mov pc, lr
- .ltorg
- /* the literal pools origin */
- #define MK_BWSCON(bws1, bws2, bws3, bws4, bws5, bws6, bws7) \
- ((bws1) << 4) + \
- ((bws2) << 8) + \
- ((bws3) << 12) + \
- ((bws4) << 16) + \
- ((bws5) << 20) + \
- ((bws6) << 24) + \
- ((bws7) << 28)
- #define MK_BANKCON(tacs, tcos, tacc, tcoh, tcah, tacp, pmc) \
- ((tacs) << 13) + \
- ((tcos) << 11) + \
- ((tacc) << 8) + \
- ((tcoh) << 6) + \
- ((tcah) << 4) + \
- ((tacp) << 2) + \
- (pmc)
- #define MK_BANKCON_SDRAM(trcd, scan) \
- ((0x03) << 15) + \
- ((trcd) << 2) + \
- (scan)
- #define MK_SDRAM_REFRESH(enable, trefmd, trp, tsrc, cnt) \
- ((enable) << 23) + \
- ((trefmd) << 22) + \
- ((trp) << 20) + \
- ((tsrc) << 18) + \
- (cnt)
- SETUPDATA:
- .word 0x32410002
- /* PLL values (MDIV, PDIV, SDIV) for 250 MHz */
- .word (0x75 << 12) + (0x01 << 4) + (0x01 << 0)
- /* PLL values for USB clock */
- .word (0x48 << 12) + (0x03 << 4) + (0x02 << 0)
- /* timing for 250 MHz*/
- 0:
- .equiv CSDATA_OFFSET, (. - SETUPDATA)
- .word MK_BWSCON(DW16, \
- DW32, \
- DW32, \
- DW16 + WAIT + UBLB, \
- DW8 + UBLB, \
- DW32, \
- DW32)
- .word MK_BANKCON(B0_Tacs_250, \
- B0_Tcos_250, \
- B0_Tacc_250, \
- B0_Tcoh_250, \
- B0_Tcah_250, \
- B0_Tacp_250, \
- B0_PMC_250)
- .word MK_BANKCON(B1_Tacs_250, \
- B1_Tcos_250, \
- B1_Tacc_250, \
- B1_Tcoh_250, \
- B1_Tcah_250, \
- B1_Tacp_250, \
- B1_PMC_250)
- .word MK_BANKCON(B2_Tacs, \
- B2_Tcos, \
- B2_Tacc, \
- B2_Tcoh, \
- B2_Tcah, \
- B2_Tacp, \
- B2_PMC)
- .word MK_BANKCON(B3_Tacs, \
- B3_Tcos, \
- B3_Tacc, \
- B3_Tcoh, \
- B3_Tcah, \
- B3_Tacp, \
- B3_PMC)
- .word MK_BANKCON(B4_Tacs_250, \
- B4_Tcos_250, \
- B4_Tacc_250, \
- B4_Tcoh_250, \
- B4_Tcah_250, \
- B4_Tacp_250, \
- B4_PMC_250)
- .word MK_BANKCON(B5_Tacs_250, \
- B5_Tcos_250, \
- B5_Tacc_250, \
- B5_Tcoh_250, \
- B5_Tcah_250, \
- B5_Tacp_250, \
- B5_PMC_250)
- .equiv CSDATAENTRY_SIZE, (. - 0b)
- /* 4Mx8x4 */
- 0:
- .word MK_BANKCON_SDRAM(B6_Trcd_250, B6_SCAN)
- .word MK_BANKCON_SDRAM(B7_Trcd_250, B7_SCAN)
- .word MK_SDRAM_REFRESH(REFEN, TREFMD, Trp_250, Tsrc_250, REFCNT_250)
- .word 0x32 + BURST_EN
- .word 0x30
- .word 0x30
- .equiv SDRAMENTRY_SIZE, (. - 0b)
- /* 8Mx8x4 */
- .word MK_BANKCON_SDRAM(B6_Trcd_250, B6_SCAN)
- .word MK_BANKCON_SDRAM(B7_Trcd_250, B7_SCAN)
- .word MK_SDRAM_REFRESH(REFEN, TREFMD, Trp_250, Tsrc_250, REFCNT_250)
- .word 0x32 + BURST_EN
- .word 0x30
- .word 0x30
- /* 2Mx8x4 */
- .word MK_BANKCON_SDRAM(B6_Trcd_250, B6_SCAN)
- .word MK_BANKCON_SDRAM(B7_Trcd_250, B7_SCAN)
- .word MK_SDRAM_REFRESH(REFEN, TREFMD, Trp_250, Tsrc_250, REFCNT_250)
- .word 0x32 + BURST_EN
- .word 0x30
- .word 0x30
- /* 4Mx8x2 */
- .word MK_BANKCON_SDRAM(B6_Trcd_250, B6_SCAN)
- .word MK_BANKCON_SDRAM(B7_Trcd_250, B7_SCAN)
- .word MK_SDRAM_REFRESH(REFEN, TREFMD, Trp_250, Tsrc_250, REFCNT_250)
- .word 0x32 + BURST_EN
- .word 0x30
- .word 0x30
- .equiv SETUPENTRY_SIZE, (. - SETUPDATA)
- .word 0x32410000
- /* PLL values (MDIV, PDIV, SDIV) for 200 MHz (Fout = 202.8MHz) */
- .word (0xA1 << 12) + (0x03 << 4) + (0x01 << 0)
- /* PLL values for USB clock */
- .word (0x48 << 12) + (0x03 << 4) + (0x02 << 0)
- /* timing for 200 MHz and default*/
- .word MK_BWSCON(DW16, \
- DW32, \
- DW32, \
- DW16 + WAIT + UBLB, \
- DW8 + UBLB, \
- DW32, \
- DW32)
- .word MK_BANKCON(B0_Tacs_200, \
- B0_Tcos_200, \
- B0_Tacc_200, \
- B0_Tcoh_200, \
- B0_Tcah_200, \
- B0_Tacp_200, \
- B0_PMC_200)
- .word MK_BANKCON(B1_Tacs_200, \
- B1_Tcos_200, \
- B1_Tacc_200, \
- B1_Tcoh_200, \
- B1_Tcah_200, \
- B1_Tacp_200, \
- B1_PMC_200)
- .word MK_BANKCON(B2_Tacs, \
- B2_Tcos, \
- B2_Tacc, \
- B2_Tcoh, \
- B2_Tcah, \
- B2_Tacp, \
- B2_PMC)
- .word MK_BANKCON(B3_Tacs, \
- B3_Tcos, \
- B3_Tacc, \
- B3_Tcoh, \
- B3_Tcah, \
- B3_Tacp, \
- B3_PMC)
- .word MK_BANKCON(B4_Tacs_200, \
- B4_Tcos_200, \
- B4_Tacc_200, \
- B4_Tcoh_200, \
- B4_Tcah_200, \
- B4_Tacp_200, \
- B4_PMC_200)
- .word MK_BANKCON(B5_Tacs_200, \
- B5_Tcos_200, \
- B5_Tacc_200, \
- B5_Tcoh_200, \
- B5_Tcah_200, \
- B5_Tacp_200, \
- B5_PMC_200)
- /* 4Mx8x4 */
- .word MK_BANKCON_SDRAM(B6_Trcd_200, B6_SCAN)
- .word MK_BANKCON_SDRAM(B7_Trcd_200, B7_SCAN)
- .word MK_SDRAM_REFRESH(REFEN, TREFMD, Trp_200, Tsrc_200, REFCNT_200)
- .word 0x32 + BURST_EN
- .word 0x30
- .word 0x30
- /* 8Mx8x4 */
- .word MK_BANKCON_SDRAM(B6_Trcd_200, B6_SCAN)
- .word MK_BANKCON_SDRAM(B7_Trcd_200, B7_SCAN)
- .word MK_SDRAM_REFRESH(REFEN, TREFMD, Trp_200, Tsrc_200, REFCNT_200)
- .word 0x32 + BURST_EN
- .word 0x30
- .word 0x30
- /* 2Mx8x4 */
- .word MK_BANKCON_SDRAM(B6_Trcd_200, B6_SCAN)
- .word MK_BANKCON_SDRAM(B7_Trcd_200, B7_SCAN)
- .word MK_SDRAM_REFRESH(REFEN, TREFMD, Trp_200, Tsrc_200, REFCNT_200)
- .word 0x32 + BURST_EN
- .word 0x30
- .word 0x30
- /* 4Mx8x2 */
- .word MK_BANKCON_SDRAM(B6_Trcd_200, B6_SCAN)
- .word MK_BANKCON_SDRAM(B7_Trcd_200, B7_SCAN)
- .word MK_SDRAM_REFRESH(REFEN, TREFMD, Trp_200, Tsrc_200, REFCNT_200)
- .word 0x32 + BURST_EN
- .word 0x30
- .word 0x30
- .equiv SETUPDATA_SIZE, (. - SETUPDATA)
|