Received: by 2002:a05:6a10:8c0a:0:0:0:0 with SMTP id go10csp3454234pxb; Fri, 12 Feb 2021 21:07:06 -0800 (PST) X-Google-Smtp-Source: ABdhPJzylQxPgSygW37gIEFme14MdwhjIf6LILMo1zfRn4YXcpvEPRwLkaqHqXFJz7iegcZYsz5N X-Received: by 2002:aa7:db47:: with SMTP id n7mr5315067edt.237.1613192825830; Fri, 12 Feb 2021 21:07:05 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1613192825; cv=none; d=google.com; s=arc-20160816; b=JcexAYfZJybhv2Ywysrxyjl/U1OvRrvhgpVqENs+hYIZ36qaIqiAW2bmYPIxfgO41o 40Qc1X1P454iQ+EWLmGtMaBeTWraJZKMIy+yOZQPWHrRY6+SovZBPHc0z4CgkiPf7kf5 KELeQ+ZpFUVYT0NDJZ7Cv9VLLXO1b5CmJwj9W8PSVszjYId6r5EzerswUZ6r0oA701y8 XjKa8dACgKWETC0aeP12wh+jO8TYE7S0+JYsHJVD53ISZkmm8oA7vGKkPMrsBmBms6fU lMlQA/zYi9JxaWqjo32KVJo7QHUNi7MIlPLF+Lz3ie6E4suWCLV7jhBt5eVy1LDSYOlt pLDQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :message-id:date:subject:cc:to:from; bh=ruvYFIln8vIFjBZcm7h2DuzUkMNwul9n4MS57IesHYg=; b=oAVkjWpC9Rp4PIBkFYvhYnLl4xkwvFoYtb0jr/lZOgJ7e0BoM2Ak2QaUkj4OVKiCZh tTdfBVadXQfnjG+ns9rewIhtRqFilbWvSWF6M2+42GffVL2uSCIUjE0bXRa/BhZYB4/d 3T6qynhbaDvHyLOJ3Ku7oPJEAWBNsNoNw9jBO0u4ob/F20SqXJF8oIbnGH9ZtSm0u7gd FTTvQAh70OYnRe6sf2t3zYsOpcgWYPnUkiBcYi1Ab1RUPelT9bd9TkjSSmCdUr9J21Xs 31xzKZpJG5bFLDcwNsKKg3ipzsasqBnyO5WeEDjLahkI3byDulHATVIoaH0UG3XX6OMu OsrQ== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=arm.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id gz19si7919683ejb.645.2021.02.12.21.06.41; Fri, 12 Feb 2021 21:07:05 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=arm.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229796AbhBMFGQ (ORCPT + 99 others); Sat, 13 Feb 2021 00:06:16 -0500 Received: from foss.arm.com ([217.140.110.172]:45716 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229648AbhBMFGO (ORCPT ); Sat, 13 Feb 2021 00:06:14 -0500 Received: from usa-sjc-imap-foss1.foss.arm.com (unknown [10.121.207.14]) by usa-sjc-mx-foss1.foss.arm.com (Postfix) with ESMTP id 0587A113E; Fri, 12 Feb 2021 21:05:28 -0800 (PST) Received: from net-arm-thunderx2-02.shanghai.arm.com (net-arm-thunderx2-02.shanghai.arm.com [10.169.208.215]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPA id A02113F73D; Fri, 12 Feb 2021 21:05:22 -0800 (PST) From: Jianlin Lv To: john.garry@huawei.com, will@kernel.org, mathieu.poirier@linaro.org, leo.yan@linaro.org, peterz@infradead.org, mingo@redhat.com, acme@kernel.org, mark.rutland@arm.com, alexander.shishkin@linux.intel.com, jolsa@redhat.com, namhyung@kernel.org, irogers@google.com, agerstmayr@redhat.com, kan.liang@linux.intel.com, adrian.hunter@intel.com Cc: Jianlin.Lv@arm.com, iecedge@gmail.com, linux-kernel@vger.kernel.org Subject: [PATCH v3] perf tools: Fix arm64 build error with gcc-11 Date: Sat, 13 Feb 2021 13:05:16 +0800 Message-Id: <20210213050516.1221523-1-Jianlin.Lv@arm.com> X-Mailer: git-send-email 2.25.1 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org gcc version: 11.0.0 20210208 (experimental) (GCC) Following build error on arm64: ....... In function ‘printf’, inlined from ‘regs_dump__printf’ at util/session.c:1141:3, inlined from ‘regs__printf’ at util/session.c:1169:2: /usr/include/aarch64-linux-gnu/bits/stdio2.h:107:10: \ error: ‘%-5s’ directive argument is null [-Werror=format-overflow=] 107 | return __printf_chk (__USE_FORTIFY_LEVEL - 1, __fmt, \ __va_arg_pack ()); ...... In function ‘fprintf’, inlined from ‘perf_sample__fprintf_regs.isra’ at \ builtin-script.c:622:14: /usr/include/aarch64-linux-gnu/bits/stdio2.h:100:10: \ error: ‘%5s’ directive argument is null [-Werror=format-overflow=] 100 | return __fprintf_chk (__stream, __USE_FORTIFY_LEVEL - 1, __fmt, 101 | __va_arg_pack ()); cc1: all warnings being treated as errors ....... This patch fixes Wformat-overflow warnings. Add ternary operator, The statement evaluates to "Unknown" if reg_name==NULL is met. Signed-off-by: Jianlin Lv --- v2: Add ternary operator to avoid similar errors in other arch. v3: Declared reg_name in inner block. --- tools/perf/builtin-script.c | 4 +++- tools/perf/util/scripting-engines/trace-event-python.c | 3 ++- tools/perf/util/session.c | 3 ++- 3 files changed, 7 insertions(+), 3 deletions(-) diff --git a/tools/perf/builtin-script.c b/tools/perf/builtin-script.c index 42dad4a0f8cf..0d52dc45b1c7 100644 --- a/tools/perf/builtin-script.c +++ b/tools/perf/builtin-script.c @@ -643,7 +643,9 @@ static int perf_sample__fprintf_regs(struct regs_dump *regs, uint64_t mask, for_each_set_bit(r, (unsigned long *) &mask, sizeof(mask) * 8) { u64 val = regs->regs[i++]; - printed += fprintf(fp, "%5s:0x%"PRIx64" ", perf_reg_name(r), val); + const char *reg_name = perf_reg_name(r); + + printed += fprintf(fp, "%5s:0x%"PRIx64" ", reg_name ?: "unknown", val); } return printed; diff --git a/tools/perf/util/scripting-engines/trace-event-python.c b/tools/perf/util/scripting-engines/trace-event-python.c index c83c2c6564e0..768bdd4240f4 100644 --- a/tools/perf/util/scripting-engines/trace-event-python.c +++ b/tools/perf/util/scripting-engines/trace-event-python.c @@ -699,10 +699,11 @@ static int regs_map(struct regs_dump *regs, uint64_t mask, char *bf, int size) for_each_set_bit(r, (unsigned long *) &mask, sizeof(mask) * 8) { u64 val = regs->regs[i++]; + const char *reg_name = perf_reg_name(r); printed += scnprintf(bf + printed, size - printed, "%5s:0x%" PRIx64 " ", - perf_reg_name(r), val); + reg_name ?: "unknown", val); } return printed; diff --git a/tools/perf/util/session.c b/tools/perf/util/session.c index 25adbcce0281..2b40f1c431a3 100644 --- a/tools/perf/util/session.c +++ b/tools/perf/util/session.c @@ -1138,9 +1138,10 @@ static void regs_dump__printf(u64 mask, u64 *regs) for_each_set_bit(rid, (unsigned long *) &mask, sizeof(mask) * 8) { u64 val = regs[i++]; + const char *reg_name = perf_reg_name(rid); printf(".... %-5s 0x%016" PRIx64 "\n", - perf_reg_name(rid), val); + reg_name ?: "unknown", val); } } -- 2.25.1