powerpc/32: Reorder instructions to avoid using CTR in syscall entry

Now that we are using rfi instead of mtmsr to reactivate MMU, it is
possible to reorder instructions and avoid the need to use CTR for
stashing SRR0.

null_syscall on 8xx is reduced by 3 cycles (283 => 280 cycles).

Signed-off-by: Christophe Leroy <christophe.leroy@csgroup.eu>
Signed-off-by: Michael Ellerman <mpe@ellerman.id.au>
Link: https://lore.kernel.org/r/8fa13a59f73647e058c95fc7e1c7a98f316bd20a.1612796617.git.christophe.leroy@csgroup.eu
This commit is contained in:
Christophe Leroy 2021-02-08 15:10:23 +00:00 committed by Michael Ellerman
parent 76249ddc27
commit 2c59e51048

View File

@ -116,30 +116,28 @@
.endm .endm
.macro SYSCALL_ENTRY trapno .macro SYSCALL_ENTRY trapno
mfspr r12,SPRN_SPRG_THREAD
mfspr r9, SPRN_SRR1 mfspr r9, SPRN_SRR1
mfspr r11, SPRN_SRR0 mfspr r10, SPRN_SRR0
mtctr r11
andi. r11, r9, MSR_PR andi. r11, r9, MSR_PR
beq- 99f
LOAD_REG_IMMEDIATE(r11, MSR_KERNEL) /* can take exceptions */
lis r12, 1f@h
ori r12, r12, 1f@l
mtspr SPRN_SRR1, r11
mtspr SPRN_SRR0, r12
mfspr r12,SPRN_SPRG_THREAD
mr r11, r1 mr r11, r1
lwz r1,TASK_STACK-THREAD(r12) lwz r1,TASK_STACK-THREAD(r12)
beq- 99f tovirt(r12, r12)
addi r1, r1, THREAD_SIZE - INT_FRAME_SIZE addi r1, r1, THREAD_SIZE - INT_FRAME_SIZE
LOAD_REG_IMMEDIATE(r10, MSR_KERNEL) /* can take exceptions */
mtspr SPRN_SRR1, r10
lis r10, 1f@h
ori r10, r10, 1f@l
mtspr SPRN_SRR0, r10
rfi rfi
1: 1:
tovirt(r12, r12)
stw r11,GPR1(r1) stw r11,GPR1(r1)
stw r11,0(r1) stw r11,0(r1)
mr r11, r1 mr r11, r1
stw r10,_NIP(r11)
mflr r10 mflr r10
stw r10, _LINK(r11) stw r10, _LINK(r11)
mfctr r10
stw r10,_NIP(r11)
mfcr r10 mfcr r10
rlwinm r10,r10,0,4,2 /* Clear SO bit in CR */ rlwinm r10,r10,0,4,2 /* Clear SO bit in CR */
stw r10,_CCR(r11) /* save registers */ stw r10,_CCR(r11) /* save registers */