[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <tip-392bef709659abea614abfe53cf228e7a59876a4@git.kernel.org>
Date: Wed, 24 Apr 2019 04:12:52 -0700
From: tip-bot for Kees Cook <tipbot@...or.com>
To: linux-tip-commits@...r.kernel.org
Cc: linux-kernel@...r.kernel.org, bp@...e.de, mingo@...nel.org,
hpa@...or.com, keescook@...omium.org, samitolvanen@...gle.com,
tglx@...utronix.de, peterz@...radead.org,
torvalds@...ux-foundation.org
Subject: [tip:x86/mm] x86/build: Move _etext to actual end of .text
Commit-ID: 392bef709659abea614abfe53cf228e7a59876a4
Gitweb: https://git.kernel.org/tip/392bef709659abea614abfe53cf228e7a59876a4
Author: Kees Cook <keescook@...omium.org>
AuthorDate: Tue, 23 Apr 2019 11:38:27 -0700
Committer: Ingo Molnar <mingo@...nel.org>
CommitDate: Wed, 24 Apr 2019 12:27:47 +0200
x86/build: Move _etext to actual end of .text
When building x86 with Clang LTO and CFI, CFI jump regions are
automatically added to the end of the .text section late in linking. As a
result, the _etext position was being labelled before the appended jump
regions, causing confusion about where the boundaries of the executable
region actually are in the running kernel, and broke at least the fault
injection code. This moves the _etext mark to outside (and immediately
after) the .text area, as it already the case on other architectures
(e.g. arm64, arm).
Reported-and-tested-by: Sami Tolvanen <samitolvanen@...gle.com>
Signed-off-by: Kees Cook <keescook@...omium.org>
Cc: Borislav Petkov <bp@...e.de>
Cc: Linus Torvalds <torvalds@...ux-foundation.org>
Cc: Peter Zijlstra <peterz@...radead.org>
Cc: Thomas Gleixner <tglx@...utronix.de>
Link: http://lkml.kernel.org/r/20190423183827.GA4012@beast
Signed-off-by: Ingo Molnar <mingo@...nel.org>
---
arch/x86/kernel/vmlinux.lds.S | 6 +++---
1 file changed, 3 insertions(+), 3 deletions(-)
diff --git a/arch/x86/kernel/vmlinux.lds.S b/arch/x86/kernel/vmlinux.lds.S
index bad8c51fee6e..de94da2366e7 100644
--- a/arch/x86/kernel/vmlinux.lds.S
+++ b/arch/x86/kernel/vmlinux.lds.S
@@ -141,11 +141,11 @@ SECTIONS
*(.text.__x86.indirect_thunk)
__indirect_thunk_end = .;
#endif
-
- /* End of text section */
- _etext = .;
} :text = 0x9090
+ /* End of text section */
+ _etext = .;
+
NOTES :text :note
EXCEPTION_TABLE(16) :text = 0x9090
Powered by blists - more mailing lists