xref: /rk3399_rockchip-uboot/arch/arm/mach-orion5x/lowlevel_init.S (revision 3e93b4e6001104152fec850d4724ea9ffad03e05)
1*3e93b4e6SMasahiro Yamada/*
2*3e93b4e6SMasahiro Yamada * Copyright (C) 2010 Albert ARIBAUD <albert.u.boot@aribaud.net>
3*3e93b4e6SMasahiro Yamada *
4*3e93b4e6SMasahiro Yamada * (C) Copyright 2009
5*3e93b4e6SMasahiro Yamada * Marvell Semiconductor <www.marvell.com>
6*3e93b4e6SMasahiro Yamada * Written-by: Prafulla Wadaskar <prafulla@marvell.com>
7*3e93b4e6SMasahiro Yamada *
8*3e93b4e6SMasahiro Yamada * SPDX-License-Identifier:	GPL-2.0+
9*3e93b4e6SMasahiro Yamada */
10*3e93b4e6SMasahiro Yamada
11*3e93b4e6SMasahiro Yamada#include <config.h>
12*3e93b4e6SMasahiro Yamada#include "asm/arch/orion5x.h"
13*3e93b4e6SMasahiro Yamada
14*3e93b4e6SMasahiro Yamada/*
15*3e93b4e6SMasahiro Yamada * Configuration values for SDRAM access setup
16*3e93b4e6SMasahiro Yamada */
17*3e93b4e6SMasahiro Yamada
18*3e93b4e6SMasahiro Yamada#define SDRAM_CONFIG			0x3148400
19*3e93b4e6SMasahiro Yamada#define SDRAM_MODE			0x62
20*3e93b4e6SMasahiro Yamada#define SDRAM_CONTROL			0x4041000
21*3e93b4e6SMasahiro Yamada#define SDRAM_TIME_CTRL_LOW		0x11602220
22*3e93b4e6SMasahiro Yamada#define SDRAM_TIME_CTRL_HI		0x40c
23*3e93b4e6SMasahiro Yamada#define SDRAM_OPEN_PAGE_EN		0x0
24*3e93b4e6SMasahiro Yamada/* DDR 1 2x 32M NANYA NT5DS16M16CS-6K ==> 64MB */
25*3e93b4e6SMasahiro Yamada#define SDRAM_BANK0_SIZE		0x3ff0001
26*3e93b4e6SMasahiro Yamada#define SDRAM_ADDR_CTRL			0x10
27*3e93b4e6SMasahiro Yamada
28*3e93b4e6SMasahiro Yamada#define SDRAM_OP_NOP			0x05
29*3e93b4e6SMasahiro Yamada#define SDRAM_OP_SETMODE		0x03
30*3e93b4e6SMasahiro Yamada
31*3e93b4e6SMasahiro Yamada#define SDRAM_PAD_CTRL_WR_EN		0x80000000
32*3e93b4e6SMasahiro Yamada#define SDRAM_PAD_CTRL_TUNE_EN		0x00010000
33*3e93b4e6SMasahiro Yamada#define SDRAM_PAD_CTRL_DRVN_MASK	0x0000003f
34*3e93b4e6SMasahiro Yamada#define SDRAM_PAD_CTRL_DRVP_MASK	0x00000fc0
35*3e93b4e6SMasahiro Yamada
36*3e93b4e6SMasahiro Yamada/*
37*3e93b4e6SMasahiro Yamada * For Guideline MEM-3 - Drive Strength value
38*3e93b4e6SMasahiro Yamada */
39*3e93b4e6SMasahiro Yamada
40*3e93b4e6SMasahiro Yamada#define DDR1_PAD_STRENGTH_DEFAULT	0x00001000
41*3e93b4e6SMasahiro Yamada#define SDRAM_PAD_CTRL_DRV_STR_MASK	0x00003000
42*3e93b4e6SMasahiro Yamada
43*3e93b4e6SMasahiro Yamada/*
44*3e93b4e6SMasahiro Yamada * For Guideline MEM-4 - DQS Reference Delay Tuning
45*3e93b4e6SMasahiro Yamada */
46*3e93b4e6SMasahiro Yamada
47*3e93b4e6SMasahiro Yamada#define MSAR_ARMDDRCLCK_MASK		0x000000f0
48*3e93b4e6SMasahiro Yamada#define MSAR_ARMDDRCLCK_H_MASK		0x00000100
49*3e93b4e6SMasahiro Yamada
50*3e93b4e6SMasahiro Yamada#define MSAR_ARMDDRCLCK_333_167		0x00000000
51*3e93b4e6SMasahiro Yamada#define MSAR_ARMDDRCLCK_500_167		0x00000030
52*3e93b4e6SMasahiro Yamada#define MSAR_ARMDDRCLCK_667_167		0x00000060
53*3e93b4e6SMasahiro Yamada#define MSAR_ARMDDRCLCK_400_200_1	0x000001E0
54*3e93b4e6SMasahiro Yamada#define MSAR_ARMDDRCLCK_400_200		0x00000010
55*3e93b4e6SMasahiro Yamada#define MSAR_ARMDDRCLCK_600_200		0x00000050
56*3e93b4e6SMasahiro Yamada#define MSAR_ARMDDRCLCK_800_200		0x00000070
57*3e93b4e6SMasahiro Yamada
58*3e93b4e6SMasahiro Yamada#define FTDLL_DDR1_166MHZ		0x0047F001
59*3e93b4e6SMasahiro Yamada
60*3e93b4e6SMasahiro Yamada#define FTDLL_DDR1_200MHZ		0x0044D001
61*3e93b4e6SMasahiro Yamada
62*3e93b4e6SMasahiro Yamada/*
63*3e93b4e6SMasahiro Yamada * Low-level init happens right after start.S has switched to SVC32,
64*3e93b4e6SMasahiro Yamada * flushed and disabled caches and disabled MMU. We're still running
65*3e93b4e6SMasahiro Yamada * from the boot chip select, so the first thing we should do is set
66*3e93b4e6SMasahiro Yamada * up RAM for us to relocate into.
67*3e93b4e6SMasahiro Yamada */
68*3e93b4e6SMasahiro Yamada
69*3e93b4e6SMasahiro Yamada.globl lowlevel_init
70*3e93b4e6SMasahiro Yamada
71*3e93b4e6SMasahiro Yamadalowlevel_init:
72*3e93b4e6SMasahiro Yamada
73*3e93b4e6SMasahiro Yamada	/* Use 'r4 as the base for internal register accesses */
74*3e93b4e6SMasahiro Yamada	ldr	r4, =ORION5X_REGS_PHY_BASE
75*3e93b4e6SMasahiro Yamada
76*3e93b4e6SMasahiro Yamada	/* move internal registers from the default 0xD0000000
77*3e93b4e6SMasahiro Yamada	 * to their intended location, defined by SoC */
78*3e93b4e6SMasahiro Yamada	ldr	r3, =0xD0000000
79*3e93b4e6SMasahiro Yamada	add	r3, r3, #0x20000
80*3e93b4e6SMasahiro Yamada	str	r4, [r3, #0x80]
81*3e93b4e6SMasahiro Yamada
82*3e93b4e6SMasahiro Yamada	/* Use R3 as the base for DRAM registers */
83*3e93b4e6SMasahiro Yamada	add	r3, r4, #0x01000
84*3e93b4e6SMasahiro Yamada
85*3e93b4e6SMasahiro Yamada	/*DDR SDRAM Initialization Control */
86*3e93b4e6SMasahiro Yamada	ldr	r6, =0x00000001
87*3e93b4e6SMasahiro Yamada	str	r6, [r3, #0x480]
88*3e93b4e6SMasahiro Yamada
89*3e93b4e6SMasahiro Yamada	/* Use R3 as the base for PCI registers */
90*3e93b4e6SMasahiro Yamada	add	r3, r4, #0x31000
91*3e93b4e6SMasahiro Yamada
92*3e93b4e6SMasahiro Yamada	/* Disable arbiter */
93*3e93b4e6SMasahiro Yamada	ldr	r6, =0x00000030
94*3e93b4e6SMasahiro Yamada	str	r6, [r3, #0xd00]
95*3e93b4e6SMasahiro Yamada
96*3e93b4e6SMasahiro Yamada	/* Use R3 as the base for DRAM registers */
97*3e93b4e6SMasahiro Yamada	add	r3, r4, #0x01000
98*3e93b4e6SMasahiro Yamada
99*3e93b4e6SMasahiro Yamada	/* set all dram windows to 0 */
100*3e93b4e6SMasahiro Yamada	mov	r6, #0
101*3e93b4e6SMasahiro Yamada	str	r6, [r3, #0x504]
102*3e93b4e6SMasahiro Yamada	str	r6, [r3, #0x50C]
103*3e93b4e6SMasahiro Yamada	str	r6, [r3, #0x514]
104*3e93b4e6SMasahiro Yamada	str	r6, [r3, #0x51C]
105*3e93b4e6SMasahiro Yamada
106*3e93b4e6SMasahiro Yamada	/* 1) Configure SDRAM  */
107*3e93b4e6SMasahiro Yamada	ldr	r6, =SDRAM_CONFIG
108*3e93b4e6SMasahiro Yamada	str	r6, [r3, #0x400]
109*3e93b4e6SMasahiro Yamada
110*3e93b4e6SMasahiro Yamada	/* 2) Set SDRAM Control reg */
111*3e93b4e6SMasahiro Yamada	ldr	r6, =SDRAM_CONTROL
112*3e93b4e6SMasahiro Yamada	str	r6, [r3, #0x404]
113*3e93b4e6SMasahiro Yamada
114*3e93b4e6SMasahiro Yamada	/* 3) Write SDRAM address control register */
115*3e93b4e6SMasahiro Yamada	ldr	r6, =SDRAM_ADDR_CTRL
116*3e93b4e6SMasahiro Yamada	str	r6, [r3, #0x410]
117*3e93b4e6SMasahiro Yamada
118*3e93b4e6SMasahiro Yamada	/* 4) Write SDRAM bank 0 size register */
119*3e93b4e6SMasahiro Yamada	ldr	r6, =SDRAM_BANK0_SIZE
120*3e93b4e6SMasahiro Yamada	str	r6, [r3, #0x504]
121*3e93b4e6SMasahiro Yamada	/* keep other banks disabled */
122*3e93b4e6SMasahiro Yamada
123*3e93b4e6SMasahiro Yamada	/* 5) Write SDRAM open pages control register */
124*3e93b4e6SMasahiro Yamada	ldr	r6, =SDRAM_OPEN_PAGE_EN
125*3e93b4e6SMasahiro Yamada	str	r6, [r3, #0x414]
126*3e93b4e6SMasahiro Yamada
127*3e93b4e6SMasahiro Yamada	/* 6) Write SDRAM timing Low register */
128*3e93b4e6SMasahiro Yamada	ldr	r6, =SDRAM_TIME_CTRL_LOW
129*3e93b4e6SMasahiro Yamada	str	r6, [r3, #0x408]
130*3e93b4e6SMasahiro Yamada
131*3e93b4e6SMasahiro Yamada	/* 7) Write SDRAM timing High register */
132*3e93b4e6SMasahiro Yamada	ldr	r6, =SDRAM_TIME_CTRL_HI
133*3e93b4e6SMasahiro Yamada	str	r6, [r3, #0x40C]
134*3e93b4e6SMasahiro Yamada
135*3e93b4e6SMasahiro Yamada	/* 8) Write SDRAM mode register */
136*3e93b4e6SMasahiro Yamada	/* The CPU must not attempt to change the SDRAM Mode register setting */
137*3e93b4e6SMasahiro Yamada	/* prior to DRAM controller completion of the DRAM initialization     */
138*3e93b4e6SMasahiro Yamada	/* sequence. To guarantee this restriction, it is recommended that    */
139*3e93b4e6SMasahiro Yamada	/* the CPU sets the SDRAM Operation register to NOP command, performs */
140*3e93b4e6SMasahiro Yamada	/* read polling until the register is back in Normal operation value, */
141*3e93b4e6SMasahiro Yamada	/* and then sets SDRAM Mode register to its new value.		      */
142*3e93b4e6SMasahiro Yamada
143*3e93b4e6SMasahiro Yamada	/* 8.1 write 'nop' to SDRAM operation */
144*3e93b4e6SMasahiro Yamada	ldr	r6, =SDRAM_OP_NOP
145*3e93b4e6SMasahiro Yamada	str	r6, [r3, #0x418]
146*3e93b4e6SMasahiro Yamada
147*3e93b4e6SMasahiro Yamada	/* 8.2 poll SDRAM operation until back in 'normal' mode.  */
148*3e93b4e6SMasahiro Yamada1:
149*3e93b4e6SMasahiro Yamada	ldr	r6, [r3, #0x418]
150*3e93b4e6SMasahiro Yamada	cmp	r6, #0
151*3e93b4e6SMasahiro Yamada	bne	1b
152*3e93b4e6SMasahiro Yamada
153*3e93b4e6SMasahiro Yamada	/* 8.3 Now its safe to write new value to SDRAM Mode register	      */
154*3e93b4e6SMasahiro Yamada	ldr	r6, =SDRAM_MODE
155*3e93b4e6SMasahiro Yamada	str	r6, [r3, #0x41C]
156*3e93b4e6SMasahiro Yamada
157*3e93b4e6SMasahiro Yamada	/* 8.4 Set new mode */
158*3e93b4e6SMasahiro Yamada	ldr	r6, =SDRAM_OP_SETMODE
159*3e93b4e6SMasahiro Yamada	str	r6, [r3, #0x418]
160*3e93b4e6SMasahiro Yamada
161*3e93b4e6SMasahiro Yamada	/* 8.5 poll SDRAM operation until back in 'normal' mode.  */
162*3e93b4e6SMasahiro Yamada2:
163*3e93b4e6SMasahiro Yamada	ldr	r6, [r3, #0x418]
164*3e93b4e6SMasahiro Yamada	cmp	r6, #0
165*3e93b4e6SMasahiro Yamada	bne	2b
166*3e93b4e6SMasahiro Yamada
167*3e93b4e6SMasahiro Yamada	/* DDR SDRAM Address/Control Pads Calibration */
168*3e93b4e6SMasahiro Yamada	ldr	r6, [r3, #0x4C0]
169*3e93b4e6SMasahiro Yamada
170*3e93b4e6SMasahiro Yamada	/* Set Bit [31] to make the register writable			*/
171*3e93b4e6SMasahiro Yamada	orr	r6, r6, #SDRAM_PAD_CTRL_WR_EN
172*3e93b4e6SMasahiro Yamada	str	r6, [r3, #0x4C0]
173*3e93b4e6SMasahiro Yamada
174*3e93b4e6SMasahiro Yamada	bic	r6, r6, #SDRAM_PAD_CTRL_WR_EN
175*3e93b4e6SMasahiro Yamada	bic	r6, r6, #SDRAM_PAD_CTRL_TUNE_EN
176*3e93b4e6SMasahiro Yamada	bic	r6, r6, #SDRAM_PAD_CTRL_DRVN_MASK
177*3e93b4e6SMasahiro Yamada	bic	r6, r6, #SDRAM_PAD_CTRL_DRVP_MASK
178*3e93b4e6SMasahiro Yamada
179*3e93b4e6SMasahiro Yamada	/* Get the final N locked value of driving strength [22:17]	*/
180*3e93b4e6SMasahiro Yamada	mov	r1, r6
181*3e93b4e6SMasahiro Yamada	mov	r1, r1, LSL #9
182*3e93b4e6SMasahiro Yamada	mov	r1, r1, LSR #26	 /* r1[5:0]<DrvN>  = r3[22:17]<LockN>	*/
183*3e93b4e6SMasahiro Yamada	orr	r1, r1, r1, LSL #6 /* r1[11:6]<DrvP> = r1[5:0]<DrvN>	*/
184*3e93b4e6SMasahiro Yamada
185*3e93b4e6SMasahiro Yamada	/* Write to both <DrvN> bits [5:0] and <DrvP> bits [11:6]	*/
186*3e93b4e6SMasahiro Yamada	orr	r6, r6, r1
187*3e93b4e6SMasahiro Yamada	str	r6, [r3, #0x4C0]
188*3e93b4e6SMasahiro Yamada
189*3e93b4e6SMasahiro Yamada	/* DDR SDRAM Data Pads Calibration				*/
190*3e93b4e6SMasahiro Yamada	ldr	r6, [r3, #0x4C4]
191*3e93b4e6SMasahiro Yamada
192*3e93b4e6SMasahiro Yamada	/* Set Bit [31] to make the register writable			*/
193*3e93b4e6SMasahiro Yamada	orr	r6, r6, #SDRAM_PAD_CTRL_WR_EN
194*3e93b4e6SMasahiro Yamada	str	r6, [r3, #0x4C4]
195*3e93b4e6SMasahiro Yamada
196*3e93b4e6SMasahiro Yamada	bic	r6, r6, #SDRAM_PAD_CTRL_WR_EN
197*3e93b4e6SMasahiro Yamada	bic	r6, r6, #SDRAM_PAD_CTRL_TUNE_EN
198*3e93b4e6SMasahiro Yamada	bic	r6, r6, #SDRAM_PAD_CTRL_DRVN_MASK
199*3e93b4e6SMasahiro Yamada	bic	r6, r6, #SDRAM_PAD_CTRL_DRVP_MASK
200*3e93b4e6SMasahiro Yamada
201*3e93b4e6SMasahiro Yamada	/* Get the final N locked value of driving strength [22:17]	*/
202*3e93b4e6SMasahiro Yamada	mov	r1, r6
203*3e93b4e6SMasahiro Yamada	mov	r1, r1, LSL #9
204*3e93b4e6SMasahiro Yamada	mov	r1, r1, LSR #26
205*3e93b4e6SMasahiro Yamada	orr	r1, r1, r1, LSL #6 /* r1[5:0] = r3[22:17]<LockN>	*/
206*3e93b4e6SMasahiro Yamada
207*3e93b4e6SMasahiro Yamada	/* Write to both <DrvN> bits [5:0] and <DrvP> bits [11:6]	*/
208*3e93b4e6SMasahiro Yamada	orr	r6, r6, r1
209*3e93b4e6SMasahiro Yamada
210*3e93b4e6SMasahiro Yamada	str	r6, [r3, #0x4C4]
211*3e93b4e6SMasahiro Yamada
212*3e93b4e6SMasahiro Yamada	/* Implement Guideline (GL# MEM-3) Drive Strength Value		*/
213*3e93b4e6SMasahiro Yamada	/* Relevant for: 88F5181-A1/B0/B1 and 88F5281-A0/B0		*/
214*3e93b4e6SMasahiro Yamada
215*3e93b4e6SMasahiro Yamada	ldr	r1, =DDR1_PAD_STRENGTH_DEFAULT
216*3e93b4e6SMasahiro Yamada
217*3e93b4e6SMasahiro Yamada	/* Enable writes to DDR SDRAM Addr/Ctrl Pads Calibration register */
218*3e93b4e6SMasahiro Yamada	ldr	r6, [r3, #0x4C0]
219*3e93b4e6SMasahiro Yamada	orr	r6, r6, #SDRAM_PAD_CTRL_WR_EN
220*3e93b4e6SMasahiro Yamada	str	r6, [r3, #0x4C0]
221*3e93b4e6SMasahiro Yamada
222*3e93b4e6SMasahiro Yamada	/* Correct strength and disable writes again */
223*3e93b4e6SMasahiro Yamada	bic	r6, r6, #SDRAM_PAD_CTRL_WR_EN
224*3e93b4e6SMasahiro Yamada	bic	r6, r6, #SDRAM_PAD_CTRL_DRV_STR_MASK
225*3e93b4e6SMasahiro Yamada	orr	r6, r6, r1
226*3e93b4e6SMasahiro Yamada	str	r6, [r3, #0x4C0]
227*3e93b4e6SMasahiro Yamada
228*3e93b4e6SMasahiro Yamada	/* Enable writes to DDR SDRAM Data Pads Calibration register */
229*3e93b4e6SMasahiro Yamada	ldr	r6, [r3, #0x4C4]
230*3e93b4e6SMasahiro Yamada	orr	r6, r6, #SDRAM_PAD_CTRL_WR_EN
231*3e93b4e6SMasahiro Yamada	str	r6, [r3, #0x4C4]
232*3e93b4e6SMasahiro Yamada
233*3e93b4e6SMasahiro Yamada	/* Correct strength and disable writes again */
234*3e93b4e6SMasahiro Yamada	bic	r6, r6, #SDRAM_PAD_CTRL_DRV_STR_MASK
235*3e93b4e6SMasahiro Yamada	bic	r6, r6, #SDRAM_PAD_CTRL_WR_EN
236*3e93b4e6SMasahiro Yamada	orr	r6, r6, r1
237*3e93b4e6SMasahiro Yamada	str	r6, [r3, #0x4C4]
238*3e93b4e6SMasahiro Yamada
239*3e93b4e6SMasahiro Yamada	/* Implement Guideline (GL# MEM-4) DQS Reference Delay Tuning	*/
240*3e93b4e6SMasahiro Yamada	/* Relevant for: 88F5181-A1/B0/B1 and 88F5281-A0/B0		*/
241*3e93b4e6SMasahiro Yamada
242*3e93b4e6SMasahiro Yamada	/* Get the "sample on reset" register for the DDR frequancy	*/
243*3e93b4e6SMasahiro Yamada	ldr	r3, =0x10000
244*3e93b4e6SMasahiro Yamada	ldr	r6, [r3, #0x010]
245*3e93b4e6SMasahiro Yamada	ldr	r1, =MSAR_ARMDDRCLCK_MASK
246*3e93b4e6SMasahiro Yamada	and	r1, r6, r1
247*3e93b4e6SMasahiro Yamada
248*3e93b4e6SMasahiro Yamada	ldr	r6, =FTDLL_DDR1_166MHZ
249*3e93b4e6SMasahiro Yamada	cmp	r1, #MSAR_ARMDDRCLCK_333_167
250*3e93b4e6SMasahiro Yamada	beq	3f
251*3e93b4e6SMasahiro Yamada	cmp	r1, #MSAR_ARMDDRCLCK_500_167
252*3e93b4e6SMasahiro Yamada	beq	3f
253*3e93b4e6SMasahiro Yamada	cmp	r1, #MSAR_ARMDDRCLCK_667_167
254*3e93b4e6SMasahiro Yamada	beq	3f
255*3e93b4e6SMasahiro Yamada
256*3e93b4e6SMasahiro Yamada	ldr	r6, =FTDLL_DDR1_200MHZ
257*3e93b4e6SMasahiro Yamada	cmp	r1, #MSAR_ARMDDRCLCK_400_200_1
258*3e93b4e6SMasahiro Yamada	beq	3f
259*3e93b4e6SMasahiro Yamada	cmp	r1, #MSAR_ARMDDRCLCK_400_200
260*3e93b4e6SMasahiro Yamada	beq	3f
261*3e93b4e6SMasahiro Yamada	cmp	r1, #MSAR_ARMDDRCLCK_600_200
262*3e93b4e6SMasahiro Yamada	beq	3f
263*3e93b4e6SMasahiro Yamada	cmp	r1, #MSAR_ARMDDRCLCK_800_200
264*3e93b4e6SMasahiro Yamada	beq	3f
265*3e93b4e6SMasahiro Yamada
266*3e93b4e6SMasahiro Yamada	ldr	r6, =0
267*3e93b4e6SMasahiro Yamada
268*3e93b4e6SMasahiro Yamada3:
269*3e93b4e6SMasahiro Yamada	/* Use R3 as the base for DRAM registers */
270*3e93b4e6SMasahiro Yamada	add	r3, r4, #0x01000
271*3e93b4e6SMasahiro Yamada
272*3e93b4e6SMasahiro Yamada	ldr	r2, [r3, #0x484]
273*3e93b4e6SMasahiro Yamada	orr	r2, r2, r6
274*3e93b4e6SMasahiro Yamada	str	r2, [r3, #0x484]
275*3e93b4e6SMasahiro Yamada
276*3e93b4e6SMasahiro Yamada	/* Return to U-boot via saved link register */
277*3e93b4e6SMasahiro Yamada	mov	pc, lr
278