forked from torvalds/linux
-
Notifications
You must be signed in to change notification settings - Fork 14
debugging Kconfig (and Kbuild) (via printf!)
Nathan Chancellor edited this page Jan 11, 2022
·
5 revisions
diff --git a/scripts/Kconfig.include b/scripts/Kconfig.include
index a5fe72c504ff..b59db288da28 100644
--- a/scripts/Kconfig.include
+++ b/scripts/Kconfig.include
@@ -25,7 +25,7 @@ failure = $(if-success,$(1),n,y)
# $(cc-option,<flag>)
# Return y if the compiler supports <flag>, n otherwise
-cc-option = $(success,mkdir .tmp_$$$$; trap "rm -rf .tmp_$$$$" EXIT; $(CC) -Werror $(CLANG_FLAGS) $(1) -c -x c /dev/null -o .tmp_$$$$/tmp.o)
+cc-option = $(success,mkdir .tmp_$$$$; trap "rm -rf .tmp_$$$$" EXIT; $(CC) -Werror $(CLANG_FLAGS) $(1) -c -x c /dev/null -o .tmp_$$$$/tmp.o; echo $(CC) -Werror $(CLANG_FLAGS) $(1) -c -x c /dev/null >> log.txt)
# $(ld-option,<flag>)
# Return y if the linker supports <flag>, n otherwise
v5.13
and newer:
diff --git a/scripts/Makefile.compiler b/scripts/Makefile.compiler
index 86ecd2ac874c..f6ec2a45e36f 100644
--- a/scripts/Makefile.compiler
+++ b/scripts/Makefile.compiler
@@ -23,7 +23,7 @@ try-run = $(shell set -e; \
TMP=$(TMPOUT)/tmp; \
mkdir -p $(TMPOUT); \
trap "rm -rf $(TMPOUT)" EXIT; \
- if ($(1)) >/dev/null 2>&1; \
+ if ($(1)) >>/tmp/build.log 2>&1; \
then echo "$(2)"; \
else echo "$(3)"; \
fi)
v5.12
and earlier:
diff --git a/scripts/Kbuild.include b/scripts/Kbuild.include
index 0d6e11820791..b509e0548c9c 100644
--- a/scripts/Kbuild.include
+++ b/scripts/Kbuild.include
@@ -95,7 +95,7 @@ try-run = $(shell set -e; \
TMPO=$(TMPOUT)/tmp.o; \
mkdir -p $(TMPOUT); \
trap "rm -rf $(TMPOUT)" EXIT; \
- if ($(1)) >/dev/null 2>&1; \
+ if ($(1)) >>/tmp/build.log 2>&1; \
then echo "$(2)"; \
else echo "$(3)"; \
fi)
-
Debugging
make
: https://stackoverflow.com/a/16489377 -
Disabling flags when bisecting problems:
CLANG_FLAGS += $(call cc-disable-warning,foo,)