Commit 6c160f16 authored by Linus Torvalds's avatar Linus Torvalds

Merge tag 'kbuild-fixes-v6.8-2' of...

Merge tag 'kbuild-fixes-v6.8-2' of git://git.kernel.org/pub/scm/linux/kernel/git/masahiroy/linux-kbuild

Pull Kbuild fixes from Masahiro Yamada:

 - Reformat nested if-conditionals in Makefiles with 4 spaces

 - Fix CONFIG_DEBUG_INFO_BTF builds for big endian

 - Fix modpost for module srcversion

 - Fix an escape sequence warning in gen_compile_commands.py

 - Fix kallsyms to ignore ARMv4 thunk symbols

* tag 'kbuild-fixes-v6.8-2' of git://git.kernel.org/pub/scm/linux/kernel/git/masahiroy/linux-kbuild:
  kallsyms: ignore ARMv4 thunks along with others
  modpost: trim leading spaces when processing source files list
  gen_compile_commands: fix invalid escape sequence warning
  kbuild: Fix changing ELF file type for output of gen_btf for big endian
  docs: kconfig: Fix grammar and formatting
  kbuild: use 4-space indentation when followed by conditionals
parents ddac3d8b a951884d
...@@ -16,13 +16,13 @@ ...@@ -16,13 +16,13 @@
# that are possible for CORE. So for example if CORE_BELL_A_ADVANCED is 'y', # that are possible for CORE. So for example if CORE_BELL_A_ADVANCED is 'y',
# CORE must be 'y' too. # CORE must be 'y' too.
# #
# * What influences CORE_BELL_A_ADVANCED ? # * What influences CORE_BELL_A_ADVANCED?
# #
# As the name implies CORE_BELL_A_ADVANCED is an advanced feature of # As the name implies CORE_BELL_A_ADVANCED is an advanced feature of
# CORE_BELL_A so naturally it depends on CORE_BELL_A. So if CORE_BELL_A is 'y' # CORE_BELL_A so naturally it depends on CORE_BELL_A. So if CORE_BELL_A is 'y'
# we know CORE_BELL_A_ADVANCED can be 'y' too. # we know CORE_BELL_A_ADVANCED can be 'y' too.
# #
# * What influences CORE_BELL_A ? # * What influences CORE_BELL_A?
# #
# CORE_BELL_A depends on CORE, so CORE influences CORE_BELL_A. # CORE_BELL_A depends on CORE, so CORE influences CORE_BELL_A.
# #
...@@ -34,7 +34,7 @@ ...@@ -34,7 +34,7 @@
# the "recursive dependency detected" error. # the "recursive dependency detected" error.
# #
# Reading the Documentation/kbuild/Kconfig.recursion-issue-01 file it may be # Reading the Documentation/kbuild/Kconfig.recursion-issue-01 file it may be
# obvious that an easy to solution to this problem should just be the removal # obvious that an easy solution to this problem should just be the removal
# of the "select CORE" from CORE_BELL_A_ADVANCED as that is implicit already # of the "select CORE" from CORE_BELL_A_ADVANCED as that is implicit already
# since CORE_BELL_A depends on CORE. Recursive dependency issues are not always # since CORE_BELL_A depends on CORE. Recursive dependency issues are not always
# so trivial to resolve, we provide another example below of practical # so trivial to resolve, we provide another example below of practical
......
...@@ -170,7 +170,7 @@ def process_line(root_directory, command_prefix, file_path): ...@@ -170,7 +170,7 @@ def process_line(root_directory, command_prefix, file_path):
# escape the pound sign '#', either as '\#' or '$(pound)' (depending on the # escape the pound sign '#', either as '\#' or '$(pound)' (depending on the
# kernel version). The compile_commands.json file is not interepreted # kernel version). The compile_commands.json file is not interepreted
# by Make, so this code replaces the escaped version with '#'. # by Make, so this code replaces the escaped version with '#'.
prefix = command_prefix.replace('\#', '#').replace('$(pound)', '#') prefix = command_prefix.replace(r'\#', '#').replace('$(pound)', '#')
# Return the canonical path, eliminating any symbolic links encountered in the path. # Return the canonical path, eliminating any symbolic links encountered in the path.
abs_path = os.path.realpath(os.path.join(root_directory, file_path)) abs_path = os.path.realpath(os.path.join(root_directory, file_path))
......
...@@ -135,8 +135,13 @@ gen_btf() ...@@ -135,8 +135,13 @@ gen_btf()
${OBJCOPY} --only-section=.BTF --set-section-flags .BTF=alloc,readonly \ ${OBJCOPY} --only-section=.BTF --set-section-flags .BTF=alloc,readonly \
--strip-all ${1} ${2} 2>/dev/null --strip-all ${1} ${2} 2>/dev/null
# Change e_type to ET_REL so that it can be used to link final vmlinux. # Change e_type to ET_REL so that it can be used to link final vmlinux.
# Unlike GNU ld, lld does not allow an ET_EXEC input. # GNU ld 2.35+ and lld do not allow an ET_EXEC input.
printf '\1' | dd of=${2} conv=notrunc bs=1 seek=16 status=none if is_enabled CONFIG_CPU_BIG_ENDIAN; then
et_rel='\0\1'
else
et_rel='\1\0'
fi
printf "${et_rel}" | dd of=${2} conv=notrunc bs=1 seek=16 status=none
} }
# Create ${2} .S file with all symbols from the ${1} object file # Create ${2} .S file with all symbols from the ${1} object file
......
...@@ -48,17 +48,8 @@ ${NM} -n ${1} | sed >${2} -e " ...@@ -48,17 +48,8 @@ ${NM} -n ${1} | sed >${2} -e "
/ __kvm_nvhe_\\$/d / __kvm_nvhe_\\$/d
/ __kvm_nvhe_\.L/d / __kvm_nvhe_\.L/d
# arm64 lld # lld arm/aarch64/mips thunks
/ __AArch64ADRPThunk_/d / __[[:alnum:]]*Thunk_/d
# arm lld
/ __ARMV5PILongThunk_/d
/ __ARMV7PILongThunk_/d
/ __ThumbV7PILongThunk_/d
# mips lld
/ __LA25Thunk_/d
/ __microLA25Thunk_/d
# CFI type identifiers # CFI type identifiers
/ __kcfi_typeid_/d / __kcfi_typeid_/d
......
...@@ -326,7 +326,12 @@ static int parse_source_files(const char *objfile, struct md4_ctx *md) ...@@ -326,7 +326,12 @@ static int parse_source_files(const char *objfile, struct md4_ctx *md)
/* Sum all files in the same dir or subdirs. */ /* Sum all files in the same dir or subdirs. */
while ((line = get_line(&pos))) { while ((line = get_line(&pos))) {
char* p = line; char* p;
/* trim the leading spaces away */
while (isspace(*line))
line++;
p = line;
if (strncmp(line, "source_", sizeof("source_")-1) == 0) { if (strncmp(line, "source_", sizeof("source_")-1) == 0) {
p = strrchr(line, ' '); p = strrchr(line, ' ');
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment