Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1755513Ab0F1Ben (ORCPT ); Sun, 27 Jun 2010 21:34:43 -0400 Received: from mail9.hitachi.co.jp ([133.145.228.44]:40593 "EHLO mail9.hitachi.co.jp" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752162Ab0F1Bek (ORCPT ); Sun, 27 Jun 2010 21:34:40 -0400 X-AuditID: b753bd60-a743eba000006d9b-50-4c27fc2e4209 Message-ID: <4C27FC2A.50909@hitachi.com> Date: Mon, 28 Jun 2010 10:34:34 +0900 From: Masami Hiramatsu Organization: Systems Development Lab., Hitachi, Ltd., Japan User-Agent: Thunderbird 2.0.0.24 (Windows/20100228) MIME-Version: 1.0 To: Jamie Iles Cc: linux-kernel@vger.kernel.org, Peter Zijlstra Subject: Re: [PATCH] perf tools: allow cross compiling with DWARF support References: <1277462318-6516-1-git-send-email-jamie.iles@picochip.com> <4C249027.1060304@hitachi.com> <20100625114150.GE4510@wear.picochip.com> <4C249B16.2090209@hitachi.com> <4C24B03B.8090504@picochip.com> In-Reply-To: <4C24B03B.8090504@picochip.com> Content-Type: text/plain; charset=ISO-8859-1 Content-Transfer-Encoding: 7bit X-Brightmail-Tracker: AAAAAA== X-FMFTCR: RANGEC Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 3984 Lines: 97 Jamie Iles wrote: > On 06/25/2010 01:03 PM, Masami Hiramatsu wrote: >> Jamie Iles wrote: >>> On Fri, Jun 25, 2010 at 08:16:55PM +0900, Masami Hiramatsu wrote: >>>> Jamie Iles wrote: >>>>> The path to elfutils was previously hardcoded as /usr/include/elfutils >>>>> which does not work with cross compilers. If CROSS_COMPILE is set, try >>>>> to set an include path from GCC's sysroot if GCC was built with sysroot >>>>> support, if sysroot support isn't enabled, don't specify a path for >>>>> elfutils allowing the user to set it with EXTRA_CFLAGS. > [...] >> It seems that $ELFUTILS_INCLUDE become "" without sysroot support. >> In that case, I guess that user have to set the elfutils header >> path to EXTRA_CFLAGS and, make will just show "No libdw.h found >> or old libdw.h found ..." message. (I just guess, not so familier >> with cross compile...) >> >> So, I just like to suggest adding a message like as; >> "No sysroot support. Please set elfutils include path in EXTRA_CFLAGS." >> Doesn't it make easier to find a problem? >> >> Other parts are OK for me. > > Ok, how about this revised patch? > > From: Jamie Iles > Date: Fri, 25 Jun 2010 13:59:44 +0100 > Subject: [PATCHv2] perf tools: allow cross compiling with DWARF support > > The path to elfutils was previously hardcoded as /usr/include/elfutils > which does not work with cross compilers. If CROSS_COMPILE is set, try > to set an include path from GCC's sysroot if GCC was built with sysroot > support, if sysroot support isn't enabled, don't specify a path for > elfutils allowing the user to set it with EXTRA_CFLAGS. > > v2: if we can't find libdw.h and there is no sysroot support but it > would be useful, warn the user. Nice! Looks good to me. :) Acked-by: Masami Hiramatsu Thanks! > > Signed-off-by: Jamie Iles > Cc: Masami Hiramatsu > Cc: Peter Zijlstra > --- > tools/perf/Makefile | 19 +++++++++++++++++-- > 1 files changed, 17 insertions(+), 2 deletions(-) > > diff --git a/tools/perf/Makefile b/tools/perf/Makefile > index 6aa2fe3..1c08b7b 100644 > --- a/tools/perf/Makefile > +++ b/tools/perf/Makefile > @@ -503,9 +503,24 @@ PERFLIBS = $(LIB_FILE) > -include config.mak.autogen > -include config.mak > > +ifndef CROSS_COMPILE > + ELFUTILS_INCLUDE = -I/usr/include/elfutils > +else > + # See if the compiler has been built with sysroot support > + SYSROOT_PATH = $(shell $(CC) -print-sysroot 2> /dev/null || echo "") > + ifneq ($(SYSROOT_PATH),) > + ELFUTILS_INCLUDE := -I$(SYSROOT_PATH)/usr/include/elfutils > + else > + NO_SYSROOT := y > + endif > +endif > + > ifndef NO_DWARF > -FLAGS_DWARF=$(ALL_CFLAGS) -I/usr/include/elfutils -ldw -lelf $(ALL_LDFLAGS) $(EXTLIBS) > +FLAGS_DWARF=$(ALL_CFLAGS) $(ELFUTILS_INCLUDE) -ldw -lelf $(ALL_LDFLAGS) $(EXTLIBS) > ifneq ($(call try-cc,$(SOURCE_DWARF),$(FLAGS_DWARF)),y) > + ifdef NO_SYSROOT > + msg := $(warning No sysroot support. Set elfutils include path in EXTRA_CFLAGS for dwarf support) > + endif > msg := $(warning No libdw.h found or old libdw.h found or elfutils is older than 0.138, disables dwarf support. Please install new elfutils-devel/libdw-dev); > NO_DWARF := 1 > endif # Dwarf support > @@ -551,7 +566,7 @@ ifndef NO_DWARF > ifeq ($(origin PERF_HAVE_DWARF_REGS), undefined) > msg := $(warning DWARF register mappings have not been defined for architecture $(ARCH), DWARF support disabled); > else > - BASIC_CFLAGS += -I/usr/include/elfutils -DDWARF_SUPPORT > + BASIC_CFLAGS += $(ELFUTILS_INCLUDE) -DDWARF_SUPPORT > EXTLIBS += -lelf -ldw > LIB_OBJS += $(OUTPUT)util/probe-finder.o > endif # PERF_HAVE_DWARF_REGS -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/