perf expr: Use macros for operators
authorIan Rogers <irogers@google.com>
Thu, 23 Sep 2021 07:46:08 +0000 (00:46 -0700)
committerArnaldo Carvalho de Melo <acme@redhat.com>
Wed, 29 Sep 2021 16:41:41 +0000 (13:41 -0300)
No functional change, switch the operators to use macros so that
additional complexity for constants can be added in a later change.

Signed-off-by: Ian Rogers <irogers@google.com>
Tested-by: John Garry <john.garry@huawei.com>
Acked-by: Jiri Olsa <jolsa@redhat.com>
Cc: Alexander Shishkin <alexander.shishkin@linux.intel.com>
Cc: Andi Kleen <ak@linux.intel.com>
Cc: Ingo Molnar <mingo@redhat.com>
Cc: Jin Yao <yao.jin@linux.intel.com>
Cc: Kajol Jain <kjain@linux.ibm.com>
Cc: Mark Rutland <mark.rutland@arm.com>
Cc: Namhyung Kim <namhyung@kernel.org>
Cc: Paul Clarke <pc@us.ibm.com>
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Sandeep Dasgupta <sdasgup@google.com>
Cc: Stephane Eranian <eranian@google.com>
Link: https://lore.kernel.org/r/20210923074616.674826-6-irogers@google.com
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
tools/perf/util/expr.y

index 68b122e..5535bad 100644 (file)
@@ -43,6 +43,12 @@ static void expr_error(double *final_val __maybe_unused,
        pr_debug("%s\n", s);
 }
 
+#define BINARY_LONG_OP(RESULT, OP, LHS, RHS)                           \
+       RESULT = (long)LHS OP (long)RHS;
+
+#define BINARY_OP(RESULT, OP, LHS, RHS)                                        \
+       RESULT = LHS OP RHS;
+
 %}
 %%
 
@@ -81,14 +87,14 @@ expr:         NUMBER
 
                                        free($1);
                                }
-       | expr '|' expr         { $$ = (long)$1 | (long)$3; }
-       | expr '&' expr         { $$ = (long)$1 & (long)$3; }
-       | expr '^' expr         { $$ = (long)$1 ^ (long)$3; }
-       | expr '<' expr         { $$ = $1 < $3; }
-       | expr '>' expr         { $$ = $1 > $3; }
-       | expr '+' expr         { $$ = $1 + $3; }
-       | expr '-' expr         { $$ = $1 - $3; }
-       | expr '*' expr         { $$ = $1 * $3; }
+       | expr '|' expr { BINARY_LONG_OP($$, |, $1, $3); }
+       | expr '&' expr { BINARY_LONG_OP($$, &, $1, $3); }
+       | expr '^' expr { BINARY_LONG_OP($$, ^, $1, $3); }
+       | expr '<' expr { BINARY_OP($$, <, $1, $3); }
+       | expr '>' expr { BINARY_OP($$, >, $1, $3); }
+       | expr '+' expr { BINARY_OP($$, +, $1, $3); }
+       | expr '-' expr { BINARY_OP($$, -, $1, $3); }
+       | expr '*' expr { BINARY_OP($$, *, $1, $3); }
        | expr '/' expr         { if ($3 == 0) {
                                        pr_debug("division by zero\n");
                                        YYABORT;