]> www.infradead.org Git - users/hch/dma-mapping.git/commitdiff
powerpc/64s: syscall real mode entry use mtmsrd rather than rfid
authorNicholas Piggin <npiggin@gmail.com>
Mon, 8 Feb 2021 06:33:26 +0000 (16:33 +1000)
committerMichael Ellerman <mpe@ellerman.id.au>
Thu, 11 Feb 2021 12:35:05 +0000 (23:35 +1100)
Have the real mode system call entry handler branch to the kernel
0xc000... address and then use mtmsrd to enable the MMU, rather than use
SRRs and rfid.

Commit 8729c26e675c ("powerpc/64s/exception: Move real to virt switch
into the common handler") implemented this style of real mode entry for
other interrupt handlers, so this brings system calls into line with
them, which is the main motivcation for the change.

This tends to be slightly faster due to avoiding the mtsprs, and it also
does not clobber the SRR registers, which becomes important in a
subsequent change. The real mode entry points don't tend to be too
important for performance these days, but it is possible for a
hypervisor to run guests in AIL=0 mode for certian reasons.

Signed-off-by: Nicholas Piggin <npiggin@gmail.com>
Signed-off-by: Michael Ellerman <mpe@ellerman.id.au>
Link: https://lore.kernel.org/r/20210208063326.331502-1-npiggin@gmail.com
arch/powerpc/kernel/entry_64.S
arch/powerpc/kernel/exceptions-64s.S

index aa1af139d947297fdac16126fdb7b48d4d189a2b..4b2d2823c7a5f094424caedaddcf4d1638a44b3a 100644 (file)
@@ -225,6 +225,12 @@ _ASM_NOKPROBE_SYMBOL(system_call_vectored_emulate)
        b       system_call_vectored_common
 #endif
 
+       .balign IFETCH_ALIGN_BYTES
+       .globl system_call_common_real
+system_call_common_real:
+       ld      r10,PACAKMSR(r13)       /* get MSR value for kernel */
+       mtmsrd  r10
+
        .balign IFETCH_ALIGN_BYTES
        .globl system_call_common
 system_call_common:
index c51c436d5845f077f3a1b7bfdf017bda8c8f8591..de3e335bd93192567fa2530bb5afb92ccf03730a 100644 (file)
@@ -1973,12 +1973,9 @@ END_FTR_SECTION_IFSET(CPU_FTR_REAL_LE)
        HMT_MEDIUM
 
        .if ! \virt
-       __LOAD_HANDLER(r10, system_call_common)
-       mtspr   SPRN_SRR0,r10
-       ld      r10,PACAKMSR(r13)
-       mtspr   SPRN_SRR1,r10
-       RFI_TO_KERNEL
-       b       .       /* prevent speculative execution */
+       __LOAD_HANDLER(r10, system_call_common_real)
+       mtctr   r10
+       bctr
        .else
        li      r10,MSR_RI
        mtmsrd  r10,1                   /* Set RI (EE=0) */