Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752194AbbEZJNj (ORCPT ); Tue, 26 May 2015 05:13:39 -0400 Received: from cantor2.suse.de ([195.135.220.15]:48632 "EHLO mx2.suse.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752149AbbEZJNh (ORCPT ); Tue, 26 May 2015 05:13:37 -0400 Message-ID: <5564393C.1090104@suse.cz> Date: Tue, 26 May 2015 11:13:32 +0200 From: =?UTF-8?B?TWFydGluIExpxaFrYQ==?= User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:31.0) Gecko/20100101 Thunderbird/31.6.0 MIME-Version: 1.0 To: Ingo Molnar , Arnaldo Carvalho de Melo CC: linux-kernel@vger.kernel.org, Ingo Molnar , Paul Mackerras , Peter Zijlstra Subject: Re: [PATCH] perf: fix wrong DEBUG configuration References: <20150520145506.GA15679@gmail.com> <555CB373.7090007@suse.cz> <20150521150536.GB13933@kernel.org> <20150522070250.GA30715@gmail.com> <5562D788.9000201@suse.cz> <20150525104708.GB30252@gmail.com> <556301D3.5040100@suse.cz> <20150525110912.GA4236@gmail.com> <556303AC.4080909@suse.cz> <20150525135238.GE17970@kernel.org> <20150525183246.GA21153@gmail.com> In-Reply-To: <20150525183246.GA21153@gmail.com> Content-Type: multipart/mixed; boundary="------------010708020306050309010601" Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 5761 Lines: 193 This is a multi-part message in MIME format. --------------010708020306050309010601 Content-Type: text/plain; charset=utf-8; format=flowed Content-Transfer-Encoding: 8bit On 05/25/2015 08:32 PM, Ingo Molnar wrote: > > * Arnaldo Carvalho de Melo wrote: > >> Em Mon, May 25, 2015 at 01:12:44PM +0200, Martin Liška escreveu: >>> On 05/25/2015 01:09 PM, Ingo Molnar wrote: >>>> >>>> * Martin Liška wrote: >>>> >>>>>>> Right optimize debugging experience is given by passing -Og to >>>>>>> compiler. Assign default value for pointers that are identified by >>>>>>> compiler as non-initialized. >>>>>> >>>>>> s/Right optimize debugging experience is given/ >>>>>> Correct debugging experience is given/ >>>> >>>>> Right debugging experience is given by passing -Og to compiler. >>>> >>>> So I fixed the spelling here once already :-/ If you want to use >>>> 'right' in this context then use it like this: >>>> >>>> The right debugging experience is given by ... >>>> >>>> Or you can use what I suggested first: >>>> >>>> Correct debugging experience is given by ... >>>> >>>> Thanks, >>>> >>>> Ingo >>>> >>> >>> Sorry Ingo for that, I overlooked that correction :) >> >> Are you ok with this Ingo? > > Yeah, certainly! > >> I can apply, but there seems to be two patches folded here, one that >> sets the possibly unitiliazed variables to NULL, and could be the >> first in the series, and the other, that deals with multiple >> versions of gcc and how should we ask something from them. > > Yeah. > > Thanks, > > Ingo > Hello. As Arnaldo pointed, I split the patch to following 2 smaller patches. Thanks, Martin --------------010708020306050309010601 Content-Type: text/x-patch; name="0001-perf-Fix-compiler-warnings.patch" Content-Transfer-Encoding: 7bit Content-Disposition: attachment; filename="0001-perf-Fix-compiler-warnings.patch" Assign default value for pointers that are identified by the compiler as non-initialized. Signed-off-by: Martin Liska Acked-by: Ingo Molnar --- tools/perf/arch/common.c | 2 +- tools/perf/util/symbol.c | 2 +- tools/perf/util/trace-event-parse.c | 2 +- 3 files changed, 3 insertions(+), 3 deletions(-) diff --git a/tools/perf/arch/common.c b/tools/perf/arch/common.c index 49776f1..b7bb42c 100644 --- a/tools/perf/arch/common.c +++ b/tools/perf/arch/common.c @@ -61,7 +61,7 @@ const char *const mips_triplets[] = { static bool lookup_path(char *name) { bool found = false; - char *path, *tmp; + char *path, *tmp = NULL; char buf[PATH_MAX]; char *env = getenv("PATH"); diff --git a/tools/perf/util/symbol.c b/tools/perf/util/symbol.c index 82a31fd..a19fbd4 100644 --- a/tools/perf/util/symbol.c +++ b/tools/perf/util/symbol.c @@ -400,7 +400,7 @@ static struct symbol *symbols__find_by_name(struct rb_root *symbols, const char *name) { struct rb_node *n; - struct symbol_name_rb_node *s; + struct symbol_name_rb_node *s = NULL; if (symbols == NULL) return NULL; diff --git a/tools/perf/util/trace-event-parse.c b/tools/perf/util/trace-event-parse.c index 25d6c73..d495741 100644 --- a/tools/perf/util/trace-event-parse.c +++ b/tools/perf/util/trace-event-parse.c @@ -173,7 +173,7 @@ void parse_ftrace_printk(struct pevent *pevent, char *line; char *next = NULL; char *addr_str; - char *fmt; + char *fmt = NULL; line = strtok_r(file, "\n", &next); while (line) { -- 2.1.4 --------------010708020306050309010601 Content-Type: text/x-patch; name="0002-perf-fix-wrong-DEBUG-configuration.patch" Content-Transfer-Encoding: 7bit Content-Disposition: attachment; filename="0002-perf-fix-wrong-DEBUG-configuration.patch" Currently, GCC optimizes -O6 same as -O3 level, thus change the value to -O3. Correct debugging experience is given by passing -Og to compiler. Signed-off-by: Martin Liska Acked-by: Ingo Molnar --- tools/perf/config/Makefile | 4 +++- tools/perf/config/utilities.mak | 19 +++++++++++++++++++ 2 files changed, 22 insertions(+), 1 deletion(-) diff --git a/tools/perf/config/Makefile b/tools/perf/config/Makefile index e3b3724..47e4ae1 100644 --- a/tools/perf/config/Makefile +++ b/tools/perf/config/Makefile @@ -129,7 +129,9 @@ ifndef DEBUG endif ifeq ($(DEBUG),0) - CFLAGS += -O6 + CFLAGS += -O3 +else + CFLAGS += $(call cc-option,-Og,-O0) endif ifdef PARSER_DEBUG diff --git a/tools/perf/config/utilities.mak b/tools/perf/config/utilities.mak index c16ce83..0ebef09 100644 --- a/tools/perf/config/utilities.mak +++ b/tools/perf/config/utilities.mak @@ -177,3 +177,22 @@ $(if $($(1)),$(call _ge_attempt,$($(1)),$(1)),$(call _ge_attempt,$(2))) endef _ge_attempt = $(if $(get-executable),$(get-executable),$(call _gea_err,$(2))) _gea_err = $(if $(1),$(error Please set '$(1)' appropriately)) + +# try-run +# Usage: option = $(call try-run, $(CC)...-o "$$TMP",option-ok,otherwise) +# Exit code chooses option. "$$TMP" is can be used as temporary file and +# is automatically cleaned up. +try-run = $(shell set -e; \ + TMP="$(TMPOUT).$$$$.tmp"; \ + TMPO="$(TMPOUT).$$$$.o"; \ + if ($(1)) >/dev/null 2>&1; \ + then echo "$(2)"; \ + else echo "$(3)"; \ + fi; \ + rm -f "$$TMP" "$$TMPO") + +# cc-option +# Usage: cflags-y += $(call cc-option,-march=winchip-c6,-march=i586) + +cc-option = $(call try-run,\ + $(CC) $(KBUILD_CPPFLAGS) $(KBUILD_CFLAGS) $(1) -c -x c /dev/null -o "$$TMP",$(1),$(2)) -- 2.1.4 --------------010708020306050309010601-- -- 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/