blob: 2a44eee1ad517647526aed75b7595c8eca704820 [file] [log] [blame]
Nobuhiro Iwamatsu113a37e2008-06-09 13:39:57 +09001/*
2 * Copyright (C) 2008 Renesas Solutions Corp.
3 * Copyright (C) 2008 Nobuhiro Iwamatsu <iwamatsu.nobuhiro@renesas.com>
4 * Copyright (C) 2007 Kenati Technologies, Inc.
5 *
6 * board/sh7763rdp/lowlevel_init.S
7 *
8 * This program is free software; you can redistribute it and/or
9 * modify it under the terms of the GNU General Public License as
10 * published by the Free Software Foundation; either version 2 of
11 * the License, or (at your option) any later version.
12 *
13 * This program is distributed in the hope that it will be useful,
14 * but WITHOUT ANY WARRANTY; without even the implied warranty of
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 * GNU General Public License for more details.
17 *
18 * You should have received a copy of the GNU General Public License
19 * along with this program; if not, write to the Free Software
20 * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
21 * MA 02111-1307 USA
22 */
23
24#include <config.h>
25#include <version.h>
26
27#include <asm/processor.h>
28
29 .global lowlevel_init
30
31 .text
32 .align 2
33
34lowlevel_init:
35
36 mov.l WDTCSR_A, r1 /* Watchdog Control / Status Register */
37 mov.l WDTCSR_D, r0
38 mov.l r0, @r1
39
40 mov.l WDTST_A, r1 /* Watchdog Stop Time Register */
41 mov.l WDTST_D, r0
42 mov.l r0, @r1
43
44 mov.l WDTBST_A, r1 /* 0xFFCC0008 (Watchdog Base Stop Time Register */
45 mov.l WDTBST_D, r0
46 mov.l r0, @r1
47
48 mov.l CCR_A, r1 /* Address of Cache Control Register */
49 mov.l CCR_CACHE_ICI_D, r0 /* Instruction Cache Invalidate */
50 mov.l r0, @r1
51
52 mov.l MMUCR_A, r1 /* Address of MMU Control Register */
53 mov.l MMU_CONTROL_TI_D, r0 /* TI == TLB Invalidate bit */
54 mov.l r0, @r1
55
56 mov.l MSTPCR0_A, r1 /* Address of Power Control Register 0 */
57 mov.l MSTPCR0_D, r0
58 mov.l r0, @r1
59
60 mov.l MSTPCR1_A, r1 /*i Address of Power Control Register 1 */
61 mov.l MSTPCR1_D, r0
62 mov.l r0, @r1
63
64 mov.l RAMCR_A,r1
65 mov.l RAMCR_D,r0
66 mov.l r0, @r1
67
68 mov.l MMSELR_A,r1
69 mov.l MMSELR_D,r0
70 synco
71 mov.l r0, @r1
72
73 mov.l @r1,r2 /* execute two reads after setting MMSELR*/
74 mov.l @r1,r2
75 synco
76
77 /* issue memory read */
78 mov.l DDRSD_START_A,r1 /* memory address to read*/
79 mov.l @r1,r0
80 synco
81
82 mov.l MIM8_A,r1
83 mov.l MIM8_D,r0
84 mov.l r0,@r1
85
86 mov.l MIMC_A,r1
87 mov.l MIMC_D1,r0
88 mov.l r0,@r1
89
90 mov.l STRC_A,r1
91 mov.l STRC_D,r0
92 mov.l r0,@r1
93
94 mov.l SDR4_A,r1
95 mov.l SDR4_D,r0
96 mov.l r0,@r1
97
98 mov.l MIMC_A,r1
99 mov.l MIMC_D2,r0
100 mov.l r0,@r1
101
102 nop
103 nop
104 nop
105
106 mov.l SCR4_A,r1
107 mov.l SCR4_D3,r0
108 mov.l r0,@r1
109
110 mov.l SCR4_A,r1
111 mov.l SCR4_D2,r0
112 mov.l r0,@r1
113
114 mov.l SDMR02000_A,r1
115 mov.l SDMR02000_D,r0
116 mov.l r0,@r1
117
118 mov.l SDMR00B08_A,r1
119 mov.l SDMR00B08_D,r0
120 mov.l r0,@r1
121
122 mov.l SCR4_A,r1
123 mov.l SCR4_D2,r0
124 mov.l r0,@r1
125
126 mov.l SCR4_A,r1
127 mov.l SCR4_D4,r0
128 mov.l r0,@r1
129
130 nop
131 nop
132 nop
133 nop
134
135 mov.l SCR4_A,r1
136 mov.l SCR4_D4,r0
137 mov.l r0,@r1
138
139 nop
140 nop
141 nop
142 nop
143
144 mov.l SDMR00308_A,r1
145 mov.l SDMR00308_D,r0
146 mov.l r0,@r1
147
148 mov.l MIMC_A,r1
149 mov.l MIMC_D3,r0
150 mov.l r0,@r1
151
152 mov.l SCR4_A,r1
153 mov.l SCR4_D1,r0
154 mov.l DELAY60_D,r3
155
156delay_loop_60:
157 mov.l r0,@r1
158 dt r3
159 bf delay_loop_60
160 nop
161
162 mov.l CCR_A, r1 /* Address of Cache Control Register */
163 mov.l CCR_CACHE_D_2, r0
164 mov.l r0, @r1
165
166bsc_init:
167 mov.l BCR_A, r1
168 mov.l BCR_D, r0
169 mov.l r0, @r1
170
171 mov.l CS0BCR_A, r1
172 mov.l CS0BCR_D, r0
173 mov.l r0, @r1
174
175 mov.l CS1BCR_A,r1
176 mov.l CS1BCR_D,r0
177 mov.l r0,@r1
178
179 mov.l CS2BCR_A, r1
180 mov.l CS2BCR_D, r0
181 mov.l r0, @r1
182
183 mov.l CS4BCR_A, r1
184 mov.l CS4BCR_D, r0
185 mov.l r0, @r1
186
187 mov.l CS5BCR_A, r1
188 mov.l CS5BCR_D, r0
189 mov.l r0, @r1
190
191 mov.l CS6BCR_A, r1
192 mov.l CS6BCR_D, r0
193 mov.l r0, @r1
194
195 mov.l CS0WCR_A, r1
196 mov.l CS0WCR_D, r0
197 mov.l r0, @r1
198
199 mov.l CS1WCR_A, r1
200 mov.l CS1WCR_D, r0
201 mov.l r0, @r1
202
203 mov.l CS2WCR_A, r1
204 mov.l CS2WCR_D, r0
205 mov.l r0, @r1
206
207 mov.l CS4WCR_A, r1
208 mov.l CS4WCR_D, r0
209 mov.l r0, @r1
210
211 mov.l CS5WCR_A, r1
212 mov.l CS5WCR_D, r0
213 mov.l r0, @r1
214
215 mov.l CS6WCR_A, r1
216 mov.l CS6WCR_D, r0
217 mov.l r0, @r1
218
219 mov.l CS5PCR_A, r1
220 mov.l CS5PCR_D, r0
221 mov.l r0, @r1
222
223 mov.l CS6PCR_A, r1
224 mov.l CS6PCR_D, r0
225 mov.l r0, @r1
226
227 mov.l DELAY200_D,r3
228
229delay_loop_200:
230 dt r3
231 bf delay_loop_200
232 nop
233
234 mov.l PSEL0_A,r1
235 mov.l PSEL0_D,r0
236 mov.w r0,@r1
237
238 mov.l PSEL1_A,r1
239 mov.l PSEL1_D,r0
240 mov.w r0,@r1
241
242 mov.l ICR0_A,r1
243 mov.l ICR0_D,r0
244 mov.l r0,@r1
245
246 stc sr, r0 /* BL bit off(init=ON) */
247 mov.l SR_MASK_D, r1
248 and r1, r0
249 ldc r0, sr
250
251 rts
252 nop
253
254 .align 2
255
256DELAY60_D: .long 60
257DELAY200_D: .long 17800
258
259CCR_A: .long 0xFF00001C
260MMUCR_A: .long 0xFF000010
261RAMCR_A: .long 0xFF000074
262
263/* Low power mode control */
264MSTPCR0_A: .long 0xFFC80030
265MSTPCR1_A: .long 0xFFC80038
266
267/* RWBT */
268WDTST_A: .long 0xFFCC0000
269WDTCSR_A: .long 0xFFCC0004
270WDTBST_A: .long 0xFFCC0008
271
272/* BSC */
273MMSELR_A: .long 0xFE600020
274BCR_A: .long 0xFF801000
275CS0BCR_A: .long 0xFF802000
276CS1BCR_A: .long 0xFF802010
277CS2BCR_A: .long 0xFF802020
278CS4BCR_A: .long 0xFF802040
279CS5BCR_A: .long 0xFF802050
280CS6BCR_A: .long 0xFF802060
281CS0WCR_A: .long 0xFF802008
282CS1WCR_A: .long 0xFF802018
283CS2WCR_A: .long 0xFF802028
284CS4WCR_A: .long 0xFF802048
285CS5WCR_A: .long 0xFF802058
286CS6WCR_A: .long 0xFF802068
287CS5PCR_A: .long 0xFF802070
288CS6PCR_A: .long 0xFF802080
289DDRSD_START_A: .long 0xAC000000
290
291/* INTC */
292ICR0_A: .long 0xFFD00000
293
294/* DDR I/F */
295MIM8_A: .long 0xFE800008
296MIMC_A: .long 0xFE80000C
297SCR4_A: .long 0xFE800014
298STRC_A: .long 0xFE80001C
299SDR4_A: .long 0xFE800034
300SDMR00308_A: .long 0xFE900308
301SDMR00B08_A: .long 0xFE900B08
302SDMR02000_A: .long 0xFE902000
303
304/* GPIO */
305PSEL0_A: .long 0xFFEF0070
306PSEL1_A: .long 0xFFEF0072
307
308CCR_CACHE_ICI_D:.long 0x00000800
309CCR_CACHE_D_2: .long 0x00000103
310MMU_CONTROL_TI_D:.long 0x00000004
311RAMCR_D: .long 0x00000200
312MSTPCR0_D: .long 0x00000000
313MSTPCR1_D: .long 0x00000000
314
315MMSELR_D: .long 0xa5a50000
316BCR_D: .long 0x00000000
317CS0BCR_D: .long 0x77777770
318CS1BCR_D: .long 0x77777670
319CS2BCR_D: .long 0x77777670
320CS4BCR_D: .long 0x77777670
321CS5BCR_D: .long 0x77777670
322CS6BCR_D: .long 0x77777670
323CS0WCR_D: .long 0x7777770F
324CS1WCR_D: .long 0x22000002
325CS2WCR_D: .long 0x7777770F
326CS4WCR_D: .long 0x7777770F
327CS5WCR_D: .long 0x7777770F
328CS6WCR_D: .long 0x7777770F
329CS5PCR_D: .long 0x77000000
330CS6PCR_D: .long 0x77000000
331ICR0_D: .long 0x00E00000
332MIM8_D: .long 0x00000000
333MIMC_D1: .long 0x01d10008
334MIMC_D2: .long 0x01d10009
335MIMC_D3: .long 0x01d10209
336SCR4_D1: .long 0x00000001
337SCR4_D2: .long 0x00000002
338SCR4_D3: .long 0x00000003
339SCR4_D4: .long 0x00000004
340STRC_D: .long 0x000f3980
341SDR4_D: .long 0x00000300
342SDMR00308_D: .long 0x00000000
343SDMR00B08_D: .long 0x00000000
344SDMR02000_D: .long 0x00000000
345PSEL0_D: .long 0x00000001
346PSEL1_D: .long 0x00000244
347SR_MASK_D: .long 0xEFFFFF0F
348WDTST_D: .long 0x5A000FFF
349WDTCSR_D: .long 0xA5000000
350WDTBST_D: .long 0x55000000