be64ba5
From b707aea6a4947c3806ced2c23e889943a0f36876 Mon Sep 17 00:00:00 2001
Kyle McMartin ed27f0b
From: Roland McGrath <roland@redhat.com>
Kyle McMartin f89b4ff
Date: Mon, 6 Oct 2008 23:03:03 -0700
Kyle McMartin f89b4ff
Subject: [PATCH] kbuild: AFTER_LINK
Kyle McMartin ed27f0b
Kyle McMartin f89b4ff
If the make variable AFTER_LINK is set, it is a command line to run
Kyle McMartin f89b4ff
after each final link.  This includes vmlinux itself and vDSO images.
Kyle McMartin f89b4ff
Kyle McMartin f89b4ff
Signed-off-by: Roland McGrath <roland@redhat.com>
be64ba5
Jesse Keating 7a32965
diff --git a/arch/powerpc/kernel/vdso32/Makefile b/arch/powerpc/kernel/vdso32/Makefile
be64ba5
index 9a7946c..28d6765 100644
Jesse Keating 7a32965
--- a/arch/powerpc/kernel/vdso32/Makefile
Jesse Keating 7a32965
+++ b/arch/powerpc/kernel/vdso32/Makefile
Jesse Keating 7a32965
@@ -41,7 +41,8 @@ $(obj-vdso32): %.o: %.S
Jesse Keating 7a32965
 
Jesse Keating 7a32965
 # actual build commands
Jesse Keating 7a32965
 quiet_cmd_vdso32ld = VDSO32L $@
Jesse Keating 7a32965
-      cmd_vdso32ld = $(CROSS32CC) $(c_flags) -Wl,-T $^ -o $@
Jesse Keating 7a32965
+      cmd_vdso32ld = $(CROSS32CC) $(c_flags) -Wl,-T $^ -o $@ \
Jesse Keating 7a32965
+		     $(if $(AFTER_LINK),; $(AFTER_LINK))
Jesse Keating 7a32965
 quiet_cmd_vdso32as = VDSO32A $@
Jesse Keating 7a32965
       cmd_vdso32as = $(CROSS32CC) $(a_flags) -c -o $@ $<
Jesse Keating 7a32965
 
Jesse Keating 7a32965
diff --git a/arch/powerpc/kernel/vdso64/Makefile b/arch/powerpc/kernel/vdso64/Makefile
be64ba5
index 8c500d8..d27737b 100644
Jesse Keating 7a32965
--- a/arch/powerpc/kernel/vdso64/Makefile
Jesse Keating 7a32965
+++ b/arch/powerpc/kernel/vdso64/Makefile
Jesse Keating 7a32965
@@ -36,7 +36,8 @@ $(obj-vdso64): %.o: %.S
Jesse Keating 7a32965
 
Jesse Keating 7a32965
 # actual build commands
Jesse Keating 7a32965
 quiet_cmd_vdso64ld = VDSO64L $@
Jesse Keating 7a32965
-      cmd_vdso64ld = $(CC) $(c_flags) -Wl,-T $^ -o $@
Jesse Keating 7a32965
+      cmd_vdso64ld = $(CC) $(c_flags) -Wl,-T $^ -o $@ \
Jesse Keating 7a32965
+		     $(if $(AFTER_LINK),; $(AFTER_LINK))
Jesse Keating 7a32965
 quiet_cmd_vdso64as = VDSO64A $@
Jesse Keating 7a32965
       cmd_vdso64as = $(CC) $(a_flags) -c -o $@ $<
Jesse Keating 7a32965
 
Kyle McMartin 9e0d2f6
diff --git a/arch/s390/kernel/vdso32/Makefile b/arch/s390/kernel/vdso32/Makefile
be64ba5
index 8ad2b34..e153572 100644
Kyle McMartin 9e0d2f6
--- a/arch/s390/kernel/vdso32/Makefile
Kyle McMartin 9e0d2f6
+++ b/arch/s390/kernel/vdso32/Makefile
be64ba5
@@ -43,7 +43,8 @@ $(obj-vdso32): %.o: %.S
Kyle McMartin 9e0d2f6
 
Kyle McMartin 9e0d2f6
 # actual build commands
Kyle McMartin 9e0d2f6
 quiet_cmd_vdso32ld = VDSO32L $@
Kyle McMartin 9e0d2f6
-      cmd_vdso32ld = $(CC) $(c_flags) -Wl,-T $^ -o $@
Kyle McMartin 9e0d2f6
+      cmd_vdso32ld = $(CC) $(c_flags) -Wl,-T $^ -o $@ \
Kyle McMartin 9e0d2f6
+		     $(if $(AFTER_LINK),; $(AFTER_LINK))
Kyle McMartin 9e0d2f6
 quiet_cmd_vdso32as = VDSO32A $@
Kyle McMartin 9e0d2f6
       cmd_vdso32as = $(CC) $(a_flags) -c -o $@ $<
Kyle McMartin 9e0d2f6
 
Kyle McMartin 9e0d2f6
diff --git a/arch/s390/kernel/vdso64/Makefile b/arch/s390/kernel/vdso64/Makefile
be64ba5
index 2a8ddfd..452ca53 100644
Kyle McMartin 9e0d2f6
--- a/arch/s390/kernel/vdso64/Makefile
Kyle McMartin 9e0d2f6
+++ b/arch/s390/kernel/vdso64/Makefile
be64ba5
@@ -43,7 +43,8 @@ $(obj-vdso64): %.o: %.S
Kyle McMartin 9e0d2f6
 
Kyle McMartin 9e0d2f6
 # actual build commands
Kyle McMartin 9e0d2f6
 quiet_cmd_vdso64ld = VDSO64L $@
Kyle McMartin 9e0d2f6
-      cmd_vdso64ld = $(CC) $(c_flags) -Wl,-T $^ -o $@
Kyle McMartin 9e0d2f6
+      cmd_vdso64ld = $(CC) $(c_flags) -Wl,-T $^ -o $@ \
Kyle McMartin 9e0d2f6
+		     $(if $(AFTER_LINK),; $(AFTER_LINK))
Kyle McMartin 9e0d2f6
 quiet_cmd_vdso64as = VDSO64A $@
Kyle McMartin 9e0d2f6
       cmd_vdso64as = $(CC) $(a_flags) -c -o $@ $<
Kyle McMartin 9e0d2f6
 
be64ba5
diff --git a/arch/x86/vdso/Makefile b/arch/x86/vdso/Makefile
be64ba5
index fd14be1..1f3eb19 100644
be64ba5
--- a/arch/x86/vdso/Makefile
be64ba5
+++ b/arch/x86/vdso/Makefile
be64ba5
@@ -178,8 +178,9 @@ $(obj)/vdso32-syms.lds: $(vdso32.so-y:%=$(obj)/vdso32-%-syms.lds) FORCE
be64ba5
 quiet_cmd_vdso = VDSO    $@
be64ba5
       cmd_vdso = $(CC) -nostdlib -o $@ \
be64ba5
 		       $(VDSO_LDFLAGS) $(VDSO_LDFLAGS_$(filter %.lds,$(^F))) \
be64ba5
-		       -Wl,-T,$(filter %.lds,$^) $(filter %.o,$^) && \
be64ba5
-		 sh $(srctree)/$(src)/checkundef.sh '$(NM)' '$@'
be64ba5
+		       -Wl,-T,$(filter %.lds,$^) $(filter %.o,$^) \
be64ba5
+		$(if $(AFTER_LINK),; $(AFTER_LINK)) && \
be64ba5
+		sh $(srctree)/$(src)/checkundef.sh '$(NM)' '$@'
be64ba5
 
be64ba5
 VDSO_LDFLAGS = -fPIC -shared $(call cc-ldoption, -Wl$(comma)--hash-style=sysv)
be64ba5
 GCOV_PROFILE := n
be64ba5
diff --git a/scripts/link-vmlinux.sh b/scripts/link-vmlinux.sh
be64ba5
index cd9c6c6..3edf048 100644
be64ba5
--- a/scripts/link-vmlinux.sh
be64ba5
+++ b/scripts/link-vmlinux.sh
be64ba5
@@ -65,6 +65,10 @@ vmlinux_link()
be64ba5
 			-lutil ${1}
be64ba5
 		rm -f linux
be64ba5
 	fi
be64ba5
+	if [ -n "${AFTER_LINK}" ]; then
be64ba5
+		/usr/lib/rpm/debugedit -b ${RPM_BUILD_DIR} -d /usr/src/debug -i ${2} \
be64ba5
+			> ${2}.id
be64ba5
+	fi
be64ba5
 }
be64ba5
 
be64ba5
 
be64ba5
-- 
be64ba5
1.7.7.6
be64ba5