]> git.baikalelectronics.ru Git - kernel.git/commit
Makefile: Improve compressed debug info support detection
authorArvind Sankar <nivedita@alum.mit.edu>
Thu, 11 Jun 2020 22:03:39 +0000 (18:03 -0400)
committerMasahiro Yamada <masahiroy@kernel.org>
Mon, 15 Jun 2020 01:26:42 +0000 (10:26 +0900)
commit39ecf88a6378ea3b13d5dea3c182417e45c8b26c
treed97a5ca6e6cbfbee27aa498ec8caac945258a0ad
parent2e0873da09585b8a2daf9ca8c2facd15f454ec3f
Makefile: Improve compressed debug info support detection

Commit
  d4b6f59c06cc ("Makefile: support compressed debug info")
added support for compressed debug sections.

Support is detected by checking
- does the compiler support -gz=zlib
- does the assembler support --compressed-debug-sections=zlib
- does the linker support --compressed-debug-sections=zlib

However, the gcc driver's support for this option is somewhat
convoluted. The driver's builtin specs are set based on the version of
binutils that it was configured with. It reports an error if the
configure-time linker/assembler (i.e., not necessarily the actual
assembler that will be run) do not support the option, but only if the
assembler (or linker) is actually invoked when -gz=zlib is passed.

The cc-option check in scripts/Kconfig.include does not invoke the
assembler, so the gcc driver reports success even if it does not support
the option being passed to the assembler.

Because the as-option check passes the option directly to the assembler
via -Wa,--compressed-debug-sections=zlib, the gcc driver does not see
this option and will never report an error.

Combined with an installed version of binutils that is more recent than
the one the compiler was built with, it is possible for all three tests
to succeed, yet an actual compilation with -gz=zlib to fail.

Moreover, it is unnecessary to explicitly pass
--compressed-debug-sections=zlib to the assembler via -Wa, since the
driver will do that automatically when it supports -gz=zlib.

Convert the as-option to just -gz=zlib, simplifying it as well as
performing a better test of the gcc driver's capabilities.

Reported-by: kernel test robot <lkp@intel.com>
Signed-off-by: Arvind Sankar <nivedita@alum.mit.edu>
Reviewed-by: Nick Desaulniers <ndesaulniers@google.com>
Signed-off-by: Masahiro Yamada <masahiroy@kernel.org>
Makefile
lib/Kconfig.debug