aboutsummaryrefslogtreecommitdiffstats
path: root/arch/sparc64/kernel
diff options
context:
space:
mode:
authorDavid S. Miller <davem@davemloft.net>2006-01-31 21:32:04 -0500
committerDavid S. Miller <davem@sunset.davemloft.net>2006-03-20 04:11:19 -0500
commitb70c0fa1613c4f69b4a340a0e2bee387560ebbb1 (patch)
treef7bf22ab75cb9118f5772353fef6efd923faa212 /arch/sparc64/kernel
parentbd40791e1d289d807b8580abe1f117e9c62894e4 (diff)
[SPARC64]: Preload TSB entries from update_mmu_cache().
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'arch/sparc64/kernel')
-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 *