Received: by 2002:a25:1985:0:0:0:0:0 with SMTP id 127csp903770ybz; Fri, 1 May 2020 10:38:26 -0700 (PDT) X-Google-Smtp-Source: APiQypKDWhAjgT1RZFkeZxPnHFhnkCwmTNoM90qHiBl90Vx2aBxyfbZJlpBsnOsrea5baC2J0D0Z X-Received: by 2002:a05:6402:3121:: with SMTP id dd1mr4585179edb.168.1588354706009; Fri, 01 May 2020 10:38:26 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1588354706; cv=none; d=google.com; s=arc-20160816; b=G3oaoXxILSQY7zTsLN1muOXTrKQSt0KpKjVBltoF9WtCrKFslM+MU26oMsh7ZzCH8l +D8ftX/37H65H4tubXUjn2Tyt/XM+T8IpVdJpNJhnFxMz/aLYoPYLsjryjWRo+vUVxOg CETWZy3fzYWRVA07q+Gb8WTDA1LRp4ffn0OfbrtB5E+8MJAudXXU3AX4VtEb4X9imiC1 b6vu1u5MeKd2KPdmyv9oRQF7Y+m75iwdkdeEIpRLL86e8slDMX4fvw0Vxosm0rZvL23+ 4pTksqnmcsUFWf9WXe2HdTWre0nj3j1yJ9SOUtpsUMoARE+uCCZqQZcrp6Xw7Ggd6Jjj VQOQ== 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=+ot4xu8P2SexJM6MGXYbzzq/GQaqN2BkLb72ro0O34w=; b=tV1PTliyLRHk7kvxd3dXXesT1kVNIIzMo9Z8beFA2sxUNUVtwhwr/jlhwJOFtydw3/ cKv4h5RKF6Xkfmux4ia7BLiAZUfStXoTZukCwDxqCFY3dzMdsb5t6HnQZyYq94yB+2LO rVnKKFSxrNIrrO647m3luBwF4gAWtWqWhN6gqDIyeg/HGt8GiKg/nk8GeGnWftbIoXXD 9M0m9GaOW5haYj3J6DQc8aj7BuPjJxkNYu+Ho+u6fQmcGt2tfIouAlNK6aZ676cMxLxv uV/DBEHcsDb3gl3sFMc2Imz0Ybg02Paa97reVTVpngk+Y71WK3spwL2O5TbVrbu2/Xwu VMyw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@google.com header.s=20161025 header.b="oa3VQjz/"; 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 c12si2007105edv.443.2020.05.01.10.38.03; Fri, 01 May 2020 10:38:25 -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="oa3VQjz/"; 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 S1730239AbgEARdw (ORCPT + 99 others); Fri, 1 May 2020 13:33:52 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:60866 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-FAIL-OK-FAIL) by vger.kernel.org with ESMTP id S1730224AbgEARdu (ORCPT ); Fri, 1 May 2020 13:33:50 -0400 Received: from mail-qk1-x74a.google.com (mail-qk1-x74a.google.com [IPv6:2607:f8b0:4864:20::74a]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id BD90DC061A0C for ; Fri, 1 May 2020 10:33:48 -0700 (PDT) Received: by mail-qk1-x74a.google.com with SMTP id 30so10798983qkp.21 for ; Fri, 01 May 2020 10:33:48 -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=+ot4xu8P2SexJM6MGXYbzzq/GQaqN2BkLb72ro0O34w=; b=oa3VQjz/hQ8JVeQoeFDTwpiphtQMkijWONyG6GmOuXFW3ds02LZMZe8sGmRnRmRqNk YXktmXjXrO/KW8P2frmIfG2Vx5hJpcHMvlEnKf5qfGOVeyNya510us4XsbmGC3tMiuYs Jue3JcF/rOP4ICiOPciTtktngmOCwr1iLturZuJA6FxeDvie49FXwmEaSm2ar6zReBfo tk9MsJyl2gvEX1G21Jlm0Z2UaPZOL17TsMyS7H328Q/zvbOX+OWajOfGVu8w6d4r0Vo5 Z10hyhHAw9QS6+Ey2+eLq2n8+VPOU00a1e8+Y9Iws5ssQ6eZDCI+98Ge/i8svHC88xTW lD+Q== 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=+ot4xu8P2SexJM6MGXYbzzq/GQaqN2BkLb72ro0O34w=; b=EHdOFguijhZmsHWWGioL1N1UUkRnxgORIl7mRcM/M1ikp3MapcbYqo1H3Qn8YbSbqk GECqj0T1D6uURe9iZdXwVdj6Jj4s5ST7pBEntmIC+DgJNWZKO1N4WY+pe90+kwbWLiJe V7WnJDXUcaktMFE+r/MxDeLYbSC2b8MpEKg7MCqX3XqcM/SPuyhKjQWw/1g7rjYN7Rvs p3ntoqtds7MQq0D8RXwvdaMmODWeDuWLyb/eWOZ63lbWb69bPEznWdG1ZVdSJhriJNiG +bJvungCuL9xDunuJO9kAQjuEFeh4tPImSN58rkIT9aejRMNTyhcu00OIQjWJMLWgKCk vZyA== X-Gm-Message-State: AGi0PubRrkv1DfuKRPwLtu2VX49HiyS6l8rrXaWiwa61qyaJ8pVOUKn3 XPxfuUXZauupr56Knx8Zwj6eBUO70M7W X-Received: by 2002:a0c:f8c4:: with SMTP id h4mr5170957qvo.15.1588354427865; Fri, 01 May 2020 10:33:47 -0700 (PDT) Date: Fri, 1 May 2020 10:33:27 -0700 In-Reply-To: <20200501173333.227162-1-irogers@google.com> Message-Id: <20200501173333.227162-7-irogers@google.com> Mime-Version: 1.0 References: <20200501173333.227162-1-irogers@google.com> X-Mailer: git-send-email 2.26.2.526.g744177e7f7-goog Subject: [PATCH v4 06/12] 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, kajoljain , 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 73db6a9ef97e..ceab11bea6f9 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); } /* @@ -81,7 +81,7 @@ static int str(yyscan_t scanner, int token, int runtime) } %} -number [0-9]+ +number [0-9]*\.?[0-9]+ sch [-,=] spec \\{sch} @@ -105,7 +105,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, sctx->runtime); } "|" { return '|'; } "^" { return '^'; } -- 2.26.2.526.g744177e7f7-goog