aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMark Rutland <mark.rutland@arm.com>2015-10-26 17:42:33 -0400
committerCatalin Marinas <catalin.marinas@arm.com>2015-10-29 13:23:39 -0400
commitcb083816ab5ac3d10a9417527f07fc5962cc3808 (patch)
treed829d1b151d207084c5af4e879a09a52f01c2e0f
parent86a5906e4d1df1ec160fa9e18b6f2277a5216c60 (diff)
arm64: page-align sections for DEBUG_RODATA
A kernel built with DEBUG_RO_DATA && !CONFIG_DEBUG_ALIGN_RODATA doesn't have .text aligned to a page boundary, though fixup_executable works at page-granularity thanks to its use of create_mapping. If .text is not page-aligned, the first page it exists in may be marked non-executable, leading to failures when an attempt is made to execute code in said page. This patch upgrades ALIGN_DEBUG_RO and ALIGN_DEBUG_RO_MIN to force page alignment for DEBUG_RO_DATA && !CONFIG_DEBUG_ALIGN_RODATA kernels, ensuring that all sections with specific RWX permission requirements are mapped with the correct permissions. Signed-off-by: Mark Rutland <mark.rutland@arm.com> Reported-by: Jeremy Linton <jeremy.linton@arm.com> Reviewed-by: Laura Abbott <laura@labbott.name> Acked-by: Ard Biesheuvel <ard.biesheuvel@linaro.org> Cc: Suzuki Poulose <suzuki.poulose@arm.com> Cc: Will Deacon <will.deacon@arm.com> Fixes: da141706aea52c1a ("arm64: add better page protections to arm64") Cc: <stable@vger.kernel.org> Signed-off-by: Catalin Marinas <catalin.marinas@arm.com>
-rw-r--r--arch/arm64/kernel/vmlinux.lds.S5
1 files changed, 4 insertions, 1 deletions
diff --git a/arch/arm64/kernel/vmlinux.lds.S b/arch/arm64/kernel/vmlinux.lds.S
index 8a5d97b461c0..1ee2c3937d4e 100644
--- a/arch/arm64/kernel/vmlinux.lds.S
+++ b/arch/arm64/kernel/vmlinux.lds.S
@@ -61,9 +61,12 @@ PECOFF_FILE_ALIGNMENT = 0x200;
61#define PECOFF_EDATA_PADDING 61#define PECOFF_EDATA_PADDING
62#endif 62#endif
63 63
64#ifdef CONFIG_DEBUG_ALIGN_RODATA 64#if defined(CONFIG_DEBUG_ALIGN_RODATA)
65#define ALIGN_DEBUG_RO . = ALIGN(1<<SECTION_SHIFT); 65#define ALIGN_DEBUG_RO . = ALIGN(1<<SECTION_SHIFT);
66#define ALIGN_DEBUG_RO_MIN(min) ALIGN_DEBUG_RO 66#define ALIGN_DEBUG_RO_MIN(min) ALIGN_DEBUG_RO
67#elif defined(CONFIG_DEBUG_RODATA)
68#define ALIGN_DEBUG_RO . = ALIGN(1<<PAGE_SHIFT);
69#define ALIGN_DEBUG_RO_MIN(min) ALIGN_DEBUG_RO
67#else 70#else
68#define ALIGN_DEBUG_RO 71#define ALIGN_DEBUG_RO
69#define ALIGN_DEBUG_RO_MIN(min) . = ALIGN(min); 72#define ALIGN_DEBUG_RO_MIN(min) . = ALIGN(min);