Commit 3ded9b7a authored by Anton Blanchard's avatar Anton Blanchard

ppc64: rework fast SLB miss handler castout code

parent de7924cb
...@@ -408,11 +408,6 @@ restore: ...@@ -408,11 +408,6 @@ restore:
ld r4,GPR4(r1) ld r4,GPR4(r1)
ld r1,GPR1(r1) ld r1,GPR1(r1)
/*
* What if we took an exception and stole this segment, we may
* fault on the above addresses and globber SRR0/1. Should check RI
* bit and repeat - Anton
*/
rfid rfid
/* Note: this must change if we start using the TIF_NOTIFY_RESUME bit */ /* Note: this must change if we start using the TIF_NOTIFY_RESUME bit */
......
...@@ -1051,7 +1051,7 @@ _GLOBAL(do_slb_bolted) ...@@ -1051,7 +1051,7 @@ _GLOBAL(do_slb_bolted)
slbmfee r23,r22 slbmfee r23,r22
rldicl r23,r23,37,63 rldicl r23,r23,37,63
cmpwi r23,0 cmpwi r23,0
beq 3f /* Found an invalid entry */ beq 4f /* Found an invalid entry */
addi r22,r22,1 addi r22,r22,1
cmpldi r22,64 cmpldi r22,64
...@@ -1060,18 +1060,37 @@ _GLOBAL(do_slb_bolted) ...@@ -1060,18 +1060,37 @@ _GLOBAL(do_slb_bolted)
/* No free entry - just take the next entry, round-robin */ /* No free entry - just take the next entry, round-robin */
/* XXX we should get the number of SLB entries from the naca */ /* XXX we should get the number of SLB entries from the naca */
SLB_NUM_ENTRIES = 64 SLB_NUM_ENTRIES = 64
mfspr r21,SPRG3 2: mfspr r21,SPRG3
ld r22,PACASTABRR(r21) ld r22,PACASTABRR(r21)
addi r23,r22,1 addi r23,r22,1
cmpdi r23,SLB_NUM_ENTRIES cmpdi r23,SLB_NUM_ENTRIES
blt 2f blt 3f
li r23,1 li r23,1
2: std r23,PACASTABRR(r21) 3: std r23,PACASTABRR(r21)
/* r20 = vsid, r22 = entry */ /* r20 = vsid, r22 = entry */
3:
/*
* Never cast out the segment for our kernel stack. Since we
* dont invalidate the ERAT we could have a valid translation
* for the kernel stack during the first part of exception exit
* which gets invalidated due to a tlbie from another cpu at a
* non recoverable point (after setting srr0/1) - Anton
*/
slbmfee r23,r22
srdi r23,r23,28
/*
* This is incorrect (r1 is not the kernel stack) if we entered
* from userspace but there is no critical window from userspace
* so this should be OK. Also if we cast out the userspace stack
* segment while in userspace we will fault it straight back in.
*/
srdi r21,r1,28
cmpd r21,r23
beq- 2b
/* Put together the vsid portion of the entry. */ /* Put together the vsid portion of the entry. */
li r21,0 4: li r21,0
rldimi r21,r20,12,0 rldimi r21,r20,12,0
ori r20,r21,1024 ori r20,r21,1024
ori r20,r20,128 /* set class bit for kernel region */ ori r20,r20,128 /* set class bit for kernel region */
...@@ -1079,17 +1098,6 @@ SLB_NUM_ENTRIES = 64 ...@@ -1079,17 +1098,6 @@ SLB_NUM_ENTRIES = 64
ori r20,r20,256 /* map kernel region with large ptes */ ori r20,r20,256 /* map kernel region with large ptes */
#endif #endif
/*
* XXX we should handle this in the exception exit path in 2.5,
* we need to make this path quick - Anton
*/
/* Invalidate the old entry */
slbmfee r21,r22
lis r23,-2049
ori r23,r23,65535
and r21,r21,r23
slbie r21
/* Put together the esid portion of the entry. */ /* Put together the esid portion of the entry. */
mfspr r21,DAR /* Get the new esid */ mfspr r21,DAR /* Get the new esid */
rldicl r21,r21,36,28 /* Permits a full 36b of ESID */ rldicl r21,r21,36,28 /* Permits a full 36b of ESID */
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment