aboutsummaryrefslogtreecommitdiffstats
path: root/arch/sparc64/kernel/tsb.S
diff options
context:
space:
mode:
Diffstat (limited to 'arch/sparc64/kernel/tsb.S')
-rw-r--r--arch/sparc64/kernel/tsb.S17
1 files changed, 17 insertions, 0 deletions
diff --git a/arch/sparc64/kernel/tsb.S b/arch/sparc64/kernel/tsb.S
index fe266bad0a28..08405ed69288 100644
--- a/arch/sparc64/kernel/tsb.S
+++ b/arch/sparc64/kernel/tsb.S
@@ -126,6 +126,23 @@ winfix_trampoline:
126 wrpr %g3, %tnpc ! Write it into TNPC 126 wrpr %g3, %tnpc ! Write it into TNPC
127 done ! Trap return 127 done ! Trap return
128 128
129 /* Insert an entry into the TSB.
130 *
131 * %o0: TSB entry pointer
132 * %o1: tag
133 * %o2: pte
134 */
135 .align 32
136 .globl tsb_insert
137tsb_insert:
138 rdpr %pstate, %o5
139 wrpr %o5, PSTATE_IE, %pstate
140 TSB_LOCK_TAG(%o0, %g2, %g3)
141 TSB_WRITE(%o0, %o2, %o1)
142 wrpr %o5, %pstate
143 retl
144 nop
145
129 /* Reload MMU related context switch state at 146 /* Reload MMU related context switch state at
130 * schedule() time. 147 * schedule() time.
131 * 148 *