|
@@ -39,6 +39,7 @@ set_pcontext:
|
|
*/
|
|
*/
|
|
.globl fill_fixup, spill_fixup
|
|
.globl fill_fixup, spill_fixup
|
|
fill_fixup:
|
|
fill_fixup:
|
|
|
|
+ TRAP_LOAD_THREAD_REG
|
|
rdpr %tstate, %g1
|
|
rdpr %tstate, %g1
|
|
andcc %g1, TSTATE_PRIV, %g0
|
|
andcc %g1, TSTATE_PRIV, %g0
|
|
or %g4, FAULT_CODE_WINFIXUP, %g4
|
|
or %g4, FAULT_CODE_WINFIXUP, %g4
|
|
@@ -84,11 +85,7 @@ fill_fixup:
|
|
wrpr %l1, (PSTATE_IE | PSTATE_AG | PSTATE_RMO), %pstate
|
|
wrpr %l1, (PSTATE_IE | PSTATE_AG | PSTATE_RMO), %pstate
|
|
mov %o7, %g6
|
|
mov %o7, %g6
|
|
ldx [%g6 + TI_TASK], %g4
|
|
ldx [%g6 + TI_TASK], %g4
|
|
-#ifdef CONFIG_SMP
|
|
|
|
-#error IMMU TSB usage must be fixed
|
|
|
|
- mov TSB_REG, %g1
|
|
|
|
- ldxa [%g1] ASI_IMMU, %g5
|
|
|
|
-#endif
|
|
|
|
|
|
+ LOAD_PER_CPU_BASE(%g1, %g2)
|
|
|
|
|
|
/* This is the same as below, except we handle this a bit special
|
|
/* This is the same as below, except we handle this a bit special
|
|
* since we must preserve %l5 and %l6, see comment above.
|
|
* since we must preserve %l5 and %l6, see comment above.
|
|
@@ -107,6 +104,7 @@ fill_fixup:
|
|
* do not touch %g7 or %g2 so we handle the two cases fine.
|
|
* do not touch %g7 or %g2 so we handle the two cases fine.
|
|
*/
|
|
*/
|
|
spill_fixup:
|
|
spill_fixup:
|
|
|
|
+ TRAP_LOAD_THREAD_REG
|
|
ldx [%g6 + TI_FLAGS], %g1
|
|
ldx [%g6 + TI_FLAGS], %g1
|
|
andcc %g1, _TIF_32BIT, %g0
|
|
andcc %g1, _TIF_32BIT, %g0
|
|
ldub [%g6 + TI_WSAVED], %g1
|
|
ldub [%g6 + TI_WSAVED], %g1
|
|
@@ -182,6 +180,7 @@ winfix_mna:
|
|
wrpr %g3, %tnpc
|
|
wrpr %g3, %tnpc
|
|
done
|
|
done
|
|
fill_fixup_mna:
|
|
fill_fixup_mna:
|
|
|
|
+ TRAP_LOAD_THREAD_REG
|
|
rdpr %tstate, %g1
|
|
rdpr %tstate, %g1
|
|
andcc %g1, TSTATE_PRIV, %g0
|
|
andcc %g1, TSTATE_PRIV, %g0
|
|
be,pt %xcc, window_mna_from_user_common
|
|
be,pt %xcc, window_mna_from_user_common
|
|
@@ -209,17 +208,14 @@ fill_fixup_mna:
|
|
wrpr %l1, (PSTATE_IE | PSTATE_AG | PSTATE_RMO), %pstate
|
|
wrpr %l1, (PSTATE_IE | PSTATE_AG | PSTATE_RMO), %pstate
|
|
mov %o7, %g6 ! Get current back.
|
|
mov %o7, %g6 ! Get current back.
|
|
ldx [%g6 + TI_TASK], %g4 ! Finish it.
|
|
ldx [%g6 + TI_TASK], %g4 ! Finish it.
|
|
-#ifdef CONFIG_SMP
|
|
|
|
-#error IMMU TSB usage must be fixed
|
|
|
|
- mov TSB_REG, %g1
|
|
|
|
- ldxa [%g1] ASI_IMMU, %g5
|
|
|
|
-#endif
|
|
|
|
|
|
+ LOAD_PER_CPU_BASE(%g1, %g2)
|
|
call mem_address_unaligned
|
|
call mem_address_unaligned
|
|
add %sp, PTREGS_OFF, %o0
|
|
add %sp, PTREGS_OFF, %o0
|
|
|
|
|
|
b,pt %xcc, rtrap
|
|
b,pt %xcc, rtrap
|
|
nop ! yes, the nop is correct
|
|
nop ! yes, the nop is correct
|
|
spill_fixup_mna:
|
|
spill_fixup_mna:
|
|
|
|
+ TRAP_LOAD_THREAD_REG
|
|
ldx [%g6 + TI_FLAGS], %g1
|
|
ldx [%g6 + TI_FLAGS], %g1
|
|
andcc %g1, _TIF_32BIT, %g0
|
|
andcc %g1, _TIF_32BIT, %g0
|
|
ldub [%g6 + TI_WSAVED], %g1
|
|
ldub [%g6 + TI_WSAVED], %g1
|
|
@@ -287,6 +283,7 @@ winfix_dax:
|
|
wrpr %g3, %tnpc
|
|
wrpr %g3, %tnpc
|
|
done
|
|
done
|
|
fill_fixup_dax:
|
|
fill_fixup_dax:
|
|
|
|
+ TRAP_LOAD_THREAD_REG
|
|
rdpr %tstate, %g1
|
|
rdpr %tstate, %g1
|
|
andcc %g1, TSTATE_PRIV, %g0
|
|
andcc %g1, TSTATE_PRIV, %g0
|
|
be,pt %xcc, window_dax_from_user_common
|
|
be,pt %xcc, window_dax_from_user_common
|
|
@@ -314,17 +311,14 @@ fill_fixup_dax:
|
|
wrpr %l1, (PSTATE_IE | PSTATE_AG | PSTATE_RMO), %pstate
|
|
wrpr %l1, (PSTATE_IE | PSTATE_AG | PSTATE_RMO), %pstate
|
|
mov %o7, %g6 ! Get current back.
|
|
mov %o7, %g6 ! Get current back.
|
|
ldx [%g6 + TI_TASK], %g4 ! Finish it.
|
|
ldx [%g6 + TI_TASK], %g4 ! Finish it.
|
|
-#ifdef CONFIG_SMP
|
|
|
|
-#error IMMU TSB usage must be fixed
|
|
|
|
- mov TSB_REG, %g1
|
|
|
|
- ldxa [%g1] ASI_IMMU, %g5
|
|
|
|
-#endif
|
|
|
|
|
|
+ LOAD_PER_CPU_BASE(%g1, %g2)
|
|
call spitfire_data_access_exception
|
|
call spitfire_data_access_exception
|
|
add %sp, PTREGS_OFF, %o0
|
|
add %sp, PTREGS_OFF, %o0
|
|
|
|
|
|
b,pt %xcc, rtrap
|
|
b,pt %xcc, rtrap
|
|
nop ! yes, the nop is correct
|
|
nop ! yes, the nop is correct
|
|
spill_fixup_dax:
|
|
spill_fixup_dax:
|
|
|
|
+ TRAP_LOAD_THREAD_REG
|
|
ldx [%g6 + TI_FLAGS], %g1
|
|
ldx [%g6 + TI_FLAGS], %g1
|
|
andcc %g1, _TIF_32BIT, %g0
|
|
andcc %g1, _TIF_32BIT, %g0
|
|
ldub [%g6 + TI_WSAVED], %g1
|
|
ldub [%g6 + TI_WSAVED], %g1
|