aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAndi Kleen <ak@linux.intel.com>2014-07-30 14:50:18 -0400
committerMichal Marek <mmarek@suse.cz>2014-07-30 16:54:52 -0400
commit866ced950bcd54820c3e571229356adc2b2dd72e (patch)
tree13cd5b869ab355f7bd193aed1452d260b1165808
parent011bf1254772b20083b1bab53f3aa58b1ec95eb1 (diff)
kbuild: Support split debug info v4
This is an alternative approach to lower the overhead of debug info (as we discussed a few days ago) gcc 4.7+ and newer binutils have a new "split debug info" debug info model where the debug info is only written once into central ".dwo" files. This avoids having to copy it around multiple times, from the object files to the final executable. It lowers the disk space requirements. In addition it defaults to compressed debug data. More details here: http://gcc.gnu.org/wiki/DebugFission This patch adds a new option to enable it. It has to be an option, because it'll undoubtedly break everyone's debuginfo packaging scheme. gdb/objdump/etc. all still work, if you have new enough versions. I don't see big compile wins (maybe a second or two faster or so), but the object dirs with debuginfo get significantly smaller. My standard kernel config (slightly bigger than defconfig) shrinks from 2.9G disk space to 1.1G objdir (with non reduced debuginfo). I presume if you are IO limited the compile time difference will be larger. Only problem I've seen so far is that it doesn't play well with older versions of ccache (apparently fixed, see https://bugzilla.samba.org/show_bug.cgi?id=10005) v2: various fixes from Dirk Gouders. Improve commit message slightly. v3: Fix clean rules and improve Kconfig slightly v4: Fix merge error in last version (Sam Ravnborg) Clarify description that it mainly helps disk size. Cc: Dirk Gouders <dirk@gouders.net> Signed-off-by: Andi Kleen <ak@linux.intel.com> Acked-by: Sam Ravnborg <sam@ravnborg.org> Signed-off-by: Michal Marek <mmarek@suse.cz>
-rw-r--r--.gitignore1
-rw-r--r--Makefile5
-rw-r--r--lib/Kconfig.debug15
3 files changed, 21 insertions, 0 deletions
diff --git a/.gitignore b/.gitignore
index f4c0b091dcf4..e213b27f3921 100644
--- a/.gitignore
+++ b/.gitignore
@@ -34,6 +34,7 @@
34*.gcno 34*.gcno
35modules.builtin 35modules.builtin
36Module.symvers 36Module.symvers
37*.dwo
37 38
38# 39#
39# Top-level generic files 40# Top-level generic files
diff --git a/Makefile b/Makefile
index 89fe23a0825c..e5a269465f99 100644
--- a/Makefile
+++ b/Makefile
@@ -684,7 +684,11 @@ endif
684endif 684endif
685 685
686ifdef CONFIG_DEBUG_INFO 686ifdef CONFIG_DEBUG_INFO
687ifdef CONFIG_DEBUG_INFO_SPLIT
688KBUILD_CFLAGS += $(call cc-option, -gsplit-dwarf, -g)
689else
687KBUILD_CFLAGS += -g 690KBUILD_CFLAGS += -g
691endif
688KBUILD_AFLAGS += -Wa,-gdwarf-2 692KBUILD_AFLAGS += -Wa,-gdwarf-2
689endif 693endif
690 694
@@ -1372,6 +1376,7 @@ clean: $(clean-dirs)
1372 @find $(if $(KBUILD_EXTMOD), $(KBUILD_EXTMOD), .) $(RCS_FIND_IGNORE) \ 1376 @find $(if $(KBUILD_EXTMOD), $(KBUILD_EXTMOD), .) $(RCS_FIND_IGNORE) \
1373 \( -name '*.[oas]' -o -name '*.ko' -o -name '.*.cmd' \ 1377 \( -name '*.[oas]' -o -name '*.ko' -o -name '.*.cmd' \
1374 -o -name '*.ko.*' \ 1378 -o -name '*.ko.*' \
1379 -o -name '*.dwo' \
1375 -o -name '.*.d' -o -name '.*.tmp' -o -name '*.mod.c' \ 1380 -o -name '.*.d' -o -name '.*.tmp' -o -name '*.mod.c' \
1376 -o -name '*.symtypes' -o -name 'modules.order' \ 1381 -o -name '*.symtypes' -o -name 'modules.order' \
1377 -o -name modules.builtin -o -name '.tmp_*.o.*' \ 1382 -o -name modules.builtin -o -name '.tmp_*.o.*' \
diff --git a/lib/Kconfig.debug b/lib/Kconfig.debug
index 7cfcc1b8e101..910355da9d14 100644
--- a/lib/Kconfig.debug
+++ b/lib/Kconfig.debug
@@ -143,6 +143,21 @@ config DEBUG_INFO_REDUCED
143 DEBUG_INFO build and compile times are reduced too. 143 DEBUG_INFO build and compile times are reduced too.
144 Only works with newer gcc versions. 144 Only works with newer gcc versions.
145 145
146config DEBUG_INFO_SPLIT
147 bool "Produce split debuginfo in .dwo files"
148 depends on DEBUG_INFO
149 help
150 Generate debug info into separate .dwo files. This significantly
151 reduces the build directory size for builds with DEBUG_INFO,
152 because it stores the information only once on disk in .dwo
153 files instead of multiple times in object files and executables.
154 In addition the debug information is also compressed.
155
156 Requires recent gcc (4.7+) and recent gdb/binutils.
157 Any tool that packages or reads debug information would need
158 to know about the .dwo files and include them.
159 Incompatible with older versions of ccache.
160
146config ENABLE_WARN_DEPRECATED 161config ENABLE_WARN_DEPRECATED
147 bool "Enable __deprecated logic" 162 bool "Enable __deprecated logic"
148 default y 163 default y