From: George Guo <[email protected]>

This series adds LoongArch support for the klp-build livepatch tooling,
enabling automated livepatch module generation using objtool on
LoongArch.

It is based on Josh Poimboeuf's klp-build series [1] (see base-commit
below) and extends it with the LoongArch-specific objtool and build
pieces, plus a few LoongArch toolchain/relocation fixes required to make
livepatch modules load and run correctly.

Overview:

 - Patch 1 wires up LoongArch klp-build (objtool-based livepatch module
   generation).
 - Patches 2-3 add the objtool bits LoongArch needs: arch_adjusted_addend()
   and the special section entry sizes (.altinstructions, __ex_table,
   __bug_table, __jump_table) so objtool can process livepatch modules.
 - Patches 4-5 fix kernel panics seen when loading livepatch modules,
   caused by LoongArch code-generation/relocation assumptions:
     * disable -mdirect-extern-access for klp builds (the module loader
       relies on GOT entries for external symbol references),
     * force -fPIC so same-compilation-unit symbol references relocate
       correctly.
 - Patch 6 fix EFI linking when building with -fdata-sections.
 - Patch 7 implements arch_jump_opcode_bytes() so klp checksums for
   jump/call instructions are position-independent, mirroring x86/arm64.
 - Patch 8 adds KLP_SYSCALL_DEFINEx() support for LoongArch.

Testing:
 - objtool builds cleanly for LoongArch.
 - Livepatch modules were generated and loaded on a LoongArch machine;
   the panics addressed by patches 4-5 no longer reproduce.

[1] 
https://git.kernel.org/pub/scm/linux/kernel/git/jpoimboe/linux.git/log/?h=klp-build-arm64

George Guo (8):
  LoongArch: Add livepatch build (KLP) support
  objtool/LoongArch: Add arch_adjusted_addend() for KLP support
  LoongArch: Add special section entry sizes for KLP support
  livepatch/klp-build: disable direct-extern-access for LoongArch to fix
    kernel panic
  LoongArch: fix kernel panic with -fPIC for same-compilation-unit
    symbol references
  LoongArch: Fix EFI linking with -fdata-sections
  objtool/klp: Add LoongArch jump opcode bytes support
  klp-build: Add LoongArch syscall patching macro

 arch/loongarch/Kconfig                       |  1 +
 arch/loongarch/include/asm/alternative-asm.h |  5 ++-
 arch/loongarch/include/asm/alternative.h     |  6 ++-
 arch/loongarch/include/asm/asm-extable.h     | 10 ++++-
 arch/loongarch/include/asm/bug.h             | 15 ++++++-
 arch/loongarch/include/asm/jump_label.h      |  9 +++-
 arch/loongarch/kernel/asm-offsets.c          | 36 +++++++++++++++
 arch/loongarch/kernel/head.S                 |  1 +
 arch/loongarch/kernel/vmlinux.lds.S          |  2 +-
 include/linux/livepatch_helpers.h            | 22 ++++++++++
 scripts/livepatch/klp-build                  | 16 ++++++-
 tools/objtool/Makefile                       |  3 +-
 tools/objtool/arch/loongarch/decode.c        | 46 ++++++++++++++++++++
 13 files changed, 161 insertions(+), 11 deletions(-)


base-commit: 85afaba140a4b9f20fe8c8a64b24fc85f022d981
-- 
2.25.1


Reply via email to