blob: 51a8b3c51b2fedb18e836794d6931a0d0508c751 [file] [log] [blame]
Albert Aribaudac2ba9e2010-06-17 19:36:07 +05301/*
Albert ARIBAUD340983d2011-04-22 19:41:02 +02002 * Copyright (C) 2010 Albert ARIBAUD <albert.u.boot@aribaud.net>
Albert Aribaudac2ba9e2010-06-17 19:36:07 +05303 *
4 * (C) Copyright 2009
5 * Marvell Semiconductor <www.marvell.com>
6 * Written-by: Prafulla Wadaskar <prafulla@marvell.com>
7 *
Wolfgang Denkd79de1d2013-07-08 09:37:19 +02008 * SPDX-License-Identifier: GPL-2.0+
Albert Aribaudac2ba9e2010-06-17 19:36:07 +05309 */
10
11#include <config.h>
12#include "asm/arch/orion5x.h"
13
14/*
15 * Configuration values for SDRAM access setup
16 */
17
18#define SDRAM_CONFIG 0x3148400
19#define SDRAM_MODE 0x62
20#define SDRAM_CONTROL 0x4041000
21#define SDRAM_TIME_CTRL_LOW 0x11602220
22#define SDRAM_TIME_CTRL_HI 0x40c
23#define SDRAM_OPEN_PAGE_EN 0x0
24/* DDR 1 2x 32M NANYA NT5DS16M16CS-6K ==> 64MB */
25#define SDRAM_BANK0_SIZE 0x3ff0001
26#define SDRAM_ADDR_CTRL 0x10
27
28#define SDRAM_OP_NOP 0x05
29#define SDRAM_OP_SETMODE 0x03
30
31#define SDRAM_PAD_CTRL_WR_EN 0x80000000
32#define SDRAM_PAD_CTRL_TUNE_EN 0x00010000
33#define SDRAM_PAD_CTRL_DRVN_MASK 0x0000003f
34#define SDRAM_PAD_CTRL_DRVP_MASK 0x00000fc0
35
36/*
37 * For Guideline MEM-3 - Drive Strength value
38 */
39
40#define DDR1_PAD_STRENGTH_DEFAULT 0x00001000
41#define SDRAM_PAD_CTRL_DRV_STR_MASK 0x00003000
42
43/*
44 * For Guideline MEM-4 - DQS Reference Delay Tuning
45 */
46
47#define MSAR_ARMDDRCLCK_MASK 0x000000f0
48#define MSAR_ARMDDRCLCK_H_MASK 0x00000100
49
50#define MSAR_ARMDDRCLCK_333_167 0x00000000
51#define MSAR_ARMDDRCLCK_500_167 0x00000030
52#define MSAR_ARMDDRCLCK_667_167 0x00000060
53#define MSAR_ARMDDRCLCK_400_200_1 0x000001E0
54#define MSAR_ARMDDRCLCK_400_200 0x00000010
55#define MSAR_ARMDDRCLCK_600_200 0x00000050
56#define MSAR_ARMDDRCLCK_800_200 0x00000070
57
58#define FTDLL_DDR1_166MHZ 0x0047F001
59
60#define FTDLL_DDR1_200MHZ 0x0044D001
61
62/*
63 * Low-level init happens right after start.S has switched to SVC32,
64 * flushed and disabled caches and disabled MMU. We're still running
Albert ARIBAUD2ac37922015-01-31 22:55:38 +010065 * from the boot chip select, so the first thing SPL should do is to
66 * set up the RAM to copy U-Boot into.
Albert Aribaudac2ba9e2010-06-17 19:36:07 +053067 */
68
69.globl lowlevel_init
70
71lowlevel_init:
72
Albert ARIBAUD2ac37922015-01-31 22:55:38 +010073#ifdef CONFIG_SPL_BUILD
74
Albert Aribaudac2ba9e2010-06-17 19:36:07 +053075 /* Use 'r4 as the base for internal register accesses */
Wolfgang Denk9a183d22010-06-23 20:50:54 +020076 ldr r4, =ORION5X_REGS_PHY_BASE
Albert Aribaudac2ba9e2010-06-17 19:36:07 +053077
78 /* move internal registers from the default 0xD0000000
79 * to their intended location, defined by SoC */
80 ldr r3, =0xD0000000
81 add r3, r3, #0x20000
Wolfgang Denk9a183d22010-06-23 20:50:54 +020082 str r4, [r3, #0x80]
Albert Aribaudac2ba9e2010-06-17 19:36:07 +053083
84 /* Use R3 as the base for DRAM registers */
Wolfgang Denk9a183d22010-06-23 20:50:54 +020085 add r3, r4, #0x01000
Albert Aribaudac2ba9e2010-06-17 19:36:07 +053086
87 /*DDR SDRAM Initialization Control */
88 ldr r6, =0x00000001
89 str r6, [r3, #0x480]
90
91 /* Use R3 as the base for PCI registers */
Wolfgang Denk9a183d22010-06-23 20:50:54 +020092 add r3, r4, #0x31000
Albert Aribaudac2ba9e2010-06-17 19:36:07 +053093
94 /* Disable arbiter */
95 ldr r6, =0x00000030
96 str r6, [r3, #0xd00]
97
98 /* Use R3 as the base for DRAM registers */
Wolfgang Denk9a183d22010-06-23 20:50:54 +020099 add r3, r4, #0x01000
Albert Aribaudac2ba9e2010-06-17 19:36:07 +0530100
101 /* set all dram windows to 0 */
102 mov r6, #0
103 str r6, [r3, #0x504]
104 str r6, [r3, #0x50C]
105 str r6, [r3, #0x514]
106 str r6, [r3, #0x51C]
107
108 /* 1) Configure SDRAM */
109 ldr r6, =SDRAM_CONFIG
110 str r6, [r3, #0x400]
111
112 /* 2) Set SDRAM Control reg */
113 ldr r6, =SDRAM_CONTROL
114 str r6, [r3, #0x404]
115
Wolfgang Denk9a183d22010-06-23 20:50:54 +0200116 /* 3) Write SDRAM address control register */
Albert Aribaudac2ba9e2010-06-17 19:36:07 +0530117 ldr r6, =SDRAM_ADDR_CTRL
118 str r6, [r3, #0x410]
119
Wolfgang Denk9a183d22010-06-23 20:50:54 +0200120 /* 4) Write SDRAM bank 0 size register */
Albert Aribaudac2ba9e2010-06-17 19:36:07 +0530121 ldr r6, =SDRAM_BANK0_SIZE
122 str r6, [r3, #0x504]
123 /* keep other banks disabled */
124
Wolfgang Denk9a183d22010-06-23 20:50:54 +0200125 /* 5) Write SDRAM open pages control register */
Albert Aribaudac2ba9e2010-06-17 19:36:07 +0530126 ldr r6, =SDRAM_OPEN_PAGE_EN
127 str r6, [r3, #0x414]
128
Wolfgang Denk9a183d22010-06-23 20:50:54 +0200129 /* 6) Write SDRAM timing Low register */
Albert Aribaudac2ba9e2010-06-17 19:36:07 +0530130 ldr r6, =SDRAM_TIME_CTRL_LOW
131 str r6, [r3, #0x408]
132
Wolfgang Denk9a183d22010-06-23 20:50:54 +0200133 /* 7) Write SDRAM timing High register */
Albert Aribaudac2ba9e2010-06-17 19:36:07 +0530134 ldr r6, =SDRAM_TIME_CTRL_HI
135 str r6, [r3, #0x40C]
136
Wolfgang Denk9a183d22010-06-23 20:50:54 +0200137 /* 8) Write SDRAM mode register */
138 /* The CPU must not attempt to change the SDRAM Mode register setting */
139 /* prior to DRAM controller completion of the DRAM initialization */
140 /* sequence. To guarantee this restriction, it is recommended that */
141 /* the CPU sets the SDRAM Operation register to NOP command, performs */
142 /* read polling until the register is back in Normal operation value, */
143 /* and then sets SDRAM Mode register to its new value. */
Albert Aribaudac2ba9e2010-06-17 19:36:07 +0530144
145 /* 8.1 write 'nop' to SDRAM operation */
Wolfgang Denk9a183d22010-06-23 20:50:54 +0200146 ldr r6, =SDRAM_OP_NOP
Albert Aribaudac2ba9e2010-06-17 19:36:07 +0530147 str r6, [r3, #0x418]
148
Wolfgang Denk9a183d22010-06-23 20:50:54 +0200149 /* 8.2 poll SDRAM operation until back in 'normal' mode. */
Albert Aribaudac2ba9e2010-06-17 19:36:07 +05301501:
151 ldr r6, [r3, #0x418]
152 cmp r6, #0
153 bne 1b
154
Wolfgang Denk9a183d22010-06-23 20:50:54 +0200155 /* 8.3 Now its safe to write new value to SDRAM Mode register */
Albert Aribaudac2ba9e2010-06-17 19:36:07 +0530156 ldr r6, =SDRAM_MODE
157 str r6, [r3, #0x41C]
158
Wolfgang Denk9a183d22010-06-23 20:50:54 +0200159 /* 8.4 Set new mode */
160 ldr r6, =SDRAM_OP_SETMODE
Albert Aribaudac2ba9e2010-06-17 19:36:07 +0530161 str r6, [r3, #0x418]
162
Wolfgang Denk9a183d22010-06-23 20:50:54 +0200163 /* 8.5 poll SDRAM operation until back in 'normal' mode. */
Albert Aribaudac2ba9e2010-06-17 19:36:07 +05301642:
165 ldr r6, [r3, #0x418]
166 cmp r6, #0
167 bne 2b
168
Wolfgang Denk9a183d22010-06-23 20:50:54 +0200169 /* DDR SDRAM Address/Control Pads Calibration */
Albert Aribaudac2ba9e2010-06-17 19:36:07 +0530170 ldr r6, [r3, #0x4C0]
171
Wolfgang Denk9a183d22010-06-23 20:50:54 +0200172 /* Set Bit [31] to make the register writable */
Albert Aribaudac2ba9e2010-06-17 19:36:07 +0530173 orr r6, r6, #SDRAM_PAD_CTRL_WR_EN
174 str r6, [r3, #0x4C0]
175
176 bic r6, r6, #SDRAM_PAD_CTRL_WR_EN
177 bic r6, r6, #SDRAM_PAD_CTRL_TUNE_EN
178 bic r6, r6, #SDRAM_PAD_CTRL_DRVN_MASK
179 bic r6, r6, #SDRAM_PAD_CTRL_DRVP_MASK
180
Wolfgang Denk9a183d22010-06-23 20:50:54 +0200181 /* Get the final N locked value of driving strength [22:17] */
182 mov r1, r6
183 mov r1, r1, LSL #9
184 mov r1, r1, LSR #26 /* r1[5:0]<DrvN> = r3[22:17]<LockN> */
185 orr r1, r1, r1, LSL #6 /* r1[11:6]<DrvP> = r1[5:0]<DrvN> */
Albert Aribaudac2ba9e2010-06-17 19:36:07 +0530186
Wolfgang Denk9a183d22010-06-23 20:50:54 +0200187 /* Write to both <DrvN> bits [5:0] and <DrvP> bits [11:6] */
Albert Aribaudac2ba9e2010-06-17 19:36:07 +0530188 orr r6, r6, r1
189 str r6, [r3, #0x4C0]
190
Wolfgang Denk9a183d22010-06-23 20:50:54 +0200191 /* DDR SDRAM Data Pads Calibration */
Albert Aribaudac2ba9e2010-06-17 19:36:07 +0530192 ldr r6, [r3, #0x4C4]
193
Wolfgang Denk9a183d22010-06-23 20:50:54 +0200194 /* Set Bit [31] to make the register writable */
Albert Aribaudac2ba9e2010-06-17 19:36:07 +0530195 orr r6, r6, #SDRAM_PAD_CTRL_WR_EN
196 str r6, [r3, #0x4C4]
197
198 bic r6, r6, #SDRAM_PAD_CTRL_WR_EN
199 bic r6, r6, #SDRAM_PAD_CTRL_TUNE_EN
200 bic r6, r6, #SDRAM_PAD_CTRL_DRVN_MASK
201 bic r6, r6, #SDRAM_PAD_CTRL_DRVP_MASK
202
Wolfgang Denk9a183d22010-06-23 20:50:54 +0200203 /* Get the final N locked value of driving strength [22:17] */
204 mov r1, r6
205 mov r1, r1, LSL #9
206 mov r1, r1, LSR #26
207 orr r1, r1, r1, LSL #6 /* r1[5:0] = r3[22:17]<LockN> */
Albert Aribaudac2ba9e2010-06-17 19:36:07 +0530208
Wolfgang Denk9a183d22010-06-23 20:50:54 +0200209 /* Write to both <DrvN> bits [5:0] and <DrvP> bits [11:6] */
Albert Aribaudac2ba9e2010-06-17 19:36:07 +0530210 orr r6, r6, r1
211
212 str r6, [r3, #0x4C4]
213
Wolfgang Denk9a183d22010-06-23 20:50:54 +0200214 /* Implement Guideline (GL# MEM-3) Drive Strength Value */
215 /* Relevant for: 88F5181-A1/B0/B1 and 88F5281-A0/B0 */
Albert Aribaudac2ba9e2010-06-17 19:36:07 +0530216
Wolfgang Denk9a183d22010-06-23 20:50:54 +0200217 ldr r1, =DDR1_PAD_STRENGTH_DEFAULT
Albert Aribaudac2ba9e2010-06-17 19:36:07 +0530218
219 /* Enable writes to DDR SDRAM Addr/Ctrl Pads Calibration register */
220 ldr r6, [r3, #0x4C0]
221 orr r6, r6, #SDRAM_PAD_CTRL_WR_EN
222 str r6, [r3, #0x4C0]
223
224 /* Correct strength and disable writes again */
225 bic r6, r6, #SDRAM_PAD_CTRL_WR_EN
226 bic r6, r6, #SDRAM_PAD_CTRL_DRV_STR_MASK
227 orr r6, r6, r1
228 str r6, [r3, #0x4C0]
229
230 /* Enable writes to DDR SDRAM Data Pads Calibration register */
231 ldr r6, [r3, #0x4C4]
232 orr r6, r6, #SDRAM_PAD_CTRL_WR_EN
233 str r6, [r3, #0x4C4]
234
235 /* Correct strength and disable writes again */
236 bic r6, r6, #SDRAM_PAD_CTRL_DRV_STR_MASK
237 bic r6, r6, #SDRAM_PAD_CTRL_WR_EN
238 orr r6, r6, r1
239 str r6, [r3, #0x4C4]
240
Wolfgang Denk9a183d22010-06-23 20:50:54 +0200241 /* Implement Guideline (GL# MEM-4) DQS Reference Delay Tuning */
242 /* Relevant for: 88F5181-A1/B0/B1 and 88F5281-A0/B0 */
Albert Aribaudac2ba9e2010-06-17 19:36:07 +0530243
Wolfgang Denk9a183d22010-06-23 20:50:54 +0200244 /* Get the "sample on reset" register for the DDR frequancy */
Albert Aribaudac2ba9e2010-06-17 19:36:07 +0530245 ldr r3, =0x10000
Wolfgang Denk9a183d22010-06-23 20:50:54 +0200246 ldr r6, [r3, #0x010]
247 ldr r1, =MSAR_ARMDDRCLCK_MASK
248 and r1, r6, r1
Albert Aribaudac2ba9e2010-06-17 19:36:07 +0530249
Wolfgang Denk9a183d22010-06-23 20:50:54 +0200250 ldr r6, =FTDLL_DDR1_166MHZ
251 cmp r1, #MSAR_ARMDDRCLCK_333_167
252 beq 3f
253 cmp r1, #MSAR_ARMDDRCLCK_500_167
254 beq 3f
255 cmp r1, #MSAR_ARMDDRCLCK_667_167
256 beq 3f
Albert Aribaudac2ba9e2010-06-17 19:36:07 +0530257
Wolfgang Denk9a183d22010-06-23 20:50:54 +0200258 ldr r6, =FTDLL_DDR1_200MHZ
259 cmp r1, #MSAR_ARMDDRCLCK_400_200_1
260 beq 3f
261 cmp r1, #MSAR_ARMDDRCLCK_400_200
262 beq 3f
263 cmp r1, #MSAR_ARMDDRCLCK_600_200
264 beq 3f
265 cmp r1, #MSAR_ARMDDRCLCK_800_200
266 beq 3f
Albert Aribaudac2ba9e2010-06-17 19:36:07 +0530267
Wolfgang Denk9a183d22010-06-23 20:50:54 +0200268 ldr r6, =0
Albert Aribaudac2ba9e2010-06-17 19:36:07 +0530269
2703:
271 /* Use R3 as the base for DRAM registers */
Wolfgang Denk9a183d22010-06-23 20:50:54 +0200272 add r3, r4, #0x01000
Albert Aribaudac2ba9e2010-06-17 19:36:07 +0530273
274 ldr r2, [r3, #0x484]
275 orr r2, r2, r6
276 str r2, [r3, #0x484]
277
Albert ARIBAUD2ac37922015-01-31 22:55:38 +0100278 /* enable for 2 GB DDR; detection should find out real amount */
279 sub r6, r6, r6
280 str r6, [r3, #0x500]
281 ldr r6, =0x7fff0001
282 str r6, [r3, #0x504]
283
284#endif /* CONFIG_SPL_BUILD */
285
Albert Aribaudac2ba9e2010-06-17 19:36:07 +0530286 /* Return to U-boot via saved link register */
Wolfgang Denk9a183d22010-06-23 20:50:54 +0200287 mov pc, lr