diff options
-rw-r--r-- | Documentation/kbuild/makefiles.txt | 5 | ||||
-rw-r--r-- | Makefile | 4 | ||||
-rw-r--r-- | scripts/Kbuild.include | 5 | ||||
-rw-r--r-- | scripts/Makefile.build | 4 |
4 files changed, 16 insertions, 2 deletions
diff --git a/Documentation/kbuild/makefiles.txt b/Documentation/kbuild/makefiles.txt index 5d145bb443c0..40e082bb8c52 100644 --- a/Documentation/kbuild/makefiles.txt +++ b/Documentation/kbuild/makefiles.txt | |||
@@ -955,6 +955,11 @@ When kbuild executes, the following steps are followed (roughly): | |||
955 | used when linking modules. This is often a linker script. | 955 | used when linking modules. This is often a linker script. |
956 | From commandline LDFLAGS_MODULE shall be used (see kbuild.txt). | 956 | From commandline LDFLAGS_MODULE shall be used (see kbuild.txt). |
957 | 957 | ||
958 | KBUILD_ARFLAGS Options for $(AR) when creating archives | ||
959 | |||
960 | $(KBUILD_ARFLAGS) set by the top level Makefile to "D" (deterministic | ||
961 | mode) if this option is supported by $(AR). | ||
962 | |||
958 | --- 6.2 Add prerequisites to archprepare: | 963 | --- 6.2 Add prerequisites to archprepare: |
959 | 964 | ||
960 | The archprepare: rule is used to list prerequisites that need to be | 965 | The archprepare: rule is used to list prerequisites that need to be |
@@ -382,6 +382,7 @@ export KBUILD_CFLAGS CFLAGS_KERNEL CFLAGS_MODULE CFLAGS_GCOV | |||
382 | export KBUILD_AFLAGS AFLAGS_KERNEL AFLAGS_MODULE | 382 | export KBUILD_AFLAGS AFLAGS_KERNEL AFLAGS_MODULE |
383 | export KBUILD_AFLAGS_MODULE KBUILD_CFLAGS_MODULE KBUILD_LDFLAGS_MODULE | 383 | export KBUILD_AFLAGS_MODULE KBUILD_CFLAGS_MODULE KBUILD_LDFLAGS_MODULE |
384 | export KBUILD_AFLAGS_KERNEL KBUILD_CFLAGS_KERNEL | 384 | export KBUILD_AFLAGS_KERNEL KBUILD_CFLAGS_KERNEL |
385 | export KBUILD_ARFLAGS | ||
385 | 386 | ||
386 | # When compiling out-of-tree modules, put MODVERDIR in the module | 387 | # When compiling out-of-tree modules, put MODVERDIR in the module |
387 | # tree rather than in the kernel tree. The kernel tree might | 388 | # tree rather than in the kernel tree. The kernel tree might |
@@ -612,6 +613,9 @@ KBUILD_CFLAGS += $(call cc-option,-fno-strict-overflow) | |||
612 | # conserve stack if available | 613 | # conserve stack if available |
613 | KBUILD_CFLAGS += $(call cc-option,-fconserve-stack) | 614 | KBUILD_CFLAGS += $(call cc-option,-fconserve-stack) |
614 | 615 | ||
616 | # use the deterministic mode of AR if available | ||
617 | KBUILD_ARFLAGS := $(call ar-option,D) | ||
618 | |||
615 | # check for 'asm goto' | 619 | # check for 'asm goto' |
616 | ifeq ($(shell $(CONFIG_SHELL) $(srctree)/scripts/gcc-goto.sh $(CC)), y) | 620 | ifeq ($(shell $(CONFIG_SHELL) $(srctree)/scripts/gcc-goto.sh $(CC)), y) |
617 | KBUILD_CFLAGS += -DCC_HAVE_ASM_GOTO | 621 | KBUILD_CFLAGS += -DCC_HAVE_ASM_GOTO |
diff --git a/scripts/Kbuild.include b/scripts/Kbuild.include index ed2773edfe71..fae2d8d8cb09 100644 --- a/scripts/Kbuild.include +++ b/scripts/Kbuild.include | |||
@@ -141,6 +141,11 @@ cc-ldoption = $(call try-run,\ | |||
141 | ld-option = $(call try-run,\ | 141 | ld-option = $(call try-run,\ |
142 | $(CC) /dev/null -c -o "$$TMPO" ; $(LD) $(1) "$$TMPO" -o "$$TMP",$(1),$(2)) | 142 | $(CC) /dev/null -c -o "$$TMPO" ; $(LD) $(1) "$$TMPO" -o "$$TMP",$(1),$(2)) |
143 | 143 | ||
144 | # ar-option | ||
145 | # Usage: KBUILD_ARFLAGS := $(call ar-option,D) | ||
146 | # Important: no spaces around options | ||
147 | ar-option = $(call try-run, $(AR) rc$(1) "$$TMP",$(1),$(2)) | ||
148 | |||
144 | ###### | 149 | ###### |
145 | 150 | ||
146 | ### | 151 | ### |
diff --git a/scripts/Makefile.build b/scripts/Makefile.build index 5f87d3709f9f..e1244ef308ce 100644 --- a/scripts/Makefile.build +++ b/scripts/Makefile.build | |||
@@ -345,7 +345,7 @@ quiet_cmd_link_o_target = LD $@ | |||
345 | cmd_link_o_target = $(if $(strip $(obj-y)),\ | 345 | cmd_link_o_target = $(if $(strip $(obj-y)),\ |
346 | $(LD) $(ld_flags) -r -o $@ $(filter $(obj-y), $^) \ | 346 | $(LD) $(ld_flags) -r -o $@ $(filter $(obj-y), $^) \ |
347 | $(cmd_secanalysis),\ | 347 | $(cmd_secanalysis),\ |
348 | rm -f $@; $(AR) rcsD $@) | 348 | rm -f $@; $(AR) rcs$(KBUILD_ARFLAGS) $@) |
349 | 349 | ||
350 | $(builtin-target): $(obj-y) FORCE | 350 | $(builtin-target): $(obj-y) FORCE |
351 | $(call if_changed,link_o_target) | 351 | $(call if_changed,link_o_target) |
@@ -371,7 +371,7 @@ $(modorder-target): $(subdir-ym) FORCE | |||
371 | # | 371 | # |
372 | ifdef lib-target | 372 | ifdef lib-target |
373 | quiet_cmd_link_l_target = AR $@ | 373 | quiet_cmd_link_l_target = AR $@ |
374 | cmd_link_l_target = rm -f $@; $(AR) rcsD $@ $(lib-y) | 374 | cmd_link_l_target = rm -f $@; $(AR) rcs$(KBUILD_ARFLAGS) $@ $(lib-y) |
375 | 375 | ||
376 | $(lib-target): $(lib-y) FORCE | 376 | $(lib-target): $(lib-y) FORCE |
377 | $(call if_changed,link_l_target) | 377 | $(call if_changed,link_l_target) |