public inbox for gcc-cvs@sourceware.org
help / color / mirror / Atom feed
* [gcc r14-4139] c/111468 - dump unordered compare operators in their GIMPLE form with -gimple
@ 2023-09-19 12:44 Richard Biener
0 siblings, 0 replies; only message in thread
From: Richard Biener @ 2023-09-19 12:44 UTC (permalink / raw)
To: gcc-cvs
https://gcc.gnu.org/g:f25960b03834712f312d46fed9a021df36f89f22
commit r14-4139-gf25960b03834712f312d46fed9a021df36f89f22
Author: Richard Biener <rguenther@suse.de>
Date: Tue Sep 19 13:18:51 2023 +0200
c/111468 - dump unordered compare operators in their GIMPLE form with -gimple
The following adjusts -gimple dumping to dump the unordered compare ops
and *h in their GIMPLE form. It also adds parsing for __LTGT which I
missed before.
PR c/111468
gcc/c/
* gimple-parser.cc (c_parser_gimple_binary_expression): Handle __LTGT.
gcc/
* tree-pretty-print.h (op_symbol_code): Add defaulted flags
argument.
* tree-pretty-print.cc (op_symbol): Likewise.
(op_symbol_code): Print TDF_GIMPLE variant if requested.
* gimple-pretty-print.cc (dump_binary_rhs): Pass flags to
op_symbol_code.
(dump_gimple_cond): Likewise.
gcc/testsuite/
* gcc.dg/gimplefe-50.c: Amend.
Diff:
---
gcc/c/gimple-parser.cc | 5 +++++
gcc/gimple-pretty-print.cc | 4 ++--
gcc/testsuite/gcc.dg/gimplefe-50.c | 1 +
gcc/tree-pretty-print.cc | 26 +++++++++++++-------------
gcc/tree-pretty-print.h | 2 +-
5 files changed, 22 insertions(+), 16 deletions(-)
diff --git a/gcc/c/gimple-parser.cc b/gcc/c/gimple-parser.cc
index 9cf29701c06..f43c0398655 100644
--- a/gcc/c/gimple-parser.cc
+++ b/gcc/c/gimple-parser.cc
@@ -1044,6 +1044,11 @@ c_parser_gimple_binary_expression (gimple_parser &parser, tree ret_type)
code = ORDERED_EXPR;
break;
}
+ else if (strcmp (IDENTIFIER_POINTER (id), "__LTGT") == 0)
+ {
+ code = LTGT_EXPR;
+ break;
+ }
}
/* Fallthru. */
default:
diff --git a/gcc/gimple-pretty-print.cc b/gcc/gimple-pretty-print.cc
index 82017b92e89..320df9197b4 100644
--- a/gcc/gimple-pretty-print.cc
+++ b/gcc/gimple-pretty-print.cc
@@ -480,7 +480,7 @@ dump_binary_rhs (pretty_printer *buffer, const gassign *gs, int spc,
else
dump_generic_node (buffer, gimple_assign_rhs1 (gs), spc, flags, false);
pp_space (buffer);
- pp_string (buffer, op_symbol_code (gimple_assign_rhs_code (gs)));
+ pp_string (buffer, op_symbol_code (gimple_assign_rhs_code (gs), flags));
pp_space (buffer);
if (op_prio (gimple_assign_rhs2 (gs)) <= op_code_prio (code))
{
@@ -1092,7 +1092,7 @@ dump_gimple_cond (pretty_printer *buffer, const gcond *gs, int spc,
flags | ((flags & TDF_GIMPLE) ? TDF_GIMPLE_VAL : TDF_NONE),
false);
pp_space (buffer);
- pp_string (buffer, op_symbol_code (gimple_cond_code (gs)));
+ pp_string (buffer, op_symbol_code (gimple_cond_code (gs), flags));
pp_space (buffer);
dump_generic_node (buffer, gimple_cond_rhs (gs), spc,
flags | ((flags & TDF_GIMPLE) ? TDF_GIMPLE_VAL : TDF_NONE),
diff --git a/gcc/testsuite/gcc.dg/gimplefe-50.c b/gcc/testsuite/gcc.dg/gimplefe-50.c
index 03db786b619..63d228ce76d 100644
--- a/gcc/testsuite/gcc.dg/gimplefe-50.c
+++ b/gcc/testsuite/gcc.dg/gimplefe-50.c
@@ -14,6 +14,7 @@ foo (float a, float b)
x_7 = a_1(D) __UNEQ b_2(D);
x_8 = a_1(D) __UNORDERED b_2(D);
x_9 = a_1(D) __ORDERED b_2(D);
+ x_10 = a_1(D) __LTGT b_2(D);
if (a_1(D) __UNEQ b_2(D))
goto __BB4;
else
diff --git a/gcc/tree-pretty-print.cc b/gcc/tree-pretty-print.cc
index 45a1fd3e848..12c57c14dd4 100644
--- a/gcc/tree-pretty-print.cc
+++ b/gcc/tree-pretty-print.cc
@@ -49,7 +49,7 @@ along with GCC; see the file COPYING3. If not see
#endif
/* Local functions, macros and variables. */
-static const char *op_symbol (const_tree);
+static const char *op_symbol (const_tree, dump_flags_t = TDF_NONE);
static void newline_and_indent (pretty_printer *, int);
static void maybe_init_pretty_print (FILE *);
static void print_struct_decl (pretty_printer *, const_tree, int, dump_flags_t);
@@ -4327,7 +4327,7 @@ op_prio (const_tree op)
/* Return the symbol associated with operator CODE. */
const char *
-op_symbol_code (enum tree_code code)
+op_symbol_code (enum tree_code code, dump_flags_t flags)
{
switch (code)
{
@@ -4354,14 +4354,14 @@ op_symbol_code (enum tree_code code)
return "&";
case ORDERED_EXPR:
- return "ord";
+ return (flags & TDF_GIMPLE) ? "__ORDERED" : "ord";
case UNORDERED_EXPR:
- return "unord";
+ return (flags & TDF_GIMPLE) ? "__UNORDERED" : "unord";
case EQ_EXPR:
return "==";
case UNEQ_EXPR:
- return "u==";
+ return (flags & TDF_GIMPLE) ? "__UNEQ" : "u==";
case NE_EXPR:
return "!=";
@@ -4369,25 +4369,25 @@ op_symbol_code (enum tree_code code)
case LT_EXPR:
return "<";
case UNLT_EXPR:
- return "u<";
+ return (flags & TDF_GIMPLE) ? "__UNLT" : "u<";
case LE_EXPR:
return "<=";
case UNLE_EXPR:
- return "u<=";
+ return (flags & TDF_GIMPLE) ? "__UNLE" : "u<=";
case GT_EXPR:
return ">";
case UNGT_EXPR:
- return "u>";
+ return (flags & TDF_GIMPLE) ? "__UNGT" : "u>";
case GE_EXPR:
return ">=";
case UNGE_EXPR:
- return "u>=";
+ return (flags & TDF_GIMPLE) ? "__UNGE" : "u>=";
case LTGT_EXPR:
- return "<>";
+ return (flags & TDF_GIMPLE) ? "__LTGT" : "<>";
case LSHIFT_EXPR:
return "<<";
@@ -4417,7 +4417,7 @@ op_symbol_code (enum tree_code code)
return "w*";
case MULT_HIGHPART_EXPR:
- return "h*";
+ return (flags & TDF_GIMPLE) ? "__MULT_HIGHPART" : "h*";
case NEGATE_EXPR:
case MINUS_EXPR:
@@ -4488,9 +4488,9 @@ op_symbol_code (enum tree_code code)
/* Return the symbol associated with operator OP. */
static const char *
-op_symbol (const_tree op)
+op_symbol (const_tree op, dump_flags_t flags)
{
- return op_symbol_code (TREE_CODE (op));
+ return op_symbol_code (TREE_CODE (op), flags);
}
/* Prints the name of a call. NODE is the CALL_EXPR_FN of a CALL_EXPR or
diff --git a/gcc/tree-pretty-print.h b/gcc/tree-pretty-print.h
index 681384a8e58..2c8ee9aa377 100644
--- a/gcc/tree-pretty-print.h
+++ b/gcc/tree-pretty-print.h
@@ -49,7 +49,7 @@ extern int dump_generic_node (pretty_printer *, tree, int, dump_flags_t, bool);
extern void print_declaration (pretty_printer *, tree, int, dump_flags_t);
extern int op_code_prio (enum tree_code);
extern int op_prio (const_tree);
-extern const char *op_symbol_code (enum tree_code);
+extern const char *op_symbol_code (enum tree_code, dump_flags_t = TDF_NONE);
extern void pretty_print_string (pretty_printer *, const char *, size_t);
extern void print_call_name (pretty_printer *, tree, dump_flags_t);
extern void pp_tree_identifier (pretty_printer *, tree);
^ permalink raw reply [flat|nested] only message in thread
only message in thread, other threads:[~2023-09-19 12:44 UTC | newest]
Thread overview: (only message) (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2023-09-19 12:44 [gcc r14-4139] c/111468 - dump unordered compare operators in their GIMPLE form with -gimple Richard Biener
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).