summaryrefslogtreecommitdiff
path: root/sys/arch
diff options
context:
space:
mode:
Diffstat (limited to 'sys/arch')
-rw-r--r--sys/arch/mips64/include/asm.h14
-rw-r--r--sys/arch/mips64/include/cpu.h3
-rw-r--r--sys/arch/mips64/mips64/context.S14
-rw-r--r--sys/arch/mips64/mips64/exception.S40
-rw-r--r--sys/arch/mips64/mips64/lcore_access.S44
-rw-r--r--sys/arch/mips64/mips64/lcore_ddb.S26
-rw-r--r--sys/arch/mips64/mips64/lcore_float.S13
-rw-r--r--sys/arch/mips64/mips64/tlbhandler.S14
-rw-r--r--sys/arch/sgi/include/asm.h11
-rw-r--r--sys/arch/sgi/include/cpu.h10
-rw-r--r--sys/arch/sgi/sgi/genassym.cf3
-rw-r--r--sys/arch/sgi/sgi/machdep.c5
12 files changed, 128 insertions, 69 deletions
diff --git a/sys/arch/mips64/include/asm.h b/sys/arch/mips64/include/asm.h
index e87474dfc1b..778a0635fe2 100644
--- a/sys/arch/mips64/include/asm.h
+++ b/sys/arch/mips64/include/asm.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: asm.h,v 1.7 2004/10/20 12:49:15 pefo Exp $ */
+/* $OpenBSD: asm.h,v 1.8 2009/09/30 06:22:00 syuu Exp $ */
/*
* Copyright (c) 2001-2002 Opsycon AB (www.opsycon.se / www.opsycon.com)
@@ -293,4 +293,16 @@ x: ; \
.asciiz str; \
.align 3
+#ifdef MULTIPROCESSOR
+#define GET_CPU_INFO(ci, tmp) \
+ HW_CPU_NUMBER(tmp); \
+ PTR_SLL tmp, tmp, LOGREGSZ; \
+ LA ci, cpu_info; \
+ PTR_ADDU ci, ci, tmp; \
+ PTR_L ci, 0(ci)
+#else /* MULTIPROCESSOR */
+#define GET_CPU_INFO(ci, tmp) \
+ LA ci, cpu_info_primary
+#endif /* MULTIPROCESSOR */
+
#endif /* !_MIPS_ASM_H */
diff --git a/sys/arch/mips64/include/cpu.h b/sys/arch/mips64/include/cpu.h
index cf133a71d95..a74da48580f 100644
--- a/sys/arch/mips64/include/cpu.h
+++ b/sys/arch/mips64/include/cpu.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: cpu.h,v 1.36 2009/09/15 04:54:31 syuu Exp $ */
+/* $OpenBSD: cpu.h,v 1.37 2009/09/30 06:22:00 syuu Exp $ */
/*-
* Copyright (c) 1992, 1993
@@ -367,6 +367,7 @@ struct cpu_info {
struct cpu_info *ci_self; /* pointer to this structure */
struct cpu_info *ci_next; /* next cpu */
struct proc *ci_curproc;
+ struct user *ci_curprocpaddr;
struct schedstate_percpu
ci_schedstate;
diff --git a/sys/arch/mips64/mips64/context.S b/sys/arch/mips64/mips64/context.S
index a57db3165d9..088e96e31cc 100644
--- a/sys/arch/mips64/mips64/context.S
+++ b/sys/arch/mips64/mips64/context.S
@@ -1,4 +1,4 @@
-/* $OpenBSD: context.S,v 1.23 2009/08/06 21:11:39 miod Exp $ */
+/* $OpenBSD: context.S,v 1.24 2009/09/30 06:22:00 syuu Exp $ */
/*
* Copyright (c) 2002-2003 Opsycon AB (www.opsycon.se / www.opsycon.com)
@@ -39,8 +39,6 @@
#include "assym.h"
-#define curproc (cpu_info_primary + CI_CURPROC)
-
.set mips3
.set noreorder # Noreorder is default style!
@@ -105,7 +103,8 @@ END(cpu_idle_cycle)
* cpu_switchto(struct proc *oldproc, struct proc *newproc)
*/
NON_LEAF(cpu_switchto, FRAMESZ(CF_SZ), ra)
- PTR_L t3, curprocpaddr
+ GET_CPU_INFO(t1, t3)
+ PTR_L t3, CI_CURPROCPADDR(t1)
REG_S sp, PCB_CONTEXT+8*REGSZ(t3) # save old sp
PTR_SUBU sp, sp, FRAMESZ(CF_SZ)
@@ -148,9 +147,10 @@ NON_LEAF(cpu_switchto, FRAMESZ(CF_SZ), ra)
move a0, s0
PTR_L t3, P_ADDR(s0) # get uarea pointer.
- PTR_S s0, curproc # set curproc
- PTR_S t3, curprocpaddr
-
+ GET_CPU_INFO(t1, t0)
+ PTR_S s0, CI_CURPROC(t1) # set curproc
+ PTR_S t3, CI_CURPROCPADDR(t1)
+
li t1, SONPROC
sb t1, P_STAT(s0) # set to onproc.
diff --git a/sys/arch/mips64/mips64/exception.S b/sys/arch/mips64/mips64/exception.S
index 6f3c8dccfec..4c6af38e399 100644
--- a/sys/arch/mips64/mips64/exception.S
+++ b/sys/arch/mips64/mips64/exception.S
@@ -1,4 +1,4 @@
-/* $OpenBSD: exception.S,v 1.21 2009/09/15 04:54:31 syuu Exp $ */
+/* $OpenBSD: exception.S,v 1.22 2009/09/30 06:22:00 syuu Exp $ */
/*
* Copyright (c) 2002-2003 Opsycon AB (www.opsycon.se / www.opsycon.com)
@@ -47,8 +47,6 @@
#include "assym.h"
-#define curproc (cpu_info_primary + CI_CURPROC)
-
.set mips3
.data
@@ -221,7 +219,8 @@ END(k_intr)
NNON_LEAF(u_intr, FRAMESZ(CF_SZ), ra)
.set noat
.mask 0x80000000, (CF_RA_OFFS - FRAMESZ(CF_SZ))
- PTR_L k0, curprocpaddr
+ GET_CPU_INFO(k1, k0)
+ PTR_L k0, CI_CURPROCPADDR(k1)
SAVE_CPU(k0, 0)
#if 0
cfc0 v1, COP_0_ICR
@@ -248,12 +247,13 @@ NNON_LEAF(u_intr, FRAMESZ(CF_SZ), ra)
ITLBNOPFIX
0:
- PTR_L t0, curproc
+ GET_CPU_INFO(t1, t0)
+ PTR_L t0, CI_CURPROC(t1)
lw v0, P_ASTPENDING(t0) # any pending AST?
beq v0, zero, 4f
nop
- PTR_L t0, P_ADDR(t0) # curprocpaddr
+ PTR_L t0, CI_CURPROCPADDR(t1) # curprocpaddr
SAVE_CPU_SREG(t0, 0)
#ifdef PERFCNTRS
@@ -287,7 +287,8 @@ NNON_LEAF(u_intr, FRAMESZ(CF_SZ), ra)
lw t0, cpu_is_rm7k
beqz t0, 1f # not an RM7K. Don't do perf setup.
- PTR_L t1, curproc # set up rm7k.
+ GET_CPU_INFO(t1, t0)
+ PTR_L t0, CI_CURPROC(t1) # set up rm7k.
ld v0, P_WATCH_1(t1)
dmtc0 v0, COP_0_WATCH_1
ld v0, P_WATCH_2(t1)
@@ -303,7 +304,8 @@ NNON_LEAF(u_intr, FRAMESZ(CF_SZ), ra)
nop;nop;nop;nop
1:
#endif
- PTR_L t0, curprocpaddr
+ GET_CPU_INFO(t1, t0)
+ PTR_L t0, CI_CURPROCPADDR(t1)
RESTORE_CPU_SREG(t0, 0)
b 0b
@@ -325,7 +327,8 @@ NNON_LEAF(u_intr, FRAMESZ(CF_SZ), ra)
mtc0 t0, COP_0_STATUS_REG # must set exception level bit.
ITLBNOPFIX
- PTR_L k0, curprocpaddr
+ GET_CPU_INFO(k1, k0)
+ PTR_L k0, CI_CURPROCPADDR(k1)
RESTORE_REG(a3, CPL, k0, 0)
sw a3, cpl
.set noat
@@ -396,7 +399,8 @@ NNON_LEAF(u_general, FRAMESZ(CF_SZ), ra)
.set noat
.mask 0x80000000, (CF_RA_OFFS - FRAMESZ(CF_SZ))
- PTR_L k0, curprocpaddr
+ GET_CPU_INFO(k1, k0)
+ PTR_L k0, CI_CURPROCPADDR(k1)
SAVE_CPU(k0, 0)
#if 0
cfc0 v1, COP_0_ICR
@@ -415,7 +419,7 @@ NNON_LEAF(u_general, FRAMESZ(CF_SZ), ra)
beqz t0, 1f # not an RM7K. Don't do perf save.
mfc0 v0, COP_0_PC_CTRL
- PTR_L t0, curproc
+ PTR_L t0, CI_CURPROC(k1)
sw v0, P_PC_CTRL(t0)
dmfc0 v0, COP_0_WATCH_1
dmfc0 v1, COP_0_WATCH_2
@@ -434,7 +438,8 @@ NNON_LEAF(u_general, FRAMESZ(CF_SZ), ra)
PTR_S a3, CF_RA_OFFS(sp) # for debugging
0:
- PTR_L t0, curproc
+ GET_CPU_INFO(t1, t0)
+ PTR_L t0, CI_CURPROC(t1)
lw v0, P_ASTPENDING(t0) # any pending AST?
beq v0, zero, 4f
nop
@@ -445,7 +450,8 @@ NNON_LEAF(u_general, FRAMESZ(CF_SZ), ra)
jal ast
nop
- PTR_L t0, curprocpaddr
+ GET_CPU_INFO(t1, t0)
+ PTR_L t0, CI_CURPROCPADDR(t1)
RESTORE_CPU_SREG(t0, 0)
b 0b
@@ -456,7 +462,7 @@ NNON_LEAF(u_general, FRAMESZ(CF_SZ), ra)
lw t0, cpu_is_rm7k
beqz t0, 1f # not an RM7K. Don't do perf setup.
- LOAD t0, curproc # set up rm7k.
+ LOAD t0, CI_CURPROC(k1) # set up rm7k.
ld v0, P_WATCH_1(t0)
dmtc0 v0, COP_0_WATCH_1
ld v0, P_WATCH_2(t0)
@@ -482,7 +488,8 @@ NNON_LEAF(u_general, FRAMESZ(CF_SZ), ra)
mtc0 t0, COP_0_STATUS_REG # must set exception level bit.
ITLBNOPFIX
- PTR_L k0, curprocpaddr
+ GET_CPU_INFO(k1, k0)
+ PTR_L k0, CI_CURPROCPADDR(k1)
RESTORE_REG(a3, CPL, k0, 0)
sw a3, cpl
.set noat
@@ -571,7 +578,8 @@ LEAF(proc_trampoline, 0)
ITLBNOPFIX
.set noat
- PTR_L k0, curprocpaddr
+ GET_CPU_INFO(k1, k0)
+ PTR_L k0, CI_CURPROCPADDR(k1)
RESTORE_CPU_SREG(k0, 0)
RESTORE_REG(a0, PC, k0, 0)
#if 0
diff --git a/sys/arch/mips64/mips64/lcore_access.S b/sys/arch/mips64/mips64/lcore_access.S
index 88644bf3aab..15eea352aae 100644
--- a/sys/arch/mips64/mips64/lcore_access.S
+++ b/sys/arch/mips64/mips64/lcore_access.S
@@ -1,4 +1,4 @@
-/* $OpenBSD: lcore_access.S,v 1.17 2009/05/22 20:37:53 miod Exp $ */
+/* $OpenBSD: lcore_access.S,v 1.18 2009/09/30 06:22:00 syuu Exp $ */
/*
* Copyright (c) 2001-2003 Opsycon AB (www.opsycon.se / www.opsycon.com)
@@ -190,12 +190,14 @@ NON_LEAF(copyinstr, FRAMESZ(CF_SZ), ra)
PTR_S ra, CF_RA_OFFS(sp)
blt a0, zero, _copyerr # make sure address is in user space
LI v0, KT_COPYERR
- PTR_L t3, curprocpaddr
+ GET_CPU_INFO(t1, t0)
+ PTR_L t3, CI_CURPROCPADDR(t1)
jal copystr
sw v0, PCB_ONFAULT(t3)
PTR_L ra, CF_RA_OFFS(sp)
- PTR_L t3, curprocpaddr
+ GET_CPU_INFO(t1, t0)
+ PTR_L t3, CI_CURPROCPADDR(t1)
sw zero, PCB_ONFAULT(t3)
PTR_ADDU sp, sp, FRAMESZ(CF_SZ)
j ra
@@ -218,12 +220,14 @@ NON_LEAF(copyoutstr, FRAMESZ(CF_SZ), ra)
PTR_S ra, CF_RA_OFFS(sp)
blt a1, zero, _copyerr # make sure address is in user space
LI v0, KT_COPYERR
- PTR_L t3, curprocpaddr
+ GET_CPU_INFO(t1, t0)
+ PTR_L t3, CI_CURPROCPADDR(t1)
jal copystr
sw v0, PCB_ONFAULT(t3)
PTR_L ra, CF_RA_OFFS(sp)
- PTR_L t3, curprocpaddr
+ GET_CPU_INFO(t1, t0)
+ PTR_L t3, CI_CURPROCPADDR(t1)
sw zero, PCB_ONFAULT(t3)
PTR_ADDU sp, sp, FRAMESZ(CF_SZ)
j ra
@@ -243,12 +247,14 @@ NON_LEAF(copyin, FRAMESZ(CF_SZ), ra)
PTR_S ra, CF_RA_OFFS(sp)
blt a0, zero, _copyerr # make sure address is in user space
li v0, KT_COPYERR
- PTR_L t3, curprocpaddr
+ GET_CPU_INFO(t1, t0)
+ PTR_L t3, CI_CURPROCPADDR(t1)
jal bcopy
sw v0, PCB_ONFAULT(t3)
PTR_L ra, CF_RA_OFFS(sp)
- PTR_L t3, curprocpaddr
+ GET_CPU_INFO(t1, t0)
+ PTR_L t3, CI_CURPROCPADDR(t1)
sw zero, PCB_ONFAULT(t3)
PTR_ADDU sp, sp, FRAMESZ(CF_SZ)
j ra
@@ -268,12 +274,14 @@ NON_LEAF(copyout, FRAMESZ(CF_SZ), ra)
PTR_S ra, CF_RA_OFFS(sp)
blt a1, zero, _copyerr # make sure address is in user space
li v0, KT_COPYERR
- PTR_L t3, curprocpaddr
+ GET_CPU_INFO(t1, t0)
+ PTR_L t3, CI_CURPROCPADDR(t1)
jal bcopy
sw v0, PCB_ONFAULT(t3)
PTR_L ra, CF_RA_OFFS(sp)
- PTR_L t3, curprocpaddr
+ GET_CPU_INFO(t1, t0)
+ PTR_L t3, CI_CURPROCPADDR(t1)
sw zero, PCB_ONFAULT(t3)
PTR_ADDU sp, sp, FRAMESZ(CF_SZ)
j ra
@@ -282,7 +290,8 @@ END(copyout)
_copyerr:
PTR_L ra, CF_RA_OFFS(sp)
- PTR_L t3, curprocpaddr
+ GET_CPU_INFO(t1, t0)
+ PTR_L t3, CI_CURPROCPADDR(t1)
sw zero, PCB_ONFAULT(t3)
PTR_ADDU sp, sp, FRAMESZ(CF_SZ)
j ra
@@ -295,7 +304,8 @@ NON_LEAF(kcopy, FRAMESZ(CF_SZ + REGSZ), ra)
PTR_SUBU sp, sp, FRAMESZ(CF_SZ + REGSZ)
.mask 0x80000000, (CF_RA_OFFS - FRAMESZ(CF_SZ + REGSZ))
PTR_S ra, CF_RA_OFFS + REGSZ(sp)
- PTR_L t3, curprocpaddr
+ GET_CPU_INFO(t1, t0)
+ PTR_L t3, CI_CURPROCPADDR(t1)
lw v1, PCB_ONFAULT(t3)
li v0, KT_KCOPYERR
PTR_S v1, CF_ARGSZ(sp) # save old pcb_onfault
@@ -303,7 +313,8 @@ NON_LEAF(kcopy, FRAMESZ(CF_SZ + REGSZ), ra)
sw v0, PCB_ONFAULT(t3)
PTR_L v0, CF_ARGSZ(sp)
- PTR_L t3, curprocpaddr
+ GET_CPU_INFO(t1, t0)
+ PTR_L t3, CI_CURPROCPADDR(t1)
PTR_L ra, CF_RA_OFFS + REGSZ(sp)
sw v0, PCB_ONFAULT(t3)
PTR_ADDU sp, sp, FRAMESZ(CF_SZ + REGSZ)
@@ -313,7 +324,8 @@ END(kcopy)
_kcopyerr:
PTR_L v0, CF_ARGSZ(sp)
- PTR_L t3, curprocpaddr
+ GET_CPU_INFO(t1, t0)
+ PTR_L t3, CI_CURPROCPADDR(t1)
PTR_L ra, CF_RA_OFFS + REGSZ(sp)
sw v0, PCB_ONFAULT(t3)
PTR_ADDU sp, sp, FRAMESZ(CF_SZ + REGSZ)
@@ -327,7 +339,8 @@ _kcopyerr:
*/
LEAF(guarded_read_4, 0)
- PTR_L t3, curprocpaddr
+ GET_CPU_INFO(t1, t0)
+ PTR_L t3, CI_CURPROCPADDR(t1)
li v0, KT_GUARDERR
lw v1, PCB_ONFAULT(t3)
sw v0, PCB_ONFAULT(t3)
@@ -341,7 +354,8 @@ LEAF(guarded_read_4, 0)
END(guarded_read_4)
LEAF(guarded_write_4, 0)
- PTR_L t3, curprocpaddr
+ GET_CPU_INFO(t1, t0)
+ PTR_L t3, CI_CURPROCPADDR(t1)
li v0, KT_GUARDERR
lw v1, PCB_ONFAULT(t3)
sw v0, PCB_ONFAULT(t3)
diff --git a/sys/arch/mips64/mips64/lcore_ddb.S b/sys/arch/mips64/mips64/lcore_ddb.S
index bf9306d5450..ee43279c83d 100644
--- a/sys/arch/mips64/mips64/lcore_ddb.S
+++ b/sys/arch/mips64/mips64/lcore_ddb.S
@@ -1,4 +1,4 @@
-/* $OpenBSD: lcore_ddb.S,v 1.9 2009/05/22 20:37:53 miod Exp $ */
+/* $OpenBSD: lcore_ddb.S,v 1.10 2009/09/30 06:22:00 syuu Exp $ */
/*
* Copyright (c) 2001-2003 Opsycon AB (www.opsycon.se / www.opsycon.com)
@@ -41,7 +41,8 @@
#ifdef __LP64__
LEAF(kdbpeekd, 0)
- PTR_L t0, curprocpaddr
+ GET_CPU_INFO(t1, t0)
+ PTR_L t0, CI_CURPROCPADDR(t1)
li v0, KT_DDBERR
and v1, a0, 7 # unaligned ?
bne v1, zero, 1f
@@ -60,7 +61,8 @@ END(kdbpeekd)
#endif
LEAF(kdbpeek, 0)
- PTR_L t0, curprocpaddr
+ GET_CPU_INFO(t1, t0)
+ PTR_L t0, CI_CURPROCPADDR(t1)
li v0, KT_DDBERR
and v1, a0, 3 # unaligned ?
bne v1, zero, 1f
@@ -78,7 +80,8 @@ LEAF(kdbpeek, 0)
END(kdbpeek)
LEAF(kdbpeekw, 0)
- PTR_L t0, curprocpaddr
+ GET_CPU_INFO(t1, t0)
+ PTR_L t0, CI_CURPROCPADDR(t1)
li v0, KT_DDBERR
and v1, a0, 1 # unaligned ?
bne v1, zero, 1f
@@ -95,7 +98,8 @@ LEAF(kdbpeekw, 0)
END(kdbpeekw)
LEAF(kdbpeekb, 0)
- PTR_L t0, curprocpaddr
+ GET_CPU_INFO(t1, t0)
+ PTR_L t0, CI_CURPROCPADDR(t1)
li v0, KT_DDBERR
sw v0, PCB_ONFAULT(t0)
lb v0, 0(a0)
@@ -110,7 +114,8 @@ kt_ddberr:
#ifdef __LP64__
LEAF(kdbpoked, 0)
- PTR_L t0, curprocpaddr
+ GET_CPU_INFO(t1, t0)
+ PTR_L t0, CI_CURPROCPADDR(t1)
li v0, KT_DDBERR
and v1, a0, 7 # unaligned ?
bne v1, zero, 1f
@@ -130,7 +135,8 @@ END(kdbpoked)
LEAF(kdbpoke, 0)
- PTR_L t0, curprocpaddr
+ GET_CPU_INFO(t1, t0)
+ PTR_L t0, CI_CURPROCPADDR(t1)
li v0, KT_DDBERR
and v1, a0, 3 # unaligned ?
bne v1, zero, 1f
@@ -148,7 +154,8 @@ LEAF(kdbpoke, 0)
END(kdbpoke)
LEAF(kdbpokew, 0)
- PTR_L t0, curprocpaddr
+ GET_CPU_INFO(t1, t0)
+ PTR_L t0, CI_CURPROCPADDR(t1)
li v0, KT_DDBERR
and v1, a0, 1 # unaligned ?
bne v1, zero, 1f
@@ -164,7 +171,8 @@ LEAF(kdbpokew, 0)
END(kdbpokew)
LEAF(kdbpokeb, 0)
- PTR_L t0, curprocpaddr
+ GET_CPU_INFO(t1, t0)
+ PTR_L t0, CI_CURPROCPADDR(t1)
li v0, KT_DDBERR
sw v0, PCB_ONFAULT(t0)
sb a1, 0(a0)
diff --git a/sys/arch/mips64/mips64/lcore_float.S b/sys/arch/mips64/mips64/lcore_float.S
index e3545676b16..686661ab64d 100644
--- a/sys/arch/mips64/mips64/lcore_float.S
+++ b/sys/arch/mips64/mips64/lcore_float.S
@@ -1,4 +1,4 @@
-/* $OpenBSD: lcore_float.S,v 1.16 2009/05/22 20:37:53 miod Exp $ */
+/* $OpenBSD: lcore_float.S,v 1.17 2009/09/30 06:22:00 syuu Exp $ */
/*
* Copyright (c) 2001-2003 Opsycon AB (www.opsycon.se / www.opsycon.com)
@@ -36,8 +36,6 @@
#include "assym.h"
-#define curproc (cpu_info_primary + CI_CURPROC)
-
.set noreorder # Noreorder is default style!
.set mips3
@@ -451,7 +449,8 @@ NON_LEAF(MipsFPTrap, FRAMESZ(CF_SZ), ra)
* The instruction is in the branch delay slot so the branch will have to
* be emulated to get the resulting PC.
*/
- PTR_L a0, curprocpaddr # first arg is ptr to CPU regs
+ GET_CPU_INFO(t2, t3)
+ PTR_L a0, CI_CURPROCPADDR(t2) # first arg is ptr to CPU regs
move a1, a2 # second arg is instruction PC
move a2, t1 # third arg is the FP CSR
jal MipsEmulateBranch # compute PC after branch
@@ -471,7 +470,8 @@ NON_LEAF(MipsFPTrap, FRAMESZ(CF_SZ), ra)
lw a0, 0(a2) # a0 = coproc instruction
PTR_ADDU v0, a2, 4 # v0 = next pc
2:
- PTR_L a3, curprocpaddr # first arg is ptr to CPU regs
+ GET_CPU_INFO(t2, t3)
+ PTR_L a3, CI_CURPROCPADDR(t2) # first arg is ptr to CPU regs
PTR_S v0, PCB_REGS+(PC * REGSZ)(a3) # save new pc
/*
* Check to see if the instruction to be emulated is a floating-point
@@ -485,7 +485,8 @@ NON_LEAF(MipsFPTrap, FRAMESZ(CF_SZ), ra)
*/
3:
cfc1 a2, FPC_CSR # code = FP exceptions
- PTR_L a0, curproc # get current process
+ GET_CPU_INFO(t2, t3)
+ PTR_L a0, CI_CURPROC(t2) # get current process
PTR_L a4, 3*REGSZ(sp)
and v0, a2, FPC_EXCEPTION_INEXACT
bnez v0, 4f
diff --git a/sys/arch/mips64/mips64/tlbhandler.S b/sys/arch/mips64/mips64/tlbhandler.S
index 087a2e0a974..022b73a55c1 100644
--- a/sys/arch/mips64/mips64/tlbhandler.S
+++ b/sys/arch/mips64/mips64/tlbhandler.S
@@ -1,4 +1,4 @@
-/* $OpenBSD: tlbhandler.S,v 1.19 2009/08/06 21:11:39 miod Exp $ */
+/* $OpenBSD: tlbhandler.S,v 1.20 2009/09/30 06:22:00 syuu Exp $ */
/*
* Copyright (c) 1995-2004 Opsycon AB (www.opsycon.se / www.opsycon.com)
@@ -84,7 +84,8 @@ tlb_miss_err_r5k:
.globl tlb_miss
.ent tlb_miss, 0
tlb_miss:
- PTR_L k1, curprocpaddr
+ GET_CPU_INFO(k1, k0)
+ PTR_L k1, CI_CURPROCPADDR(k1)
dmfc0 k0, COP_0_BAD_VADDR
bltz k0, _k_miss # kernel address space
PTR_SRL k0, k0, SEGSHIFT - LOGREGSZ
@@ -141,8 +142,12 @@ xtlb_miss:
PTR_SRL k0, k0, SEGSHIFT
sltiu k1, k0, PMAP_SEGTABSIZE
beqz k1, _inv_seg # wrong if outside pm_segtab
+ nop
+ GET_CPU_INFO(k1, k0)
+ PTR_L k1, CI_CURPROCPADDR(k1)
+ dmfc0 k0, COP_0_BAD_VADDR
+ PTR_SRL k0, k0, SEGSHIFT
PTR_SLL k0, k0, LOGREGSZ
- PTR_L k1, curprocpaddr
PTR_L k1, PCB_SEGTAB(k1)
PTR_ADDU k1, k1, k0
PTR_L k1, 0(k1) # get pointer to page table
@@ -321,7 +326,8 @@ NLEAF(k_tlb_miss, 0)
eret
sys_stk_chk:
- PTR_L k1, curprocpaddr
+ GET_CPU_INFO(k1, k0)
+ PTR_L k1, CI_CURPROCPADDR(k1)
PTR_SUBU k0, sp, k1 # check to see if we have a
sltiu k0, 2048 # valid kernel stack
beqz k0, go_k_general # yes, handle.
diff --git a/sys/arch/sgi/include/asm.h b/sys/arch/sgi/include/asm.h
index 997fa0dc94d..23aea156911 100644
--- a/sys/arch/sgi/include/asm.h
+++ b/sys/arch/sgi/include/asm.h
@@ -1,5 +1,14 @@
-/* $OpenBSD: asm.h,v 1.1 2004/08/06 21:12:18 pefo Exp $ */
+/* $OpenBSD: asm.h,v 1.2 2009/09/30 06:22:00 syuu Exp $ */
/* Use Mips generic include file */
+#ifdef MULTIPROCESSOR
+#define HW_CPU_NUMBER(reg) \
+ LA reg, HW_CPU_NUMBER_REG; \
+ PTR_L reg, 0(reg)
+#else /* MULTIPROCESSOR */
+#define HW_CPU_NUMBER(reg) \
+ LI reg, 0
+#endif /* MULTIPROCESSOR */
+
#include <mips64/asm.h>
diff --git a/sys/arch/sgi/include/cpu.h b/sys/arch/sgi/include/cpu.h
index b8740d1af54..18e457c2c5a 100644
--- a/sys/arch/sgi/include/cpu.h
+++ b/sys/arch/sgi/include/cpu.h
@@ -1,15 +1,15 @@
-/* $OpenBSD: cpu.h,v 1.2 2009/09/15 04:54:31 syuu Exp $ */
+/* $OpenBSD: cpu.h,v 1.3 2009/09/30 06:22:00 syuu Exp $ */
/* Use Mips generic include file */
#ifdef _KERNEL
#ifdef MULTIPROCESSOR
#if defined(TGT_OCTANE)
-#define HW_CPU_NUMBER 0x900000000ff50000/* HEART_PRID */
-#else
+#define HW_CPU_NUMBER_REG 0x900000000ff50000 /* HEART_PRID */
+#else /* TGT_OCTANE */
#error MULTIPROCESSOR kernel not supported on this configuration
-#endif
-#define hw_cpu_number() (*(uint64_t *)HW_CPU_NUMBER)
+#endif /* TGT_OCTANE */
+#define hw_cpu_number() (*(uint64_t *)HW_CPU_NUMBER_REG)
#else/* MULTIPROCESSOR */
#define hw_cpu_number() 0
#endif/* MULTIPROCESSOR */
diff --git a/sys/arch/sgi/sgi/genassym.cf b/sys/arch/sgi/sgi/genassym.cf
index 8c68800f0dd..445e84bc2bc 100644
--- a/sys/arch/sgi/sgi/genassym.cf
+++ b/sys/arch/sgi/sgi/genassym.cf
@@ -1,4 +1,4 @@
-# $OpenBSD: genassym.cf,v 1.13 2009/06/10 18:05:31 miod Exp $
+# $OpenBSD: genassym.cf,v 1.14 2009/09/30 06:22:00 syuu Exp $
#
# Copyright (c) 1997 Per Fogelstrom / Opsycon AB
#
@@ -57,6 +57,7 @@ member pcb_segtab
struct cpu_info
member ci_curproc
+member ci_curprocpaddr
export VM_MIN_KERNEL_ADDRESS
export SIGFPE
diff --git a/sys/arch/sgi/sgi/machdep.c b/sys/arch/sgi/sgi/machdep.c
index 8059aa99591..d941ce5f241 100644
--- a/sys/arch/sgi/sgi/machdep.c
+++ b/sys/arch/sgi/sgi/machdep.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: machdep.c,v 1.82 2009/08/19 12:33:06 jasper Exp $ */
+/* $OpenBSD: machdep.c,v 1.83 2009/09/30 06:22:00 syuu Exp $ */
/*
* Copyright (c) 2003-2004 Opsycon AB (www.opsycon.se / www.opsycon.com)
@@ -103,7 +103,6 @@ int physmem; /* Max supported memory, changes to actual. */
int rsvdmem; /* Reserved memory not usable. */
int ncpu = 1; /* At least one CPU in the system. */
struct user *proc0paddr;
-struct user *curprocpaddr;
int console_ok; /* Set when console initialized. */
int kbd_reset;
int16_t masternasid;
@@ -490,7 +489,7 @@ mips_init(int argc, void *argv, caddr_t boot_esym)
/*
* Allocate U page(s) for proc[0], pm_tlbpid 1.
*/
- proc0.p_addr = proc0paddr = curprocpaddr =
+ proc0.p_addr = proc0paddr = curcpu()->ci_curprocpaddr =
(struct user *)pmap_steal_memory(USPACE, NULL, NULL);
proc0.p_md.md_regs = (struct trap_frame *)&proc0paddr->u_pcb.pcb_regs;
tlb_set_pid(1);