| From 7877d76b409181af38d307b98d8fed1024f3c9c2 Mon Sep 17 00:00:00 2001 |
| From: Roland McGrath <roland@redhat.com> |
| Date: Mon, 6 Oct 2008 23:03:03 -0700 |
| Subject: [PATCH] kbuild: AFTER_LINK |
| |
| If the make variable AFTER_LINK is set, it is a command line to run |
| after each final link. This includes vmlinux itself and vDSO images. |
| |
| Bugzilla: N/A |
| Upstream-status: ?? |
| |
| Signed-off-by: Roland McGrath <roland@redhat.com> |
| |
| arch/arm64/kernel/vdso/Makefile | 3 ++- |
| arch/powerpc/kernel/vdso32/Makefile | 3 ++- |
| arch/powerpc/kernel/vdso64/Makefile | 3 ++- |
| arch/s390/kernel/vdso32/Makefile | 3 ++- |
| arch/s390/kernel/vdso64/Makefile | 3 ++- |
| arch/x86/entry/vdso/Makefile | 5 +++-- |
| scripts/link-vmlinux.sh | 4 ++++ |
| 7 files changed, 17 insertions(+), 7 deletions(-) |
| |
| diff --git a/arch/arm64/kernel/vdso/Makefile b/arch/arm64/kernel/vdso/Makefile |
| index f6fe17d88da5..eb6ddbf37f30 100644 |
| |
| |
| @@ -52,7 +52,8 @@ $(obj-vdso): %.o: %.S FORCE |
| |
| # Actual build commands |
| quiet_cmd_vdsold = VDSOL $@ |
| - cmd_vdsold = $(CC) $(c_flags) -Wl,-n -Wl,-T $^ -o $@ |
| + cmd_vdsold = $(CC) $(c_flags) -Wl,-n -Wl,-T $^ -o $@ \ |
| + $(if $(AFTER_LINK),;$(AFTER_LINK)) |
| quiet_cmd_vdsoas = VDSOA $@ |
| cmd_vdsoas = $(CC) $(a_flags) -c -o $@ $< |
| |
| diff --git a/arch/powerpc/kernel/vdso32/Makefile b/arch/powerpc/kernel/vdso32/Makefile |
| index 53e6c9b979ec..e427844e9bb0 100644 |
| |
| |
| @@ -43,7 +43,8 @@ $(obj-vdso32): %.o: %.S |
| |
| # actual build commands |
| quiet_cmd_vdso32ld = VDSO32L $@ |
| - cmd_vdso32ld = $(CROSS32CC) $(c_flags) -Wl,-T $^ -o $@ |
| + cmd_vdso32ld = $(CROSS32CC) $(c_flags) -Wl,-T $^ -o $@ \ |
| + $(if $(AFTER_LINK),; $(AFTER_LINK)) |
| quiet_cmd_vdso32as = VDSO32A $@ |
| cmd_vdso32as = $(CROSS32CC) $(a_flags) -c -o $@ $< |
| |
| diff --git a/arch/powerpc/kernel/vdso64/Makefile b/arch/powerpc/kernel/vdso64/Makefile |
| index effca9404b17..713891a92d23 100644 |
| |
| |
| @@ -36,7 +36,8 @@ $(obj-vdso64): %.o: %.S |
| |
| # actual build commands |
| quiet_cmd_vdso64ld = VDSO64L $@ |
| - cmd_vdso64ld = $(CC) $(c_flags) -Wl,-T $^ -o $@ |
| + cmd_vdso64ld = $(CC) $(c_flags) -Wl,-T $^ -o $@ \ |
| + $(if $(AFTER_LINK),; $(AFTER_LINK)) |
| quiet_cmd_vdso64as = VDSO64A $@ |
| cmd_vdso64as = $(CC) $(a_flags) -c -o $@ $< |
| |
| diff --git a/arch/s390/kernel/vdso32/Makefile b/arch/s390/kernel/vdso32/Makefile |
| index ee8a18e50a25..63e33fa049f8 100644 |
| |
| |
| @@ -43,7 +43,8 @@ $(obj-vdso32): %.o: %.S |
| |
| # actual build commands |
| quiet_cmd_vdso32ld = VDSO32L $@ |
| - cmd_vdso32ld = $(CC) $(c_flags) -Wl,-T $^ -o $@ |
| + cmd_vdso32ld = $(CC) $(c_flags) -Wl,-T $^ -o $@ \ |
| + $(if $(AFTER_LINK),; $(AFTER_LINK)) |
| quiet_cmd_vdso32as = VDSO32A $@ |
| cmd_vdso32as = $(CC) $(a_flags) -c -o $@ $< |
| |
| diff --git a/arch/s390/kernel/vdso64/Makefile b/arch/s390/kernel/vdso64/Makefile |
| index c4b03f9ed228..550450fc2f95 100644 |
| |
| |
| @@ -43,7 +43,8 @@ $(obj-vdso64): %.o: %.S |
| |
| # actual build commands |
| quiet_cmd_vdso64ld = VDSO64L $@ |
| - cmd_vdso64ld = $(CC) $(c_flags) -Wl,-T $^ -o $@ |
| + cmd_vdso64ld = $(CC) $(c_flags) -Wl,-T $^ -o $@ \ |
| + $(if $(AFTER_LINK),; $(AFTER_LINK)) |
| quiet_cmd_vdso64as = VDSO64A $@ |
| cmd_vdso64as = $(CC) $(a_flags) -c -o $@ $< |
| |
| diff --git a/arch/x86/entry/vdso/Makefile b/arch/x86/entry/vdso/Makefile |
| index a3d0767a6b29..078c9be1db8f 100644 |
| |
| |
| @@ -172,8 +172,9 @@ $(vdso32-images:%=$(obj)/%.dbg): $(obj)/vdso32-%.so.dbg: FORCE \ |
| quiet_cmd_vdso = VDSO $@ |
| cmd_vdso = $(CC) -nostdlib -o $@ \ |
| $(VDSO_LDFLAGS) $(VDSO_LDFLAGS_$(filter %.lds,$(^F))) \ |
| - -Wl,-T,$(filter %.lds,$^) $(filter %.o,$^) && \ |
| - sh $(srctree)/$(src)/checkundef.sh '$(NM)' '$@' |
| + -Wl,-T,$(filter %.lds,$^) $(filter %.o,$^) \ |
| + $(if $(AFTER_LINK),; $(AFTER_LINK)) && \ |
| + sh $(srctree)/$(src)/checkundef.sh '$(NM)' '$@' |
| |
| VDSO_LDFLAGS = -fPIC -shared $(call cc-ldoption, -Wl$(comma)--hash-style=both) \ |
| $(call cc-ldoption, -Wl$(comma)--build-id) -Wl,-Bsymbolic $(LTO_CFLAGS) |
| diff --git a/scripts/link-vmlinux.sh b/scripts/link-vmlinux.sh |
| index 1a10d8ac8162..092d0c0cf72c 100755 |
| |
| |
| @@ -65,6 +65,10 @@ vmlinux_link() |
| -lutil ${1} |
| rm -f linux |
| fi |
| + if [ -n "${AFTER_LINK}" ]; then |
| + /usr/lib/rpm/debugedit -b ${RPM_BUILD_DIR} -d /usr/src/debug -i ${2} \ |
| + > ${2}.id |
| + fi |
| } |
| |
| |
| -- |
| 2.4.3 |
| |