Received: by 2002:a25:1506:0:0:0:0:0 with SMTP id 6csp1749768ybv; Fri, 14 Feb 2020 05:24:56 -0800 (PST) X-Google-Smtp-Source: APXvYqxvJQ90G0tBzfHcgEhgfdDL2HR05dw1OMOwOu8YzuIst3flmpfNzVX65A66ZMP8VqVUum/i X-Received: by 2002:a05:6808:30d:: with SMTP id i13mr1755907oie.144.1581686696397; Fri, 14 Feb 2020 05:24:56 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1581686696; cv=none; d=google.com; s=arc-20160816; b=DN+qJP6k34ip97e4XPTrI0aDJNapZ7Af+LHunYFAOIClaioaeJPWVIriJuN/TXx+ng T1GI8+hReFtGzhMRA5BIiOhP40t11cJs6M9qQ4rc5VFHbrO9yeB1GfRsfE/SMtIUbPO0 K6V4pMlU33c9k3sfROutDx8Z3JfK+s4ZPCwjSAHkE+eJmofMBfw3efbQXcWIBR8xDuOg WoPHW/Ph3IcE6yAAUyxKfzveLKj8vf/jfJRvSYVYwjyCNxyoUqMIwhMfyVgbgO/KqgWv yRWSyvBjTOBPlNeXgzGxYUlQwJk2Go8StB8Sswz7L8aNrG5p0BHJHrSIj+OCSTlOBHof 8fJw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :message-id:date:subject:to:from; bh=MJCCh9y+YREzSXJGVAw0ysKy22VCG/1CR1N2iQKJRJg=; b=RO0ImmbJ2A4YdFZN5Ka/P+UAcGJ8c2O5r0j8rmYhFsIpGGMyukXgeUVCVtsHvXM5V9 Y+GgzBFFRNcCcGNbF3XIPrxy1U0gwD+Prm57b2fY/VfsEmn0vDrEsF3JYR0HEDmV5H7p Xe60XFNbmDK6cvXo3RbEj4EUQjQhMJTF25rpUT3vGG1xMAIPGaLI6yAjEhjj0Qj3UGjs L0O0KVRX9YP4u59PeVDcfJJMszz/ByvWSOhOl2vNL64YqITyhRLJj+M4wef0rBBSFPNf 4GO3h3n8qjpsKn2JhnJVaK70rdOcxVhYbkc4Crf/cdOOs2Aey6hgxnzIO652HEW5b/XC RSNQ== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id e6si2743234otq.217.2020.02.14.05.24.43; Fri, 14 Feb 2020 05:24:56 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2387398AbgBNNXm (ORCPT + 99 others); Fri, 14 Feb 2020 08:23:42 -0500 Received: from mail5.windriver.com ([192.103.53.11]:34496 "EHLO mail5.wrs.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726191AbgBNNXl (ORCPT ); Fri, 14 Feb 2020 08:23:41 -0500 Received: from ALA-HCA.corp.ad.wrs.com (ala-hca.corp.ad.wrs.com [147.11.189.40]) by mail5.wrs.com (8.15.2/8.15.2) with ESMTPS id 01EDLYvu021307 (version=TLSv1 cipher=AES256-SHA bits=256 verify=FAIL); Fri, 14 Feb 2020 05:21:45 -0800 Received: from pek-lpg-core2.corp.ad.wrs.com (128.224.153.41) by ALA-HCA.corp.ad.wrs.com (147.11.189.40) with Microsoft SMTP Server id 14.3.468.0; Fri, 14 Feb 2020 05:21:24 -0800 From: To: , , , , , Subject: [PATCH v2] tools lib traceevent: Take care of return value of asprintf Date: Fri, 14 Feb 2020 21:21:21 +0800 Message-ID: <1581686481-180476-1-git-send-email-zhe.he@windriver.com> X-Mailer: git-send-email 2.7.4 MIME-Version: 1.0 Content-Type: text/plain; charset="UTF-8" Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: He Zhe According to the API, if memory allocation wasn't possible, or some other error occurs, asprintf will return -1, and the contents of strp below are undefined. int asprintf(char **strp, const char *fmt, ...); This patch takes care of return value of asprintf to make it less error prone and prevent the following build warning. ignoring return value of ‘asprintf’, declared with attribute warn_unused_result [-Wunused-result] Signed-off-by: He Zhe --- v2: directly check the return value without saving to a variable tools/lib/traceevent/parse-filter.c | 35 +++++++++++++++++++++-------------- 1 file changed, 21 insertions(+), 14 deletions(-) diff --git a/tools/lib/traceevent/parse-filter.c b/tools/lib/traceevent/parse-filter.c index 20eed71..6cd0228 100644 --- a/tools/lib/traceevent/parse-filter.c +++ b/tools/lib/traceevent/parse-filter.c @@ -274,8 +274,7 @@ find_event(struct tep_handle *tep, struct event_list **events, sys_name = NULL; } - ret = asprintf(®, "^%s$", event_name); - if (ret < 0) + if (asprintf(®, "^%s$", event_name) < 0) return TEP_ERRNO__MEM_ALLOC_FAILED; ret = regcomp(&ereg, reg, REG_ICASE|REG_NOSUB); @@ -285,8 +284,7 @@ find_event(struct tep_handle *tep, struct event_list **events, return TEP_ERRNO__INVALID_EVENT_NAME; if (sys_name) { - ret = asprintf(®, "^%s$", sys_name); - if (ret < 0) { + if (asprintf(®, "^%s$", sys_name) < 0) { regfree(&ereg); return TEP_ERRNO__MEM_ALLOC_FAILED; } @@ -1958,7 +1956,8 @@ static char *op_to_str(struct tep_event_filter *filter, struct tep_filter_arg *a default: break; } - asprintf(&str, val ? "TRUE" : "FALSE"); + if (asprintf(&str, val ? "TRUE" : "FALSE") < 0) + str = NULL; break; } } @@ -1976,7 +1975,8 @@ static char *op_to_str(struct tep_event_filter *filter, struct tep_filter_arg *a break; } - asprintf(&str, "(%s) %s (%s)", left, op, right); + if (asprintf(&str, "(%s) %s (%s)", left, op, right) < 0) + str = NULL; break; case TEP_FILTER_OP_NOT: @@ -1992,10 +1992,12 @@ static char *op_to_str(struct tep_event_filter *filter, struct tep_filter_arg *a right_val = 0; if (right_val >= 0) { /* just return the opposite */ - asprintf(&str, right_val ? "FALSE" : "TRUE"); + if (asprintf(&str, right_val ? "FALSE" : "TRUE") < 0) + str = NULL; break; } - asprintf(&str, "%s(%s)", op, right); + if (asprintf(&str, "%s(%s)", op, right) < 0) + str = NULL; break; default: @@ -2011,7 +2013,8 @@ static char *val_to_str(struct tep_event_filter *filter, struct tep_filter_arg * { char *str = NULL; - asprintf(&str, "%lld", arg->value.val); + if (asprintf(&str, "%lld", arg->value.val) < 0) + str = NULL; return str; } @@ -2069,7 +2072,8 @@ static char *exp_to_str(struct tep_event_filter *filter, struct tep_filter_arg * break; } - asprintf(&str, "%s %s %s", lstr, op, rstr); + if (asprintf(&str, "%s %s %s", lstr, op, rstr) < 0) + str = NULL; out: free(lstr); free(rstr); @@ -2113,7 +2117,8 @@ static char *num_to_str(struct tep_event_filter *filter, struct tep_filter_arg * if (!op) op = "<="; - asprintf(&str, "%s %s %s", lstr, op, rstr); + if (asprintf(&str, "%s %s %s", lstr, op, rstr) < 0) + str = NULL; break; default: @@ -2148,8 +2153,9 @@ static char *str_to_str(struct tep_event_filter *filter, struct tep_filter_arg * if (!op) op = "!~"; - asprintf(&str, "%s %s \"%s\"", - arg->str.field->name, op, arg->str.val); + if (asprintf(&str, "%s %s \"%s\"", + arg->str.field->name, op, arg->str.val) < 0) + str = NULL; break; default: @@ -2165,7 +2171,8 @@ static char *arg_to_str(struct tep_event_filter *filter, struct tep_filter_arg * switch (arg->type) { case TEP_FILTER_ARG_BOOLEAN: - asprintf(&str, arg->boolean.value ? "TRUE" : "FALSE"); + if (asprintf(&str, arg->boolean.value ? "TRUE" : "FALSE") < 0) + str = NULL; return str; case TEP_FILTER_ARG_OP: -- 2.7.4