blob: 80ef2580515e91932c41ee45be922022f7ec3822 [file] [log] [blame]
Tom Rini83d290c2018-05-06 17:58:06 -04001/* SPDX-License-Identifier: GPL-2.0+ */
Nobuhiro Iwamatsu7faddae2008-06-09 13:39:57 +09002/*
3 * Copyright (C) 2008 Renesas Solutions Corp.
4 * Copyright (C) 2008 Nobuhiro Iwamatsu <iwamatsu.nobuhiro@renesas.com>
5 * Copyright (C) 2007 Kenati Technologies, Inc.
6 *
7 * board/sh7763rdp/lowlevel_init.S
Nobuhiro Iwamatsu7faddae2008-06-09 13:39:57 +09008 */
9
10#include <config.h>
Nobuhiro Iwamatsu7faddae2008-06-09 13:39:57 +090011
12#include <asm/processor.h>
Jean-Christophe PLAGNIOL-VILLARDf7e78f32008-12-20 19:29:49 +010013#include <asm/macro.h>
Nobuhiro Iwamatsu7faddae2008-06-09 13:39:57 +090014
15 .global lowlevel_init
16
17 .text
18 .align 2
19
20lowlevel_init:
21
Jean-Christophe PLAGNIOL-VILLARDf7e78f32008-12-20 19:29:49 +010022 write32 WDTCSR_A, WDTCSR_D /* Watchdog Control / Status Register */
Nobuhiro Iwamatsu7faddae2008-06-09 13:39:57 +090023
Jean-Christophe PLAGNIOL-VILLARDf7e78f32008-12-20 19:29:49 +010024 write32 WDTST_A, WDTST_D /* Watchdog Stop Time Register */
Nobuhiro Iwamatsu7faddae2008-06-09 13:39:57 +090025
Jean-Christophe PLAGNIOL-VILLARDf7e78f32008-12-20 19:29:49 +010026 write32 WDTBST_A, WDTBST_D /*
27 * 0xFFCC0008
28 * Watchdog Base Stop Time Register
29 */
Nobuhiro Iwamatsu7faddae2008-06-09 13:39:57 +090030
Jean-Christophe PLAGNIOL-VILLARDf7e78f32008-12-20 19:29:49 +010031 write32 CCR_A, CCR_CACHE_ICI_D /* Address of Cache Control Register */
32 /* Instruction Cache Invalidate */
Nobuhiro Iwamatsu7faddae2008-06-09 13:39:57 +090033
Jean-Christophe PLAGNIOL-VILLARDf7e78f32008-12-20 19:29:49 +010034 write32 MMUCR_A, MMU_CONTROL_TI_D /* MMU Control Register */
35 /* TI == TLB Invalidate bit */
Nobuhiro Iwamatsu7faddae2008-06-09 13:39:57 +090036
Jean-Christophe PLAGNIOL-VILLARDf7e78f32008-12-20 19:29:49 +010037 write32 MSTPCR0_A, MSTPCR0_D /* Address of Power Control Register 0 */
Nobuhiro Iwamatsu7faddae2008-06-09 13:39:57 +090038
Jean-Christophe PLAGNIOL-VILLARDf7e78f32008-12-20 19:29:49 +010039 write32 MSTPCR1_A, MSTPCR1_D /* Address of Power Control Register 1 */
Nobuhiro Iwamatsu7faddae2008-06-09 13:39:57 +090040
Jean-Christophe PLAGNIOL-VILLARDf7e78f32008-12-20 19:29:49 +010041 write32 RAMCR_A, RAMCR_D
Nobuhiro Iwamatsu7faddae2008-06-09 13:39:57 +090042
Jean-Christophe PLAGNIOL-VILLARDe4430772008-12-20 19:29:48 +010043 mov.l MMSELR_A, r1
44 mov.l MMSELR_D, r0
Nobuhiro Iwamatsu7faddae2008-06-09 13:39:57 +090045 synco
46 mov.l r0, @r1
47
Jean-Christophe PLAGNIOL-VILLARDf7e78f32008-12-20 19:29:49 +010048 mov.l @r1, r2 /* execute two reads after setting MMSELR */
Jean-Christophe PLAGNIOL-VILLARDe4430772008-12-20 19:29:48 +010049 mov.l @r1, r2
Nobuhiro Iwamatsu7faddae2008-06-09 13:39:57 +090050 synco
51
52 /* issue memory read */
Jean-Christophe PLAGNIOL-VILLARDe4430772008-12-20 19:29:48 +010053 mov.l DDRSD_START_A, r1 /* memory address to read*/
54 mov.l @r1, r0
Nobuhiro Iwamatsu7faddae2008-06-09 13:39:57 +090055 synco
56
Jean-Christophe PLAGNIOL-VILLARDf7e78f32008-12-20 19:29:49 +010057 write32 MIM8_A, MIM8_D
Nobuhiro Iwamatsu7faddae2008-06-09 13:39:57 +090058
Jean-Christophe PLAGNIOL-VILLARDf7e78f32008-12-20 19:29:49 +010059 write32 MIMC_A, MIMC_D1
Nobuhiro Iwamatsu7faddae2008-06-09 13:39:57 +090060
Jean-Christophe PLAGNIOL-VILLARDf7e78f32008-12-20 19:29:49 +010061 write32 STRC_A, STRC_D
Nobuhiro Iwamatsu7faddae2008-06-09 13:39:57 +090062
Jean-Christophe PLAGNIOL-VILLARDf7e78f32008-12-20 19:29:49 +010063 write32 SDR4_A, SDR4_D
Nobuhiro Iwamatsu7faddae2008-06-09 13:39:57 +090064
Jean-Christophe PLAGNIOL-VILLARDf7e78f32008-12-20 19:29:49 +010065 write32 MIMC_A, MIMC_D2
Nobuhiro Iwamatsu7faddae2008-06-09 13:39:57 +090066
67 nop
68 nop
69 nop
70
Jean-Christophe PLAGNIOL-VILLARDf7e78f32008-12-20 19:29:49 +010071 write32 SCR4_A, SCR4_D3
Nobuhiro Iwamatsu7faddae2008-06-09 13:39:57 +090072
Jean-Christophe PLAGNIOL-VILLARDf7e78f32008-12-20 19:29:49 +010073 write32 SCR4_A, SCR4_D2
Nobuhiro Iwamatsu7faddae2008-06-09 13:39:57 +090074
Jean-Christophe PLAGNIOL-VILLARDf7e78f32008-12-20 19:29:49 +010075 write32 SDMR02000_A, SDMR02000_D
Nobuhiro Iwamatsu7faddae2008-06-09 13:39:57 +090076
Jean-Christophe PLAGNIOL-VILLARDf7e78f32008-12-20 19:29:49 +010077 write32 SDMR00B08_A, SDMR00B08_D
Nobuhiro Iwamatsu7faddae2008-06-09 13:39:57 +090078
Jean-Christophe PLAGNIOL-VILLARDf7e78f32008-12-20 19:29:49 +010079 write32 SCR4_A, SCR4_D2
Nobuhiro Iwamatsu7faddae2008-06-09 13:39:57 +090080
Jean-Christophe PLAGNIOL-VILLARDf7e78f32008-12-20 19:29:49 +010081 write32 SCR4_A, SCR4_D4
Nobuhiro Iwamatsu7faddae2008-06-09 13:39:57 +090082
83 nop
84 nop
85 nop
86 nop
87
Jean-Christophe PLAGNIOL-VILLARDf7e78f32008-12-20 19:29:49 +010088 write32 SCR4_A, SCR4_D4
Nobuhiro Iwamatsu7faddae2008-06-09 13:39:57 +090089
90 nop
91 nop
92 nop
93 nop
94
Jean-Christophe PLAGNIOL-VILLARDf7e78f32008-12-20 19:29:49 +010095 write32 SDMR00308_A, SDMR00308_D
Nobuhiro Iwamatsu7faddae2008-06-09 13:39:57 +090096
Jean-Christophe PLAGNIOL-VILLARDf7e78f32008-12-20 19:29:49 +010097 write32 MIMC_A, MIMC_D3
Nobuhiro Iwamatsu7faddae2008-06-09 13:39:57 +090098
Jean-Christophe PLAGNIOL-VILLARDe4430772008-12-20 19:29:48 +010099 mov.l SCR4_A, r1
100 mov.l SCR4_D1, r0
101 mov.l DELAY60_D, r3
Nobuhiro Iwamatsu7faddae2008-06-09 13:39:57 +0900102
103delay_loop_60:
Jean-Christophe PLAGNIOL-VILLARDe4430772008-12-20 19:29:48 +0100104 mov.l r0, @r1
Nobuhiro Iwamatsu7faddae2008-06-09 13:39:57 +0900105 dt r3
106 bf delay_loop_60
107 nop
108
Jean-Christophe PLAGNIOL-VILLARDf7e78f32008-12-20 19:29:49 +0100109 write32 CCR_A, CCR_CACHE_D_2 /* Address of Cache Control Register */
Nobuhiro Iwamatsu7faddae2008-06-09 13:39:57 +0900110
111bsc_init:
Jean-Christophe PLAGNIOL-VILLARDf7e78f32008-12-20 19:29:49 +0100112 write32 BCR_A, BCR_D
Nobuhiro Iwamatsu7faddae2008-06-09 13:39:57 +0900113
Jean-Christophe PLAGNIOL-VILLARDf7e78f32008-12-20 19:29:49 +0100114 write32 CS0BCR_A, CS0BCR_D
Nobuhiro Iwamatsu7faddae2008-06-09 13:39:57 +0900115
Jean-Christophe PLAGNIOL-VILLARDf7e78f32008-12-20 19:29:49 +0100116 write32 CS1BCR_A, CS1BCR_D
Nobuhiro Iwamatsu7faddae2008-06-09 13:39:57 +0900117
Jean-Christophe PLAGNIOL-VILLARDf7e78f32008-12-20 19:29:49 +0100118 write32 CS2BCR_A, CS2BCR_D
Nobuhiro Iwamatsu7faddae2008-06-09 13:39:57 +0900119
Jean-Christophe PLAGNIOL-VILLARDf7e78f32008-12-20 19:29:49 +0100120 write32 CS4BCR_A, CS4BCR_D
Nobuhiro Iwamatsu7faddae2008-06-09 13:39:57 +0900121
Jean-Christophe PLAGNIOL-VILLARDf7e78f32008-12-20 19:29:49 +0100122 write32 CS5BCR_A, CS5BCR_D
Nobuhiro Iwamatsu7faddae2008-06-09 13:39:57 +0900123
Jean-Christophe PLAGNIOL-VILLARDf7e78f32008-12-20 19:29:49 +0100124 write32 CS6BCR_A, CS6BCR_D
Nobuhiro Iwamatsu7faddae2008-06-09 13:39:57 +0900125
Jean-Christophe PLAGNIOL-VILLARDf7e78f32008-12-20 19:29:49 +0100126 write32 CS0WCR_A, CS0WCR_D
Nobuhiro Iwamatsu7faddae2008-06-09 13:39:57 +0900127
Jean-Christophe PLAGNIOL-VILLARDf7e78f32008-12-20 19:29:49 +0100128 write32 CS1WCR_A, CS1WCR_D
Nobuhiro Iwamatsu7faddae2008-06-09 13:39:57 +0900129
Jean-Christophe PLAGNIOL-VILLARDf7e78f32008-12-20 19:29:49 +0100130 write32 CS2WCR_A, CS2WCR_D
Nobuhiro Iwamatsu7faddae2008-06-09 13:39:57 +0900131
Jean-Christophe PLAGNIOL-VILLARDf7e78f32008-12-20 19:29:49 +0100132 write32 CS4WCR_A, CS4WCR_D
Nobuhiro Iwamatsu7faddae2008-06-09 13:39:57 +0900133
Jean-Christophe PLAGNIOL-VILLARDf7e78f32008-12-20 19:29:49 +0100134 write32 CS5WCR_A, CS5WCR_D
Nobuhiro Iwamatsu7faddae2008-06-09 13:39:57 +0900135
Jean-Christophe PLAGNIOL-VILLARDf7e78f32008-12-20 19:29:49 +0100136 write32 CS6WCR_A, CS6WCR_D
Nobuhiro Iwamatsu7faddae2008-06-09 13:39:57 +0900137
Jean-Christophe PLAGNIOL-VILLARDf7e78f32008-12-20 19:29:49 +0100138 write32 CS5PCR_A, CS5PCR_D
Nobuhiro Iwamatsu7faddae2008-06-09 13:39:57 +0900139
Jean-Christophe PLAGNIOL-VILLARDf7e78f32008-12-20 19:29:49 +0100140 write32 CS6PCR_A, CS6PCR_D
Nobuhiro Iwamatsu7faddae2008-06-09 13:39:57 +0900141
Jean-Christophe PLAGNIOL-VILLARDe4430772008-12-20 19:29:48 +0100142 mov.l DELAY200_D, r3
Nobuhiro Iwamatsu7faddae2008-06-09 13:39:57 +0900143
144delay_loop_200:
145 dt r3
146 bf delay_loop_200
147 nop
148
Jean-Christophe PLAGNIOL-VILLARDf7e78f32008-12-20 19:29:49 +0100149 write16 PSEL0_A, PSEL0_D
Nobuhiro Iwamatsu7faddae2008-06-09 13:39:57 +0900150
Jean-Christophe PLAGNIOL-VILLARDf7e78f32008-12-20 19:29:49 +0100151 write16 PSEL1_A, PSEL1_D
Nobuhiro Iwamatsu7faddae2008-06-09 13:39:57 +0900152
Jean-Christophe PLAGNIOL-VILLARDf7e78f32008-12-20 19:29:49 +0100153 write32 ICR0_A, ICR0_D
Nobuhiro Iwamatsu7faddae2008-06-09 13:39:57 +0900154
155 stc sr, r0 /* BL bit off(init=ON) */
Jean-Christophe PLAGNIOL-VILLARDe4430772008-12-20 19:29:48 +0100156 mov.l SR_MASK_D, r1
Nobuhiro Iwamatsu7faddae2008-06-09 13:39:57 +0900157 and r1, r0
158 ldc r0, sr
159
160 rts
161 nop
162
163 .align 2
164
165DELAY60_D: .long 60
166DELAY200_D: .long 17800
167
168CCR_A: .long 0xFF00001C
169MMUCR_A: .long 0xFF000010
170RAMCR_A: .long 0xFF000074
171
172/* Low power mode control */
173MSTPCR0_A: .long 0xFFC80030
174MSTPCR1_A: .long 0xFFC80038
175
176/* RWBT */
177WDTST_A: .long 0xFFCC0000
178WDTCSR_A: .long 0xFFCC0004
179WDTBST_A: .long 0xFFCC0008
180
181/* BSC */
182MMSELR_A: .long 0xFE600020
183BCR_A: .long 0xFF801000
184CS0BCR_A: .long 0xFF802000
185CS1BCR_A: .long 0xFF802010
186CS2BCR_A: .long 0xFF802020
187CS4BCR_A: .long 0xFF802040
188CS5BCR_A: .long 0xFF802050
189CS6BCR_A: .long 0xFF802060
190CS0WCR_A: .long 0xFF802008
191CS1WCR_A: .long 0xFF802018
192CS2WCR_A: .long 0xFF802028
193CS4WCR_A: .long 0xFF802048
194CS5WCR_A: .long 0xFF802058
195CS6WCR_A: .long 0xFF802068
196CS5PCR_A: .long 0xFF802070
197CS6PCR_A: .long 0xFF802080
198DDRSD_START_A: .long 0xAC000000
199
200/* INTC */
201ICR0_A: .long 0xFFD00000
202
203/* DDR I/F */
204MIM8_A: .long 0xFE800008
205MIMC_A: .long 0xFE80000C
206SCR4_A: .long 0xFE800014
207STRC_A: .long 0xFE80001C
208SDR4_A: .long 0xFE800034
209SDMR00308_A: .long 0xFE900308
210SDMR00B08_A: .long 0xFE900B08
211SDMR02000_A: .long 0xFE902000
212
213/* GPIO */
214PSEL0_A: .long 0xFFEF0070
215PSEL1_A: .long 0xFFEF0072
216
217CCR_CACHE_ICI_D:.long 0x00000800
218CCR_CACHE_D_2: .long 0x00000103
219MMU_CONTROL_TI_D:.long 0x00000004
220RAMCR_D: .long 0x00000200
221MSTPCR0_D: .long 0x00000000
222MSTPCR1_D: .long 0x00000000
223
224MMSELR_D: .long 0xa5a50000
225BCR_D: .long 0x00000000
226CS0BCR_D: .long 0x77777770
227CS1BCR_D: .long 0x77777670
228CS2BCR_D: .long 0x77777670
229CS4BCR_D: .long 0x77777670
230CS5BCR_D: .long 0x77777670
231CS6BCR_D: .long 0x77777670
232CS0WCR_D: .long 0x7777770F
Jean-Christophe PLAGNIOL-VILLARDe4430772008-12-20 19:29:48 +0100233CS1WCR_D: .long 0x22000002
Nobuhiro Iwamatsu7faddae2008-06-09 13:39:57 +0900234CS2WCR_D: .long 0x7777770F
235CS4WCR_D: .long 0x7777770F
236CS5WCR_D: .long 0x7777770F
237CS6WCR_D: .long 0x7777770F
238CS5PCR_D: .long 0x77000000
239CS6PCR_D: .long 0x77000000
240ICR0_D: .long 0x00E00000
241MIM8_D: .long 0x00000000
242MIMC_D1: .long 0x01d10008
243MIMC_D2: .long 0x01d10009
244MIMC_D3: .long 0x01d10209
245SCR4_D1: .long 0x00000001
246SCR4_D2: .long 0x00000002
247SCR4_D3: .long 0x00000003
248SCR4_D4: .long 0x00000004
249STRC_D: .long 0x000f3980
250SDR4_D: .long 0x00000300
251SDMR00308_D: .long 0x00000000
252SDMR00B08_D: .long 0x00000000
253SDMR02000_D: .long 0x00000000
Nobuhiro Iwamatsu31067322010-07-22 15:29:10 +0900254PSEL0_D: .word 0x00000001
255PSEL1_D: .word 0x00000244
Nobuhiro Iwamatsu7faddae2008-06-09 13:39:57 +0900256SR_MASK_D: .long 0xEFFFFF0F
257WDTST_D: .long 0x5A000FFF
258WDTCSR_D: .long 0xA5000000
259WDTBST_D: .long 0x55000000