Received: by 2002:a25:1985:0:0:0:0:0 with SMTP id 127csp1170259ybz; Wed, 22 Apr 2020 15:06:27 -0700 (PDT) X-Google-Smtp-Source: APiQypJJpfweqG8M228awt2bj1EQq4a+Dn3/p5bwn+6ySuYme0QwlpUaA7/wzkH1STq9XNQBKHiS X-Received: by 2002:a17:906:4c46:: with SMTP id d6mr345987ejw.257.1587593186923; Wed, 22 Apr 2020 15:06:26 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1587593186; cv=none; d=google.com; s=arc-20160816; b=T6ugRb7WhwoIMiddrBnaBPYsDSheYYsBkQL/OzrqcekYW8yKI7Fv36fuIIFYIqjnhn VncnboaBeenn9UPZmkh371zyR9hpqBhpwQhwYpowraiPs9YmWxm8oSkNtttYMvKVx4zj mlnqFJMPMsz80No1F6eQ+pvwRb8kDGCqDUqIy/J1AEpdaL2w4cYLM7dZeL2UphJaPey3 MtAhjOb1MmTEq2Esas5qty9pZK7BI6s8xqZBaD8qasSa3gufsImC8E6Ge1nYW239lUEB fiu/CcDgOoujHWbJr3uJyVnp07dvXY4yQK0KQHSss2gQANR8qsedYjN6tlVL0Hp5/xQg kOLg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:cc:to:from:subject:references :mime-version:message-id:in-reply-to:date:dkim-signature; bh=9v/SqbpPNd1vIjcwX2QJUR1yjeQPBkaJciMvLWYLL8Q=; b=SwLtbuwutYVKbMf29mxXY3bsOy4auJnfeS0JH/BGnk4gEdT8iuGEAwn0sGd8silGqs QCrRnsWTMlUX5q596k6fG0giZ5a/YSxD15BaSPOiCM+wU6cJfgKwgBUY+UstoU0oYrz9 EhCmXS1gSNhT4pEPhS/HhtVC6/AmEADmrQS+VMs7TFZ6MBFDhvglgTEj0xXvR70slj0Z nb4E6bgRXNoA8msA4PvPkyBUIdVmbzUzi3EXswkUwajMuHKcBYVx62JZeo8iohhsyPbI VEg+of9QicrPCquD9ICoF9xhiDq2CNL/tqrV7NEjgV0Q5/evXKdHw3gWd5H1eTJ8pK6f uR0w== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@google.com header.s=20161025 header.b=Y9ZDFYaL; 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=pass (p=REJECT sp=REJECT dis=NONE) header.from=google.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id w22si239540edu.568.2020.04.22.15.06.04; Wed, 22 Apr 2020 15:06:26 -0700 (PDT) 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; dkim=pass header.i=@google.com header.s=20161025 header.b=Y9ZDFYaL; 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=pass (p=REJECT sp=REJECT dis=NONE) header.from=google.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726498AbgDVWEx (ORCPT + 99 others); Wed, 22 Apr 2020 18:04:53 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:60070 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726383AbgDVWEu (ORCPT ); Wed, 22 Apr 2020 18:04:50 -0400 Received: from mail-pg1-x54a.google.com (mail-pg1-x54a.google.com [IPv6:2607:f8b0:4864:20::54a]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 70CF7C03C1AA for ; Wed, 22 Apr 2020 15:04:49 -0700 (PDT) Received: by mail-pg1-x54a.google.com with SMTP id q8so2924746pgv.13 for ; Wed, 22 Apr 2020 15:04:49 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=20161025; h=date:in-reply-to:message-id:mime-version:references:subject:from:to :cc; bh=9v/SqbpPNd1vIjcwX2QJUR1yjeQPBkaJciMvLWYLL8Q=; b=Y9ZDFYaLlv/caQHJDJGOLNMlKtvgP/RHif2GdM2dYMRT8BjhpShvSkupnhyS45r2J3 9zJ/8qSGsJ48Wqz9Tj5Vg0XK07NtRJngYBO6zsd2f9ZJ+zmV62O2VN/mK4g6FQP/pnXT ST/bbEMcob/5Jph1u1/2vG3KT1vz9MXIZUzv9YRMFIw7zHbZCjEERljAu8es6/O1d5iD WUG8hwOMbhLhQt7EPQJiUmw6DaYY3s8nvMpmTUYMY3SmvHHLMvIpF+J6QOdMI8mNYmor VpnphvBPMMyYlqEDkV/jbGSQBueu7/R6Ymdi/A93u5v7SLkkEzEel2eS1NYobxharUVl +r3A== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:date:in-reply-to:message-id:mime-version :references:subject:from:to:cc; bh=9v/SqbpPNd1vIjcwX2QJUR1yjeQPBkaJciMvLWYLL8Q=; b=f27c8XvpJkev2wDXmJ3zNKyKxeEsTFOeMXdndLYXr9hBP/BxWw8vxsLpek0fTaXijz 3yFhOuXLBtCmeiG3ZVihgsRukF5E/uDRM4BV6cepSxwF6pKbyiRViloPauzqs/isyZa0 IdmNdEa9NMo1DsCrh9epOEc3O+xmt1LTFGllHGK3QpoCX2OIWu6VX+JFRDVCKZ+tokbe toZnt+YraBgBovjnXdMfByf933LYbdOlx3l4u5FtV6l8eaqqtgO/bZw+eZxsXbD0ifB6 KsC/5P2lN50w5Oup7om86TA/LwJaHrTvgP1SzWOEhAbD1V7PPt6jgNiassDgQoAhoIu5 CRrw== X-Gm-Message-State: AGi0PuZGFz9/vgknQf4+SaGE+4z6s3SqDYaAM48m4NjA3cwo9DNTQkKT TGrhpBs836SL82CMCaHjPtisfA+JEk4d X-Received: by 2002:a63:4f0a:: with SMTP id d10mr1135904pgb.146.1587593088624; Wed, 22 Apr 2020 15:04:48 -0700 (PDT) Date: Wed, 22 Apr 2020 15:04:25 -0700 In-Reply-To: <20200422220430.254014-1-irogers@google.com> Message-Id: <20200422220430.254014-7-irogers@google.com> Mime-Version: 1.0 References: <20200422220430.254014-1-irogers@google.com> X-Mailer: git-send-email 2.26.2.303.gf8c07b1a785-goog Subject: [PATCH v2 06/11] perf expr: parse numbers as doubles From: Ian Rogers To: Peter Zijlstra , Ingo Molnar , Arnaldo Carvalho de Melo , Mark Rutland , Alexander Shishkin , Jiri Olsa , Namhyung Kim , Kan Liang , Andi Kleen , Haiyan Song , Jin Yao , Song Liu , Ravi Bangoria , John Garry , Leo Yan , Adrian Hunter , Paul Clarke , linux-kernel@vger.kernel.org, linux-perf-users@vger.kernel.org Cc: Stephane Eranian , Ian Rogers Content-Type: text/plain; charset="UTF-8" Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org This is expected in expr.y and metrics use floating point values such as x86 broadwell IFetch_Line_Utilization. Fixes: 26226a97724d (perf expr: Move expr lexer to flex) Signed-off-by: Ian Rogers --- tools/perf/util/expr.l | 14 +++++++------- 1 file changed, 7 insertions(+), 7 deletions(-) diff --git a/tools/perf/util/expr.l b/tools/perf/util/expr.l index 95bcf3629edf..0efda2ce2766 100644 --- a/tools/perf/util/expr.l +++ b/tools/perf/util/expr.l @@ -10,12 +10,12 @@ char *expr_get_text(yyscan_t yyscanner); YYSTYPE *expr_get_lval(yyscan_t yyscanner); -static int __value(YYSTYPE *yylval, char *str, int base, int token) +static double __value(YYSTYPE *yylval, char *str, int token) { - u64 num; + double num; errno = 0; - num = strtoull(str, NULL, base); + num = strtod(str, NULL); if (errno) return EXPR_ERROR; @@ -23,12 +23,12 @@ static int __value(YYSTYPE *yylval, char *str, int base, int token) return token; } -static int value(yyscan_t scanner, int base) +static int value(yyscan_t scanner) { YYSTYPE *yylval = expr_get_lval(scanner); char *text = expr_get_text(scanner); - return __value(yylval, text, base, NUMBER); + return __value(yylval, text, NUMBER); } /* @@ -68,7 +68,7 @@ static int str(yyscan_t scanner, int token) } %} -number [0-9]+ +number [0-9]*\.?[0-9]+ sch [-,=] spec \\{sch} @@ -92,7 +92,7 @@ min { return MIN; } if { return IF; } else { return ELSE; } #smt_on { return SMT_ON; } -{number} { return value(yyscanner, 10); } +{number} { return value(yyscanner); } {symbol} { return str(yyscanner, ID); } "|" { return '|'; } "^" { return '^'; } -- 2.26.2.303.gf8c07b1a785-goog