summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--sys/arch/sparc64/include/cpu.h10
-rw-r--r--sys/arch/sparc64/sparc64/locore.s208
-rw-r--r--sys/arch/sparc64/sparc64/mutex.S21
3 files changed, 106 insertions, 133 deletions
diff --git a/sys/arch/sparc64/include/cpu.h b/sys/arch/sparc64/include/cpu.h
index 27fc8491636..608333983a4 100644
--- a/sys/arch/sparc64/include/cpu.h
+++ b/sys/arch/sparc64/include/cpu.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: cpu.h,v 1.59 2008/03/31 22:14:01 kettenis Exp $ */
+/* $OpenBSD: cpu.h,v 1.60 2008/04/13 16:32:55 kettenis Exp $ */
/* $NetBSD: cpu.h,v 1.28 2001/06/14 22:56:58 thorpej Exp $ */
/*
@@ -162,12 +162,10 @@ extern __inline struct cpu_info *curcpu(void);
extern __inline struct cpu_info *
curcpu(void)
{
- if (CPU_ISSUN4V) {
- __asm __volatile("nop" : : : "memory");
- return (struct cpu_info *)ldxa(0, ASI_SCRATCHPAD);
- }
+ struct cpu_info *ci;
- return (((struct cpu_info *)CPUINFO_VA)->ci_self);
+ __asm __volatile("mov %%g7, %0" : "=r"(ci));
+ return (ci->ci_self);
}
#define CPU_IS_PRIMARY(ci) ((ci)->ci_number == 0)
diff --git a/sys/arch/sparc64/sparc64/locore.s b/sys/arch/sparc64/sparc64/locore.s
index 59fdb3a1adc..d1f0ea3d659 100644
--- a/sys/arch/sparc64/sparc64/locore.s
+++ b/sys/arch/sparc64/sparc64/locore.s
@@ -1,4 +1,4 @@
-/* $OpenBSD: locore.s,v 1.131 2008/04/12 14:59:30 kettenis Exp $ */
+/* $OpenBSD: locore.s,v 1.132 2008/04/13 16:32:55 kettenis Exp $ */
/* $NetBSD: locore.s,v 1.137 2001/08/13 06:10:10 jdolecek Exp $ */
/*
@@ -2352,6 +2352,8 @@ Ldatafault_internal:
/* Finish stackframe, call C trap handler */
flushw ! Get this clean so we won't take any more user faults
+ GET_CPUINFO_VA(%g7)
+
/*
* Right now the registers have the following values:
*
@@ -2580,7 +2582,9 @@ textfault:
wr %g0, ASI_PRIMARY_NOFAULT, %asi ! Restore default ASI
flushw ! Get rid of any user windows so we don't deadlock
-
+
+ GET_CPUINFO_VA(%g7)
+
/* Use trap type to see what handler to call */
cmp %o1, T_INST_ERROR
be,pn %xcc, text_error
@@ -3318,20 +3322,19 @@ sun4v_datatrap:
*/
wrpr %g0, 0, %tl
-#ifdef SUN4V
- GET_CPUINFO_VA(%g1)
- ldx [%g1 + CI_RWSP], %g2
+ GET_CPUINFO_VA(%g7)
+ ldx [%g7 + CI_RWSP], %g2
brz,pt %g2, 1f
nop
- ldx [%g1 + CI_RW + (0*8)], %l0
- ldx [%g1 + CI_RW + (1*8)], %l1
- ldx [%g1 + CI_RW + (2*8)], %l2
- ldx [%g1 + CI_RW + (3*8)], %l3
- ldx [%g1 + CI_RW + (4*8)], %l4
- ldx [%g1 + CI_RW + (5*8)], %l5
- ldx [%g1 + CI_RW + (6*8)], %l6
- ldx [%g1 + CI_RW + (7*8)], %l7
+ ldx [%g7 + CI_RW + (0*8)], %l0
+ ldx [%g7 + CI_RW + (1*8)], %l1
+ ldx [%g7 + CI_RW + (2*8)], %l2
+ ldx [%g7 + CI_RW + (3*8)], %l3
+ ldx [%g7 + CI_RW + (4*8)], %l4
+ ldx [%g7 + CI_RW + (5*8)], %l5
+ ldx [%g7 + CI_RW + (6*8)], %l6
+ ldx [%g7 + CI_RW + (7*8)], %l7
stx %l0, [%g2 + BIAS + (0*8)]
stx %l1, [%g2 + BIAS + (1*8)]
stx %l2, [%g2 + BIAS + (2*8)]
@@ -3340,14 +3343,14 @@ sun4v_datatrap:
stx %l5, [%g2 + BIAS + (5*8)]
stx %l6, [%g2 + BIAS + (6*8)]
stx %l7, [%g2 + BIAS + (7*8)]
- ldx [%g1 + CI_RW + (8*8)], %l0
- ldx [%g1 + CI_RW + (9*8)], %l1
- ldx [%g1 + CI_RW + (10*8)], %l2
- ldx [%g1 + CI_RW + (11*8)], %l3
- ldx [%g1 + CI_RW + (12*8)], %l4
- ldx [%g1 + CI_RW + (13*8)], %l5
- ldx [%g1 + CI_RW + (14*8)], %l6
- ldx [%g1 + CI_RW + (15*8)], %l7
+ ldx [%g7 + CI_RW + (8*8)], %l0
+ ldx [%g7 + CI_RW + (9*8)], %l1
+ ldx [%g7 + CI_RW + (10*8)], %l2
+ ldx [%g7 + CI_RW + (11*8)], %l3
+ ldx [%g7 + CI_RW + (12*8)], %l4
+ ldx [%g7 + CI_RW + (13*8)], %l5
+ ldx [%g7 + CI_RW + (14*8)], %l6
+ ldx [%g7 + CI_RW + (15*8)], %l7
stx %l0, [%g2 + BIAS + (8*8)]
stx %l1, [%g2 + BIAS + (9*8)]
stx %l2, [%g2 + BIAS + (10*8)]
@@ -3357,9 +3360,8 @@ sun4v_datatrap:
stx %l6, [%g2 + BIAS + (14*8)]
stx %l7, [%g2 + BIAS + (15*8)]
- stx %g0, [%g1 + CI_RWSP]
+ stx %g0, [%g7 + CI_RWSP]
1:
-#endif
wr %g0, ASI_PRIMARY_NOFAULT, %asi ! Restore default ASI
wrpr %g0, PSTATE_INTR, %pstate ! traps on again
@@ -3415,20 +3417,19 @@ sun4v_texttrap:
*/
wrpr %g0, 0, %tl
-#ifdef SUN4V
- GET_CPUINFO_VA(%g1)
- ldx [%g1 + CI_RWSP], %g2
+ GET_CPUINFO_VA(%g7)
+ ldx [%g7 + CI_RWSP], %g2
brz,pt %g2, 1f
nop
- ldx [%g1 + CI_RW + (0*8)], %l0
- ldx [%g1 + CI_RW + (1*8)], %l1
- ldx [%g1 + CI_RW + (2*8)], %l2
- ldx [%g1 + CI_RW + (3*8)], %l3
- ldx [%g1 + CI_RW + (4*8)], %l4
- ldx [%g1 + CI_RW + (5*8)], %l5
- ldx [%g1 + CI_RW + (6*8)], %l6
- ldx [%g1 + CI_RW + (7*8)], %l7
+ ldx [%g7 + CI_RW + (0*8)], %l0
+ ldx [%g7 + CI_RW + (1*8)], %l1
+ ldx [%g7 + CI_RW + (2*8)], %l2
+ ldx [%g7 + CI_RW + (3*8)], %l3
+ ldx [%g7 + CI_RW + (4*8)], %l4
+ ldx [%g7 + CI_RW + (5*8)], %l5
+ ldx [%g7 + CI_RW + (6*8)], %l6
+ ldx [%g7 + CI_RW + (7*8)], %l7
stx %l0, [%g2 + BIAS + (0*8)]
stx %l1, [%g2 + BIAS + (1*8)]
stx %l2, [%g2 + BIAS + (2*8)]
@@ -3437,14 +3438,14 @@ sun4v_texttrap:
stx %l5, [%g2 + BIAS + (5*8)]
stx %l6, [%g2 + BIAS + (6*8)]
stx %l7, [%g2 + BIAS + (7*8)]
- ldx [%g1 + CI_RW + (8*8)], %l0
- ldx [%g1 + CI_RW + (9*8)], %l1
- ldx [%g1 + CI_RW + (10*8)], %l2
- ldx [%g1 + CI_RW + (11*8)], %l3
- ldx [%g1 + CI_RW + (12*8)], %l4
- ldx [%g1 + CI_RW + (13*8)], %l5
- ldx [%g1 + CI_RW + (14*8)], %l6
- ldx [%g1 + CI_RW + (15*8)], %l7
+ ldx [%g7 + CI_RW + (8*8)], %l0
+ ldx [%g7 + CI_RW + (9*8)], %l1
+ ldx [%g7 + CI_RW + (10*8)], %l2
+ ldx [%g7 + CI_RW + (11*8)], %l3
+ ldx [%g7 + CI_RW + (12*8)], %l4
+ ldx [%g7 + CI_RW + (13*8)], %l5
+ ldx [%g7 + CI_RW + (14*8)], %l6
+ ldx [%g7 + CI_RW + (15*8)], %l7
stx %l0, [%g2 + BIAS + (8*8)]
stx %l1, [%g2 + BIAS + (9*8)]
stx %l2, [%g2 + BIAS + (10*8)]
@@ -3454,9 +3455,8 @@ sun4v_texttrap:
stx %l6, [%g2 + BIAS + (14*8)]
stx %l7, [%g2 + BIAS + (15*8)]
- stx %g0, [%g1 + CI_RWSP]
+ stx %g0, [%g7 + CI_RWSP]
1:
-#endif
wr %g0, ASI_PRIMARY_NOFAULT, %asi ! Restore default ASI
wrpr %g0, PSTATE_INTR, %pstate ! traps on again
@@ -3582,20 +3582,20 @@ gl0_1: nop
*/
wrpr %g0, 0, %tl
+ GET_CPUINFO_VA(%g7)
#ifdef SUN4V
- GET_CPUINFO_VA(%g1)
- ldx [%g1 + CI_RWSP], %g2
+ ldx [%g7 + CI_RWSP], %g2
brz,pt %g2, 1f
nop
- ldx [%g1 + CI_RW + (0*8)], %l0
- ldx [%g1 + CI_RW + (1*8)], %l1
- ldx [%g1 + CI_RW + (2*8)], %l2
- ldx [%g1 + CI_RW + (3*8)], %l3
- ldx [%g1 + CI_RW + (4*8)], %l4
- ldx [%g1 + CI_RW + (5*8)], %l5
- ldx [%g1 + CI_RW + (6*8)], %l6
- ldx [%g1 + CI_RW + (7*8)], %l7
+ ldx [%g7 + CI_RW + (0*8)], %l0
+ ldx [%g7 + CI_RW + (1*8)], %l1
+ ldx [%g7 + CI_RW + (2*8)], %l2
+ ldx [%g7 + CI_RW + (3*8)], %l3
+ ldx [%g7 + CI_RW + (4*8)], %l4
+ ldx [%g7 + CI_RW + (5*8)], %l5
+ ldx [%g7 + CI_RW + (6*8)], %l6
+ ldx [%g7 + CI_RW + (7*8)], %l7
stx %l0, [%g2 + BIAS + (0*8)]
stx %l1, [%g2 + BIAS + (1*8)]
stx %l2, [%g2 + BIAS + (2*8)]
@@ -3604,14 +3604,14 @@ gl0_1: nop
stx %l5, [%g2 + BIAS + (5*8)]
stx %l6, [%g2 + BIAS + (6*8)]
stx %l7, [%g2 + BIAS + (7*8)]
- ldx [%g1 + CI_RW + (8*8)], %l0
- ldx [%g1 + CI_RW + (9*8)], %l1
- ldx [%g1 + CI_RW + (10*8)], %l2
- ldx [%g1 + CI_RW + (11*8)], %l3
- ldx [%g1 + CI_RW + (12*8)], %l4
- ldx [%g1 + CI_RW + (13*8)], %l5
- ldx [%g1 + CI_RW + (14*8)], %l6
- ldx [%g1 + CI_RW + (15*8)], %l7
+ ldx [%g7 + CI_RW + (8*8)], %l0
+ ldx [%g7 + CI_RW + (9*8)], %l1
+ ldx [%g7 + CI_RW + (10*8)], %l2
+ ldx [%g7 + CI_RW + (11*8)], %l3
+ ldx [%g7 + CI_RW + (12*8)], %l4
+ ldx [%g7 + CI_RW + (13*8)], %l5
+ ldx [%g7 + CI_RW + (14*8)], %l6
+ ldx [%g7 + CI_RW + (15*8)], %l7
stx %l0, [%g2 + BIAS + (8*8)]
stx %l1, [%g2 + BIAS + (9*8)]
stx %l2, [%g2 + BIAS + (10*8)]
@@ -3621,7 +3621,7 @@ gl0_1: nop
stx %l6, [%g2 + BIAS + (14*8)]
stx %l7, [%g2 + BIAS + (15*8)]
- stx %g0, [%g1 + CI_RWSP]
+ stx %g0, [%g7 + CI_RWSP]
1:
#endif
@@ -3754,6 +3754,7 @@ gl0_2: nop
wr %g0, ASI_PRIMARY_NOFAULT, %asi ! Restore default ASI
+ GET_CPUINFO_VA(%g7)
call _C_LABEL(syscall) ! syscall(&tf, code, pc)
wrpr %g0, PSTATE_INTR, %pstate ! turn on interrupts
@@ -4251,20 +4252,20 @@ gl0_3: nop
gl0_x:
flushw ! Do not remove this instruction -- causes interrupt loss
+ GET_CPUINFO_VA(%g7)
#ifdef SUN4V
- GET_CPUINFO_VA(%g1)
- ldx [%g1 + CI_RWSP], %g2
+ ldx [%g7 + CI_RWSP], %g2
brz,pt %g2, 1f
nop
- ldx [%g1 + CI_RW + (0*8)], %l0
- ldx [%g1 + CI_RW + (1*8)], %l1
- ldx [%g1 + CI_RW + (2*8)], %l2
- ldx [%g1 + CI_RW + (3*8)], %l3
- ldx [%g1 + CI_RW + (4*8)], %l4
- ldx [%g1 + CI_RW + (5*8)], %l5
- ldx [%g1 + CI_RW + (6*8)], %l6
- ldx [%g1 + CI_RW + (7*8)], %l7
+ ldx [%g7 + CI_RW + (0*8)], %l0
+ ldx [%g7 + CI_RW + (1*8)], %l1
+ ldx [%g7 + CI_RW + (2*8)], %l2
+ ldx [%g7 + CI_RW + (3*8)], %l3
+ ldx [%g7 + CI_RW + (4*8)], %l4
+ ldx [%g7 + CI_RW + (5*8)], %l5
+ ldx [%g7 + CI_RW + (6*8)], %l6
+ ldx [%g7 + CI_RW + (7*8)], %l7
stx %l0, [%g2 + BIAS + (0*8)]
stx %l1, [%g2 + BIAS + (1*8)]
stx %l2, [%g2 + BIAS + (2*8)]
@@ -4273,14 +4274,14 @@ gl0_x:
stx %l5, [%g2 + BIAS + (5*8)]
stx %l6, [%g2 + BIAS + (6*8)]
stx %l7, [%g2 + BIAS + (7*8)]
- ldx [%g1 + CI_RW + (8*8)], %l0
- ldx [%g1 + CI_RW + (9*8)], %l1
- ldx [%g1 + CI_RW + (10*8)], %l2
- ldx [%g1 + CI_RW + (11*8)], %l3
- ldx [%g1 + CI_RW + (12*8)], %l4
- ldx [%g1 + CI_RW + (13*8)], %l5
- ldx [%g1 + CI_RW + (14*8)], %l6
- ldx [%g1 + CI_RW + (15*8)], %l7
+ ldx [%g7 + CI_RW + (8*8)], %l0
+ ldx [%g7 + CI_RW + (9*8)], %l1
+ ldx [%g7 + CI_RW + (10*8)], %l2
+ ldx [%g7 + CI_RW + (11*8)], %l3
+ ldx [%g7 + CI_RW + (12*8)], %l4
+ ldx [%g7 + CI_RW + (13*8)], %l5
+ ldx [%g7 + CI_RW + (14*8)], %l6
+ ldx [%g7 + CI_RW + (15*8)], %l7
stx %l0, [%g2 + BIAS + (8*8)]
stx %l1, [%g2 + BIAS + (9*8)]
stx %l2, [%g2 + BIAS + (10*8)]
@@ -4290,7 +4291,7 @@ gl0_x:
stx %l6, [%g2 + BIAS + (14*8)]
stx %l7, [%g2 + BIAS + (15*8)]
- stx %g0, [%g1 + CI_RWSP]
+ stx %g0, [%g7 + CI_RWSP]
1:
#endif
@@ -4319,24 +4320,21 @@ gl0_x:
mov 1, %l3 ! Ack softint
sll %l3, %l6, %l3 ! Generate IRQ mask
- GET_CPUINFO_VA(%l4)
-
wrpr %l6, %pil
/*
* Set handled_intr_level and save the old one so we can restore it
* later.
*/
- ld [%l4 + CI_HANDLED_INTR_LEVEL], %l7
- st %l6, [%l4 + CI_HANDLED_INTR_LEVEL]
+ ld [%g7 + CI_HANDLED_INTR_LEVEL], %l7
+ st %l6, [%g7 + CI_HANDLED_INTR_LEVEL]
st %l7, [%sp + CC64FSZ + BIAS + TF_SIZE]
sparc_intr_retry:
wr %l3, 0, CLEAR_SOFTINT ! (don't clear possible %tick IRQ)
wrpr %g0, PSTATE_INTR, %pstate ! Reenable interrupts
sll %l6, 3+3, %l2
- GET_CPUINFO_VA(%l4)
- add %l4, CI_INTRPENDING, %l4
+ add %g7, CI_INTRPENDING, %l4
mov 8, %l7
add %l2, %l4, %l4
@@ -4420,9 +4418,8 @@ intrcmplt:
#endif /* DEBUG */
/* Restore old handled_intr_level */
- GET_CPUINFO_VA(%l4)
ld [%sp + CC64FSZ + BIAS + TF_SIZE], %l7
- st %l7, [%l4 + CI_HANDLED_INTR_LEVEL]
+ st %l7, [%g7 + CI_HANDLED_INTR_LEVEL]
ldub [%sp + CC64FSZ + BIAS + TF_OLDPIL], %l3 ! restore old %pil
wrpr %g0, PSTATE_KERN, %pstate ! Disable interrupts
@@ -4486,7 +4483,10 @@ gl0_4: nop
ldx [%sp + CC64FSZ + BIAS + TF_G + (4*8)], %g4
ldx [%sp + CC64FSZ + BIAS + TF_G + (5*8)], %g5
ldx [%sp + CC64FSZ + BIAS + TF_G + (6*8)], %g6
+ bnz %icc, 2f
+ nop
ldx [%sp + CC64FSZ + BIAS + TF_G + (7*8)], %g7
+2:
/* Switch to alternate globals and load outs */
gl1_1:
wrpr %g0, PSTATE_KERN|PSTATE_AG, %pstate
@@ -4858,16 +4858,15 @@ _C_LABEL(cpu_initialize):
* Switch to our initial stack.
*/
- GET_CPUINFO_VA(%l0)
- ldx [%l0 + CI_INITSTACK], %l0
+ GET_CPUINFO_VA(%g7)
+ ldx [%g7 + CI_INITSTACK], %l0
add %l0, -BIAS-CC64FSZ, %sp
/*
* Call our startup routine.
*/
- GET_CPUINFO_VA(%l0)
- ldx [%l0 + CI_SPINUP], %o1
+ ldx [%g7 + CI_SPINUP], %o1
call %o1 ! Call routine
nop
NOTREACHED
@@ -5990,8 +5989,7 @@ ENTRY(cpu_switchto)
mov %i0, %l4 ! oldproc
mov %i1, %l3 ! newproc
- GET_CPUINFO_VA(%l6)
- ldx [%l6 + CI_CPCB], %l5
+ ldx [%g7 + CI_CPCB], %l5
/*
* Register usage:
@@ -6001,7 +5999,6 @@ ENTRY(cpu_switchto)
* %l3 = p
* %l4 = lastproc
* %l5 = cpcb
- * %l6 = curcpu
* %o0 = tmp 1
* %o1 = oldpstate
* %o2 = tmp 2
@@ -6026,14 +6023,14 @@ ENTRY(cpu_switchto)
/*
* p->p_cpu = curcpu();
*/
- ldx [%l6 + CI_SELF], %o0
+ ldx [%g7 + CI_SELF], %o0
stx %o0, [%l3 + P_CPU]
#endif /* defined(MULTIPROCESSOR) */
mov SONPROC, %o0 ! p->p_stat = SONPROC
stb %o0, [%l3 + P_STAT]
- st %g0, [%l6 + CI_WANT_RESCHED] ! want_resched = 0;
+ st %g0, [%g7 + CI_WANT_RESCHED] ! want_resched = 0;
ldx [%l3 + P_ADDR], %l1 ! newpcb = p->p_addr;
- stx %l4, [%l6 + CI_CURPROC] ! restore old proc so we can save it
+ stx %l4, [%g7 + CI_CURPROC] ! restore old proc so we can save it
flushw ! save all register windows except this one
@@ -6059,8 +6056,8 @@ ENTRY(cpu_switchto)
*/
Lsw_load:
/* set new cpcb */
- stx %l3, [%l6 + CI_CURPROC] ! curproc = p;
- stx %l1, [%l6 + CI_CPCB] ! cpcb = newpcb;
+ stx %l3, [%g7 + CI_CURPROC] ! curproc = p;
+ stx %l1, [%g7 + CI_CPCB] ! cpcb = newpcb;
ldx [%l1 + PCB_SP], %i6
ldx [%l1 + PCB_PC], %i7
@@ -8840,9 +8837,7 @@ ENTRY(send_softint)
wrpr %g1, 0, %pstate
brz,pn %o2, 1f
- nop
- GET_CPUINFO_VA(%o3)
- add %o3, CI_INTRPENDING, %o3
+ add %g7, CI_INTRPENDING, %o3
ldx [%o2 + IH_PEND], %o5
brnz,pn %o5, 1f
@@ -9143,12 +9138,9 @@ _C_LABEL(gl1_start):
_C_LABEL(sun4v_patch_end):
.previous
- /* XXX This is in mutex.S for now */
-#if 0
#ifdef MULTIPROCESSOR
.section .sun4v_mp_patch, "ax"
.globl _C_LABEL(sun4v_mp_patch_end)
_C_LABEL(sun4v_mp_patch_end):
.previous
#endif
-#endif
diff --git a/sys/arch/sparc64/sparc64/mutex.S b/sys/arch/sparc64/sparc64/mutex.S
index 2243f54e855..d98f7aac0d6 100644
--- a/sys/arch/sparc64/sparc64/mutex.S
+++ b/sys/arch/sparc64/sparc64/mutex.S
@@ -1,4 +1,4 @@
-/* $OpenBSD: mutex.S,v 1.2 2008/03/31 22:14:01 kettenis Exp $ */
+/* $OpenBSD: mutex.S,v 1.3 2008/04/13 16:32:55 kettenis Exp $ */
/*
* Copyright (c) 2007 Mark Kettenis
@@ -27,15 +27,8 @@
#ifdef MULTIPROCESSOR
-#include <machine/ctlreg.h>
-
#define GET_CURCPU(ci) \
- sethi %hi(CPUINFO_VA + CI_SELF), ci ;\
-999: ldx [ci + %lo(CPUINFO_VA + CI_SELF)], ci ;\
- .section .sun4v_mp_patch, "ax" ;\
- .word 999b ;\
- ldxa [%g0] ASI_SCRATCHPAD, ci ;\
- .previous
+ ldx [%g7 + CI_SELF], ci
#else
@@ -88,13 +81,3 @@ ENTRY(mtx_leave)
stx %g0, [%o0 + MTX_OWNER]
retl
wrpr %g1, %pil
-
-/*
- * XXX Move this back to locore.s.
- */
-#ifdef MULTIPROCESSOR
- .section .sun4v_mp_patch, "ax"
- .globl _C_LABEL(sun4v_mp_patch_end)
-_C_LABEL(sun4v_mp_patch_end):
- .previous
-#endif