UPSTREAM: arm64: factor out entry stack manipulation
authorMark Rutland <mark.rutland@arm.com>
Wed, 19 Jul 2017 16:24:49 +0000 (17:24 +0100)
committerGreg Kroah-Hartman <gregkh@google.com>
Sat, 6 Jan 2018 10:09:28 +0000 (11:09 +0100)
In subsequent patches, we will detect stack overflow in our exception
entry code, by verifying the SP after it has been decremented to make
space for the exception regs.

This verification code is small, and we can minimize its impact by
placing it directly in the vectors. To avoid redundant modification of
the SP, we also need to move the initial decrement of the SP into the
vectors.

As a preparatory step, this patch introduces kernel_ventry, which
performs this decrement, and updates the entry code accordingly.
Subsequent patches will fold SP verification into kernel_ventry.

There should be no functional change as a result of this patch.

Signed-off-by: Ard Biesheuvel <ard.biesheuvel@linaro.org>
[Mark: turn into prep patch, expand commit msg]
Signed-off-by: Mark Rutland <mark.rutland@arm.com>
Reviewed-by: Will Deacon <will.deacon@arm.com>
Tested-by: Laura Abbott <labbott@redhat.com>
Cc: Catalin Marinas <catalin.marinas@arm.com>
Cc: James Morse <james.morse@arm.com>
(cherry picked from commit b11e5759bfac0c474d95ec4780b1566350e64cad)

Change-Id: I5883da81b374498f2f9e16ccb596b22c5568f2fe
Signed-off-by: Greg Hackmann <ghackmann@google.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@google.com>
arch/arm64/kernel/entry.S

index dba3aceaed2fa4237b05378cbd4e7ca2504eab36..e89231f1e323c7feccb6870f6352eabf0e8c210a 100644 (file)
 #define BAD_FIQ                2
 #define BAD_ERROR      3
 
-       .macro  kernel_entry, el, regsize = 64
+       .macro kernel_ventry    label
+       .align 7
        sub     sp, sp, #S_FRAME_SIZE
+       b       \label
+       .endm
+
+       .macro  kernel_entry, el, regsize = 64
        .if     \regsize == 32
        mov     w0, w0                          // zero upper 32 bits of x0
        .endif
@@ -345,31 +350,31 @@ tsk       .req    x28             // current thread_info
 
        .align  11
 ENTRY(vectors)
-       ventry  el1_sync_invalid                // Synchronous EL1t
-       ventry  el1_irq_invalid                 // IRQ EL1t
-       ventry  el1_fiq_invalid                 // FIQ EL1t
-       ventry  el1_error_invalid               // Error EL1t
+       kernel_ventry   el1_sync_invalid                // Synchronous EL1t
+       kernel_ventry   el1_irq_invalid                 // IRQ EL1t
+       kernel_ventry   el1_fiq_invalid                 // FIQ EL1t
+       kernel_ventry   el1_error_invalid               // Error EL1t
 
-       ventry  el1_sync                        // Synchronous EL1h
-       ventry  el1_irq                         // IRQ EL1h
-       ventry  el1_fiq_invalid                 // FIQ EL1h
-       ventry  el1_error_invalid               // Error EL1h
+       kernel_ventry   el1_sync                        // Synchronous EL1h
+       kernel_ventry   el1_irq                         // IRQ EL1h
+       kernel_ventry   el1_fiq_invalid                 // FIQ EL1h
+       kernel_ventry   el1_error_invalid               // Error EL1h
 
-       ventry  el0_sync                        // Synchronous 64-bit EL0
-       ventry  el0_irq                         // IRQ 64-bit EL0
-       ventry  el0_fiq_invalid                 // FIQ 64-bit EL0
-       ventry  el0_error_invalid               // Error 64-bit EL0
+       kernel_ventry   el0_sync                        // Synchronous 64-bit EL0
+       kernel_ventry   el0_irq                         // IRQ 64-bit EL0
+       kernel_ventry   el0_fiq_invalid                 // FIQ 64-bit EL0
+       kernel_ventry   el0_error_invalid               // Error 64-bit EL0
 
 #ifdef CONFIG_COMPAT
-       ventry  el0_sync_compat                 // Synchronous 32-bit EL0
-       ventry  el0_irq_compat                  // IRQ 32-bit EL0
-       ventry  el0_fiq_invalid_compat          // FIQ 32-bit EL0
-       ventry  el0_error_invalid_compat        // Error 32-bit EL0
+       kernel_ventry   el0_sync_compat                 // Synchronous 32-bit EL0
+       kernel_ventry   el0_irq_compat                  // IRQ 32-bit EL0
+       kernel_ventry   el0_fiq_invalid_compat          // FIQ 32-bit EL0
+       kernel_ventry   el0_error_invalid_compat        // Error 32-bit EL0
 #else
-       ventry  el0_sync_invalid                // Synchronous 32-bit EL0
-       ventry  el0_irq_invalid                 // IRQ 32-bit EL0
-       ventry  el0_fiq_invalid                 // FIQ 32-bit EL0
-       ventry  el0_error_invalid               // Error 32-bit EL0
+       kernel_ventry   el0_sync_invalid                // Synchronous 32-bit EL0
+       kernel_ventry   el0_irq_invalid                 // IRQ 32-bit EL0
+       kernel_ventry   el0_fiq_invalid                 // FIQ 32-bit EL0
+       kernel_ventry   el0_error_invalid               // Error 32-bit EL0
 #endif
 END(vectors)