arm64: ptrauth: Add bootup/runtime flags for __cpu_setup
authorAmit Daniel Kachhap <amit.kachhap@arm.com>
Fri, 13 Mar 2020 09:04:52 +0000 (14:34 +0530)
committerCatalin Marinas <catalin.marinas@arm.com>
Wed, 18 Mar 2020 09:50:19 +0000 (09:50 +0000)
This patch allows __cpu_setup to be invoked with one of these flags,
ARM64_CPU_BOOT_PRIMARY, ARM64_CPU_BOOT_SECONDARY or ARM64_CPU_RUNTIME.
This is required as some cpufeatures need different handling during
different scenarios.

The input parameter in x0 is preserved till the end to be used inside
this function.

There should be no functional change with this patch and is useful
for the subsequent ptrauth patch which utilizes it. Some upcoming
arm cpufeatures can also utilize these flags.

Suggested-by: James Morse <james.morse@arm.com>
Signed-off-by: Amit Daniel Kachhap <amit.kachhap@arm.com>
Reviewed-by: Vincenzo Frascino <Vincenzo.Frascino@arm.com>
Reviewed-by: James Morse <james.morse@arm.com>
Reviewed-by: Suzuki K Poulose <suzuki.poulose@arm.com>
Signed-off-by: Catalin Marinas <catalin.marinas@arm.com>
arch/arm64/include/asm/smp.h
arch/arm64/kernel/head.S
arch/arm64/kernel/sleep.S
arch/arm64/mm/proc.S

index a0c8a0b652593b66fb8e909627d92af15c0f2cde..8d66497d81571dc6f65759bb12619a2a1a8594bd 100644 (file)
 #define CPU_STUCK_REASON_52_BIT_VA     (UL(1) << CPU_STUCK_REASON_SHIFT)
 #define CPU_STUCK_REASON_NO_GRAN       (UL(2) << CPU_STUCK_REASON_SHIFT)
 
+/* Possible options for __cpu_setup */
+/* Option to setup primary cpu */
+#define ARM64_CPU_BOOT_PRIMARY         (1)
+/* Option to setup secondary cpus */
+#define ARM64_CPU_BOOT_SECONDARY       (2)
+/* Option to setup cpus for different cpu run time services */
+#define ARM64_CPU_RUNTIME              (3)
+
 #ifndef __ASSEMBLY__
 
 #include <asm/percpu.h>
index 989b1944cb719bb5afcd1f4fe1547ba4e2511d4e..797573fe0e9c97878840705e52efe33dd1483ee5 100644 (file)
@@ -118,6 +118,7 @@ ENTRY(stext)
         * On return, the CPU will be ready for the MMU to be turned on and
         * the TCR will have been set.
         */
+       mov     x0, #ARM64_CPU_BOOT_PRIMARY
        bl      __cpu_setup                     // initialise processor
        b       __primary_switch
 ENDPROC(stext)
@@ -712,6 +713,7 @@ secondary_startup:
         * Common entry point for secondary CPUs.
         */
        bl      __cpu_secondary_check52bitva
+       mov     x0, #ARM64_CPU_BOOT_SECONDARY
        bl      __cpu_setup                     // initialise processor
        adrp    x1, swapper_pg_dir
        bl      __enable_mmu
index f5b04dd8a7107275b7cd145a9c29c38a8dd98cf4..7b2f2e650c44d01aacbafa4562a9d986f5316f4e 100644 (file)
@@ -3,6 +3,7 @@
 #include <linux/linkage.h>
 #include <asm/asm-offsets.h>
 #include <asm/assembler.h>
+#include <asm/smp.h>
 
        .text
 /*
@@ -99,6 +100,7 @@ ENDPROC(__cpu_suspend_enter)
        .pushsection ".idmap.text", "awx"
 ENTRY(cpu_resume)
        bl      el2_setup               // if in EL2 drop to EL1 cleanly
+       mov     x0, #ARM64_CPU_RUNTIME
        bl      __cpu_setup
        /* enable the MMU early - so we can access sleep_save_stash by va */
        adrp    x1, swapper_pg_dir
index aafed690241147f661b000532d4d0b788b37b04d..ea0db1744c297bee635f1dd1f40a1f2e32d5981a 100644 (file)
@@ -408,30 +408,30 @@ SYM_FUNC_END(idmap_kpti_install_ng_mappings)
 /*
  *     __cpu_setup
  *
- *     Initialise the processor for turning the MMU on.  Return in x0 the
- *     value of the SCTLR_EL1 register.
+ *     Initialise the processor for turning the MMU on.
+ *
+ * Input:
+ *     x0 with a flag ARM64_CPU_BOOT_PRIMARY/ARM64_CPU_BOOT_SECONDARY/ARM64_CPU_RUNTIME.
+ * Output:
+ *     Return in x0 the value of the SCTLR_EL1 register.
  */
        .pushsection ".idmap.text", "awx"
 SYM_FUNC_START(__cpu_setup)
        tlbi    vmalle1                         // Invalidate local TLB
        dsb     nsh
 
-       mov     x0, #3 << 20
-       msr     cpacr_el1, x0                   // Enable FP/ASIMD
-       mov     x0, #1 << 12                    // Reset mdscr_el1 and disable
-       msr     mdscr_el1, x0                   // access to the DCC from EL0
+       mov     x1, #3 << 20
+       msr     cpacr_el1, x1                   // Enable FP/ASIMD
+       mov     x1, #1 << 12                    // Reset mdscr_el1 and disable
+       msr     mdscr_el1, x1                   // access to the DCC from EL0
        isb                                     // Unmask debug exceptions now,
        enable_dbg                              // since this is per-cpu
-       reset_pmuserenr_el0 x0                  // Disable PMU access from EL0
+       reset_pmuserenr_el0 x1                  // Disable PMU access from EL0
        /*
         * Memory region attributes
         */
        mov_q   x5, MAIR_EL1_SET
        msr     mair_el1, x5
-       /*
-        * Prepare SCTLR
-        */
-       mov_q   x0, SCTLR_EL1_SET
        /*
         * Set/prepare TCR and TTBR. We use 512GB (39-bit) address range for
         * both user and kernel.
@@ -468,5 +468,9 @@ SYM_FUNC_START(__cpu_setup)
 1:
 #endif /* CONFIG_ARM64_HW_AFDBM */
        msr     tcr_el1, x10
+       /*
+        * Prepare SCTLR
+        */
+       mov_q   x0, SCTLR_EL1_SET
        ret                                     // return to head.S
 SYM_FUNC_END(__cpu_setup)