From 2a84d30e55502c01c27fa176e3e09c09c59361d7 Mon Sep 17 00:00:00 2001 From: Naohiro Aota Date: Sun, 16 Aug 2015 22:22:46 +0900 Subject: [PATCH] dev-util/perf: fix install dir perf binary and libs are accidentaly installed under / not /usr. Add a patch to fix "prefix=" behavior and reuse prefix argument. --- dev-util/perf/files/perf-4.1.5-prefix.patch | 43 +++++++++++++++++++ ...perf-4.1.5.ebuild => perf-4.1.5-r1.ebuild} | 4 +- 2 files changed, 46 insertions(+), 1 deletion(-) create mode 100644 dev-util/perf/files/perf-4.1.5-prefix.patch rename dev-util/perf/{perf-4.1.5.ebuild => perf-4.1.5-r1.ebuild} (98%) diff --git a/dev-util/perf/files/perf-4.1.5-prefix.patch b/dev-util/perf/files/perf-4.1.5-prefix.patch new file mode 100644 index 000000000000..0c4dff011306 --- /dev/null +++ b/dev-util/perf/files/perf-4.1.5-prefix.patch @@ -0,0 +1,43 @@ +commit 75e84ab906ef8935cff3df3d8929f1bafea81599 +Author: Lukas Wunner +Date: Thu Jun 18 13:00:32 2015 +0200 + + perf tools: Fix build breakage if prefix= is specified + + Invoking Makefile.perf with prefix= breaks the build since Makefile.perf + hands that variable down to Makefile.build where it overrides + + prefix := $(subst ./,,$(OUTPUT)$(dir)/) + + leading to errors like this: + + No rule to make target '/usrabspath.o', needed by '/usrlibperf-in.o' + + Signed-off-by: Lukas Wunner + Acked-by: Jiri Olsa + Cc: David Ahern + Fixes: c819e2cf2eb6f65d3208d195d7a0edef6108d5 + Link: http://lkml.kernel.org/r/5582c48a.84a22b0a.a918.5285SMTPIN_ADDED_MISSING@mx.google.com + Signed-off-by: Arnaldo Carvalho de Melo + +diff --git a/tools/build/Makefile.build b/tools/build/Makefile.build +index 10df572..98cfc38 100644 +--- a/tools/build/Makefile.build ++++ b/tools/build/Makefile.build +@@ -94,12 +94,12 @@ obj-y := $(patsubst %/, %/$(obj)-in.o, $(obj-y)) + subdir-obj-y := $(filter %/$(obj)-in.o, $(obj-y)) + + # '$(OUTPUT)/dir' prefix to all objects +-prefix := $(subst ./,,$(OUTPUT)$(dir)/) +-obj-y := $(addprefix $(prefix),$(obj-y)) +-subdir-obj-y := $(addprefix $(prefix),$(subdir-obj-y)) ++objprefix := $(subst ./,,$(OUTPUT)$(dir)/) ++obj-y := $(addprefix $(objprefix),$(obj-y)) ++subdir-obj-y := $(addprefix $(objprefix),$(subdir-obj-y)) + + # Final '$(obj)-in.o' object +-in-target := $(prefix)$(obj)-in.o ++in-target := $(objprefix)$(obj)-in.o + + PHONY += $(subdir-y) + diff --git a/dev-util/perf/perf-4.1.5.ebuild b/dev-util/perf/perf-4.1.5-r1.ebuild similarity index 98% rename from dev-util/perf/perf-4.1.5.ebuild rename to dev-util/perf/perf-4.1.5-r1.ebuild index b49b73f63653..1323e675b275 100644 --- a/dev-util/perf/perf-4.1.5.ebuild +++ b/dev-util/perf/perf-4.1.5-r1.ebuild @@ -107,6 +107,8 @@ src_prepare() { epatch "${WORKDIR}"/${P}.patch fi + epatch "${FILESDIR}"/${P}-prefix.patch + # Drop some upstream too-developer-oriented flags and fix the # Makefile in general sed -i \ @@ -140,10 +142,10 @@ perf_make() { # but it also wants to know about the split value -- i386/x86_64 vs just # x86. We can get that by telling the func to use an older linux version. # It's kind of a hack, but not that bad ... - # prefix="/usr" bindir_relative="bin" \ local arch=$(tc-arch-kernel) emake V=1 \ CC="$(tc-getCC)" AR="$(tc-getAR)" \ + prefix="/usr" bindir_relative="bin" \ CFLAGS_OPTIMIZE="${CFLAGS}" \ LDFLAGS_OPTIMIZE="${LDFLAGS}" \ ARCH="${arch}" \ -- 2.26.2