summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDale Rahn <drahn@cvs.openbsd.org>2005-10-03 02:16:11 +0000
committerDale Rahn <drahn@cvs.openbsd.org>2005-10-03 02:16:11 +0000
commit8d93507761c678254a6484c24994be455a2796dd (patch)
tree74ace63491254e3dd62369415eaa75b711d0266c
parentf2e709e247aad62c71e9107297739e4fdb223379 (diff)
First part of locore G5 support, this is one step of many.
Get this in and tested before the rest hits the tree.
-rw-r--r--sys/arch/macppc/macppc/cpu.c30
-rw-r--r--sys/arch/macppc/macppc/locore.S97
-rw-r--r--sys/arch/macppc/macppc/machdep.c4
3 files changed, 121 insertions, 10 deletions
diff --git a/sys/arch/macppc/macppc/cpu.c b/sys/arch/macppc/macppc/cpu.c
index 0fe338a959a..dc322062f7e 100644
--- a/sys/arch/macppc/macppc/cpu.c
+++ b/sys/arch/macppc/macppc/cpu.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: cpu.c,v 1.23 2005/10/01 19:55:25 drahn Exp $ */
+/* $OpenBSD: cpu.c,v 1.24 2005/10/03 02:16:10 drahn Exp $ */
/*
* Copyright (c) 1997 Per Fogelstrom
@@ -98,20 +98,48 @@ ppc_cpuspeed(int *freq)
}
int ppc_proc_is_64b;
+extern u_int32_t rfi_inst, rfid_inst, nop_inst;
+extern u_int32_t *rfi_whack[], *rfi_whackend[];
+struct noppatch{
+ u_int32_t *s;
+ u_int32_t *e;
+};
+extern struct noppatch nop32_start;
+extern struct noppatch nop32_end;
+extern struct noppatch nop64_start;
+extern struct noppatch nop64_end;
+
void
ppc_check_procid()
{
u_int32_t cpu, pvr;
+ u_int32_t *inst;
+ int i;
+ struct noppatch *pnop;
+
pvr = ppc_mfpvr();
cpu = pvr >> 16;
switch (cpu) {
case PPC_CPU_IBM970:
ppc_proc_is_64b = 1;
+ for (i = 0; &rfi_whack[i] < &rfi_whackend[0]; i++) {
+ inst = rfi_whack[i];
+ *inst = rfid_inst;
+ }
+ for (pnop = &nop64_start; pnop < &nop64_end; pnop++) {
+ for (inst = pnop->s; inst < pnop->e; inst++)
+ *inst = nop_inst;
+ }
+
break;
default:
ppc_proc_is_64b = 0;
+ for (pnop = &nop32_start; pnop < &nop32_end; pnop++) {
+ for (inst = pnop->s; inst < pnop->e; inst++)
+ *inst = nop_inst;
+ }
}
}
diff --git a/sys/arch/macppc/macppc/locore.S b/sys/arch/macppc/macppc/locore.S
index 35958bee209..4d71a774a08 100644
--- a/sys/arch/macppc/macppc/locore.S
+++ b/sys/arch/macppc/macppc/locore.S
@@ -1,4 +1,4 @@
-/* $OpenBSD: locore.S,v 1.22 2005/09/19 04:16:24 drahn Exp $ */
+/* $OpenBSD: locore.S,v 1.23 2005/10/03 02:16:10 drahn Exp $ */
/* $NetBSD: locore.S,v 1.2 1996/10/16 19:33:09 ws Exp $ */
/*
@@ -290,12 +290,14 @@ switch_exited:
addic. %r5,%r5,64
li %r6,0
mfsr %r8,PPC_KERNEL_SR /* save kernel SR */
+nop64_1s:
1:
addis %r6,%r6,-0x10000000@ha /* set new procs segment registers */
or. %r6,%r6,%r6 /* This is done from the real address pmap */
lwzu %r7,-4(%r5) /* so we don't have to worry */
mtsrin %r7,%r6 /* about accessibility */
bne 1b
+nop64_1e:
mtsr PPC_KERNEL_SR,%r8 /* restore kernel SR */
isync
@@ -352,6 +354,11 @@ _C_LABEL(intr_depth):
.type _C_LABEL(trapsize),@object
_C_LABEL(trapcode):
mtsprg 1,%r1 /* save SP */
+nop32_1s:
+ mfmsr %r1
+ clrldi %r1,%r1,1
+ mtmsrd %r1
+nop32_1e:
stmw %r28,tempsave(%r0) /* free r28-r31 */
mflr %r28 /* save LR */
mfcr %r29 /* save CR */
@@ -373,6 +380,12 @@ _C_LABEL(trapsize) = .-_C_LABEL(trapcode)
.globl _C_LABEL(alitrap),_C_LABEL(alisize)
_C_LABEL(alitrap):
mtsprg 1,%r1 /* save SP */
+nop32_2s:
+ mfmsr %r1
+ clrldi %r1,%r1,1
+ mtmsrd %r1
+ mfsprg %r1,1 /* restore SP */
+nop32_2e:
stmw %r28,tempsave(0) /* free r28-r31 */
mfdar %r30
mfdsisr %r31
@@ -401,6 +414,11 @@ _C_LABEL(alisize) = .-_C_LABEL(alitrap)
.type _C_LABEL(dsisize),@object
_C_LABEL(dsitrap):
stmw %r28,disisave(0) /* free r28-r31 */
+nop32_3s:
+ mfmsr %r28
+ clrldi %r28,%r28,1
+ mtmsrd %r28
+nop32_3e:
mfcr %r29 /* save CR */
mfxer %r30 /* save XER */
mtsprg 2,%r30 /* in SPRG2 */
@@ -430,7 +448,7 @@ _C_LABEL(dsitrap):
mtxer %r30
mtcr %r29 /* restore CR */
lmw %r28,disisave(0) /* restore r28-r31 */
- rfi /* return to trapped code */
+rfi1: rfi /* return to trapped code */
1:
#endif
mflr %r28 /* save LR */
@@ -444,6 +462,13 @@ _C_LABEL(dsisize) = .-_C_LABEL(dsitrap)
.type _C_LABEL(isitrap),@function
.type _C_LABEL(isisize),@object
_C_LABEL(isitrap):
+nop32_4s:
+ mtsprg 1,%r1 /* save SP */
+ mfmsr %r1
+ clrldi %r1,%r1,1
+ mtmsrd %r1
+ mfsprg %r1,1 /* restore SP */
+nop32_4e:
stmw %r28,disisave(0) /* free r28-r31 */
mflr %r28 /* save LR */
mfcr %r29 /* save CR */
@@ -462,7 +487,7 @@ _C_LABEL(isitrap):
mtibatl 3,%r30
mtcr %r29 /* restore CR */
lmw %r28,disisave(0) /* restore r28-r31 */
- rfi /* return to trapped code */
+rfi2: rfi /* return to trapped code */
1:
#endif
bla s_isitrap
@@ -476,6 +501,11 @@ _C_LABEL(isisize) = .-_C_LABEL(isitrap)
.type _C_LABEL(extsize),@object
_C_LABEL(extint):
mtsprg 1,%r1 /* save SP */
+nop32_5s:
+ mfmsr %r1
+ clrldi %r1,%r1,1
+ mtmsrd %r1
+nop32_5e:
stmw %r28,tempsave(0) /* free r28-r31 */
mflr %r28 /* save LR */
mfcr %r29 /* save CR */
@@ -499,6 +529,11 @@ _C_LABEL(extsize) = .-_C_LABEL(extint)
.type _C_LABEL(decrsize),@object
_C_LABEL(decrint):
mtsprg 1,%r1 /* save SP */
+nop32_6s:
+ mfmsr %r1
+ clrldi %r1,%r1,1
+ mtmsrd %r1
+nop32_6e:
stmw %r28,tempsave(0) /* free r28-r31 */
mflr %r28 /* save LR */
mfcr %r29 /* save CR */
@@ -727,7 +762,12 @@ _C_LABEL(tlbdsmsize) = .-_C_LABEL(tlbdsmiss)
.globl _C_LABEL(ddblow),_C_LABEL(ddbsize)
_C_LABEL(ddblow):
- mtsprg 1,%r1 /* save SP */
+ mtspr 1,%r1 /* save SP */
+nop32_7s:
+ mfmsr %r1
+ clrldi %r1,%r1,1
+ mtmsrd %r1
+nop32_7e:
stmw %r28,ddbsave(0) /* free r28-r31 */
mflr %r28 /* save LR */
mfcr %r29 /* save CR */
@@ -884,7 +924,7 @@ trapexit:
b trapagain
1:
FRAME_LEAVE(tempsave)
- rfi
+rfi3: rfi
/*
* Child comes here at the end of a fork.
@@ -953,7 +993,7 @@ s_pte_spill:
mtcr %r29 /* restore CR */
mtlr %r28 /* restore LR */
lmw %r28,disisave(0) /* restore r28-r31 */
- rfi /* return to trapped code */
+rfi4: rfi /* return to trapped code */
/*
* ISI second stage fault handler
@@ -1100,7 +1140,7 @@ intr_exit:
lwz %r3,80(%r1)
lwz %r0,84(%r1)
lwz %r1,0(%r1)
- rfi
+rfi5: rfi
/*
* Decrementer interrupt second level handler
@@ -1235,6 +1275,47 @@ ddbtrap:
b realtrap
ddbleave:
FRAME_LEAVE(ddbsave)
- rfi
+rfi6: rfi
#endif /* DDB */
+ .globl _C_LABEL(rfi_inst)
+_C_LABEL(rfi_inst):
+ rfi
+ .globl _C_LABEL(rfid_inst)
+_C_LABEL(rfid_inst):
+ rfid
+ .globl _C_LABEL(rfi_whack)
+_C_LABEL(rfi_whack):
+#if 0
+ /* rfi1 and rfi2 are currently inside if 0ed code */
+ .long rfi1
+ .long rfi2
+#endif
+ .long rfi3
+ .long rfi4
+ .long rfi5
+ .long rfi6
+ .globl _C_LABEL(rfi_whackend)
+_C_LABEL(rfi_whackend):
+
+ .globl _C_LABEL(nop_inst)
+ _C_LABEL(nop_inst):
+ nop
+
+ .globl _C_LABEL(nop64_start)
+ .globl _C_LABEL(nop64_end)
+_C_LABEL(nop64_start):
+ .long nop64_1s, nop64_1e
+_C_LABEL(nop64_end):
+
+ .globl _C_LABEL(nop32_start)
+ .globl _C_LABEL(nop32_end)
+_C_LABEL(nop32_start):
+ .long nop32_1s, nop32_1e
+ .long nop32_2s, nop32_2e
+ .long nop32_3s, nop32_3e
+ .long nop32_4s, nop32_4e
+ .long nop32_5s, nop32_5e
+ .long nop32_6s, nop32_6e
+ .long nop32_7s, nop32_7e
+_C_LABEL(nop32_end):
diff --git a/sys/arch/macppc/macppc/machdep.c b/sys/arch/macppc/macppc/machdep.c
index 83b5475c111..800433f56ac 100644
--- a/sys/arch/macppc/macppc/machdep.c
+++ b/sys/arch/macppc/macppc/machdep.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: machdep.c,v 1.72 2005/07/04 01:02:10 mickey Exp $ */
+/* $OpenBSD: machdep.c,v 1.73 2005/10/03 02:16:10 drahn Exp $ */
/* $NetBSD: machdep.c,v 1.4 1996/10/16 19:33:11 ws Exp $ */
/*
@@ -208,6 +208,8 @@ initppc(startkernel, endkernel, args)
curpm = curpcb->pcb_pmreal = curpcb->pcb_pm = pmap_kernel();
+ ppc_check_procid();
+
/*
* Initialize BAT registers to unmapped to not generate
* overlapping mappings below.