Add qemu 2.4.0
[kvmfornfv.git] / qemu / roms / u-boot / board / mpl / vcma9 / lowlevel_init.S
diff --git a/qemu/roms/u-boot/board/mpl/vcma9/lowlevel_init.S b/qemu/roms/u-boot/board/mpl/vcma9/lowlevel_init.S
new file mode 100644 (file)
index 0000000..cca9c0c
--- /dev/null
@@ -0,0 +1,502 @@
+/*
+ * 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
+ *
+ * SPDX-License-Identifier:    GPL-2.0+
+ */
+
+
+#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
+/**************************************/
+
+.globl lowlevel_init
+lowlevel_init:
+       /* use r0 to relocate DATA read/write to flash rather than memory ! */
+       ldr     r0, =CONFIG_SYS_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)