objtool: Don't make .altinstructions writable

When objtool creates the .altinstructions section, it sets the SHF_WRITE
flag to make the section writable -- unless the section had already been
previously created by the kernel.  The mismatch between kernel-created
and objtool-created section flags can cause failures with external
tooling (kpatch-build).  And the section doesn't need to be writable
anyway.

Make the section flags consistent with the kernel's.

Fixes: 9bc0bb5072 ("objtool/x86: Rewrite retpoline thunk calls")
Reported-by: Joe Lawrence <joe.lawrence@redhat.com>
Signed-off-by: Josh Poimboeuf <jpoimboe@redhat.com>
Signed-off-by: Ingo Molnar <mingo@kernel.org>
Link: https://lore.kernel.org/r/6c284ae89717889ea136f9f0064d914cd8329d31.1624462939.git.jpoimboe@redhat.com
This commit is contained in:
Josh Poimboeuf 2021-06-23 10:42:28 -05:00 committed by Ingo Molnar
parent 49faa77759
commit e31694e0a7

View File

@ -684,7 +684,7 @@ static int elf_add_alternative(struct elf *elf,
sec = find_section_by_name(elf, ".altinstructions"); sec = find_section_by_name(elf, ".altinstructions");
if (!sec) { if (!sec) {
sec = elf_create_section(elf, ".altinstructions", sec = elf_create_section(elf, ".altinstructions",
SHF_WRITE, size, 0); SHF_ALLOC, size, 0);
if (!sec) { if (!sec) {
WARN_ELF("elf_create_section"); WARN_ELF("elf_create_section");