aboutsummaryrefslogtreecommitdiffstats
path: root/arch/arm64/kernel/entry.S
diff options
context:
space:
mode:
authorLaura Abbott <lauraa@codeaurora.org>2014-11-21 16:50:38 -0500
committerWill Deacon <will.deacon@arm.com>2014-11-25 10:56:44 -0500
commitfcff588633e848aa728a4437ef96d437299ba03d (patch)
tree295e7b44cc0e9c6a8ba64304815b5b61b777cc6b /arch/arm64/kernel/entry.S
parent3eebdbe5fc7d64c7a6ef14cc5b8be518ffd563fa (diff)
arm64: Treat handle_arch_irq as a function pointer
handle_arch_irq isn't actually text, it's just a function pointer. It doesn't need to be stored in the text section and doing so causes problesm if we ever want to make the kernel text read only. Declare handle_arch_irq as a proper function pointer stored in the data section. Reviewed-by: Kees Cook <keescook@chromium.org> Reviewed-by: Mark Rutland <mark.rutland@arm.com> Acked-by: Ard Biesheuvel <ard.biesheuvel@linaro.org> Tested-by: Mark Rutland <mark.rutland@arm.com> Tested-by: Kees Cook <keescook@chromium.org> Signed-off-by: Laura Abbott <lauraa@codeaurora.org> Signed-off-by: Will Deacon <will.deacon@arm.com>
Diffstat (limited to 'arch/arm64/kernel/entry.S')
-rw-r--r--arch/arm64/kernel/entry.S6
1 files changed, 2 insertions, 4 deletions
diff --git a/arch/arm64/kernel/entry.S b/arch/arm64/kernel/entry.S
index 622a409916f3..99c8d13fc00d 100644
--- a/arch/arm64/kernel/entry.S
+++ b/arch/arm64/kernel/entry.S
@@ -167,7 +167,8 @@ tsk .req x28 // current thread_info
167 * Interrupt handling. 167 * Interrupt handling.
168 */ 168 */
169 .macro irq_handler 169 .macro irq_handler
170 ldr x1, handle_arch_irq 170 adrp x1, handle_arch_irq
171 ldr x1, [x1, #:lo12:handle_arch_irq]
171 mov x0, sp 172 mov x0, sp
172 blr x1 173 blr x1
173 .endm 174 .endm
@@ -699,6 +700,3 @@ ENTRY(sys_rt_sigreturn_wrapper)
699 mov x0, sp 700 mov x0, sp
700 b sys_rt_sigreturn 701 b sys_rt_sigreturn
701ENDPROC(sys_rt_sigreturn_wrapper) 702ENDPROC(sys_rt_sigreturn_wrapper)
702
703ENTRY(handle_arch_irq)
704 .quad 0