explora_start.S revision 1.13 1 1.13 rin /* $NetBSD: explora_start.S,v 1.13 2022/06/04 22:32:20 rin Exp $ */
2 1.1 hannken
3 1.1 hannken /*-
4 1.1 hannken * Copyright (c) 2003 The NetBSD Foundation, Inc.
5 1.1 hannken * All rights reserved.
6 1.1 hannken *
7 1.1 hannken * This code is derived from software contributed to The NetBSD Foundation
8 1.1 hannken * by Juergen Hannken-Illjes.
9 1.1 hannken *
10 1.1 hannken * Redistribution and use in source and binary forms, with or without
11 1.1 hannken * modification, are permitted provided that the following conditions
12 1.1 hannken * are met:
13 1.1 hannken * 1. Redistributions of source code must retain the above copyright
14 1.1 hannken * notice, this list of conditions and the following disclaimer.
15 1.1 hannken * 2. Redistributions in binary form must reproduce the above copyright
16 1.1 hannken * notice, this list of conditions and the following disclaimer in the
17 1.1 hannken * documentation and/or other materials provided with the distribution.
18 1.1 hannken *
19 1.1 hannken * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
20 1.1 hannken * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
21 1.1 hannken * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
22 1.1 hannken * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
23 1.1 hannken * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
24 1.1 hannken * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
25 1.1 hannken * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
26 1.1 hannken * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
27 1.1 hannken * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
28 1.1 hannken * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
29 1.1 hannken * POSSIBILITY OF SUCH DAMAGE.
30 1.1 hannken */
31 1.1 hannken
32 1.1 hannken /*
33 1.1 hannken * Initial state:
34 1.1 hannken *
35 1.1 hannken * iccr = 0x00008001 0x80000000-0x87ffffff 0xf80000000-0xffffffff
36 1.1 hannken * dccr = 0x00008001 0x80000000-0x87ffffff 0xf80000000-0xffffffff
37 1.1 hannken * dcwr = 0x00000000
38 1.1 hannken * msr = 0x00001000 ME=machine check enable
39 1.1 hannken *
40 1.1 hannken */
41 1.1 hannken
42 1.1 hannken #include "assym.h"
43 1.1 hannken
44 1.1 hannken #include <machine/param.h>
45 1.1 hannken #include <machine/psl.h>
46 1.1 hannken #include <machine/trap.h>
47 1.1 hannken #include <machine/asm.h>
48 1.1 hannken
49 1.1 hannken #include <powerpc/spr.h>
50 1.7 matt #include <powerpc/ibm4xx/spr.h>
51 1.1 hannken #include <powerpc/ibm4xx/dcr403cgx.h>
52 1.1 hannken
53 1.1 hannken #include "opt_ddb.h"
54 1.1 hannken #include "opt_ppcparam.h"
55 1.1 hannken
56 1.1 hannken /*
57 1.1 hannken * Initially the dram starts at 0x01000000. This is way too high.
58 1.1 hannken * We relocate dram to 0x00000000. We use the video ram at 0xf0000000
59 1.1 hannken * as a temporary staging area.
60 1.1 hannken */
61 1.1 hannken
62 1.1 hannken #define STAGE1_BASE 0xf0000000
63 1.1 hannken
64 1.1 hannken .text
65 1.1 hannken .globl __start
66 1.1 hannken __start:
67 1.1 hannken b 1f
68 1.1 hannken nop
69 1.1 hannken nop
70 1.1 hannken .long 0
71 1.1 hannken .ascii "XncdPPC\0"
72 1.1 hannken .long 0
73 1.1 hannken .long 0
74 1.1 hannken
75 1.1 hannken 1:
76 1.1 hannken /* Disable exceptions, caches, invalidate all TLB's. */
77 1.1 hannken
78 1.13 rin li %r0,0
79 1.13 rin mtmsr %r0
80 1.13 rin mttcr %r0
81 1.13 rin mtdccr %r0
82 1.13 rin mticcr %r0
83 1.1 hannken sync
84 1.1 hannken isync
85 1.1 hannken
86 1.1 hannken /* Clear caches and invalidate tlbs */
87 1.13 rin li %r7,256
88 1.13 rin mtctr %r7
89 1.13 rin li %r6,0
90 1.1 hannken 1:
91 1.13 rin dccci %r0,%r6
92 1.13 rin addi %r6,%r6,16
93 1.1 hannken bdnz 1b
94 1.1 hannken
95 1.13 rin li %r7,512
96 1.13 rin mtctr %r7
97 1.13 rin li %r6,0
98 1.1 hannken 1:
99 1.13 rin iccci %r0,%r6
100 1.13 rin addi %r6,%r6,16
101 1.1 hannken bdnz 1b
102 1.1 hannken
103 1.1 hannken tlbia
104 1.1 hannken sync
105 1.1 hannken isync
106 1.1 hannken
107 1.1 hannken /* Get current address -- NOT the same as . */
108 1.1 hannken
109 1.1 hannken bl _next
110 1.1 hannken _next:
111 1.13 rin mflr %r3
112 1.13 rin subi %r3,%r3,_next-__start
113 1.13 rin lis %r4,STAGE1_BASE@h
114 1.13 rin ori %r4,%r4,STAGE1_BASE@l
115 1.13 rin li %r5,stage1size
116 1.1 hannken
117 1.1 hannken 1:
118 1.13 rin lbz %r1,0(%r3)
119 1.13 rin mr %r0,%r5
120 1.13 rin cmpwi %r0,0
121 1.13 rin stb %r1,0(%r4)
122 1.13 rin addi %r3,%r3,1
123 1.13 rin addi %r4,%r4,1
124 1.13 rin addi %r5,%r5,-1
125 1.1 hannken bgt 1b
126 1.1 hannken
127 1.1 hannken /* Jump into the staging area so we can remap the dram. */
128 1.1 hannken
129 1.13 rin lis %r0,stage1reloc@h
130 1.13 rin ori %r0,%r0,stage1reloc@l
131 1.13 rin mtlr %r0
132 1.1 hannken blr
133 1.1 hannken
134 1.1 hannken stage1reloc = .-__start+STAGE1_BASE
135 1.1 hannken
136 1.1 hannken /* Remap the dram from 0x01000000 to 0x00000000. */
137 1.1 hannken
138 1.1 hannken #define REMAP(r, tmp1, tmp2) \
139 1.1 hannken mfbr##r tmp1 ; \
140 1.1 hannken lis tmp2,0xff ; \
141 1.1 hannken ori tmp2,tmp2,0xffff ; \
142 1.1 hannken cmplw tmp1,tmp2 ; \
143 1.1 hannken ble 1f ; \
144 1.1 hannken addis tmp1,tmp1,0xf000 ; \
145 1.1 hannken mtbr##r tmp1 ; \
146 1.1 hannken 1:
147 1.1 hannken
148 1.13 rin REMAP(4, %r1, %r2)
149 1.13 rin REMAP(5, %r1, %r2)
150 1.13 rin REMAP(6, %r1, %r2)
151 1.13 rin REMAP(7, %r1, %r2)
152 1.1 hannken
153 1.1 hannken #undef REMAP
154 1.1 hannken
155 1.1 hannken /* Initial setup. */
156 1.1 hannken
157 1.1 hannken ba stage2
158 1.1 hannken
159 1.1 hannken stage2:
160 1.1 hannken
161 1.1 hannken #ifdef PPC_4XX_NOCACHE
162 1.13 rin li %r0,0
163 1.1 hannken #else
164 1.13 rin lis %r0,0xfffc
165 1.1 hannken #endif
166 1.13 rin mtdccr %r0
167 1.13 rin mticcr %r0
168 1.1 hannken sync
169 1.1 hannken isync
170 1.1 hannken
171 1.1 hannken /* get start of bss */
172 1.13 rin lis %r7,_C_LABEL(edata)-4@h
173 1.13 rin ori %r7,%r7,_C_LABEL(edata)-4@l
174 1.1 hannken /* get end of kernel */
175 1.13 rin lis %r4,_C_LABEL(end)@h
176 1.13 rin ori %r4,%r4,_C_LABEL(end)@l
177 1.1 hannken /* clear bss */
178 1.13 rin li %r3,0
179 1.1 hannken 1:
180 1.13 rin stwu %r3,4(%r7)
181 1.13 rin cmpw %r7,%r4
182 1.1 hannken bne+ 1b
183 1.1 hannken
184 1.12 rin /* Set kernel MMU context. */
185 1.13 rin li %r0,KERNEL_PID
186 1.13 rin mtpid %r0
187 1.12 rin sync
188 1.12 rin
189 1.13 rin INIT_CPUINFO(%r4,%r1,%r9,%r0)
190 1.1 hannken
191 1.13 rin lis %r3,__start@h
192 1.13 rin ori %r3,%r3,__start@l
193 1.1 hannken
194 1.1 hannken /* Run the remaining setup in C. */
195 1.9 matt bl _C_LABEL(initppc)
196 1.1 hannken
197 1.1 hannken bl _C_LABEL(main)
198 1.1 hannken
199 1.1 hannken /* NOTREACHED */
200 1.1 hannken 2: nop
201 1.1 hannken b 2b
202 1.1 hannken
203 1.1 hannken stage1size = .-__start
204 1.1 hannken
205 1.1 hannken #include <powerpc/ibm4xx/4xx_locore.S>
206