1 /* Generate pattern matching and transform code shared between
2 GENERIC and GIMPLE folding code from match-and-simplify description.
4 Copyright (C) 2014-2017 Free Software Foundation, Inc.
5 Contributed by Richard Biener <rguenther@suse.de>
6 and Prathamesh Kulkarni <bilbotheelffriend@gmail.com>
8 This file is part of GCC.
10 GCC is free software; you can redistribute it and/or modify it under
11 the terms of the GNU General Public License as published by the Free
12 Software Foundation; either version 3, or (at your option) any later
15 GCC is distributed in the hope that it will be useful, but WITHOUT ANY
16 WARRANTY; without even the implied warranty of MERCHANTABILITY or
17 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
20 You should have received a copy of the GNU General Public License
21 along with GCC; see the file COPYING3. If not see
22 <http://www.gnu.org/licenses/>. */
26 #include "coretypes.h"
29 #include "hash-table.h"
34 /* Stubs for GGC referenced through instantiations triggered by hash-map. */
35 void *ggc_internal_cleared_alloc (size_t, void (*)(void *),
36 size_t, size_t MEM_STAT_DECL
)
40 void ggc_free (void *)
47 /* Verboseness. 0 is quiet, 1 adds some warnings, 2 is for debugging. */
53 static struct line_maps
*line_table
;
55 /* The rich_location class within libcpp requires a way to expand
56 source_location instances, and relies on the client code
57 providing a symbol named
58 linemap_client_expand_location_to_spelling_point
61 This is the implementation for genmatch. */
64 linemap_client_expand_location_to_spelling_point (source_location loc
)
66 const struct line_map_ordinary
*map
;
67 loc
= linemap_resolve_location (line_table
, loc
, LRK_SPELLING_LOCATION
, &map
);
68 return linemap_expand_location (line_table
, map
, loc
);
72 #if GCC_VERSION >= 4001
73 __attribute__((format (printf
, 5, 0)))
75 error_cb (cpp_reader
*, int errtype
, int, rich_location
*richloc
,
76 const char *msg
, va_list *ap
)
78 const line_map_ordinary
*map
;
79 source_location location
= richloc
->get_loc ();
80 linemap_resolve_location (line_table
, location
, LRK_SPELLING_LOCATION
, &map
);
81 expanded_location loc
= linemap_expand_location (line_table
, map
, location
);
82 fprintf (stderr
, "%s:%d:%d %s: ", loc
.file
, loc
.line
, loc
.column
,
83 (errtype
== CPP_DL_WARNING
) ? "warning" : "error");
84 vfprintf (stderr
, msg
, *ap
);
85 fprintf (stderr
, "\n");
86 FILE *f
= fopen (loc
.file
, "r");
92 if (!fgets (buf
, 128, f
))
94 if (buf
[strlen (buf
) - 1] != '\n')
101 fprintf (stderr
, "%s", buf
);
102 for (int i
= 0; i
< loc
.column
- 1; ++i
)
105 fputc ('\n', stderr
);
110 if (errtype
== CPP_DL_FATAL
)
116 #if GCC_VERSION >= 4001
117 __attribute__((format (printf
, 2, 3)))
119 fatal_at (const cpp_token
*tk
, const char *msg
, ...)
121 rich_location
richloc (line_table
, tk
->src_loc
);
124 error_cb (NULL
, CPP_DL_FATAL
, 0, &richloc
, msg
, &ap
);
129 #if GCC_VERSION >= 4001
130 __attribute__((format (printf
, 2, 3)))
132 fatal_at (source_location loc
, const char *msg
, ...)
134 rich_location
richloc (line_table
, loc
);
137 error_cb (NULL
, CPP_DL_FATAL
, 0, &richloc
, msg
, &ap
);
142 #if GCC_VERSION >= 4001
143 __attribute__((format (printf
, 2, 3)))
145 warning_at (const cpp_token
*tk
, const char *msg
, ...)
147 rich_location
richloc (line_table
, tk
->src_loc
);
150 error_cb (NULL
, CPP_DL_WARNING
, 0, &richloc
, msg
, &ap
);
155 #if GCC_VERSION >= 4001
156 __attribute__((format (printf
, 2, 3)))
158 warning_at (source_location loc
, const char *msg
, ...)
160 rich_location
richloc (line_table
, loc
);
163 error_cb (NULL
, CPP_DL_WARNING
, 0, &richloc
, msg
, &ap
);
167 /* Like fprintf, but print INDENT spaces at the beginning. */
170 #if GCC_VERSION >= 4001
171 __attribute__((format (printf
, 3, 4)))
173 fprintf_indent (FILE *f
, unsigned int indent
, const char *format
, ...)
176 for (; indent
>= 8; indent
-= 8)
178 fprintf (f
, "%*s", indent
, "");
179 va_start (ap
, format
);
180 vfprintf (f
, format
, ap
);
185 output_line_directive (FILE *f
, source_location location
,
186 bool dumpfile
= false)
188 const line_map_ordinary
*map
;
189 linemap_resolve_location (line_table
, location
, LRK_SPELLING_LOCATION
, &map
);
190 expanded_location loc
= linemap_expand_location (line_table
, map
, location
);
193 /* When writing to a dumpfile only dump the filename. */
194 const char *file
= strrchr (loc
.file
, DIR_SEPARATOR
);
195 #if defined(DIR_SEPARATOR_2)
196 const char *pos2
= strrchr (loc
.file
, DIR_SEPARATOR_2
);
197 if (pos2
&& (!file
|| (pos2
> file
)))
204 fprintf (f
, "%s:%d", file
, loc
.line
);
207 /* Other gen programs really output line directives here, at least for
208 development it's right now more convenient to have line information
209 from the generated file. Still keep the directives as comment for now
210 to easily back-point to the meta-description. */
211 fprintf (f
, "/* #line %d \"%s\" */\n", loc
.line
, loc
.file
);
215 /* Pull in tree codes and builtin function codes from their
218 #define DEFTREECODE(SYM, STRING, TYPE, NARGS) SYM,
231 #define DEF_BUILTIN(ENUM, N, C, T, LT, B, F, NA, AT, IM, COND) ENUM,
232 enum built_in_function
{
233 #include "builtins.def"
237 #define DEF_INTERNAL_FN(CODE, FLAGS, FNSPEC) IFN_##CODE,
239 #include "internal-fn.def"
243 /* Return true if CODE represents a commutative tree code. Otherwise
246 commutative_tree_code (enum tree_code code
)
252 case MULT_HIGHPART_EXPR
:
267 case WIDEN_MULT_EXPR
:
268 case VEC_WIDEN_MULT_HI_EXPR
:
269 case VEC_WIDEN_MULT_LO_EXPR
:
270 case VEC_WIDEN_MULT_EVEN_EXPR
:
271 case VEC_WIDEN_MULT_ODD_EXPR
:
280 /* Return true if CODE represents a ternary tree code for which the
281 first two operands are commutative. Otherwise return false. */
283 commutative_ternary_tree_code (enum tree_code code
)
287 case WIDEN_MULT_PLUS_EXPR
:
288 case WIDEN_MULT_MINUS_EXPR
:
299 /* Return true if CODE is a comparison. */
302 comparison_code_p (enum tree_code code
)
329 /* Base class for all identifiers the parser knows. */
331 struct id_base
: nofree_ptr_hash
<id_base
>
333 enum id_kind
{ CODE
, FN
, PREDICATE
, USER
, NULL_ID
} kind
;
335 id_base (id_kind
, const char *, int = -1);
341 /* hash_table support. */
342 static inline hashval_t
hash (const id_base
*);
343 static inline int equal (const id_base
*, const id_base
*);
347 id_base::hash (const id_base
*op
)
353 id_base::equal (const id_base
*op1
,
356 return (op1
->hashval
== op2
->hashval
357 && strcmp (op1
->id
, op2
->id
) == 0);
360 /* The special id "null", which matches nothing. */
361 static id_base
*null_id
;
363 /* Hashtable of known pattern operators. This is pre-seeded from
364 all known tree codes and all known builtin function ids. */
365 static hash_table
<id_base
> *operators
;
367 id_base::id_base (id_kind kind_
, const char *id_
, int nargs_
)
372 hashval
= htab_hash_string (id
);
375 /* Identifier that maps to a tree code. */
377 struct operator_id
: public id_base
379 operator_id (enum tree_code code_
, const char *id_
, unsigned nargs_
,
381 : id_base (id_base::CODE
, id_
, nargs_
), code (code_
), tcc (tcc_
) {}
386 /* Identifier that maps to a builtin or internal function code. */
388 struct fn_id
: public id_base
390 fn_id (enum built_in_function fn_
, const char *id_
)
391 : id_base (id_base::FN
, id_
), fn (fn_
) {}
392 fn_id (enum internal_fn fn_
, const char *id_
)
393 : id_base (id_base::FN
, id_
), fn (int (END_BUILTINS
) + int (fn_
)) {}
399 /* Identifier that maps to a user-defined predicate. */
401 struct predicate_id
: public id_base
403 predicate_id (const char *id_
)
404 : id_base (id_base::PREDICATE
, id_
), matchers (vNULL
) {}
405 vec
<simplify
*> matchers
;
408 /* Identifier that maps to a operator defined by a 'for' directive. */
410 struct user_id
: public id_base
412 user_id (const char *id_
, bool is_oper_list_
= false)
413 : id_base (id_base::USER
, id_
), substitutes (vNULL
),
414 used (false), is_oper_list (is_oper_list_
) {}
415 vec
<id_base
*> substitutes
;
423 is_a_helper
<fn_id
*>::test (id_base
*id
)
425 return id
->kind
== id_base::FN
;
431 is_a_helper
<operator_id
*>::test (id_base
*id
)
433 return id
->kind
== id_base::CODE
;
439 is_a_helper
<predicate_id
*>::test (id_base
*id
)
441 return id
->kind
== id_base::PREDICATE
;
447 is_a_helper
<user_id
*>::test (id_base
*id
)
449 return id
->kind
== id_base::USER
;
452 /* Add a predicate identifier to the hash. */
454 static predicate_id
*
455 add_predicate (const char *id
)
457 predicate_id
*p
= new predicate_id (id
);
458 id_base
**slot
= operators
->find_slot_with_hash (p
, p
->hashval
, INSERT
);
460 fatal ("duplicate id definition");
465 /* Add a tree code identifier to the hash. */
468 add_operator (enum tree_code code
, const char *id
,
469 const char *tcc
, unsigned nargs
)
471 if (strcmp (tcc
, "tcc_unary") != 0
472 && strcmp (tcc
, "tcc_binary") != 0
473 && strcmp (tcc
, "tcc_comparison") != 0
474 && strcmp (tcc
, "tcc_expression") != 0
475 /* For {REAL,IMAG}PART_EXPR and VIEW_CONVERT_EXPR. */
476 && strcmp (tcc
, "tcc_reference") != 0
477 /* To have INTEGER_CST and friends as "predicate operators". */
478 && strcmp (tcc
, "tcc_constant") != 0
479 /* And allow CONSTRUCTOR for vector initializers. */
480 && !(code
== CONSTRUCTOR
)
481 /* Allow SSA_NAME as predicate operator. */
482 && !(code
== SSA_NAME
))
484 /* Treat ADDR_EXPR as atom, thus don't allow matching its operand. */
485 if (code
== ADDR_EXPR
)
487 operator_id
*op
= new operator_id (code
, id
, nargs
, tcc
);
488 id_base
**slot
= operators
->find_slot_with_hash (op
, op
->hashval
, INSERT
);
490 fatal ("duplicate id definition");
494 /* Add a built-in or internal function identifier to the hash. ID is
495 the name of its CFN_* enumeration value. */
497 template <typename T
>
499 add_function (T code
, const char *id
)
501 fn_id
*fn
= new fn_id (code
, id
);
502 id_base
**slot
= operators
->find_slot_with_hash (fn
, fn
->hashval
, INSERT
);
504 fatal ("duplicate id definition");
508 /* Helper for easy comparing ID with tree code CODE. */
511 operator==(id_base
&id
, enum tree_code code
)
513 if (operator_id
*oid
= dyn_cast
<operator_id
*> (&id
))
514 return oid
->code
== code
;
518 /* Lookup the identifier ID. Allow "null" if ALLOW_NULL. */
521 get_operator (const char *id
, bool allow_null
= false)
523 if (allow_null
&& strcmp (id
, "null") == 0)
526 id_base
tem (id_base::CODE
, id
);
528 id_base
*op
= operators
->find_with_hash (&tem
, tem
.hashval
);
531 /* If this is a user-defined identifier track whether it was used. */
532 if (user_id
*uid
= dyn_cast
<user_id
*> (op
))
538 bool all_upper
= true;
539 bool all_lower
= true;
540 for (unsigned int i
= 0; id
[i
]; ++i
)
543 else if (ISLOWER (id
[i
]))
547 /* Try in caps with _EXPR appended. */
548 id2
= ACONCAT ((id
, "_EXPR", NULL
));
549 for (unsigned int i
= 0; id2
[i
]; ++i
)
550 id2
[i
] = TOUPPER (id2
[i
]);
552 else if (all_upper
&& strncmp (id
, "IFN_", 4) == 0)
553 /* Try CFN_ instead of IFN_. */
554 id2
= ACONCAT (("CFN_", id
+ 4, NULL
));
555 else if (all_upper
&& strncmp (id
, "BUILT_IN_", 9) == 0)
556 /* Try prepending CFN_. */
557 id2
= ACONCAT (("CFN_", id
, NULL
));
561 new (&tem
) id_base (id_base::CODE
, id2
);
562 return operators
->find_with_hash (&tem
, tem
.hashval
);
565 /* Return the comparison operators that results if the operands are
566 swapped. This is safe for floating-point. */
569 swap_tree_comparison (operator_id
*p
)
581 return get_operator ("LT_EXPR");
583 return get_operator ("LE_EXPR");
585 return get_operator ("GT_EXPR");
587 return get_operator ("GE_EXPR");
589 return get_operator ("UNLT_EXPR");
591 return get_operator ("UNLE_EXPR");
593 return get_operator ("UNGT_EXPR");
595 return get_operator ("UNGE_EXPR");
601 typedef hash_map
<nofree_string_hash
, unsigned> cid_map_t
;
604 /* The AST produced by parsing of the pattern definitions. */
609 /* The base class for operands. */
612 enum op_type
{ OP_PREDICATE
, OP_EXPR
, OP_CAPTURE
, OP_C_EXPR
, OP_IF
, OP_WITH
};
613 operand (enum op_type type_
, source_location loc_
)
614 : type (type_
), location (loc_
) {}
616 source_location location
;
617 virtual void gen_transform (FILE *, int, const char *, bool, int,
618 const char *, capture_info
*,
621 { gcc_unreachable (); }
624 /* A predicate operand. Predicates are leafs in the AST. */
626 struct predicate
: public operand
628 predicate (predicate_id
*p_
, source_location loc
)
629 : operand (OP_PREDICATE
, loc
), p (p_
) {}
633 /* An operand that constitutes an expression. Expressions include
634 function calls and user-defined predicate invocations. */
636 struct expr
: public operand
638 expr (id_base
*operation_
, source_location loc
, bool is_commutative_
= false)
639 : operand (OP_EXPR
, loc
), operation (operation_
),
640 ops (vNULL
), expr_type (NULL
), is_commutative (is_commutative_
),
641 is_generic (false), force_single_use (false) {}
643 : operand (OP_EXPR
, e
->location
), operation (e
->operation
),
644 ops (vNULL
), expr_type (e
->expr_type
), is_commutative (e
->is_commutative
),
645 is_generic (e
->is_generic
), force_single_use (e
->force_single_use
) {}
646 void append_op (operand
*op
) { ops
.safe_push (op
); }
647 /* The operator and its operands. */
650 /* An explicitely specified type - used exclusively for conversions. */
651 const char *expr_type
;
652 /* Whether the operation is to be applied commutatively. This is
653 later lowered to two separate patterns. */
655 /* Whether the expression is expected to be in GENERIC form. */
657 /* Whether pushing any stmt to the sequence should be conditional
658 on this expression having a single-use. */
659 bool force_single_use
;
660 virtual void gen_transform (FILE *f
, int, const char *, bool, int,
661 const char *, capture_info
*,
662 dt_operand
** = 0, int = 0);
665 /* An operator that is represented by native C code. This is always
666 a leaf operand in the AST. This class is also used to represent
667 the code to be generated for 'if' and 'with' expressions. */
669 struct c_expr
: public operand
671 /* A mapping of an identifier and its replacement. Used to apply
676 id_tab (const char *id_
, const char *oper_
): id (id_
), oper (oper_
) {}
679 c_expr (cpp_reader
*r_
, source_location loc
,
680 vec
<cpp_token
> code_
, unsigned nr_stmts_
,
681 vec
<id_tab
> ids_
, cid_map_t
*capture_ids_
)
682 : operand (OP_C_EXPR
, loc
), r (r_
), code (code_
),
683 capture_ids (capture_ids_
), nr_stmts (nr_stmts_
), ids (ids_
) {}
684 /* cpplib tokens and state to transform this back to source. */
687 cid_map_t
*capture_ids
;
688 /* The number of statements parsed (well, the number of ';'s). */
690 /* The identifier replacement vector. */
692 virtual void gen_transform (FILE *f
, int, const char *, bool, int,
693 const char *, capture_info
*,
694 dt_operand
** = 0, int = 0);
697 /* A wrapper around another operand that captures its value. */
699 struct capture
: public operand
701 capture (source_location loc
, unsigned where_
, operand
*what_
, bool value_
)
702 : operand (OP_CAPTURE
, loc
), where (where_
), value_match (value_
),
704 /* Identifier index for the value. */
706 /* Whether in a match of two operands the compare should be for
707 equal values rather than equal atoms (boils down to a type
710 /* The captured value. */
712 virtual void gen_transform (FILE *f
, int, const char *, bool, int,
713 const char *, capture_info
*,
714 dt_operand
** = 0, int = 0);
719 struct if_expr
: public operand
721 if_expr (source_location loc
)
722 : operand (OP_IF
, loc
), cond (NULL
), trueexpr (NULL
), falseexpr (NULL
) {}
728 /* with expression. */
730 struct with_expr
: public operand
732 with_expr (source_location loc
)
733 : operand (OP_WITH
, loc
), with (NULL
), subexpr (NULL
) {}
741 is_a_helper
<capture
*>::test (operand
*op
)
743 return op
->type
== operand::OP_CAPTURE
;
749 is_a_helper
<predicate
*>::test (operand
*op
)
751 return op
->type
== operand::OP_PREDICATE
;
757 is_a_helper
<c_expr
*>::test (operand
*op
)
759 return op
->type
== operand::OP_C_EXPR
;
765 is_a_helper
<expr
*>::test (operand
*op
)
767 return op
->type
== operand::OP_EXPR
;
773 is_a_helper
<if_expr
*>::test (operand
*op
)
775 return op
->type
== operand::OP_IF
;
781 is_a_helper
<with_expr
*>::test (operand
*op
)
783 return op
->type
== operand::OP_WITH
;
786 /* The main class of a pattern and its transform. This is used to
787 represent both (simplify ...) and (match ...) kinds. The AST
788 duplicates all outer 'if' and 'for' expressions here so each
789 simplify can exist in isolation. */
793 enum simplify_kind
{ SIMPLIFY
, MATCH
};
795 simplify (simplify_kind kind_
, operand
*match_
, operand
*result_
,
796 vec
<vec
<user_id
*> > for_vec_
, cid_map_t
*capture_ids_
)
797 : kind (kind_
), match (match_
), result (result_
),
798 for_vec (for_vec_
), for_subst_vec (vNULL
),
799 capture_ids (capture_ids_
), capture_max (capture_ids_
->elements () - 1) {}
802 /* The expression that is matched against the GENERIC or GIMPLE IL. */
804 /* For a (simplify ...) an expression with ifs and withs with the expression
805 produced when the pattern applies in the leafs.
806 For a (match ...) the leafs are either empty if it is a simple predicate
807 or the single expression specifying the matched operands. */
808 struct operand
*result
;
809 /* Collected 'for' expression operators that have to be replaced
810 in the lowering phase. */
811 vec
<vec
<user_id
*> > for_vec
;
812 vec
<std::pair
<user_id
*, id_base
*> > for_subst_vec
;
813 /* A map of capture identifiers to indexes. */
814 cid_map_t
*capture_ids
;
818 /* Debugging routines for dumping the AST. */
821 print_operand (operand
*o
, FILE *f
= stderr
, bool flattened
= false)
823 if (capture
*c
= dyn_cast
<capture
*> (o
))
825 if (c
->what
&& flattened
== false)
826 print_operand (c
->what
, f
, flattened
);
827 fprintf (f
, "@%u", c
->where
);
830 else if (predicate
*p
= dyn_cast
<predicate
*> (o
))
831 fprintf (f
, "%s", p
->p
->id
);
833 else if (is_a
<c_expr
*> (o
))
834 fprintf (f
, "c_expr");
836 else if (expr
*e
= dyn_cast
<expr
*> (o
))
838 if (e
->ops
.length () == 0)
839 fprintf (f
, "%s", e
->operation
->id
);
842 fprintf (f
, "(%s", e
->operation
->id
);
844 if (flattened
== false)
846 for (unsigned i
= 0; i
< e
->ops
.length (); ++i
)
849 print_operand (e
->ops
[i
], f
, flattened
);
861 print_matches (struct simplify
*s
, FILE *f
= stderr
)
863 fprintf (f
, "for expression: ");
864 print_operand (s
->match
, f
);
871 /* Lowering of commutative operators. */
874 cartesian_product (const vec
< vec
<operand
*> >& ops_vector
,
875 vec
< vec
<operand
*> >& result
, vec
<operand
*>& v
, unsigned n
)
877 if (n
== ops_vector
.length ())
879 vec
<operand
*> xv
= v
.copy ();
880 result
.safe_push (xv
);
884 for (unsigned i
= 0; i
< ops_vector
[n
].length (); ++i
)
886 v
[n
] = ops_vector
[n
][i
];
887 cartesian_product (ops_vector
, result
, v
, n
+ 1);
891 /* Lower OP to two operands in case it is marked as commutative. */
893 static vec
<operand
*>
894 commutate (operand
*op
, vec
<vec
<user_id
*> > &for_vec
)
896 vec
<operand
*> ret
= vNULL
;
898 if (capture
*c
= dyn_cast
<capture
*> (op
))
905 vec
<operand
*> v
= commutate (c
->what
, for_vec
);
906 for (unsigned i
= 0; i
< v
.length (); ++i
)
908 capture
*nc
= new capture (c
->location
, c
->where
, v
[i
],
915 expr
*e
= dyn_cast
<expr
*> (op
);
916 if (!e
|| e
->ops
.length () == 0)
922 vec
< vec
<operand
*> > ops_vector
= vNULL
;
923 for (unsigned i
= 0; i
< e
->ops
.length (); ++i
)
924 ops_vector
.safe_push (commutate (e
->ops
[i
], for_vec
));
926 auto_vec
< vec
<operand
*> > result
;
927 auto_vec
<operand
*> v (e
->ops
.length ());
928 v
.quick_grow_cleared (e
->ops
.length ());
929 cartesian_product (ops_vector
, result
, v
, 0);
932 for (unsigned i
= 0; i
< result
.length (); ++i
)
934 expr
*ne
= new expr (e
);
935 ne
->is_commutative
= false;
936 for (unsigned j
= 0; j
< result
[i
].length (); ++j
)
937 ne
->append_op (result
[i
][j
]);
941 if (!e
->is_commutative
)
944 for (unsigned i
= 0; i
< result
.length (); ++i
)
946 expr
*ne
= new expr (e
);
947 if (operator_id
*p
= dyn_cast
<operator_id
*> (ne
->operation
))
949 if (comparison_code_p (p
->code
))
950 ne
->operation
= swap_tree_comparison (p
);
952 else if (user_id
*p
= dyn_cast
<user_id
*> (ne
->operation
))
954 bool found_compare
= false;
955 for (unsigned j
= 0; j
< p
->substitutes
.length (); ++j
)
956 if (operator_id
*q
= dyn_cast
<operator_id
*> (p
->substitutes
[j
]))
958 if (comparison_code_p (q
->code
)
959 && swap_tree_comparison (q
) != q
)
961 found_compare
= true;
967 user_id
*newop
= new user_id ("<internal>");
968 for (unsigned j
= 0; j
< p
->substitutes
.length (); ++j
)
970 id_base
*subst
= p
->substitutes
[j
];
971 if (operator_id
*q
= dyn_cast
<operator_id
*> (subst
))
973 if (comparison_code_p (q
->code
))
974 subst
= swap_tree_comparison (q
);
976 newop
->substitutes
.safe_push (subst
);
978 ne
->operation
= newop
;
979 /* Search for 'p' inside the for vector and push 'newop'
980 to the same level. */
981 for (unsigned j
= 0; newop
&& j
< for_vec
.length (); ++j
)
982 for (unsigned k
= 0; k
< for_vec
[j
].length (); ++k
)
983 if (for_vec
[j
][k
] == p
)
985 for_vec
[j
].safe_push (newop
);
991 ne
->is_commutative
= false;
992 // result[i].length () is 2 since e->operation is binary
993 for (unsigned j
= result
[i
].length (); j
; --j
)
994 ne
->append_op (result
[i
][j
-1]);
1001 /* Lower operations marked as commutative in the AST of S and push
1002 the resulting patterns to SIMPLIFIERS. */
1005 lower_commutative (simplify
*s
, vec
<simplify
*>& simplifiers
)
1007 vec
<operand
*> matchers
= commutate (s
->match
, s
->for_vec
);
1008 for (unsigned i
= 0; i
< matchers
.length (); ++i
)
1010 simplify
*ns
= new simplify (s
->kind
, matchers
[i
], s
->result
,
1011 s
->for_vec
, s
->capture_ids
);
1012 simplifiers
.safe_push (ns
);
1016 /* Strip conditional conversios using operator OPER from O and its
1017 children if STRIP, else replace them with an unconditional convert. */
1020 lower_opt_convert (operand
*o
, enum tree_code oper
,
1021 enum tree_code to_oper
, bool strip
)
1023 if (capture
*c
= dyn_cast
<capture
*> (o
))
1026 return new capture (c
->location
, c
->where
,
1027 lower_opt_convert (c
->what
, oper
, to_oper
, strip
),
1033 expr
*e
= dyn_cast
<expr
*> (o
);
1037 if (*e
->operation
== oper
)
1040 return lower_opt_convert (e
->ops
[0], oper
, to_oper
, strip
);
1042 expr
*ne
= new expr (e
);
1043 ne
->operation
= (to_oper
== CONVERT_EXPR
1044 ? get_operator ("CONVERT_EXPR")
1045 : get_operator ("VIEW_CONVERT_EXPR"));
1046 ne
->append_op (lower_opt_convert (e
->ops
[0], oper
, to_oper
, strip
));
1050 expr
*ne
= new expr (e
);
1051 for (unsigned i
= 0; i
< e
->ops
.length (); ++i
)
1052 ne
->append_op (lower_opt_convert (e
->ops
[i
], oper
, to_oper
, strip
));
1057 /* Determine whether O or its children uses the conditional conversion
1061 has_opt_convert (operand
*o
, enum tree_code oper
)
1063 if (capture
*c
= dyn_cast
<capture
*> (o
))
1066 return has_opt_convert (c
->what
, oper
);
1071 expr
*e
= dyn_cast
<expr
*> (o
);
1075 if (*e
->operation
== oper
)
1078 for (unsigned i
= 0; i
< e
->ops
.length (); ++i
)
1079 if (has_opt_convert (e
->ops
[i
], oper
))
1085 /* Lower conditional convert operators in O, expanding it to a vector
1088 static vec
<operand
*>
1089 lower_opt_convert (operand
*o
)
1091 vec
<operand
*> v1
= vNULL
, v2
;
1095 enum tree_code opers
[]
1096 = { CONVERT0
, CONVERT_EXPR
,
1097 CONVERT1
, CONVERT_EXPR
,
1098 CONVERT2
, CONVERT_EXPR
,
1099 VIEW_CONVERT0
, VIEW_CONVERT_EXPR
,
1100 VIEW_CONVERT1
, VIEW_CONVERT_EXPR
,
1101 VIEW_CONVERT2
, VIEW_CONVERT_EXPR
};
1103 /* Conditional converts are lowered to a pattern with the
1104 conversion and one without. The three different conditional
1105 convert codes are lowered separately. */
1107 for (unsigned i
= 0; i
< sizeof (opers
) / sizeof (enum tree_code
); i
+= 2)
1110 for (unsigned j
= 0; j
< v1
.length (); ++j
)
1111 if (has_opt_convert (v1
[j
], opers
[i
]))
1113 v2
.safe_push (lower_opt_convert (v1
[j
],
1114 opers
[i
], opers
[i
+1], false));
1115 v2
.safe_push (lower_opt_convert (v1
[j
],
1116 opers
[i
], opers
[i
+1], true));
1122 for (unsigned j
= 0; j
< v2
.length (); ++j
)
1123 v1
.safe_push (v2
[j
]);
1130 /* Lower conditional convert operators in the AST of S and push
1131 the resulting multiple patterns to SIMPLIFIERS. */
1134 lower_opt_convert (simplify
*s
, vec
<simplify
*>& simplifiers
)
1136 vec
<operand
*> matchers
= lower_opt_convert (s
->match
);
1137 for (unsigned i
= 0; i
< matchers
.length (); ++i
)
1139 simplify
*ns
= new simplify (s
->kind
, matchers
[i
], s
->result
,
1140 s
->for_vec
, s
->capture_ids
);
1141 simplifiers
.safe_push (ns
);
1145 /* Lower the compare operand of COND_EXPRs and VEC_COND_EXPRs to a
1146 GENERIC and a GIMPLE variant. */
1148 static vec
<operand
*>
1149 lower_cond (operand
*o
)
1151 vec
<operand
*> ro
= vNULL
;
1153 if (capture
*c
= dyn_cast
<capture
*> (o
))
1157 vec
<operand
*> lop
= vNULL
;
1158 lop
= lower_cond (c
->what
);
1160 for (unsigned i
= 0; i
< lop
.length (); ++i
)
1161 ro
.safe_push (new capture (c
->location
, c
->where
, lop
[i
],
1167 expr
*e
= dyn_cast
<expr
*> (o
);
1168 if (!e
|| e
->ops
.length () == 0)
1174 vec
< vec
<operand
*> > ops_vector
= vNULL
;
1175 for (unsigned i
= 0; i
< e
->ops
.length (); ++i
)
1176 ops_vector
.safe_push (lower_cond (e
->ops
[i
]));
1178 auto_vec
< vec
<operand
*> > result
;
1179 auto_vec
<operand
*> v (e
->ops
.length ());
1180 v
.quick_grow_cleared (e
->ops
.length ());
1181 cartesian_product (ops_vector
, result
, v
, 0);
1183 for (unsigned i
= 0; i
< result
.length (); ++i
)
1185 expr
*ne
= new expr (e
);
1186 for (unsigned j
= 0; j
< result
[i
].length (); ++j
)
1187 ne
->append_op (result
[i
][j
]);
1189 /* If this is a COND with a captured expression or an
1190 expression with two operands then also match a GENERIC
1191 form on the compare. */
1192 if ((*e
->operation
== COND_EXPR
1193 || *e
->operation
== VEC_COND_EXPR
)
1194 && ((is_a
<capture
*> (e
->ops
[0])
1195 && as_a
<capture
*> (e
->ops
[0])->what
1196 && is_a
<expr
*> (as_a
<capture
*> (e
->ops
[0])->what
)
1198 (as_a
<capture
*> (e
->ops
[0])->what
)->ops
.length () == 2)
1199 || (is_a
<expr
*> (e
->ops
[0])
1200 && as_a
<expr
*> (e
->ops
[0])->ops
.length () == 2)))
1202 expr
*ne
= new expr (e
);
1203 for (unsigned j
= 0; j
< result
[i
].length (); ++j
)
1204 ne
->append_op (result
[i
][j
]);
1205 if (capture
*c
= dyn_cast
<capture
*> (ne
->ops
[0]))
1207 expr
*ocmp
= as_a
<expr
*> (c
->what
);
1208 expr
*cmp
= new expr (ocmp
);
1209 for (unsigned j
= 0; j
< ocmp
->ops
.length (); ++j
)
1210 cmp
->append_op (ocmp
->ops
[j
]);
1211 cmp
->is_generic
= true;
1212 ne
->ops
[0] = new capture (c
->location
, c
->where
, cmp
,
1217 expr
*ocmp
= as_a
<expr
*> (ne
->ops
[0]);
1218 expr
*cmp
= new expr (ocmp
);
1219 for (unsigned j
= 0; j
< ocmp
->ops
.length (); ++j
)
1220 cmp
->append_op (ocmp
->ops
[j
]);
1221 cmp
->is_generic
= true;
1231 /* Lower the compare operand of COND_EXPRs and VEC_COND_EXPRs to a
1232 GENERIC and a GIMPLE variant. */
1235 lower_cond (simplify
*s
, vec
<simplify
*>& simplifiers
)
1237 vec
<operand
*> matchers
= lower_cond (s
->match
);
1238 for (unsigned i
= 0; i
< matchers
.length (); ++i
)
1240 simplify
*ns
= new simplify (s
->kind
, matchers
[i
], s
->result
,
1241 s
->for_vec
, s
->capture_ids
);
1242 simplifiers
.safe_push (ns
);
1246 /* Return true if O refers to ID. */
1249 contains_id (operand
*o
, user_id
*id
)
1251 if (capture
*c
= dyn_cast
<capture
*> (o
))
1252 return c
->what
&& contains_id (c
->what
, id
);
1254 if (expr
*e
= dyn_cast
<expr
*> (o
))
1256 if (e
->operation
== id
)
1258 for (unsigned i
= 0; i
< e
->ops
.length (); ++i
)
1259 if (contains_id (e
->ops
[i
], id
))
1264 if (with_expr
*w
= dyn_cast
<with_expr
*> (o
))
1265 return (contains_id (w
->with
, id
)
1266 || contains_id (w
->subexpr
, id
));
1268 if (if_expr
*ife
= dyn_cast
<if_expr
*> (o
))
1269 return (contains_id (ife
->cond
, id
)
1270 || contains_id (ife
->trueexpr
, id
)
1271 || (ife
->falseexpr
&& contains_id (ife
->falseexpr
, id
)));
1273 if (c_expr
*ce
= dyn_cast
<c_expr
*> (o
))
1274 return ce
->capture_ids
&& ce
->capture_ids
->get (id
->id
);
1280 /* In AST operand O replace operator ID with operator WITH. */
1283 replace_id (operand
*o
, user_id
*id
, id_base
*with
)
1285 /* Deep-copy captures and expressions, replacing operations as
1287 if (capture
*c
= dyn_cast
<capture
*> (o
))
1291 return new capture (c
->location
, c
->where
,
1292 replace_id (c
->what
, id
, with
), c
->value_match
);
1294 else if (expr
*e
= dyn_cast
<expr
*> (o
))
1296 expr
*ne
= new expr (e
);
1297 if (e
->operation
== id
)
1298 ne
->operation
= with
;
1299 for (unsigned i
= 0; i
< e
->ops
.length (); ++i
)
1300 ne
->append_op (replace_id (e
->ops
[i
], id
, with
));
1303 else if (with_expr
*w
= dyn_cast
<with_expr
*> (o
))
1305 with_expr
*nw
= new with_expr (w
->location
);
1306 nw
->with
= as_a
<c_expr
*> (replace_id (w
->with
, id
, with
));
1307 nw
->subexpr
= replace_id (w
->subexpr
, id
, with
);
1310 else if (if_expr
*ife
= dyn_cast
<if_expr
*> (o
))
1312 if_expr
*nife
= new if_expr (ife
->location
);
1313 nife
->cond
= as_a
<c_expr
*> (replace_id (ife
->cond
, id
, with
));
1314 nife
->trueexpr
= replace_id (ife
->trueexpr
, id
, with
);
1316 nife
->falseexpr
= replace_id (ife
->falseexpr
, id
, with
);
1320 /* For c_expr we simply record a string replacement table which is
1321 applied at code-generation time. */
1322 if (c_expr
*ce
= dyn_cast
<c_expr
*> (o
))
1324 vec
<c_expr::id_tab
> ids
= ce
->ids
.copy ();
1325 ids
.safe_push (c_expr::id_tab (id
->id
, with
->id
));
1326 return new c_expr (ce
->r
, ce
->location
,
1327 ce
->code
, ce
->nr_stmts
, ids
, ce
->capture_ids
);
1333 /* Return true if the binary operator OP is ok for delayed substitution
1334 during for lowering. */
1337 binary_ok (operator_id
*op
)
1344 case TRUNC_DIV_EXPR
:
1346 case FLOOR_DIV_EXPR
:
1347 case ROUND_DIV_EXPR
:
1348 case TRUNC_MOD_EXPR
:
1350 case FLOOR_MOD_EXPR
:
1351 case ROUND_MOD_EXPR
:
1353 case EXACT_DIV_EXPR
:
1365 /* Lower recorded fors for SIN and output to SIMPLIFIERS. */
1368 lower_for (simplify
*sin
, vec
<simplify
*>& simplifiers
)
1370 vec
<vec
<user_id
*> >& for_vec
= sin
->for_vec
;
1371 unsigned worklist_start
= 0;
1372 auto_vec
<simplify
*> worklist
;
1373 worklist
.safe_push (sin
);
1375 /* Lower each recorded for separately, operating on the
1376 set of simplifiers created by the previous one.
1377 Lower inner-to-outer so inner for substitutes can refer
1378 to operators replaced by outer fors. */
1379 for (int fi
= for_vec
.length () - 1; fi
>= 0; --fi
)
1381 vec
<user_id
*>& ids
= for_vec
[fi
];
1382 unsigned n_ids
= ids
.length ();
1383 unsigned max_n_opers
= 0;
1384 bool can_delay_subst
= (sin
->kind
== simplify::SIMPLIFY
);
1385 for (unsigned i
= 0; i
< n_ids
; ++i
)
1387 if (ids
[i
]->substitutes
.length () > max_n_opers
)
1388 max_n_opers
= ids
[i
]->substitutes
.length ();
1389 /* Require that all substitutes are of the same kind so that
1390 if we delay substitution to the result op code generation
1391 can look at the first substitute for deciding things like
1392 types of operands. */
1393 enum id_base::id_kind kind
= ids
[i
]->substitutes
[0]->kind
;
1394 for (unsigned j
= 0; j
< ids
[i
]->substitutes
.length (); ++j
)
1395 if (ids
[i
]->substitutes
[j
]->kind
!= kind
)
1396 can_delay_subst
= false;
1397 else if (operator_id
*op
1398 = dyn_cast
<operator_id
*> (ids
[i
]->substitutes
[j
]))
1401 = as_a
<operator_id
*> (ids
[i
]->substitutes
[0]);
1402 if (strcmp (op
->tcc
, "tcc_comparison") == 0
1403 && strcmp (op0
->tcc
, "tcc_comparison") == 0)
1405 /* Unfortunately we can't just allow all tcc_binary. */
1406 else if (strcmp (op
->tcc
, "tcc_binary") == 0
1407 && strcmp (op0
->tcc
, "tcc_binary") == 0
1411 else if ((strcmp (op
->id
+ 1, "SHIFT_EXPR") == 0
1412 || strcmp (op
->id
+ 1, "ROTATE_EXPR") == 0)
1413 && (strcmp (op0
->id
+ 1, "SHIFT_EXPR") == 0
1414 || strcmp (op0
->id
+ 1, "ROTATE_EXPR") == 0))
1417 can_delay_subst
= false;
1419 else if (is_a
<fn_id
*> (ids
[i
]->substitutes
[j
]))
1422 can_delay_subst
= false;
1425 unsigned worklist_end
= worklist
.length ();
1426 for (unsigned si
= worklist_start
; si
< worklist_end
; ++si
)
1428 simplify
*s
= worklist
[si
];
1429 for (unsigned j
= 0; j
< max_n_opers
; ++j
)
1431 operand
*match_op
= s
->match
;
1432 operand
*result_op
= s
->result
;
1433 auto_vec
<std::pair
<user_id
*, id_base
*> > subst (n_ids
);
1435 for (unsigned i
= 0; i
< n_ids
; ++i
)
1437 user_id
*id
= ids
[i
];
1438 id_base
*oper
= id
->substitutes
[j
% id
->substitutes
.length ()];
1440 && (contains_id (match_op
, id
)
1441 || contains_id (result_op
, id
)))
1446 subst
.quick_push (std::make_pair (id
, oper
));
1447 match_op
= replace_id (match_op
, id
, oper
);
1449 && !can_delay_subst
)
1450 result_op
= replace_id (result_op
, id
, oper
);
1455 simplify
*ns
= new simplify (s
->kind
, match_op
, result_op
,
1456 vNULL
, s
->capture_ids
);
1457 ns
->for_subst_vec
.safe_splice (s
->for_subst_vec
);
1460 ns
->for_subst_vec
.safe_splice (subst
);
1462 worklist
.safe_push (ns
);
1465 worklist_start
= worklist_end
;
1468 /* Copy out the result from the last for lowering. */
1469 for (unsigned i
= worklist_start
; i
< worklist
.length (); ++i
)
1470 simplifiers
.safe_push (worklist
[i
]);
1473 /* Lower the AST for everything in SIMPLIFIERS. */
1476 lower (vec
<simplify
*>& simplifiers
, bool gimple
)
1478 auto_vec
<simplify
*> out_simplifiers
;
1479 for (unsigned i
= 0; i
< simplifiers
.length (); ++i
)
1480 lower_opt_convert (simplifiers
[i
], out_simplifiers
);
1482 simplifiers
.truncate (0);
1483 for (unsigned i
= 0; i
< out_simplifiers
.length (); ++i
)
1484 lower_commutative (out_simplifiers
[i
], simplifiers
);
1486 out_simplifiers
.truncate (0);
1488 for (unsigned i
= 0; i
< simplifiers
.length (); ++i
)
1489 lower_cond (simplifiers
[i
], out_simplifiers
);
1491 out_simplifiers
.safe_splice (simplifiers
);
1494 simplifiers
.truncate (0);
1495 for (unsigned i
= 0; i
< out_simplifiers
.length (); ++i
)
1496 lower_for (out_simplifiers
[i
], simplifiers
);
1502 /* The decision tree built for generating GIMPLE and GENERIC pattern
1503 matching code. It represents the 'match' expression of all
1504 simplifies and has those as its leafs. */
1508 /* A hash-map collecting semantically equivalent leafs in the decision
1509 tree for splitting out to separate functions. */
1518 struct sinfo_hashmap_traits
: simple_hashmap_traits
<pointer_hash
<dt_simplify
>,
1521 static inline hashval_t
hash (const key_type
&);
1522 static inline bool equal_keys (const key_type
&, const key_type
&);
1523 template <typename T
> static inline void remove (T
&) {}
1526 typedef hash_map
<void * /* unused */, sinfo
*, sinfo_hashmap_traits
>
1530 /* Decision tree base class, used for DT_TRUE and DT_NODE. */
1534 enum dt_type
{ DT_NODE
, DT_OPERAND
, DT_TRUE
, DT_MATCH
, DT_SIMPLIFY
};
1538 vec
<dt_node
*> kids
;
1542 unsigned total_size
;
1545 dt_node (enum dt_type type_
): type (type_
), level (0), kids (vNULL
) {}
1547 dt_node
*append_node (dt_node
*);
1548 dt_node
*append_op (operand
*, dt_node
*parent
= 0, unsigned pos
= 0);
1549 dt_node
*append_true_op (dt_node
*parent
= 0, unsigned pos
= 0);
1550 dt_node
*append_match_op (dt_operand
*, dt_node
*parent
= 0, unsigned pos
= 0);
1551 dt_node
*append_simplify (simplify
*, unsigned, dt_operand
**);
1553 virtual void gen (FILE *, int, bool) {}
1555 void gen_kids (FILE *, int, bool);
1556 void gen_kids_1 (FILE *, int, bool,
1557 vec
<dt_operand
*>, vec
<dt_operand
*>, vec
<dt_operand
*>,
1558 vec
<dt_operand
*>, vec
<dt_operand
*>, vec
<dt_node
*>);
1560 void analyze (sinfo_map_t
&);
1563 /* Generic decision tree node used for DT_OPERAND and DT_MATCH. */
1565 struct dt_operand
: public dt_node
1568 dt_operand
*match_dop
;
1573 dt_operand (enum dt_type type
, operand
*op_
, dt_operand
*match_dop_
,
1574 dt_operand
*parent_
= 0, unsigned pos_
= 0)
1575 : dt_node (type
), op (op_
), match_dop (match_dop_
),
1576 parent (parent_
), pos (pos_
), value_match (false) {}
1578 void gen (FILE *, int, bool);
1579 unsigned gen_predicate (FILE *, int, const char *, bool);
1580 unsigned gen_match_op (FILE *, int, const char *, bool);
1582 unsigned gen_gimple_expr (FILE *, int);
1583 unsigned gen_generic_expr (FILE *, int, const char *);
1585 char *get_name (char *);
1586 void gen_opname (char *, unsigned);
1589 /* Leaf node of the decision tree, used for DT_SIMPLIFY. */
1591 struct dt_simplify
: public dt_node
1594 unsigned pattern_no
;
1595 dt_operand
**indexes
;
1598 dt_simplify (simplify
*s_
, unsigned pattern_no_
, dt_operand
**indexes_
)
1599 : dt_node (DT_SIMPLIFY
), s (s_
), pattern_no (pattern_no_
),
1600 indexes (indexes_
), info (NULL
) {}
1602 void gen_1 (FILE *, int, bool, operand
*);
1603 void gen (FILE *f
, int, bool);
1609 is_a_helper
<dt_operand
*>::test (dt_node
*n
)
1611 return (n
->type
== dt_node::DT_OPERAND
1612 || n
->type
== dt_node::DT_MATCH
);
1618 is_a_helper
<dt_simplify
*>::test (dt_node
*n
)
1620 return n
->type
== dt_node::DT_SIMPLIFY
;
1625 /* A container for the actual decision tree. */
1627 struct decision_tree
1631 void insert (struct simplify
*, unsigned);
1632 void gen (FILE *f
, bool gimple
);
1633 void print (FILE *f
= stderr
);
1635 decision_tree () { root
= new dt_node (dt_node::DT_NODE
); }
1637 static dt_node
*insert_operand (dt_node
*, operand
*, dt_operand
**indexes
,
1638 unsigned pos
= 0, dt_node
*parent
= 0);
1639 static dt_node
*find_node (vec
<dt_node
*>&, dt_node
*);
1640 static bool cmp_node (dt_node
*, dt_node
*);
1641 static void print_node (dt_node
*, FILE *f
= stderr
, unsigned = 0);
1644 /* Compare two AST operands O1 and O2 and return true if they are equal. */
1647 cmp_operand (operand
*o1
, operand
*o2
)
1649 if (!o1
|| !o2
|| o1
->type
!= o2
->type
)
1652 if (o1
->type
== operand::OP_PREDICATE
)
1654 predicate
*p1
= as_a
<predicate
*>(o1
);
1655 predicate
*p2
= as_a
<predicate
*>(o2
);
1656 return p1
->p
== p2
->p
;
1658 else if (o1
->type
== operand::OP_EXPR
)
1660 expr
*e1
= static_cast<expr
*>(o1
);
1661 expr
*e2
= static_cast<expr
*>(o2
);
1662 return (e1
->operation
== e2
->operation
1663 && e1
->is_generic
== e2
->is_generic
);
1669 /* Compare two decision tree nodes N1 and N2 and return true if they
1673 decision_tree::cmp_node (dt_node
*n1
, dt_node
*n2
)
1675 if (!n1
|| !n2
|| n1
->type
!= n2
->type
)
1681 if (n1
->type
== dt_node::DT_TRUE
)
1684 if (n1
->type
== dt_node::DT_OPERAND
)
1685 return cmp_operand ((as_a
<dt_operand
*> (n1
))->op
,
1686 (as_a
<dt_operand
*> (n2
))->op
);
1687 else if (n1
->type
== dt_node::DT_MATCH
)
1688 return (((as_a
<dt_operand
*> (n1
))->match_dop
1689 == (as_a
<dt_operand
*> (n2
))->match_dop
)
1690 && ((as_a
<dt_operand
*> (n1
))->value_match
1691 == (as_a
<dt_operand
*> (n2
))->value_match
));
1695 /* Search OPS for a decision tree node like P and return it if found. */
1698 decision_tree::find_node (vec
<dt_node
*>& ops
, dt_node
*p
)
1700 /* We can merge adjacent DT_TRUE. */
1701 if (p
->type
== dt_node::DT_TRUE
1703 && ops
.last ()->type
== dt_node::DT_TRUE
)
1705 for (int i
= ops
.length () - 1; i
>= 0; --i
)
1707 /* But we can't merge across DT_TRUE nodes as they serve as
1708 pattern order barriers to make sure that patterns apply
1709 in order of appearance in case multiple matches are possible. */
1710 if (ops
[i
]->type
== dt_node::DT_TRUE
)
1712 if (decision_tree::cmp_node (ops
[i
], p
))
1718 /* Append N to the decision tree if it there is not already an existing
1722 dt_node::append_node (dt_node
*n
)
1726 kid
= decision_tree::find_node (kids
, n
);
1731 n
->level
= this->level
+ 1;
1736 /* Append OP to the decision tree. */
1739 dt_node::append_op (operand
*op
, dt_node
*parent
, unsigned pos
)
1741 dt_operand
*parent_
= safe_as_a
<dt_operand
*> (parent
);
1742 dt_operand
*n
= new dt_operand (DT_OPERAND
, op
, 0, parent_
, pos
);
1743 return append_node (n
);
1746 /* Append a DT_TRUE decision tree node. */
1749 dt_node::append_true_op (dt_node
*parent
, unsigned pos
)
1751 dt_operand
*parent_
= safe_as_a
<dt_operand
*> (parent
);
1752 dt_operand
*n
= new dt_operand (DT_TRUE
, 0, 0, parent_
, pos
);
1753 return append_node (n
);
1756 /* Append a DT_MATCH decision tree node. */
1759 dt_node::append_match_op (dt_operand
*match_dop
, dt_node
*parent
, unsigned pos
)
1761 dt_operand
*parent_
= as_a
<dt_operand
*> (parent
);
1762 dt_operand
*n
= new dt_operand (DT_MATCH
, 0, match_dop
, parent_
, pos
);
1763 return append_node (n
);
1766 /* Append S to the decision tree. */
1769 dt_node::append_simplify (simplify
*s
, unsigned pattern_no
,
1770 dt_operand
**indexes
)
1772 dt_simplify
*n
= new dt_simplify (s
, pattern_no
, indexes
);
1773 for (unsigned i
= 0; i
< kids
.length (); ++i
)
1774 if (dt_simplify
*s2
= dyn_cast
<dt_simplify
*> (kids
[i
]))
1776 warning_at (s
->match
->location
, "duplicate pattern");
1777 warning_at (s2
->s
->match
->location
, "previous pattern defined here");
1778 print_operand (s
->match
, stderr
);
1779 fprintf (stderr
, "\n");
1781 return append_node (n
);
1784 /* Analyze the node and its children. */
1787 dt_node::analyze (sinfo_map_t
&map
)
1793 if (type
== DT_SIMPLIFY
)
1795 /* Populate the map of equivalent simplifies. */
1796 dt_simplify
*s
= as_a
<dt_simplify
*> (this);
1798 sinfo
*&si
= map
.get_or_insert (s
, &existed
);
1813 for (unsigned i
= 0; i
< kids
.length (); ++i
)
1815 kids
[i
]->analyze (map
);
1816 num_leafs
+= kids
[i
]->num_leafs
;
1817 total_size
+= kids
[i
]->total_size
;
1818 max_level
= MAX (max_level
, kids
[i
]->max_level
);
1822 /* Insert O into the decision tree and return the decision tree node found
1826 decision_tree::insert_operand (dt_node
*p
, operand
*o
, dt_operand
**indexes
,
1827 unsigned pos
, dt_node
*parent
)
1829 dt_node
*q
, *elm
= 0;
1831 if (capture
*c
= dyn_cast
<capture
*> (o
))
1833 unsigned capt_index
= c
->where
;
1835 if (indexes
[capt_index
] == 0)
1838 q
= insert_operand (p
, c
->what
, indexes
, pos
, parent
);
1841 q
= elm
= p
->append_true_op (parent
, pos
);
1844 // get to the last capture
1845 for (operand
*what
= c
->what
;
1846 what
&& is_a
<capture
*> (what
);
1847 c
= as_a
<capture
*> (what
), what
= c
->what
)
1852 unsigned cc_index
= c
->where
;
1853 dt_operand
*match_op
= indexes
[cc_index
];
1855 dt_operand
temp (dt_node::DT_TRUE
, 0, 0);
1856 elm
= decision_tree::find_node (p
->kids
, &temp
);
1860 dt_operand
temp (dt_node::DT_MATCH
, 0, match_op
);
1861 temp
.value_match
= c
->value_match
;
1862 elm
= decision_tree::find_node (p
->kids
, &temp
);
1867 dt_operand
temp (dt_node::DT_OPERAND
, c
->what
, 0);
1868 elm
= decision_tree::find_node (p
->kids
, &temp
);
1872 gcc_assert (elm
->type
== dt_node::DT_TRUE
1873 || elm
->type
== dt_node::DT_OPERAND
1874 || elm
->type
== dt_node::DT_MATCH
);
1875 indexes
[capt_index
] = static_cast<dt_operand
*> (elm
);
1880 p
= p
->append_match_op (indexes
[capt_index
], parent
, pos
);
1881 as_a
<dt_operand
*>(p
)->value_match
= c
->value_match
;
1883 return insert_operand (p
, c
->what
, indexes
, 0, p
);
1888 p
= p
->append_op (o
, parent
, pos
);
1891 if (expr
*e
= dyn_cast
<expr
*>(o
))
1893 for (unsigned i
= 0; i
< e
->ops
.length (); ++i
)
1894 q
= decision_tree::insert_operand (q
, e
->ops
[i
], indexes
, i
, p
);
1900 /* Insert S into the decision tree. */
1903 decision_tree::insert (struct simplify
*s
, unsigned pattern_no
)
1905 dt_operand
**indexes
= XCNEWVEC (dt_operand
*, s
->capture_max
+ 1);
1906 dt_node
*p
= decision_tree::insert_operand (root
, s
->match
, indexes
);
1907 p
->append_simplify (s
, pattern_no
, indexes
);
1910 /* Debug functions to dump the decision tree. */
1913 decision_tree::print_node (dt_node
*p
, FILE *f
, unsigned indent
)
1915 if (p
->type
== dt_node::DT_NODE
)
1916 fprintf (f
, "root");
1920 for (unsigned i
= 0; i
< indent
; i
++)
1923 if (p
->type
== dt_node::DT_OPERAND
)
1925 dt_operand
*dop
= static_cast<dt_operand
*>(p
);
1926 print_operand (dop
->op
, f
, true);
1928 else if (p
->type
== dt_node::DT_TRUE
)
1929 fprintf (f
, "true");
1930 else if (p
->type
== dt_node::DT_MATCH
)
1931 fprintf (f
, "match (%p)", (void *)((as_a
<dt_operand
*>(p
))->match_dop
));
1932 else if (p
->type
== dt_node::DT_SIMPLIFY
)
1934 dt_simplify
*s
= static_cast<dt_simplify
*> (p
);
1935 fprintf (f
, "simplify_%u { ", s
->pattern_no
);
1936 for (int i
= 0; i
<= s
->s
->capture_max
; ++i
)
1937 fprintf (f
, "%p, ", (void *) s
->indexes
[i
]);
1942 fprintf (stderr
, " (%p), %u, %u\n", (void *) p
, p
->level
, p
->kids
.length ());
1944 for (unsigned i
= 0; i
< p
->kids
.length (); ++i
)
1945 decision_tree::print_node (p
->kids
[i
], f
, indent
+ 2);
1949 decision_tree::print (FILE *f
)
1951 return decision_tree::print_node (root
, f
);
1955 /* For GENERIC we have to take care of wrapping multiple-used
1956 expressions with side-effects in save_expr and preserve side-effects
1957 of expressions with omit_one_operand. Analyze captures in
1958 match, result and with expressions and perform early-outs
1959 on the outermost match expression operands for cases we cannot
1964 capture_info (simplify
*s
, operand
*, bool);
1965 void walk_match (operand
*o
, unsigned toplevel_arg
, bool, bool);
1966 bool walk_result (operand
*o
, bool, operand
*);
1967 void walk_c_expr (c_expr
*);
1973 bool force_no_side_effects_p
;
1974 bool force_single_use
;
1975 bool cond_expr_cond_p
;
1976 unsigned long toplevel_msk
;
1977 unsigned match_use_count
;
1978 unsigned result_use_count
;
1983 auto_vec
<cinfo
> info
;
1984 unsigned long force_no_side_effects
;
1988 /* Analyze captures in S. */
1990 capture_info::capture_info (simplify
*s
, operand
*result
, bool gimple_
)
1995 if (s
->kind
== simplify::MATCH
)
1997 force_no_side_effects
= -1;
2001 force_no_side_effects
= 0;
2002 info
.safe_grow_cleared (s
->capture_max
+ 1);
2003 for (int i
= 0; i
<= s
->capture_max
; ++i
)
2004 info
[i
].same_as
= i
;
2006 e
= as_a
<expr
*> (s
->match
);
2007 for (unsigned i
= 0; i
< e
->ops
.length (); ++i
)
2008 walk_match (e
->ops
[i
], i
,
2009 (i
!= 0 && *e
->operation
== COND_EXPR
)
2010 || *e
->operation
== TRUTH_ANDIF_EXPR
2011 || *e
->operation
== TRUTH_ORIF_EXPR
,
2013 && (*e
->operation
== COND_EXPR
2014 || *e
->operation
== VEC_COND_EXPR
));
2016 walk_result (s
->result
, false, result
);
2019 /* Analyze captures in the match expression piece O. */
2022 capture_info::walk_match (operand
*o
, unsigned toplevel_arg
,
2023 bool conditional_p
, bool cond_expr_cond_p
)
2025 if (capture
*c
= dyn_cast
<capture
*> (o
))
2027 unsigned where
= c
->where
;
2028 info
[where
].match_use_count
++;
2029 info
[where
].toplevel_msk
|= 1 << toplevel_arg
;
2030 info
[where
].force_no_side_effects_p
|= conditional_p
;
2031 info
[where
].cond_expr_cond_p
|= cond_expr_cond_p
;
2036 /* Recurse to exprs and captures. */
2037 if (is_a
<capture
*> (c
->what
)
2038 || is_a
<expr
*> (c
->what
))
2039 walk_match (c
->what
, toplevel_arg
, conditional_p
, false);
2040 /* We need to look past multiple captures to find a captured
2041 expression as with conditional converts two captures
2042 can be collapsed onto the same expression. Also collect
2043 what captures capture the same thing. */
2044 while (c
->what
&& is_a
<capture
*> (c
->what
))
2046 c
= as_a
<capture
*> (c
->what
);
2047 if (info
[c
->where
].same_as
!= c
->where
2048 && info
[c
->where
].same_as
!= info
[where
].same_as
)
2049 fatal_at (c
->location
, "cannot handle this collapsed capture");
2050 info
[c
->where
].same_as
= info
[where
].same_as
;
2052 /* Mark expr (non-leaf) captures and forced single-use exprs. */
2055 && (e
= dyn_cast
<expr
*> (c
->what
)))
2057 info
[where
].expr_p
= true;
2058 info
[where
].force_single_use
|= e
->force_single_use
;
2061 else if (expr
*e
= dyn_cast
<expr
*> (o
))
2063 for (unsigned i
= 0; i
< e
->ops
.length (); ++i
)
2065 bool cond_p
= conditional_p
;
2066 bool cond_expr_cond_p
= false;
2067 if (i
!= 0 && *e
->operation
== COND_EXPR
)
2069 else if (*e
->operation
== TRUTH_ANDIF_EXPR
2070 || *e
->operation
== TRUTH_ORIF_EXPR
)
2073 && (*e
->operation
== COND_EXPR
2074 || *e
->operation
== VEC_COND_EXPR
))
2075 cond_expr_cond_p
= true;
2076 walk_match (e
->ops
[i
], toplevel_arg
, cond_p
, cond_expr_cond_p
);
2079 else if (is_a
<predicate
*> (o
))
2081 /* Mark non-captured leafs toplevel arg for checking. */
2082 force_no_side_effects
|= 1 << toplevel_arg
;
2085 warning_at (o
->location
,
2086 "forcing no side-effects on possibly lost leaf");
2092 /* Analyze captures in the result expression piece O. Return true
2093 if RESULT was visited in one of the children. Only visit
2094 non-if/with children if they are rooted on RESULT. */
2097 capture_info::walk_result (operand
*o
, bool conditional_p
, operand
*result
)
2099 if (capture
*c
= dyn_cast
<capture
*> (o
))
2101 unsigned where
= info
[c
->where
].same_as
;
2102 info
[where
].result_use_count
++;
2103 /* If we substitute an expression capture we don't know
2104 which captures this will end up using (well, we don't
2105 compute that). Force the uses to be side-effect free
2106 which means forcing the toplevels that reach the
2107 expression side-effect free. */
2108 if (info
[where
].expr_p
)
2109 force_no_side_effects
|= info
[where
].toplevel_msk
;
2110 /* Mark CSE capture uses as forced to have no side-effects. */
2112 && is_a
<expr
*> (c
->what
))
2114 info
[where
].cse_p
= true;
2115 walk_result (c
->what
, true, result
);
2118 else if (expr
*e
= dyn_cast
<expr
*> (o
))
2120 id_base
*opr
= e
->operation
;
2121 if (user_id
*uid
= dyn_cast
<user_id
*> (opr
))
2122 opr
= uid
->substitutes
[0];
2123 for (unsigned i
= 0; i
< e
->ops
.length (); ++i
)
2125 bool cond_p
= conditional_p
;
2126 if (i
!= 0 && *e
->operation
== COND_EXPR
)
2128 else if (*e
->operation
== TRUTH_ANDIF_EXPR
2129 || *e
->operation
== TRUTH_ORIF_EXPR
)
2131 walk_result (e
->ops
[i
], cond_p
, result
);
2134 else if (if_expr
*e
= dyn_cast
<if_expr
*> (o
))
2136 /* 'if' conditions should be all fine. */
2137 if (e
->trueexpr
== result
)
2139 walk_result (e
->trueexpr
, false, result
);
2142 if (e
->falseexpr
== result
)
2144 walk_result (e
->falseexpr
, false, result
);
2148 if (is_a
<if_expr
*> (e
->trueexpr
)
2149 || is_a
<with_expr
*> (e
->trueexpr
))
2150 res
|= walk_result (e
->trueexpr
, false, result
);
2152 && (is_a
<if_expr
*> (e
->falseexpr
)
2153 || is_a
<with_expr
*> (e
->falseexpr
)))
2154 res
|= walk_result (e
->falseexpr
, false, result
);
2157 else if (with_expr
*e
= dyn_cast
<with_expr
*> (o
))
2159 bool res
= (e
->subexpr
== result
);
2161 || is_a
<if_expr
*> (e
->subexpr
)
2162 || is_a
<with_expr
*> (e
->subexpr
))
2163 res
|= walk_result (e
->subexpr
, false, result
);
2165 walk_c_expr (e
->with
);
2168 else if (c_expr
*e
= dyn_cast
<c_expr
*> (o
))
2176 /* Look for captures in the C expr E. */
2179 capture_info::walk_c_expr (c_expr
*e
)
2181 /* Give up for C exprs mentioning captures not inside TREE_TYPE,
2182 TREE_REAL_CST, TREE_CODE or a predicate where they cannot
2183 really escape through. */
2184 unsigned p_depth
= 0;
2185 for (unsigned i
= 0; i
< e
->code
.length (); ++i
)
2187 const cpp_token
*t
= &e
->code
[i
];
2188 const cpp_token
*n
= i
< e
->code
.length () - 1 ? &e
->code
[i
+1] : NULL
;
2190 if (t
->type
== CPP_NAME
2191 && (strcmp ((const char *)CPP_HASHNODE
2192 (t
->val
.node
.node
)->ident
.str
, "TREE_TYPE") == 0
2193 || strcmp ((const char *)CPP_HASHNODE
2194 (t
->val
.node
.node
)->ident
.str
, "TREE_CODE") == 0
2195 || strcmp ((const char *)CPP_HASHNODE
2196 (t
->val
.node
.node
)->ident
.str
, "TREE_REAL_CST") == 0
2197 || ((id
= get_operator ((const char *)CPP_HASHNODE
2198 (t
->val
.node
.node
)->ident
.str
))
2199 && is_a
<predicate_id
*> (id
)))
2200 && n
->type
== CPP_OPEN_PAREN
)
2202 else if (t
->type
== CPP_CLOSE_PAREN
2205 else if (p_depth
== 0
2206 && t
->type
== CPP_ATSIGN
2207 && (n
->type
== CPP_NUMBER
2208 || n
->type
== CPP_NAME
)
2209 && !(n
->flags
& PREV_WHITE
))
2212 if (n
->type
== CPP_NUMBER
)
2213 id
= (const char *)n
->val
.str
.text
;
2215 id
= (const char *)CPP_HASHNODE (n
->val
.node
.node
)->ident
.str
;
2216 unsigned *where
= e
->capture_ids
->get(id
);
2218 fatal_at (n
, "unknown capture id '%s'", id
);
2219 info
[info
[*where
].same_as
].force_no_side_effects_p
= true;
2222 warning_at (t
, "capture escapes");
2228 /* Code generation off the decision tree and the refered AST nodes. */
2231 is_conversion (id_base
*op
)
2233 return (*op
== CONVERT_EXPR
2235 || *op
== FLOAT_EXPR
2236 || *op
== FIX_TRUNC_EXPR
2237 || *op
== VIEW_CONVERT_EXPR
);
2240 /* Get the type to be used for generating operand POS of OP from the
2244 get_operand_type (id_base
*op
, unsigned pos
,
2245 const char *in_type
,
2246 const char *expr_type
,
2247 const char *other_oprnd_type
)
2249 /* Generally operands whose type does not match the type of the
2250 expression generated need to know their types but match and
2251 thus can fall back to 'other_oprnd_type'. */
2252 if (is_conversion (op
))
2253 return other_oprnd_type
;
2254 else if (*op
== REALPART_EXPR
2255 || *op
== IMAGPART_EXPR
)
2256 return other_oprnd_type
;
2257 else if (is_a
<operator_id
*> (op
)
2258 && strcmp (as_a
<operator_id
*> (op
)->tcc
, "tcc_comparison") == 0)
2259 return other_oprnd_type
;
2260 else if (*op
== COND_EXPR
2262 return "boolean_type_node";
2265 /* Otherwise all types should match - choose one in order of
2272 return other_oprnd_type
;
2276 /* Generate transform code for an expression. */
2279 expr::gen_transform (FILE *f
, int indent
, const char *dest
, bool gimple
,
2280 int depth
, const char *in_type
, capture_info
*cinfo
,
2281 dt_operand
**indexes
, int)
2283 id_base
*opr
= operation
;
2284 /* When we delay operator substituting during lowering of fors we
2285 make sure that for code-gen purposes the effects of each substitute
2286 are the same. Thus just look at that. */
2287 if (user_id
*uid
= dyn_cast
<user_id
*> (opr
))
2288 opr
= uid
->substitutes
[0];
2290 bool conversion_p
= is_conversion (opr
);
2291 const char *type
= expr_type
;
2294 /* If there was a type specification in the pattern use it. */
2296 else if (conversion_p
)
2297 /* For conversions we need to build the expression using the
2298 outer type passed in. */
2300 else if (*opr
== REALPART_EXPR
2301 || *opr
== IMAGPART_EXPR
)
2303 /* __real and __imag use the component type of its operand. */
2304 sprintf (optype
, "TREE_TYPE (TREE_TYPE (ops%d[0]))", depth
);
2307 else if (is_a
<operator_id
*> (opr
)
2308 && !strcmp (as_a
<operator_id
*> (opr
)->tcc
, "tcc_comparison"))
2310 /* comparisons use boolean_type_node (or what gets in), but
2311 their operands need to figure out the types themselves. */
2316 sprintf (optype
, "boolean_type_node");
2321 else if (*opr
== COND_EXPR
2322 || *opr
== VEC_COND_EXPR
)
2324 /* Conditions are of the same type as their first alternative. */
2325 sprintf (optype
, "TREE_TYPE (ops%d[1])", depth
);
2330 /* Other operations are of the same type as their first operand. */
2331 sprintf (optype
, "TREE_TYPE (ops%d[0])", depth
);
2335 fatal_at (location
, "cannot determine type of operand");
2337 fprintf_indent (f
, indent
, "{\n");
2339 fprintf_indent (f
, indent
, "tree ops%d[%u], res;\n", depth
, ops
.length ());
2341 snprintf (op0type
, 64, "TREE_TYPE (ops%d[0])", depth
);
2342 for (unsigned i
= 0; i
< ops
.length (); ++i
)
2345 snprintf (dest
, 32, "ops%d[%u]", depth
, i
);
2347 = get_operand_type (opr
, i
, in_type
, expr_type
,
2348 i
== 0 ? NULL
: op0type
);
2349 ops
[i
]->gen_transform (f
, indent
, dest
, gimple
, depth
+ 1, optype
,
2352 || *opr
== VEC_COND_EXPR
) && i
== 0 ? 1 : 2);
2355 const char *opr_name
;
2356 if (*operation
== CONVERT_EXPR
)
2357 opr_name
= "NOP_EXPR";
2359 opr_name
= operation
->id
;
2363 if (*opr
== CONVERT_EXPR
)
2365 fprintf_indent (f
, indent
,
2366 "if (%s != TREE_TYPE (ops%d[0])\n",
2368 fprintf_indent (f
, indent
,
2369 " && !useless_type_conversion_p (%s, TREE_TYPE (ops%d[0])))\n",
2371 fprintf_indent (f
, indent
+ 2, "{\n");
2374 /* ??? Building a stmt can fail for various reasons here, seq being
2375 NULL or the stmt referencing SSA names occuring in abnormal PHIs.
2376 So if we fail here we should continue matching other patterns. */
2377 fprintf_indent (f
, indent
, "code_helper tem_code = %s;\n", opr_name
);
2378 fprintf_indent (f
, indent
, "tree tem_ops[3] = { ");
2379 for (unsigned i
= 0; i
< ops
.length (); ++i
)
2380 fprintf (f
, "ops%d[%u]%s", depth
, i
,
2381 i
== ops
.length () - 1 ? " };\n" : ", ");
2382 fprintf_indent (f
, indent
,
2383 "gimple_resimplify%d (lseq, &tem_code, %s, tem_ops, valueize);\n",
2384 ops
.length (), type
);
2385 fprintf_indent (f
, indent
,
2386 "res = maybe_push_res_to_seq (tem_code, %s, tem_ops, lseq);\n",
2388 fprintf_indent (f
, indent
,
2389 "if (!res) return false;\n");
2390 if (*opr
== CONVERT_EXPR
)
2393 fprintf_indent (f
, indent
, " }\n");
2394 fprintf_indent (f
, indent
, "else\n");
2395 fprintf_indent (f
, indent
, " res = ops%d[0];\n", depth
);
2400 if (*opr
== CONVERT_EXPR
)
2402 fprintf_indent (f
, indent
, "if (TREE_TYPE (ops%d[0]) != %s)\n",
2406 if (opr
->kind
== id_base::CODE
)
2407 fprintf_indent (f
, indent
, "res = fold_build%d_loc (loc, %s, %s",
2408 ops
.length(), opr_name
, type
);
2411 fprintf_indent (f
, indent
, "{\n");
2412 fprintf_indent (f
, indent
, " res = maybe_build_call_expr_loc (loc, "
2413 "%s, %s, %d", opr_name
, type
, ops
.length());
2415 for (unsigned i
= 0; i
< ops
.length (); ++i
)
2416 fprintf (f
, ", ops%d[%u]", depth
, i
);
2417 fprintf (f
, ");\n");
2418 if (opr
->kind
!= id_base::CODE
)
2420 fprintf_indent (f
, indent
, " if (!res)\n");
2421 fprintf_indent (f
, indent
, " return NULL_TREE;\n");
2422 fprintf_indent (f
, indent
, "}\n");
2424 if (*opr
== CONVERT_EXPR
)
2427 fprintf_indent (f
, indent
, "else\n");
2428 fprintf_indent (f
, indent
, " res = ops%d[0];\n", depth
);
2431 fprintf_indent (f
, indent
, "%s = res;\n", dest
);
2433 fprintf_indent (f
, indent
, "}\n");
2436 /* Generate code for a c_expr which is either the expression inside
2437 an if statement or a sequence of statements which computes a
2438 result to be stored to DEST. */
2441 c_expr::gen_transform (FILE *f
, int indent
, const char *dest
,
2442 bool, int, const char *, capture_info
*,
2445 if (dest
&& nr_stmts
== 1)
2446 fprintf_indent (f
, indent
, "%s = ", dest
);
2448 unsigned stmt_nr
= 1;
2449 for (unsigned i
= 0; i
< code
.length (); ++i
)
2451 const cpp_token
*token
= &code
[i
];
2453 /* Replace captures for code-gen. */
2454 if (token
->type
== CPP_ATSIGN
)
2456 const cpp_token
*n
= &code
[i
+1];
2457 if ((n
->type
== CPP_NUMBER
2458 || n
->type
== CPP_NAME
)
2459 && !(n
->flags
& PREV_WHITE
))
2461 if (token
->flags
& PREV_WHITE
)
2464 if (n
->type
== CPP_NUMBER
)
2465 id
= (const char *)n
->val
.str
.text
;
2467 id
= (const char *)CPP_HASHNODE (n
->val
.node
.node
)->ident
.str
;
2468 unsigned *cid
= capture_ids
->get (id
);
2470 fatal_at (token
, "unknown capture id");
2471 fprintf (f
, "captures[%u]", *cid
);
2477 if (token
->flags
& PREV_WHITE
)
2480 if (token
->type
== CPP_NAME
)
2482 const char *id
= (const char *) NODE_NAME (token
->val
.node
.node
);
2484 for (j
= 0; j
< ids
.length (); ++j
)
2486 if (strcmp (id
, ids
[j
].id
) == 0)
2488 fprintf (f
, "%s", ids
[j
].oper
);
2492 if (j
< ids
.length ())
2496 /* Output the token as string. */
2497 char *tk
= (char *)cpp_token_as_text (r
, token
);
2500 if (token
->type
== CPP_SEMICOLON
)
2504 if (dest
&& stmt_nr
== nr_stmts
)
2505 fprintf_indent (f
, indent
, "%s = ", dest
);
2510 /* Generate transform code for a capture. */
2513 capture::gen_transform (FILE *f
, int indent
, const char *dest
, bool gimple
,
2514 int depth
, const char *in_type
, capture_info
*cinfo
,
2515 dt_operand
**indexes
, int cond_handling
)
2517 if (what
&& is_a
<expr
*> (what
))
2519 if (indexes
[where
] == 0)
2522 sprintf (buf
, "captures[%u]", where
);
2523 what
->gen_transform (f
, indent
, buf
, gimple
, depth
, in_type
,
2528 /* If in GENERIC some capture is used multiple times, unshare it except
2529 when emitting the last use. */
2531 && cinfo
->info
.exists ()
2532 && cinfo
->info
[cinfo
->info
[where
].same_as
].result_use_count
> 1)
2534 fprintf_indent (f
, indent
, "%s = unshare_expr (captures[%u]);\n",
2536 cinfo
->info
[cinfo
->info
[where
].same_as
].result_use_count
--;
2539 fprintf_indent (f
, indent
, "%s = captures[%u];\n", dest
, where
);
2541 /* ??? Stupid tcc_comparison GENERIC trees in COND_EXPRs. Deal
2542 with substituting a capture of that. */
2544 && cond_handling
!= 0
2545 && cinfo
->info
[where
].cond_expr_cond_p
)
2547 /* If substituting into a cond_expr condition, unshare. */
2548 if (cond_handling
== 1)
2549 fprintf_indent (f
, indent
, "%s = unshare_expr (%s);\n", dest
, dest
);
2550 /* If substituting elsewhere we might need to decompose it. */
2551 else if (cond_handling
== 2)
2553 /* ??? Returning false here will also not allow any other patterns
2554 to match unless this generator was split out. */
2555 fprintf_indent (f
, indent
, "if (COMPARISON_CLASS_P (%s))\n", dest
);
2556 fprintf_indent (f
, indent
, " {\n");
2557 fprintf_indent (f
, indent
, " if (!seq) return false;\n");
2558 fprintf_indent (f
, indent
, " %s = gimple_build (seq,"
2560 " TREE_TYPE (%s), TREE_OPERAND (%s, 0),"
2561 " TREE_OPERAND (%s, 1));\n",
2562 dest
, dest
, dest
, dest
, dest
);
2563 fprintf_indent (f
, indent
, " }\n");
2568 /* Return the name of the operand representing the decision tree node.
2569 Use NAME as space to generate it. */
2572 dt_operand::get_name (char *name
)
2575 sprintf (name
, "t");
2576 else if (parent
->level
== 1)
2577 sprintf (name
, "op%u", pos
);
2578 else if (parent
->type
== dt_node::DT_MATCH
)
2579 return parent
->get_name (name
);
2581 sprintf (name
, "o%u%u", parent
->level
, pos
);
2585 /* Fill NAME with the operand name at position POS. */
2588 dt_operand::gen_opname (char *name
, unsigned pos
)
2591 sprintf (name
, "op%u", pos
);
2593 sprintf (name
, "o%u%u", level
, pos
);
2596 /* Generate matching code for the decision tree operand which is
2600 dt_operand::gen_predicate (FILE *f
, int indent
, const char *opname
, bool gimple
)
2602 predicate
*p
= as_a
<predicate
*> (op
);
2604 if (p
->p
->matchers
.exists ())
2606 /* If this is a predicate generated from a pattern mangle its
2607 name and pass on the valueize hook. */
2609 fprintf_indent (f
, indent
, "if (gimple_%s (%s, valueize))\n",
2612 fprintf_indent (f
, indent
, "if (tree_%s (%s))\n", p
->p
->id
, opname
);
2615 fprintf_indent (f
, indent
, "if (%s (%s))\n", p
->p
->id
, opname
);
2616 fprintf_indent (f
, indent
+ 2, "{\n");
2620 /* Generate matching code for the decision tree operand which is
2624 dt_operand::gen_match_op (FILE *f
, int indent
, const char *opname
, bool)
2626 char match_opname
[20];
2627 match_dop
->get_name (match_opname
);
2629 fprintf_indent (f
, indent
, "if (%s == %s || operand_equal_p (%s, %s, 0))\n",
2630 opname
, match_opname
, opname
, match_opname
);
2632 fprintf_indent (f
, indent
, "if (%s == %s || (operand_equal_p (%s, %s, 0) "
2633 "&& types_match (%s, %s)))\n",
2634 opname
, match_opname
, opname
, match_opname
,
2635 opname
, match_opname
);
2636 fprintf_indent (f
, indent
+ 2, "{\n");
2640 /* Generate GIMPLE matching code for the decision tree operand. */
2643 dt_operand::gen_gimple_expr (FILE *f
, int indent
)
2645 expr
*e
= static_cast<expr
*> (op
);
2646 id_base
*id
= e
->operation
;
2647 unsigned n_ops
= e
->ops
.length ();
2649 for (unsigned i
= 0; i
< n_ops
; ++i
)
2651 char child_opname
[20];
2652 gen_opname (child_opname
, i
);
2654 if (id
->kind
== id_base::CODE
)
2657 || *id
== REALPART_EXPR
|| *id
== IMAGPART_EXPR
2658 || *id
== BIT_FIELD_REF
|| *id
== VIEW_CONVERT_EXPR
)
2660 /* ??? If this is a memory operation we can't (and should not)
2661 match this. The only sensible operand types are
2662 SSA names and invariants. */
2667 fprintf_indent (f
, indent
,
2668 "tree %s = TREE_OPERAND (%s, %i);\n",
2669 child_opname
, opname
, i
);
2672 fprintf_indent (f
, indent
,
2673 "tree %s = TREE_OPERAND "
2674 "(gimple_assign_rhs1 (def), %i);\n",
2676 fprintf_indent (f
, indent
,
2677 "if ((TREE_CODE (%s) == SSA_NAME\n",
2679 fprintf_indent (f
, indent
,
2680 " || is_gimple_min_invariant (%s))\n",
2682 fprintf_indent (f
, indent
,
2683 " && (%s = do_valueize (valueize, %s)))\n",
2684 child_opname
, child_opname
);
2685 fprintf_indent (f
, indent
,
2691 fprintf_indent (f
, indent
,
2692 "tree %s = gimple_assign_rhs%u (def);\n",
2693 child_opname
, i
+ 1);
2696 fprintf_indent (f
, indent
,
2697 "tree %s = gimple_call_arg (def, %u);\n",
2699 fprintf_indent (f
, indent
,
2700 "if ((%s = do_valueize (valueize, %s)))\n",
2701 child_opname
, child_opname
);
2702 fprintf_indent (f
, indent
, " {\n");
2705 /* While the toplevel operands are canonicalized by the caller
2706 after valueizing operands of sub-expressions we have to
2707 re-canonicalize operand order. */
2708 if (operator_id
*code
= dyn_cast
<operator_id
*> (id
))
2710 /* ??? We can't canonicalize tcc_comparison operands here
2711 because that requires changing the comparison code which
2712 we already matched... */
2713 if (commutative_tree_code (code
->code
)
2714 || commutative_ternary_tree_code (code
->code
))
2716 char child_opname0
[20], child_opname1
[20];
2717 gen_opname (child_opname0
, 0);
2718 gen_opname (child_opname1
, 1);
2719 fprintf_indent (f
, indent
,
2720 "if (tree_swap_operands_p (%s, %s))\n",
2721 child_opname0
, child_opname1
);
2722 fprintf_indent (f
, indent
,
2723 " std::swap (%s, %s);\n",
2724 child_opname0
, child_opname1
);
2731 /* Generate GENERIC matching code for the decision tree operand. */
2734 dt_operand::gen_generic_expr (FILE *f
, int indent
, const char *opname
)
2736 expr
*e
= static_cast<expr
*> (op
);
2737 unsigned n_ops
= e
->ops
.length ();
2739 for (unsigned i
= 0; i
< n_ops
; ++i
)
2741 char child_opname
[20];
2742 gen_opname (child_opname
, i
);
2744 if (e
->operation
->kind
== id_base::CODE
)
2745 fprintf_indent (f
, indent
, "tree %s = TREE_OPERAND (%s, %u);\n",
2746 child_opname
, opname
, i
);
2748 fprintf_indent (f
, indent
, "tree %s = CALL_EXPR_ARG (%s, %u);\n",
2749 child_opname
, opname
, i
);
2755 /* Generate matching code for the children of the decision tree node. */
2758 dt_node::gen_kids (FILE *f
, int indent
, bool gimple
)
2760 auto_vec
<dt_operand
*> gimple_exprs
;
2761 auto_vec
<dt_operand
*> generic_exprs
;
2762 auto_vec
<dt_operand
*> fns
;
2763 auto_vec
<dt_operand
*> generic_fns
;
2764 auto_vec
<dt_operand
*> preds
;
2765 auto_vec
<dt_node
*> others
;
2767 for (unsigned i
= 0; i
< kids
.length (); ++i
)
2769 if (kids
[i
]->type
== dt_node::DT_OPERAND
)
2771 dt_operand
*op
= as_a
<dt_operand
*> (kids
[i
]);
2772 if (expr
*e
= dyn_cast
<expr
*> (op
->op
))
2774 if (e
->ops
.length () == 0
2775 && (!gimple
|| !(*e
->operation
== CONSTRUCTOR
)))
2776 generic_exprs
.safe_push (op
);
2777 else if (e
->operation
->kind
== id_base::FN
)
2782 generic_fns
.safe_push (op
);
2784 else if (e
->operation
->kind
== id_base::PREDICATE
)
2785 preds
.safe_push (op
);
2788 if (gimple
&& !e
->is_generic
)
2789 gimple_exprs
.safe_push (op
);
2791 generic_exprs
.safe_push (op
);
2794 else if (op
->op
->type
== operand::OP_PREDICATE
)
2795 others
.safe_push (kids
[i
]);
2799 else if (kids
[i
]->type
== dt_node::DT_SIMPLIFY
)
2800 others
.safe_push (kids
[i
]);
2801 else if (kids
[i
]->type
== dt_node::DT_MATCH
2802 || kids
[i
]->type
== dt_node::DT_TRUE
)
2804 /* A DT_TRUE operand serves as a barrier - generate code now
2805 for what we have collected sofar.
2806 Like DT_TRUE, DT_MATCH serves as a barrier as it can cause
2807 dependent matches to get out-of-order. Generate code now
2808 for what we have collected sofar. */
2809 gen_kids_1 (f
, indent
, gimple
, gimple_exprs
, generic_exprs
,
2810 fns
, generic_fns
, preds
, others
);
2811 /* And output the true operand itself. */
2812 kids
[i
]->gen (f
, indent
, gimple
);
2813 gimple_exprs
.truncate (0);
2814 generic_exprs
.truncate (0);
2816 generic_fns
.truncate (0);
2818 others
.truncate (0);
2824 /* Generate code for the remains. */
2825 gen_kids_1 (f
, indent
, gimple
, gimple_exprs
, generic_exprs
,
2826 fns
, generic_fns
, preds
, others
);
2829 /* Generate matching code for the children of the decision tree node. */
2832 dt_node::gen_kids_1 (FILE *f
, int indent
, bool gimple
,
2833 vec
<dt_operand
*> gimple_exprs
,
2834 vec
<dt_operand
*> generic_exprs
,
2835 vec
<dt_operand
*> fns
,
2836 vec
<dt_operand
*> generic_fns
,
2837 vec
<dt_operand
*> preds
,
2838 vec
<dt_node
*> others
)
2841 char *kid_opname
= buf
;
2843 unsigned exprs_len
= gimple_exprs
.length ();
2844 unsigned gexprs_len
= generic_exprs
.length ();
2845 unsigned fns_len
= fns
.length ();
2846 unsigned gfns_len
= generic_fns
.length ();
2848 if (exprs_len
|| fns_len
|| gexprs_len
|| gfns_len
)
2851 gimple_exprs
[0]->get_name (kid_opname
);
2853 fns
[0]->get_name (kid_opname
);
2855 generic_fns
[0]->get_name (kid_opname
);
2857 generic_exprs
[0]->get_name (kid_opname
);
2859 fprintf_indent (f
, indent
, "switch (TREE_CODE (%s))\n", kid_opname
);
2860 fprintf_indent (f
, indent
, " {\n");
2864 if (exprs_len
|| fns_len
)
2866 fprintf_indent (f
, indent
,
2867 "case SSA_NAME:\n");
2868 fprintf_indent (f
, indent
,
2869 " if (do_valueize (valueize, %s) != NULL_TREE)\n",
2871 fprintf_indent (f
, indent
,
2873 fprintf_indent (f
, indent
,
2874 " gimple *def_stmt = SSA_NAME_DEF_STMT (%s);\n",
2880 fprintf_indent (f
, indent
,
2881 "if (gassign *def = dyn_cast <gassign *> (def_stmt))\n");
2882 fprintf_indent (f
, indent
,
2883 " switch (gimple_assign_rhs_code (def))\n");
2885 fprintf_indent (f
, indent
, "{\n");
2886 for (unsigned i
= 0; i
< exprs_len
; ++i
)
2888 expr
*e
= as_a
<expr
*> (gimple_exprs
[i
]->op
);
2889 id_base
*op
= e
->operation
;
2890 if (*op
== CONVERT_EXPR
|| *op
== NOP_EXPR
)
2891 fprintf_indent (f
, indent
, "CASE_CONVERT:\n");
2893 fprintf_indent (f
, indent
, "case %s:\n", op
->id
);
2894 fprintf_indent (f
, indent
, " {\n");
2895 gimple_exprs
[i
]->gen (f
, indent
+ 4, true);
2896 fprintf_indent (f
, indent
, " break;\n");
2897 fprintf_indent (f
, indent
, " }\n");
2899 fprintf_indent (f
, indent
, "default:;\n");
2900 fprintf_indent (f
, indent
, "}\n");
2906 fprintf_indent (f
, indent
,
2907 "%sif (gcall *def = dyn_cast <gcall *>"
2909 exprs_len
? "else " : "");
2910 fprintf_indent (f
, indent
,
2911 " switch (gimple_call_combined_fn (def))\n");
2914 fprintf_indent (f
, indent
, "{\n");
2915 for (unsigned i
= 0; i
< fns_len
; ++i
)
2917 expr
*e
= as_a
<expr
*>(fns
[i
]->op
);
2918 fprintf_indent (f
, indent
, "case %s:\n", e
->operation
->id
);
2919 fprintf_indent (f
, indent
, " {\n");
2920 fns
[i
]->gen (f
, indent
+ 4, true);
2921 fprintf_indent (f
, indent
, " break;\n");
2922 fprintf_indent (f
, indent
, " }\n");
2925 fprintf_indent (f
, indent
, "default:;\n");
2926 fprintf_indent (f
, indent
, "}\n");
2931 fprintf_indent (f
, indent
, " }\n");
2932 /* See if there is SSA_NAME among generic_exprs and if yes, emit it
2933 here rather than in the next loop. */
2934 for (unsigned i
= 0; i
< generic_exprs
.length (); ++i
)
2936 expr
*e
= as_a
<expr
*>(generic_exprs
[i
]->op
);
2937 id_base
*op
= e
->operation
;
2938 if (*op
== SSA_NAME
&& (exprs_len
|| fns_len
))
2940 fprintf_indent (f
, indent
+ 4, "{\n");
2941 generic_exprs
[i
]->gen (f
, indent
+ 6, gimple
);
2942 fprintf_indent (f
, indent
+ 4, "}\n");
2946 fprintf_indent (f
, indent
, " break;\n");
2949 for (unsigned i
= 0; i
< generic_exprs
.length (); ++i
)
2951 expr
*e
= as_a
<expr
*>(generic_exprs
[i
]->op
);
2952 id_base
*op
= e
->operation
;
2953 if (*op
== CONVERT_EXPR
|| *op
== NOP_EXPR
)
2954 fprintf_indent (f
, indent
, "CASE_CONVERT:\n");
2955 else if (*op
== SSA_NAME
&& (exprs_len
|| fns_len
))
2956 /* Already handled above. */
2959 fprintf_indent (f
, indent
, "case %s:\n", op
->id
);
2960 fprintf_indent (f
, indent
, " {\n");
2961 generic_exprs
[i
]->gen (f
, indent
+ 4, gimple
);
2962 fprintf_indent (f
, indent
, " break;\n");
2963 fprintf_indent (f
, indent
, " }\n");
2968 fprintf_indent (f
, indent
,
2969 "case CALL_EXPR:\n");
2970 fprintf_indent (f
, indent
,
2971 " switch (get_call_combined_fn (%s))\n",
2973 fprintf_indent (f
, indent
,
2977 for (unsigned j
= 0; j
< generic_fns
.length (); ++j
)
2979 expr
*e
= as_a
<expr
*>(generic_fns
[j
]->op
);
2980 gcc_assert (e
->operation
->kind
== id_base::FN
);
2982 fprintf_indent (f
, indent
, "case %s:\n", e
->operation
->id
);
2983 fprintf_indent (f
, indent
, " {\n");
2984 generic_fns
[j
]->gen (f
, indent
+ 4, false);
2985 fprintf_indent (f
, indent
, " break;\n");
2986 fprintf_indent (f
, indent
, " }\n");
2988 fprintf_indent (f
, indent
, "default:;\n");
2991 fprintf_indent (f
, indent
, " }\n");
2992 fprintf_indent (f
, indent
, " break;\n");
2995 /* Close switch (TREE_CODE ()). */
2996 if (exprs_len
|| fns_len
|| gexprs_len
|| gfns_len
)
2999 fprintf_indent (f
, indent
, " default:;\n");
3000 fprintf_indent (f
, indent
, " }\n");
3003 for (unsigned i
= 0; i
< preds
.length (); ++i
)
3005 expr
*e
= as_a
<expr
*> (preds
[i
]->op
);
3006 predicate_id
*p
= as_a
<predicate_id
*> (e
->operation
);
3007 preds
[i
]->get_name (kid_opname
);
3008 fprintf_indent (f
, indent
, "tree %s_pops[%d];\n", kid_opname
, p
->nargs
);
3009 fprintf_indent (f
, indent
, "if (%s_%s (%s, %s_pops%s))\n",
3010 gimple
? "gimple" : "tree",
3011 p
->id
, kid_opname
, kid_opname
,
3012 gimple
? ", valueize" : "");
3013 fprintf_indent (f
, indent
, " {\n");
3014 for (int j
= 0; j
< p
->nargs
; ++j
)
3016 char child_opname
[20];
3017 preds
[i
]->gen_opname (child_opname
, j
);
3018 fprintf_indent (f
, indent
+ 4, "tree %s = %s_pops[%d];\n",
3019 child_opname
, kid_opname
, j
);
3021 preds
[i
]->gen_kids (f
, indent
+ 4, gimple
);
3025 for (unsigned i
= 0; i
< others
.length (); ++i
)
3026 others
[i
]->gen (f
, indent
, gimple
);
3029 /* Generate matching code for the decision tree operand. */
3032 dt_operand::gen (FILE *f
, int indent
, bool gimple
)
3037 unsigned n_braces
= 0;
3039 if (type
== DT_OPERAND
)
3042 case operand::OP_PREDICATE
:
3043 n_braces
= gen_predicate (f
, indent
, opname
, gimple
);
3046 case operand::OP_EXPR
:
3048 n_braces
= gen_gimple_expr (f
, indent
);
3050 n_braces
= gen_generic_expr (f
, indent
, opname
);
3056 else if (type
== DT_TRUE
)
3058 else if (type
== DT_MATCH
)
3059 n_braces
= gen_match_op (f
, indent
, opname
, gimple
);
3063 indent
+= 4 * n_braces
;
3064 gen_kids (f
, indent
, gimple
);
3066 for (unsigned i
= 0; i
< n_braces
; ++i
)
3071 fprintf_indent (f
, indent
, " }\n");
3076 /* Generate code for the '(if ...)', '(with ..)' and actual transform
3077 step of a '(simplify ...)' or '(match ...)'. This handles everything
3078 that is not part of the decision tree (simplify->match).
3079 Main recursive worker. */
3082 dt_simplify::gen_1 (FILE *f
, int indent
, bool gimple
, operand
*result
)
3086 if (with_expr
*w
= dyn_cast
<with_expr
*> (result
))
3088 fprintf_indent (f
, indent
, "{\n");
3090 output_line_directive (f
, w
->location
);
3091 w
->with
->gen_transform (f
, indent
, NULL
, true, 1, "type", NULL
);
3092 gen_1 (f
, indent
, gimple
, w
->subexpr
);
3094 fprintf_indent (f
, indent
, "}\n");
3097 else if (if_expr
*ife
= dyn_cast
<if_expr
*> (result
))
3099 output_line_directive (f
, ife
->location
);
3100 fprintf_indent (f
, indent
, "if (");
3101 ife
->cond
->gen_transform (f
, indent
, NULL
, true, 1, "type", NULL
);
3103 fprintf_indent (f
, indent
+ 2, "{\n");
3105 gen_1 (f
, indent
, gimple
, ife
->trueexpr
);
3107 fprintf_indent (f
, indent
+ 2, "}\n");
3110 fprintf_indent (f
, indent
, "else\n");
3111 fprintf_indent (f
, indent
+ 2, "{\n");
3113 gen_1 (f
, indent
, gimple
, ife
->falseexpr
);
3115 fprintf_indent (f
, indent
+ 2, "}\n");
3121 /* Analyze captures and perform early-outs on the incoming arguments
3122 that cover cases we cannot handle. */
3123 capture_info
cinfo (s
, result
, gimple
);
3124 if (s
->kind
== simplify::SIMPLIFY
)
3128 for (unsigned i
= 0; i
< as_a
<expr
*> (s
->match
)->ops
.length (); ++i
)
3129 if (cinfo
.force_no_side_effects
& (1 << i
))
3131 fprintf_indent (f
, indent
,
3132 "if (TREE_SIDE_EFFECTS (op%d)) return NULL_TREE;\n",
3135 warning_at (as_a
<expr
*> (s
->match
)->ops
[i
]->location
,
3136 "forcing toplevel operand to have no "
3139 for (int i
= 0; i
<= s
->capture_max
; ++i
)
3140 if (cinfo
.info
[i
].cse_p
)
3142 else if (cinfo
.info
[i
].force_no_side_effects_p
3143 && (cinfo
.info
[i
].toplevel_msk
3144 & cinfo
.force_no_side_effects
) == 0)
3146 fprintf_indent (f
, indent
,
3147 "if (TREE_SIDE_EFFECTS (captures[%d])) "
3148 "return NULL_TREE;\n", i
);
3150 warning_at (cinfo
.info
[i
].c
->location
,
3151 "forcing captured operand to have no "
3154 else if ((cinfo
.info
[i
].toplevel_msk
3155 & cinfo
.force_no_side_effects
) != 0)
3156 /* Mark capture as having no side-effects if we had to verify
3157 that via forced toplevel operand checks. */
3158 cinfo
.info
[i
].force_no_side_effects_p
= true;
3162 /* Force single-use restriction by only allowing simple
3163 results via setting seq to NULL. */
3164 fprintf_indent (f
, indent
, "gimple_seq *lseq = seq;\n");
3165 bool first_p
= true;
3166 for (int i
= 0; i
<= s
->capture_max
; ++i
)
3167 if (cinfo
.info
[i
].force_single_use
)
3171 fprintf_indent (f
, indent
, "if (lseq\n");
3172 fprintf_indent (f
, indent
, " && (");
3178 fprintf_indent (f
, indent
, " || ");
3180 fprintf (f
, "!single_use (captures[%d])", i
);
3184 fprintf (f
, "))\n");
3185 fprintf_indent (f
, indent
, " lseq = NULL;\n");
3190 fprintf_indent (f
, indent
, "if (dump_file && (dump_flags & TDF_DETAILS)) "
3191 "fprintf (dump_file, \"Applying pattern ");
3192 output_line_directive (f
,
3193 result
? result
->location
: s
->match
->location
, true);
3194 fprintf (f
, ", %%s:%%d\\n\", __FILE__, __LINE__);\n");
3198 /* If there is no result then this is a predicate implementation. */
3199 fprintf_indent (f
, indent
, "return true;\n");
3203 /* For GIMPLE simply drop NON_LVALUE_EXPR (which only appears
3204 in outermost position). */
3205 if (result
->type
== operand::OP_EXPR
3206 && *as_a
<expr
*> (result
)->operation
== NON_LVALUE_EXPR
)
3207 result
= as_a
<expr
*> (result
)->ops
[0];
3208 if (result
->type
== operand::OP_EXPR
)
3210 expr
*e
= as_a
<expr
*> (result
);
3211 id_base
*opr
= e
->operation
;
3212 bool is_predicate
= false;
3213 /* When we delay operator substituting during lowering of fors we
3214 make sure that for code-gen purposes the effects of each substitute
3215 are the same. Thus just look at that. */
3216 if (user_id
*uid
= dyn_cast
<user_id
*> (opr
))
3217 opr
= uid
->substitutes
[0];
3218 else if (is_a
<predicate_id
*> (opr
))
3219 is_predicate
= true;
3221 fprintf_indent (f
, indent
, "*res_code = %s;\n",
3222 *e
->operation
== CONVERT_EXPR
3223 ? "NOP_EXPR" : e
->operation
->id
);
3224 for (unsigned j
= 0; j
< e
->ops
.length (); ++j
)
3227 snprintf (dest
, 32, "res_ops[%d]", j
);
3229 = get_operand_type (opr
, j
,
3230 "type", e
->expr_type
,
3231 j
== 0 ? NULL
: "TREE_TYPE (res_ops[0])");
3232 /* We need to expand GENERIC conditions we captured from
3233 COND_EXPRs and we need to unshare them when substituting
3235 int cond_handling
= 0;
3237 cond_handling
= ((*opr
== COND_EXPR
3238 || *opr
== VEC_COND_EXPR
) && j
== 0) ? 1 : 2;
3239 e
->ops
[j
]->gen_transform (f
, indent
, dest
, true, 1, optype
,
3240 &cinfo
, indexes
, cond_handling
);
3243 /* Re-fold the toplevel result. It's basically an embedded
3244 gimple_build w/o actually building the stmt. */
3246 fprintf_indent (f
, indent
,
3247 "gimple_resimplify%d (lseq, res_code, type, "
3248 "res_ops, valueize);\n", e
->ops
.length ());
3250 else if (result
->type
== operand::OP_CAPTURE
3251 || result
->type
== operand::OP_C_EXPR
)
3253 result
->gen_transform (f
, indent
, "res_ops[0]", true, 1, "type",
3255 fprintf_indent (f
, indent
, "*res_code = TREE_CODE (res_ops[0]);\n");
3256 if (is_a
<capture
*> (result
)
3257 && cinfo
.info
[as_a
<capture
*> (result
)->where
].cond_expr_cond_p
)
3259 /* ??? Stupid tcc_comparison GENERIC trees in COND_EXPRs. Deal
3260 with substituting a capture of that. */
3261 fprintf_indent (f
, indent
,
3262 "if (COMPARISON_CLASS_P (res_ops[0]))\n");
3263 fprintf_indent (f
, indent
,
3265 fprintf_indent (f
, indent
,
3266 " tree tem = res_ops[0];\n");
3267 fprintf_indent (f
, indent
,
3268 " res_ops[0] = TREE_OPERAND (tem, 0);\n");
3269 fprintf_indent (f
, indent
,
3270 " res_ops[1] = TREE_OPERAND (tem, 1);\n");
3271 fprintf_indent (f
, indent
,
3277 fprintf_indent (f
, indent
, "return true;\n");
3281 bool is_predicate
= false;
3282 if (result
->type
== operand::OP_EXPR
)
3284 expr
*e
= as_a
<expr
*> (result
);
3285 id_base
*opr
= e
->operation
;
3286 /* When we delay operator substituting during lowering of fors we
3287 make sure that for code-gen purposes the effects of each substitute
3288 are the same. Thus just look at that. */
3289 if (user_id
*uid
= dyn_cast
<user_id
*> (opr
))
3290 opr
= uid
->substitutes
[0];
3291 else if (is_a
<predicate_id
*> (opr
))
3292 is_predicate
= true;
3293 /* Search for captures used multiple times in the result expression
3294 and wrap them in a SAVE_EXPR. Allow as many uses as in the
3295 original expression. */
3297 for (int i
= 0; i
< s
->capture_max
+ 1; ++i
)
3299 if (cinfo
.info
[i
].same_as
!= (unsigned)i
3300 || cinfo
.info
[i
].cse_p
)
3302 if (cinfo
.info
[i
].result_use_count
3303 > cinfo
.info
[i
].match_use_count
)
3304 fprintf_indent (f
, indent
,
3305 "if (! tree_invariant_p (captures[%d])) "
3306 "return NULL_TREE;\n", i
);
3308 for (unsigned j
= 0; j
< e
->ops
.length (); ++j
)
3312 snprintf (dest
, 32, "res_ops[%d]", j
);
3315 fprintf_indent (f
, indent
, "tree res_op%d;\n", j
);
3316 snprintf (dest
, 32, "res_op%d", j
);
3319 = get_operand_type (opr
, j
,
3320 "type", e
->expr_type
,
3322 ? NULL
: "TREE_TYPE (res_op0)");
3323 e
->ops
[j
]->gen_transform (f
, indent
, dest
, false, 1, optype
,
3327 fprintf_indent (f
, indent
, "return true;\n");
3330 fprintf_indent (f
, indent
, "tree res;\n");
3331 /* Re-fold the toplevel result. Use non_lvalue to
3332 build NON_LVALUE_EXPRs so they get properly
3333 ignored when in GIMPLE form. */
3334 if (*opr
== NON_LVALUE_EXPR
)
3335 fprintf_indent (f
, indent
,
3336 "res = non_lvalue_loc (loc, res_op0);\n");
3339 if (is_a
<operator_id
*> (opr
))
3340 fprintf_indent (f
, indent
,
3341 "res = fold_build%d_loc (loc, %s, type",
3343 *e
->operation
== CONVERT_EXPR
3344 ? "NOP_EXPR" : e
->operation
->id
);
3346 fprintf_indent (f
, indent
,
3347 "res = maybe_build_call_expr_loc (loc, "
3348 "%s, type, %d", e
->operation
->id
,
3350 for (unsigned j
= 0; j
< e
->ops
.length (); ++j
)
3351 fprintf (f
, ", res_op%d", j
);
3352 fprintf (f
, ");\n");
3353 if (!is_a
<operator_id
*> (opr
))
3355 fprintf_indent (f
, indent
, "if (!res)\n");
3356 fprintf_indent (f
, indent
, " return NULL_TREE;\n");
3361 else if (result
->type
== operand::OP_CAPTURE
3362 || result
->type
== operand::OP_C_EXPR
)
3365 fprintf_indent (f
, indent
, "tree res;\n");
3366 result
->gen_transform (f
, indent
, "res", false, 1, "type",
3373 /* Search for captures not used in the result expression and dependent
3374 on TREE_SIDE_EFFECTS emit omit_one_operand. */
3375 for (int i
= 0; i
< s
->capture_max
+ 1; ++i
)
3377 if (cinfo
.info
[i
].same_as
!= (unsigned)i
)
3379 if (!cinfo
.info
[i
].force_no_side_effects_p
3380 && !cinfo
.info
[i
].expr_p
3381 && cinfo
.info
[i
].result_use_count
== 0)
3383 fprintf_indent (f
, indent
,
3384 "if (TREE_SIDE_EFFECTS (captures[%d]))\n",
3386 fprintf_indent (f
, indent
+ 2,
3387 "res = build2_loc (loc, COMPOUND_EXPR, type, "
3388 "fold_ignored_result (captures[%d]), res);\n",
3392 fprintf_indent (f
, indent
, "return res;\n");
3397 /* Generate code for the '(if ...)', '(with ..)' and actual transform
3398 step of a '(simplify ...)' or '(match ...)'. This handles everything
3399 that is not part of the decision tree (simplify->match). */
3402 dt_simplify::gen (FILE *f
, int indent
, bool gimple
)
3404 fprintf_indent (f
, indent
, "{\n");
3406 output_line_directive (f
,
3407 s
->result
? s
->result
->location
: s
->match
->location
);
3408 if (s
->capture_max
>= 0)
3411 fprintf_indent (f
, indent
, "tree captures[%u] ATTRIBUTE_UNUSED = { %s",
3412 s
->capture_max
+ 1, indexes
[0]->get_name (opname
));
3414 for (int i
= 1; i
<= s
->capture_max
; ++i
)
3418 fprintf (f
, ", %s", indexes
[i
]->get_name (opname
));
3420 fprintf (f
, " };\n");
3423 /* If we have a split-out function for the actual transform, call it. */
3424 if (info
&& info
->fname
)
3428 fprintf_indent (f
, indent
, "if (%s (res_code, res_ops, seq, "
3429 "valueize, type, captures", info
->fname
);
3430 for (unsigned i
= 0; i
< s
->for_subst_vec
.length (); ++i
)
3431 if (s
->for_subst_vec
[i
].first
->used
)
3432 fprintf (f
, ", %s", s
->for_subst_vec
[i
].second
->id
);
3433 fprintf (f
, "))\n");
3434 fprintf_indent (f
, indent
, " return true;\n");
3438 fprintf_indent (f
, indent
, "tree res = %s (loc, type",
3440 for (unsigned i
= 0; i
< as_a
<expr
*> (s
->match
)->ops
.length (); ++i
)
3441 fprintf (f
, ", op%d", i
);
3442 fprintf (f
, ", captures");
3443 for (unsigned i
= 0; i
< s
->for_subst_vec
.length (); ++i
)
3445 if (s
->for_subst_vec
[i
].first
->used
)
3446 fprintf (f
, ", %s", s
->for_subst_vec
[i
].second
->id
);
3448 fprintf (f
, ");\n");
3449 fprintf_indent (f
, indent
, "if (res) return res;\n");
3454 for (unsigned i
= 0; i
< s
->for_subst_vec
.length (); ++i
)
3456 if (! s
->for_subst_vec
[i
].first
->used
)
3458 if (is_a
<operator_id
*> (s
->for_subst_vec
[i
].second
))
3459 fprintf_indent (f
, indent
, "enum tree_code %s = %s;\n",
3460 s
->for_subst_vec
[i
].first
->id
,
3461 s
->for_subst_vec
[i
].second
->id
);
3462 else if (is_a
<fn_id
*> (s
->for_subst_vec
[i
].second
))
3463 fprintf_indent (f
, indent
, "combined_fn %s = %s;\n",
3464 s
->for_subst_vec
[i
].first
->id
,
3465 s
->for_subst_vec
[i
].second
->id
);
3469 gen_1 (f
, indent
, gimple
, s
->result
);
3473 fprintf_indent (f
, indent
, "}\n");
3477 /* Hash function for finding equivalent transforms. */
3480 sinfo_hashmap_traits::hash (const key_type
&v
)
3482 /* Only bother to compare those originating from the same source pattern. */
3483 return v
->s
->result
->location
;
3486 /* Compare function for finding equivalent transforms. */
3489 compare_op (operand
*o1
, simplify
*s1
, operand
*o2
, simplify
*s2
)
3491 if (o1
->type
!= o2
->type
)
3496 case operand::OP_IF
:
3498 if_expr
*if1
= as_a
<if_expr
*> (o1
);
3499 if_expr
*if2
= as_a
<if_expr
*> (o2
);
3500 /* ??? Properly compare c-exprs. */
3501 if (if1
->cond
!= if2
->cond
)
3503 if (!compare_op (if1
->trueexpr
, s1
, if2
->trueexpr
, s2
))
3505 if (if1
->falseexpr
!= if2
->falseexpr
3507 && !compare_op (if1
->falseexpr
, s1
, if2
->falseexpr
, s2
)))
3511 case operand::OP_WITH
:
3513 with_expr
*with1
= as_a
<with_expr
*> (o1
);
3514 with_expr
*with2
= as_a
<with_expr
*> (o2
);
3515 if (with1
->with
!= with2
->with
)
3517 return compare_op (with1
->subexpr
, s1
, with2
->subexpr
, s2
);
3522 /* We've hit a result. Time to compare capture-infos - this is required
3523 in addition to the conservative pointer-equivalency of the result IL. */
3524 capture_info
cinfo1 (s1
, o1
, true);
3525 capture_info
cinfo2 (s2
, o2
, true);
3527 if (cinfo1
.force_no_side_effects
!= cinfo2
.force_no_side_effects
3528 || cinfo1
.info
.length () != cinfo2
.info
.length ())
3531 for (unsigned i
= 0; i
< cinfo1
.info
.length (); ++i
)
3533 if (cinfo1
.info
[i
].expr_p
!= cinfo2
.info
[i
].expr_p
3534 || cinfo1
.info
[i
].cse_p
!= cinfo2
.info
[i
].cse_p
3535 || (cinfo1
.info
[i
].force_no_side_effects_p
3536 != cinfo2
.info
[i
].force_no_side_effects_p
)
3537 || cinfo1
.info
[i
].force_single_use
!= cinfo2
.info
[i
].force_single_use
3538 || cinfo1
.info
[i
].cond_expr_cond_p
!= cinfo2
.info
[i
].cond_expr_cond_p
3539 /* toplevel_msk is an optimization */
3540 || cinfo1
.info
[i
].result_use_count
!= cinfo2
.info
[i
].result_use_count
3541 || cinfo1
.info
[i
].same_as
!= cinfo2
.info
[i
].same_as
3542 /* the pointer back to the capture is for diagnostics only */)
3546 /* ??? Deep-compare the actual result. */
3551 sinfo_hashmap_traits::equal_keys (const key_type
&v
,
3552 const key_type
&candidate
)
3554 return compare_op (v
->s
->result
, v
->s
, candidate
->s
->result
, candidate
->s
);
3558 /* Main entry to generate code for matching GIMPLE IL off the decision
3562 decision_tree::gen (FILE *f
, bool gimple
)
3568 fprintf (stderr
, "%s decision tree has %u leafs, maximum depth %u and "
3569 "a total number of %u nodes\n",
3570 gimple
? "GIMPLE" : "GENERIC",
3571 root
->num_leafs
, root
->max_level
, root
->total_size
);
3573 /* First split out the transform part of equal leafs. */
3576 for (sinfo_map_t::iterator iter
= si
.begin ();
3577 iter
!= si
.end (); ++iter
)
3579 sinfo
*s
= (*iter
).second
;
3580 /* Do not split out single uses. */
3587 fprintf (stderr
, "found %u uses of", s
->cnt
);
3588 output_line_directive (stderr
, s
->s
->s
->result
->location
);
3591 /* Generate a split out function with the leaf transform code. */
3592 s
->fname
= xasprintf ("%s_simplify_%u", gimple
? "gimple" : "generic",
3595 fprintf (f
, "\nstatic bool\n"
3596 "%s (code_helper *res_code, tree *res_ops,\n"
3597 " gimple_seq *seq, tree (*valueize)(tree) "
3598 "ATTRIBUTE_UNUSED,\n"
3599 " tree ARG_UNUSED (type), tree *ARG_UNUSED "
3604 fprintf (f
, "\nstatic tree\n"
3605 "%s (location_t ARG_UNUSED (loc), tree ARG_UNUSED (type),\n",
3606 (*iter
).second
->fname
);
3607 for (unsigned i
= 0;
3608 i
< as_a
<expr
*>(s
->s
->s
->match
)->ops
.length (); ++i
)
3609 fprintf (f
, " tree ARG_UNUSED (op%d),", i
);
3610 fprintf (f
, " tree *captures\n");
3612 for (unsigned i
= 0; i
< s
->s
->s
->for_subst_vec
.length (); ++i
)
3614 if (! s
->s
->s
->for_subst_vec
[i
].first
->used
)
3616 if (is_a
<operator_id
*> (s
->s
->s
->for_subst_vec
[i
].second
))
3617 fprintf (f
, ", enum tree_code ARG_UNUSED (%s)",
3618 s
->s
->s
->for_subst_vec
[i
].first
->id
);
3619 else if (is_a
<fn_id
*> (s
->s
->s
->for_subst_vec
[i
].second
))
3620 fprintf (f
, ", combined_fn ARG_UNUSED (%s)",
3621 s
->s
->s
->for_subst_vec
[i
].first
->id
);
3624 fprintf (f
, ")\n{\n");
3625 s
->s
->gen_1 (f
, 2, gimple
, s
->s
->s
->result
);
3627 fprintf (f
, " return false;\n");
3629 fprintf (f
, " return NULL_TREE;\n");
3632 fprintf (stderr
, "removed %u duplicate tails\n", rcnt
);
3634 for (unsigned n
= 1; n
<= 3; ++n
)
3636 /* First generate split-out functions. */
3637 for (unsigned i
= 0; i
< root
->kids
.length (); i
++)
3639 dt_operand
*dop
= static_cast<dt_operand
*>(root
->kids
[i
]);
3640 expr
*e
= static_cast<expr
*>(dop
->op
);
3641 if (e
->ops
.length () != n
3642 /* Builtin simplifications are somewhat premature on
3643 GENERIC. The following drops patterns with outermost
3644 calls. It's easy to emit overloads for function code
3645 though if necessary. */
3647 && e
->operation
->kind
!= id_base::CODE
))
3651 fprintf (f
, "\nstatic bool\n"
3652 "gimple_simplify_%s (code_helper *res_code, tree *res_ops,\n"
3653 " gimple_seq *seq, tree (*valueize)(tree) "
3654 "ATTRIBUTE_UNUSED,\n"
3655 " code_helper ARG_UNUSED (code), tree "
3656 "ARG_UNUSED (type)\n",
3659 fprintf (f
, "\nstatic tree\n"
3660 "generic_simplify_%s (location_t ARG_UNUSED (loc), enum "
3661 "tree_code ARG_UNUSED (code), tree ARG_UNUSED (type)",
3663 for (unsigned i
= 0; i
< n
; ++i
)
3664 fprintf (f
, ", tree op%d", i
);
3667 dop
->gen_kids (f
, 2, gimple
);
3669 fprintf (f
, " return false;\n");
3671 fprintf (f
, " return NULL_TREE;\n");
3675 /* Then generate the main entry with the outermost switch and
3676 tail-calls to the split-out functions. */
3678 fprintf (f
, "\nstatic bool\n"
3679 "gimple_simplify (code_helper *res_code, tree *res_ops,\n"
3680 " gimple_seq *seq, tree (*valueize)(tree),\n"
3681 " code_helper code, tree type");
3683 fprintf (f
, "\ntree\n"
3684 "generic_simplify (location_t loc, enum tree_code code, "
3685 "tree type ATTRIBUTE_UNUSED");
3686 for (unsigned i
= 0; i
< n
; ++i
)
3687 fprintf (f
, ", tree op%d", i
);
3692 fprintf (f
, " switch (code.get_rep())\n"
3695 fprintf (f
, " switch (code)\n"
3697 for (unsigned i
= 0; i
< root
->kids
.length (); i
++)
3699 dt_operand
*dop
= static_cast<dt_operand
*>(root
->kids
[i
]);
3700 expr
*e
= static_cast<expr
*>(dop
->op
);
3701 if (e
->ops
.length () != n
3702 /* Builtin simplifications are somewhat premature on
3703 GENERIC. The following drops patterns with outermost
3704 calls. It's easy to emit overloads for function code
3705 though if necessary. */
3707 && e
->operation
->kind
!= id_base::CODE
))
3710 if (*e
->operation
== CONVERT_EXPR
3711 || *e
->operation
== NOP_EXPR
)
3712 fprintf (f
, " CASE_CONVERT:\n");
3714 fprintf (f
, " case %s%s:\n",
3715 is_a
<fn_id
*> (e
->operation
) ? "-" : "",
3718 fprintf (f
, " return gimple_simplify_%s (res_code, res_ops, "
3719 "seq, valueize, code, type", e
->operation
->id
);
3721 fprintf (f
, " return generic_simplify_%s (loc, code, type",
3723 for (unsigned i
= 0; i
< n
; ++i
)
3724 fprintf (f
, ", op%d", i
);
3725 fprintf (f
, ");\n");
3727 fprintf (f
, " default:;\n"
3731 fprintf (f
, " return false;\n");
3733 fprintf (f
, " return NULL_TREE;\n");
3738 /* Output code to implement the predicate P from the decision tree DT. */
3741 write_predicate (FILE *f
, predicate_id
*p
, decision_tree
&dt
, bool gimple
)
3743 fprintf (f
, "\nbool\n"
3744 "%s%s (tree t%s%s)\n"
3745 "{\n", gimple
? "gimple_" : "tree_", p
->id
,
3746 p
->nargs
> 0 ? ", tree *res_ops" : "",
3747 gimple
? ", tree (*valueize)(tree) ATTRIBUTE_UNUSED" : "");
3748 /* Conveniently make 'type' available. */
3749 fprintf_indent (f
, 2, "tree type = TREE_TYPE (t);\n");
3752 fprintf_indent (f
, 2, "if (TREE_SIDE_EFFECTS (t)) return false;\n");
3753 dt
.root
->gen_kids (f
, 2, gimple
);
3755 fprintf_indent (f
, 2, "return false;\n"
3759 /* Write the common header for the GIMPLE/GENERIC IL matching routines. */
3762 write_header (FILE *f
, const char *head
)
3764 fprintf (f
, "/* Generated automatically by the program `genmatch' from\n");
3765 fprintf (f
, " a IL pattern matching and simplification description. */\n");
3767 /* Include the header instead of writing it awkwardly quoted here. */
3768 fprintf (f
, "\n#include \"%s\"\n", head
);
3778 parser (cpp_reader
*);
3781 const cpp_token
*next ();
3782 const cpp_token
*peek (unsigned = 1);
3783 const cpp_token
*peek_ident (const char * = NULL
, unsigned = 1);
3784 const cpp_token
*expect (enum cpp_ttype
);
3785 const cpp_token
*eat_token (enum cpp_ttype
);
3786 const char *get_string ();
3787 const char *get_ident ();
3788 const cpp_token
*eat_ident (const char *);
3789 const char *get_number ();
3791 unsigned get_internal_capture_id ();
3793 id_base
*parse_operation ();
3794 operand
*parse_capture (operand
*, bool);
3795 operand
*parse_expr ();
3796 c_expr
*parse_c_expr (cpp_ttype
);
3797 operand
*parse_op ();
3799 void record_operlist (source_location
, user_id
*);
3801 void parse_pattern ();
3802 operand
*parse_result (operand
*, predicate_id
*);
3803 void push_simplify (simplify::simplify_kind
,
3804 vec
<simplify
*>&, operand
*, operand
*);
3805 void parse_simplify (simplify::simplify_kind
,
3806 vec
<simplify
*>&, predicate_id
*, operand
*);
3807 void parse_for (source_location
);
3808 void parse_if (source_location
);
3809 void parse_predicates (source_location
);
3810 void parse_operator_list (source_location
);
3812 void finish_match_operand (operand
*);
3815 vec
<c_expr
*> active_ifs
;
3816 vec
<vec
<user_id
*> > active_fors
;
3817 hash_set
<user_id
*> *oper_lists_set
;
3818 vec
<user_id
*> oper_lists
;
3820 cid_map_t
*capture_ids
;
3823 vec
<simplify
*> simplifiers
;
3824 vec
<predicate_id
*> user_predicates
;
3825 bool parsing_match_operand
;
3828 /* Lexing helpers. */
3830 /* Read the next non-whitespace token from R. */
3835 const cpp_token
*token
;
3838 token
= cpp_get_token (r
);
3840 while (token
->type
== CPP_PADDING
);
3844 /* Peek at the next non-whitespace token from R. */
3847 parser::peek (unsigned num
)
3849 const cpp_token
*token
;
3853 token
= cpp_peek_token (r
, i
++);
3855 while (token
->type
== CPP_PADDING
3857 /* If we peek at EOF this is a fatal error as it leaves the
3858 cpp_reader in unusable state. Assume we really wanted a
3859 token and thus this EOF is unexpected. */
3860 if (token
->type
== CPP_EOF
)
3861 fatal_at (token
, "unexpected end of file");
3865 /* Peek at the next identifier token (or return NULL if the next
3866 token is not an identifier or equal to ID if supplied). */
3869 parser::peek_ident (const char *id
, unsigned num
)
3871 const cpp_token
*token
= peek (num
);
3872 if (token
->type
!= CPP_NAME
)
3878 const char *t
= (const char *) CPP_HASHNODE (token
->val
.node
.node
)->ident
.str
;
3879 if (strcmp (id
, t
) == 0)
3885 /* Read the next token from R and assert it is of type TK. */
3888 parser::expect (enum cpp_ttype tk
)
3890 const cpp_token
*token
= next ();
3891 if (token
->type
!= tk
)
3892 fatal_at (token
, "expected %s, got %s",
3893 cpp_type2name (tk
, 0), cpp_type2name (token
->type
, 0));
3898 /* Consume the next token from R and assert it is of type TK. */
3901 parser::eat_token (enum cpp_ttype tk
)
3906 /* Read the next token from R and assert it is of type CPP_STRING and
3907 return its value. */
3910 parser::get_string ()
3912 const cpp_token
*token
= expect (CPP_STRING
);
3913 return (const char *)token
->val
.str
.text
;
3916 /* Read the next token from R and assert it is of type CPP_NAME and
3917 return its value. */
3920 parser::get_ident ()
3922 const cpp_token
*token
= expect (CPP_NAME
);
3923 return (const char *)CPP_HASHNODE (token
->val
.node
.node
)->ident
.str
;
3926 /* Eat an identifier token with value S from R. */
3929 parser::eat_ident (const char *s
)
3931 const cpp_token
*token
= peek ();
3932 const char *t
= get_ident ();
3933 if (strcmp (s
, t
) != 0)
3934 fatal_at (token
, "expected '%s' got '%s'\n", s
, t
);
3938 /* Read the next token from R and assert it is of type CPP_NUMBER and
3939 return its value. */
3942 parser::get_number ()
3944 const cpp_token
*token
= expect (CPP_NUMBER
);
3945 return (const char *)token
->val
.str
.text
;
3948 /* Return a capture ID that can be used internally. */
3951 parser::get_internal_capture_id ()
3953 unsigned newid
= capture_ids
->elements ();
3954 /* Big enough for a 32-bit UINT_MAX plus prefix. */
3957 sprintf (id
, "__%u", newid
);
3958 capture_ids
->get_or_insert (xstrdup (id
), &existed
);
3960 fatal ("reserved capture id '%s' already used", id
);
3964 /* Record an operator-list use for transparent for handling. */
3967 parser::record_operlist (source_location loc
, user_id
*p
)
3969 if (!oper_lists_set
->add (p
))
3971 if (!oper_lists
.is_empty ()
3972 && oper_lists
[0]->substitutes
.length () != p
->substitutes
.length ())
3973 fatal_at (loc
, "User-defined operator list does not have the "
3974 "same number of entries as others used in the pattern");
3975 oper_lists
.safe_push (p
);
3979 /* Parse the operator ID, special-casing convert?, convert1? and
3983 parser::parse_operation ()
3985 const cpp_token
*id_tok
= peek ();
3986 const char *id
= get_ident ();
3987 const cpp_token
*token
= peek ();
3988 if (strcmp (id
, "convert0") == 0)
3989 fatal_at (id_tok
, "use 'convert?' here");
3990 else if (strcmp (id
, "view_convert0") == 0)
3991 fatal_at (id_tok
, "use 'view_convert?' here");
3992 if (token
->type
== CPP_QUERY
3993 && !(token
->flags
& PREV_WHITE
))
3995 if (strcmp (id
, "convert") == 0)
3997 else if (strcmp (id
, "convert1") == 0)
3999 else if (strcmp (id
, "convert2") == 0)
4001 else if (strcmp (id
, "view_convert") == 0)
4002 id
= "view_convert0";
4003 else if (strcmp (id
, "view_convert1") == 0)
4005 else if (strcmp (id
, "view_convert2") == 0)
4008 fatal_at (id_tok
, "non-convert operator conditionalized");
4010 if (!parsing_match_operand
)
4011 fatal_at (id_tok
, "conditional convert can only be used in "
4012 "match expression");
4013 eat_token (CPP_QUERY
);
4015 else if (strcmp (id
, "convert1") == 0
4016 || strcmp (id
, "convert2") == 0
4017 || strcmp (id
, "view_convert1") == 0
4018 || strcmp (id
, "view_convert2") == 0)
4019 fatal_at (id_tok
, "expected '?' after conditional operator");
4020 id_base
*op
= get_operator (id
);
4022 fatal_at (id_tok
, "unknown operator %s", id
);
4024 user_id
*p
= dyn_cast
<user_id
*> (op
);
4025 if (p
&& p
->is_oper_list
)
4027 if (active_fors
.length() == 0)
4028 record_operlist (id_tok
->src_loc
, p
);
4030 fatal_at (id_tok
, "operator-list %s cannot be exapnded inside 'for'", id
);
4036 capture = '@'<number> */
4039 parser::parse_capture (operand
*op
, bool require_existing
)
4041 source_location src_loc
= eat_token (CPP_ATSIGN
)->src_loc
;
4042 const cpp_token
*token
= peek ();
4043 const char *id
= NULL
;
4044 bool value_match
= false;
4045 /* For matches parse @@ as a value-match denoting the prevailing operand. */
4046 if (token
->type
== CPP_ATSIGN
4047 && ! (token
->flags
& PREV_WHITE
)
4048 && parsing_match_operand
)
4050 eat_token (CPP_ATSIGN
);
4054 if (token
->type
== CPP_NUMBER
)
4056 else if (token
->type
== CPP_NAME
)
4059 fatal_at (token
, "expected number or identifier");
4060 unsigned next_id
= capture_ids
->elements ();
4062 unsigned &num
= capture_ids
->get_or_insert (id
, &existed
);
4065 if (require_existing
)
4066 fatal_at (src_loc
, "unknown capture id");
4069 return new capture (src_loc
, num
, op
, value_match
);
4072 /* Parse an expression
4073 expr = '(' <operation>[capture][flag][type] <operand>... ')' */
4076 parser::parse_expr ()
4078 const cpp_token
*token
= peek ();
4079 expr
*e
= new expr (parse_operation (), token
->src_loc
);
4082 bool is_commutative
= false;
4083 bool force_capture
= false;
4084 const char *expr_type
= NULL
;
4086 if (token
->type
== CPP_COLON
4087 && !(token
->flags
& PREV_WHITE
))
4089 eat_token (CPP_COLON
);
4091 if (token
->type
== CPP_NAME
4092 && !(token
->flags
& PREV_WHITE
))
4094 const char *s
= get_ident ();
4095 if (!parsing_match_operand
)
4105 = dyn_cast
<operator_id
*> (e
->operation
))
4107 if (!commutative_tree_code (p
->code
)
4108 && !comparison_code_p (p
->code
))
4109 fatal_at (token
, "operation is not commutative");
4111 else if (user_id
*p
= dyn_cast
<user_id
*> (e
->operation
))
4112 for (unsigned i
= 0;
4113 i
< p
->substitutes
.length (); ++i
)
4116 = dyn_cast
<operator_id
*> (p
->substitutes
[i
]))
4118 if (!commutative_tree_code (q
->code
)
4119 && !comparison_code_p (q
->code
))
4120 fatal_at (token
, "operation %s is not "
4121 "commutative", q
->id
);
4124 is_commutative
= true;
4126 else if (*sp
== 'C')
4127 is_commutative
= true;
4128 else if (*sp
== 's')
4130 e
->force_single_use
= true;
4131 force_capture
= true;
4134 fatal_at (token
, "flag %c not recognized", *sp
);
4141 fatal_at (token
, "expected flag or type specifying identifier");
4144 if (token
->type
== CPP_ATSIGN
4145 && !(token
->flags
& PREV_WHITE
))
4146 op
= parse_capture (e
, false);
4147 else if (force_capture
)
4149 unsigned num
= get_internal_capture_id ();
4150 op
= new capture (token
->src_loc
, num
, e
, false);
4156 const cpp_token
*token
= peek ();
4157 if (token
->type
== CPP_CLOSE_PAREN
)
4159 if (e
->operation
->nargs
!= -1
4160 && e
->operation
->nargs
!= (int) e
->ops
.length ())
4161 fatal_at (token
, "'%s' expects %u operands, not %u",
4162 e
->operation
->id
, e
->operation
->nargs
, e
->ops
.length ());
4165 if (e
->ops
.length () == 2)
4166 e
->is_commutative
= true;
4168 fatal_at (token
, "only binary operators or function with "
4169 "two arguments can be marked commutative");
4171 e
->expr_type
= expr_type
;
4174 else if (!(token
->flags
& PREV_WHITE
))
4175 fatal_at (token
, "expected expression operand");
4177 e
->append_op (parse_op ());
4182 /* Lex native C code delimited by START recording the preprocessing tokens
4183 for later processing.
4184 c_expr = ('{'|'(') <pp token>... ('}'|')') */
4187 parser::parse_c_expr (cpp_ttype start
)
4189 const cpp_token
*token
;
4192 vec
<cpp_token
> code
= vNULL
;
4193 unsigned nr_stmts
= 0;
4194 source_location loc
= eat_token (start
)->src_loc
;
4195 if (start
== CPP_OPEN_PAREN
)
4196 end
= CPP_CLOSE_PAREN
;
4197 else if (start
== CPP_OPEN_BRACE
)
4198 end
= CPP_CLOSE_BRACE
;
4206 /* Count brace pairs to find the end of the expr to match. */
4207 if (token
->type
== start
)
4209 else if (token
->type
== end
4212 else if (token
->type
== CPP_EOF
)
4213 fatal_at (token
, "unexpected end of file");
4215 /* This is a lame way of counting the number of statements. */
4216 if (token
->type
== CPP_SEMICOLON
)
4219 /* If this is possibly a user-defined identifier mark it used. */
4220 if (token
->type
== CPP_NAME
)
4222 id_base
*idb
= get_operator ((const char *)CPP_HASHNODE
4223 (token
->val
.node
.node
)->ident
.str
);
4225 if (idb
&& (p
= dyn_cast
<user_id
*> (idb
)) && p
->is_oper_list
)
4226 record_operlist (token
->src_loc
, p
);
4229 /* Record the token. */
4230 code
.safe_push (*token
);
4233 return new c_expr (r
, loc
, code
, nr_stmts
, vNULL
, capture_ids
);
4236 /* Parse an operand which is either an expression, a predicate or
4237 a standalone capture.
4238 op = predicate | expr | c_expr | capture */
4243 const cpp_token
*token
= peek ();
4244 struct operand
*op
= NULL
;
4245 if (token
->type
== CPP_OPEN_PAREN
)
4247 eat_token (CPP_OPEN_PAREN
);
4249 eat_token (CPP_CLOSE_PAREN
);
4251 else if (token
->type
== CPP_OPEN_BRACE
)
4253 op
= parse_c_expr (CPP_OPEN_BRACE
);
4257 /* Remaining ops are either empty or predicates */
4258 if (token
->type
== CPP_NAME
)
4260 const char *id
= get_ident ();
4261 id_base
*opr
= get_operator (id
);
4263 fatal_at (token
, "expected predicate name");
4264 if (operator_id
*code
= dyn_cast
<operator_id
*> (opr
))
4266 if (code
->nargs
!= 0)
4267 fatal_at (token
, "using an operator with operands as predicate");
4268 /* Parse the zero-operand operator "predicates" as
4270 op
= new expr (opr
, token
->src_loc
);
4272 else if (user_id
*code
= dyn_cast
<user_id
*> (opr
))
4274 if (code
->nargs
!= 0)
4275 fatal_at (token
, "using an operator with operands as predicate");
4276 /* Parse the zero-operand operator "predicates" as
4278 op
= new expr (opr
, token
->src_loc
);
4280 else if (predicate_id
*p
= dyn_cast
<predicate_id
*> (opr
))
4281 op
= new predicate (p
, token
->src_loc
);
4283 fatal_at (token
, "using an unsupported operator as predicate");
4284 if (!parsing_match_operand
)
4285 fatal_at (token
, "predicates are only allowed in match expression");
4287 if (token
->flags
& PREV_WHITE
)
4290 else if (token
->type
!= CPP_COLON
4291 && token
->type
!= CPP_ATSIGN
)
4292 fatal_at (token
, "expected expression or predicate");
4293 /* optionally followed by a capture and a predicate. */
4294 if (token
->type
== CPP_COLON
)
4295 fatal_at (token
, "not implemented: predicate on leaf operand");
4296 if (token
->type
== CPP_ATSIGN
)
4297 op
= parse_capture (op
, !parsing_match_operand
);
4303 /* Create a new simplify from the current parsing state and MATCH,
4304 MATCH_LOC, RESULT and RESULT_LOC and push it to SIMPLIFIERS. */
4307 parser::push_simplify (simplify::simplify_kind kind
,
4308 vec
<simplify
*>& simplifiers
,
4309 operand
*match
, operand
*result
)
4311 /* Build and push a temporary for operator list uses in expressions. */
4312 if (!oper_lists
.is_empty ())
4313 active_fors
.safe_push (oper_lists
);
4315 simplifiers
.safe_push
4316 (new simplify (kind
, match
, result
,
4317 active_fors
.copy (), capture_ids
));
4319 if (!oper_lists
.is_empty ())
4324 <result-op> = <op> | <if> | <with>
4325 <if> = '(' 'if' '(' <c-expr> ')' <result-op> ')'
4326 <with> = '(' 'with' '{' <c-expr> '}' <result-op> ')'
4330 parser::parse_result (operand
*result
, predicate_id
*matcher
)
4332 const cpp_token
*token
= peek ();
4333 if (token
->type
!= CPP_OPEN_PAREN
)
4336 eat_token (CPP_OPEN_PAREN
);
4337 if (peek_ident ("if"))
4340 if_expr
*ife
= new if_expr (token
->src_loc
);
4341 ife
->cond
= parse_c_expr (CPP_OPEN_PAREN
);
4342 if (peek ()->type
== CPP_OPEN_PAREN
)
4344 ife
->trueexpr
= parse_result (result
, matcher
);
4345 if (peek ()->type
== CPP_OPEN_PAREN
)
4346 ife
->falseexpr
= parse_result (result
, matcher
);
4347 else if (peek ()->type
!= CPP_CLOSE_PAREN
)
4348 ife
->falseexpr
= parse_op ();
4350 else if (peek ()->type
!= CPP_CLOSE_PAREN
)
4352 ife
->trueexpr
= parse_op ();
4353 if (peek ()->type
== CPP_OPEN_PAREN
)
4354 ife
->falseexpr
= parse_result (result
, matcher
);
4355 else if (peek ()->type
!= CPP_CLOSE_PAREN
)
4356 ife
->falseexpr
= parse_op ();
4358 /* If this if is immediately closed then it contains a
4359 manual matcher or is part of a predicate definition. */
4360 else /* if (peek ()->type == CPP_CLOSE_PAREN) */
4363 fatal_at (peek (), "manual transform not implemented");
4364 ife
->trueexpr
= result
;
4366 eat_token (CPP_CLOSE_PAREN
);
4369 else if (peek_ident ("with"))
4372 with_expr
*withe
= new with_expr (token
->src_loc
);
4373 /* Parse (with c-expr expr) as (if-with (true) expr). */
4374 withe
->with
= parse_c_expr (CPP_OPEN_BRACE
);
4375 withe
->with
->nr_stmts
= 0;
4376 withe
->subexpr
= parse_result (result
, matcher
);
4377 eat_token (CPP_CLOSE_PAREN
);
4380 else if (peek_ident ("switch"))
4382 token
= eat_ident ("switch");
4383 source_location ifloc
= eat_token (CPP_OPEN_PAREN
)->src_loc
;
4385 if_expr
*ife
= new if_expr (ifloc
);
4387 ife
->cond
= parse_c_expr (CPP_OPEN_PAREN
);
4388 if (peek ()->type
== CPP_OPEN_PAREN
)
4389 ife
->trueexpr
= parse_result (result
, matcher
);
4391 ife
->trueexpr
= parse_op ();
4392 eat_token (CPP_CLOSE_PAREN
);
4393 if (peek ()->type
!= CPP_OPEN_PAREN
4394 || !peek_ident ("if", 2))
4395 fatal_at (token
, "switch can be implemented with a single if");
4396 while (peek ()->type
!= CPP_CLOSE_PAREN
)
4398 if (peek ()->type
== CPP_OPEN_PAREN
)
4400 if (peek_ident ("if", 2))
4402 ifloc
= eat_token (CPP_OPEN_PAREN
)->src_loc
;
4404 ife
->falseexpr
= new if_expr (ifloc
);
4405 ife
= as_a
<if_expr
*> (ife
->falseexpr
);
4406 ife
->cond
= parse_c_expr (CPP_OPEN_PAREN
);
4407 if (peek ()->type
== CPP_OPEN_PAREN
)
4408 ife
->trueexpr
= parse_result (result
, matcher
);
4410 ife
->trueexpr
= parse_op ();
4411 eat_token (CPP_CLOSE_PAREN
);
4415 /* switch default clause */
4416 ife
->falseexpr
= parse_result (result
, matcher
);
4417 eat_token (CPP_CLOSE_PAREN
);
4423 /* switch default clause */
4424 ife
->falseexpr
= parse_op ();
4425 eat_token (CPP_CLOSE_PAREN
);
4429 eat_token (CPP_CLOSE_PAREN
);
4434 operand
*op
= result
;
4437 eat_token (CPP_CLOSE_PAREN
);
4443 simplify = 'simplify' <expr> <result-op>
4445 match = 'match' <ident> <expr> [<result-op>]
4446 and fill SIMPLIFIERS with the results. */
4449 parser::parse_simplify (simplify::simplify_kind kind
,
4450 vec
<simplify
*>& simplifiers
, predicate_id
*matcher
,
4453 /* Reset the capture map. */
4455 capture_ids
= new cid_map_t
;
4456 /* Reset oper_lists and set. */
4457 hash_set
<user_id
*> olist
;
4458 oper_lists_set
= &olist
;
4461 const cpp_token
*loc
= peek ();
4462 parsing_match_operand
= true;
4463 struct operand
*match
= parse_op ();
4464 finish_match_operand (match
);
4465 parsing_match_operand
= false;
4466 if (match
->type
== operand::OP_CAPTURE
&& !matcher
)
4467 fatal_at (loc
, "outermost expression cannot be captured");
4468 if (match
->type
== operand::OP_EXPR
4469 && is_a
<predicate_id
*> (as_a
<expr
*> (match
)->operation
))
4470 fatal_at (loc
, "outermost expression cannot be a predicate");
4472 /* Splice active_ifs onto result and continue parsing the
4474 if_expr
*active_if
= NULL
;
4475 for (int i
= active_ifs
.length (); i
> 0; --i
)
4477 if_expr
*ifc
= new if_expr (active_ifs
[i
-1]->location
);
4478 ifc
->cond
= active_ifs
[i
-1];
4479 ifc
->trueexpr
= active_if
;
4482 if_expr
*outermost_if
= active_if
;
4483 while (active_if
&& active_if
->trueexpr
)
4484 active_if
= as_a
<if_expr
*> (active_if
->trueexpr
);
4486 const cpp_token
*token
= peek ();
4488 /* If this if is immediately closed then it is part of a predicate
4489 definition. Push it. */
4490 if (token
->type
== CPP_CLOSE_PAREN
)
4493 fatal_at (token
, "expected transform expression");
4496 active_if
->trueexpr
= result
;
4497 result
= outermost_if
;
4499 push_simplify (kind
, simplifiers
, match
, result
);
4503 operand
*tem
= parse_result (result
, matcher
);
4506 active_if
->trueexpr
= tem
;
4507 result
= outermost_if
;
4512 push_simplify (kind
, simplifiers
, match
, result
);
4515 /* Parsing of the outer control structures. */
4517 /* Parse a for expression
4518 for = '(' 'for' <subst>... <pattern> ')'
4519 subst = <ident> '(' <ident>... ')' */
4522 parser::parse_for (source_location
)
4524 auto_vec
<const cpp_token
*> user_id_tokens
;
4525 vec
<user_id
*> user_ids
= vNULL
;
4526 const cpp_token
*token
;
4527 unsigned min_n_opers
= 0, max_n_opers
= 0;
4532 if (token
->type
!= CPP_NAME
)
4535 /* Insert the user defined operators into the operator hash. */
4536 const char *id
= get_ident ();
4537 if (get_operator (id
, true) != NULL
)
4538 fatal_at (token
, "operator already defined");
4539 user_id
*op
= new user_id (id
);
4540 id_base
**slot
= operators
->find_slot_with_hash (op
, op
->hashval
, INSERT
);
4542 user_ids
.safe_push (op
);
4543 user_id_tokens
.safe_push (token
);
4545 eat_token (CPP_OPEN_PAREN
);
4548 while ((token
= peek_ident ()) != 0)
4550 const char *oper
= get_ident ();
4551 id_base
*idb
= get_operator (oper
, true);
4553 fatal_at (token
, "no such operator '%s'", oper
);
4554 if (*idb
== CONVERT0
|| *idb
== CONVERT1
|| *idb
== CONVERT2
4555 || *idb
== VIEW_CONVERT0
|| *idb
== VIEW_CONVERT1
4556 || *idb
== VIEW_CONVERT2
)
4557 fatal_at (token
, "conditional operators cannot be used inside for");
4561 else if (idb
->nargs
== -1)
4563 else if (idb
->nargs
!= arity
)
4564 fatal_at (token
, "operator '%s' with arity %d does not match "
4565 "others with arity %d", oper
, idb
->nargs
, arity
);
4567 user_id
*p
= dyn_cast
<user_id
*> (idb
);
4570 if (p
->is_oper_list
)
4571 op
->substitutes
.safe_splice (p
->substitutes
);
4573 fatal_at (token
, "iterator cannot be used as operator-list");
4576 op
->substitutes
.safe_push (idb
);
4579 token
= expect (CPP_CLOSE_PAREN
);
4581 unsigned nsubstitutes
= op
->substitutes
.length ();
4582 if (nsubstitutes
== 0)
4583 fatal_at (token
, "A user-defined operator must have at least "
4584 "one substitution");
4585 if (max_n_opers
== 0)
4587 min_n_opers
= nsubstitutes
;
4588 max_n_opers
= nsubstitutes
;
4592 if (nsubstitutes
% min_n_opers
!= 0
4593 && min_n_opers
% nsubstitutes
!= 0)
4594 fatal_at (token
, "All user-defined identifiers must have a "
4595 "multiple number of operator substitutions of the "
4596 "smallest number of substitutions");
4597 if (nsubstitutes
< min_n_opers
)
4598 min_n_opers
= nsubstitutes
;
4599 else if (nsubstitutes
> max_n_opers
)
4600 max_n_opers
= nsubstitutes
;
4604 unsigned n_ids
= user_ids
.length ();
4606 fatal_at (token
, "for requires at least one user-defined identifier");
4609 if (token
->type
== CPP_CLOSE_PAREN
)
4610 fatal_at (token
, "no pattern defined in for");
4612 active_fors
.safe_push (user_ids
);
4616 if (token
->type
== CPP_CLOSE_PAREN
)
4622 /* Remove user-defined operators from the hash again. */
4623 for (unsigned i
= 0; i
< user_ids
.length (); ++i
)
4625 if (!user_ids
[i
]->used
)
4626 warning_at (user_id_tokens
[i
],
4627 "operator %s defined but not used", user_ids
[i
]->id
);
4628 operators
->remove_elt (user_ids
[i
]);
4632 /* Parse an identifier associated with a list of operators.
4633 oprs = '(' 'define_operator_list' <ident> <ident>... ')' */
4636 parser::parse_operator_list (source_location
)
4638 const cpp_token
*token
= peek ();
4639 const char *id
= get_ident ();
4641 if (get_operator (id
, true) != 0)
4642 fatal_at (token
, "operator %s already defined", id
);
4644 user_id
*op
= new user_id (id
, true);
4647 while ((token
= peek_ident ()) != 0)
4650 const char *oper
= get_ident ();
4651 id_base
*idb
= get_operator (oper
, true);
4654 fatal_at (token
, "no such operator '%s'", oper
);
4658 else if (idb
->nargs
== -1)
4660 else if (arity
!= idb
->nargs
)
4661 fatal_at (token
, "operator '%s' with arity %d does not match "
4662 "others with arity %d", oper
, idb
->nargs
, arity
);
4664 /* We allow composition of multiple operator lists. */
4665 if (user_id
*p
= dyn_cast
<user_id
*> (idb
))
4666 op
->substitutes
.safe_splice (p
->substitutes
);
4668 op
->substitutes
.safe_push (idb
);
4671 // Check that there is no junk after id-list
4673 if (token
->type
!= CPP_CLOSE_PAREN
)
4674 fatal_at (token
, "expected identifier got %s", cpp_type2name (token
->type
, 0));
4676 if (op
->substitutes
.length () == 0)
4677 fatal_at (token
, "operator-list cannot be empty");
4680 id_base
**slot
= operators
->find_slot_with_hash (op
, op
->hashval
, INSERT
);
4684 /* Parse an outer if expression.
4685 if = '(' 'if' '(' <c-expr> ')' <pattern> ')' */
4688 parser::parse_if (source_location
)
4690 c_expr
*ifexpr
= parse_c_expr (CPP_OPEN_PAREN
);
4692 const cpp_token
*token
= peek ();
4693 if (token
->type
== CPP_CLOSE_PAREN
)
4694 fatal_at (token
, "no pattern defined in if");
4696 active_ifs
.safe_push (ifexpr
);
4699 const cpp_token
*token
= peek ();
4700 if (token
->type
== CPP_CLOSE_PAREN
)
4708 /* Parse a list of predefined predicate identifiers.
4709 preds = '(' 'define_predicates' <ident>... ')' */
4712 parser::parse_predicates (source_location
)
4716 const cpp_token
*token
= peek ();
4717 if (token
->type
!= CPP_NAME
)
4720 add_predicate (get_ident ());
4725 /* Parse outer control structures.
4726 pattern = <preds>|<for>|<if>|<simplify>|<match> */
4729 parser::parse_pattern ()
4731 /* All clauses start with '('. */
4732 eat_token (CPP_OPEN_PAREN
);
4733 const cpp_token
*token
= peek ();
4734 const char *id
= get_ident ();
4735 if (strcmp (id
, "simplify") == 0)
4737 parse_simplify (simplify::SIMPLIFY
, simplifiers
, NULL
, NULL
);
4740 else if (strcmp (id
, "match") == 0)
4742 bool with_args
= false;
4743 source_location e_loc
= peek ()->src_loc
;
4744 if (peek ()->type
== CPP_OPEN_PAREN
)
4746 eat_token (CPP_OPEN_PAREN
);
4749 const char *name
= get_ident ();
4750 id_base
*id
= get_operator (name
);
4754 p
= add_predicate (name
);
4755 user_predicates
.safe_push (p
);
4757 else if ((p
= dyn_cast
<predicate_id
*> (id
)))
4760 fatal_at (token
, "cannot add a match to a non-predicate ID");
4761 /* Parse (match <id> <arg>... (match-expr)) here. */
4765 capture_ids
= new cid_map_t
;
4766 e
= new expr (p
, e_loc
);
4767 while (peek ()->type
== CPP_ATSIGN
)
4768 e
->append_op (parse_capture (NULL
, false));
4769 eat_token (CPP_CLOSE_PAREN
);
4772 && ((e
&& e
->ops
.length () != (unsigned)p
->nargs
)
4773 || (!e
&& p
->nargs
!= 0)))
4774 fatal_at (token
, "non-matching number of match operands");
4775 p
->nargs
= e
? e
->ops
.length () : 0;
4776 parse_simplify (simplify::MATCH
, p
->matchers
, p
, e
);
4779 else if (strcmp (id
, "for") == 0)
4780 parse_for (token
->src_loc
);
4781 else if (strcmp (id
, "if") == 0)
4782 parse_if (token
->src_loc
);
4783 else if (strcmp (id
, "define_predicates") == 0)
4785 if (active_ifs
.length () > 0
4786 || active_fors
.length () > 0)
4787 fatal_at (token
, "define_predicates inside if or for is not supported");
4788 parse_predicates (token
->src_loc
);
4790 else if (strcmp (id
, "define_operator_list") == 0)
4792 if (active_ifs
.length () > 0
4793 || active_fors
.length () > 0)
4794 fatal_at (token
, "operator-list inside if or for is not supported");
4795 parse_operator_list (token
->src_loc
);
4798 fatal_at (token
, "expected %s'simplify', 'match', 'for' or 'if'",
4799 active_ifs
.length () == 0 && active_fors
.length () == 0
4800 ? "'define_predicates', " : "");
4802 eat_token (CPP_CLOSE_PAREN
);
4805 /* Helper for finish_match_operand, collecting captures of OP in CPTS
4809 walk_captures (operand
*op
, vec
<vec
<capture
*> > cpts
)
4814 if (capture
*c
= dyn_cast
<capture
*> (op
))
4816 cpts
[c
->where
].safe_push (c
);
4817 walk_captures (c
->what
, cpts
);
4819 else if (expr
*e
= dyn_cast
<expr
*> (op
))
4820 for (unsigned i
= 0; i
< e
->ops
.length (); ++i
)
4821 walk_captures (e
->ops
[i
], cpts
);
4824 /* Finish up OP which is a match operand. */
4827 parser::finish_match_operand (operand
*op
)
4829 /* Look for matching captures, diagnose mis-uses of @@ and apply
4830 early lowering and distribution of value_match. */
4831 auto_vec
<vec
<capture
*> > cpts
;
4832 cpts
.safe_grow_cleared (capture_ids
->elements ());
4833 walk_captures (op
, cpts
);
4834 for (unsigned i
= 0; i
< cpts
.length (); ++i
)
4836 capture
*value_match
= NULL
;
4837 for (unsigned j
= 0; j
< cpts
[i
].length (); ++j
)
4839 if (cpts
[i
][j
]->value_match
)
4842 fatal_at (cpts
[i
][j
]->location
, "duplicate @@");
4843 value_match
= cpts
[i
][j
];
4846 if (cpts
[i
].length () == 1 && value_match
)
4847 fatal_at (value_match
->location
, "@@ without a matching capture");
4850 /* Duplicate prevailing capture with the existing ID, create
4851 a fake ID and rewrite all captures to use it. This turns
4852 @@1 into @__<newid>@1 and @1 into @__<newid>. */
4853 value_match
->what
= new capture (value_match
->location
,
4855 value_match
->what
, false);
4856 /* Create a fake ID and rewrite all captures to use it. */
4857 unsigned newid
= get_internal_capture_id ();
4858 for (unsigned j
= 0; j
< cpts
[i
].length (); ++j
)
4860 cpts
[i
][j
]->where
= newid
;
4861 cpts
[i
][j
]->value_match
= true;
4868 /* Main entry of the parser. Repeatedly parse outer control structures. */
4870 parser::parser (cpp_reader
*r_
)
4874 active_fors
= vNULL
;
4875 simplifiers
= vNULL
;
4876 oper_lists_set
= NULL
;
4879 user_predicates
= vNULL
;
4880 parsing_match_operand
= false;
4882 const cpp_token
*token
= next ();
4883 while (token
->type
!= CPP_EOF
)
4885 _cpp_backup_tokens (r
, 1);
4892 /* Helper for the linemap code. */
4895 round_alloc_size (size_t s
)
4901 /* The genmatch generator progam. It reads from a pattern description
4902 and outputs GIMPLE or GENERIC IL matching and simplification routines. */
4905 main (int argc
, char **argv
)
4909 progname
= "genmatch";
4915 char *input
= argv
[argc
-1];
4916 for (int i
= 1; i
< argc
- 1; ++i
)
4918 if (strcmp (argv
[i
], "--gimple") == 0)
4920 else if (strcmp (argv
[i
], "--generic") == 0)
4922 else if (strcmp (argv
[i
], "-v") == 0)
4924 else if (strcmp (argv
[i
], "-vv") == 0)
4928 fprintf (stderr
, "Usage: genmatch "
4929 "[--gimple] [--generic] [-v[v]] input\n");
4934 line_table
= XCNEW (struct line_maps
);
4935 linemap_init (line_table
, 0);
4936 line_table
->reallocator
= xrealloc
;
4937 line_table
->round_alloc_size
= round_alloc_size
;
4939 r
= cpp_create_reader (CLK_GNUC99
, NULL
, line_table
);
4940 cpp_callbacks
*cb
= cpp_get_callbacks (r
);
4941 cb
->error
= error_cb
;
4943 /* Add the build directory to the #include "" search path. */
4944 cpp_dir
*dir
= XCNEW (cpp_dir
);
4945 dir
->name
= getpwd ();
4947 dir
->name
= ASTRDUP (".");
4948 cpp_set_include_chains (r
, dir
, NULL
, false);
4950 if (!cpp_read_main_file (r
, input
))
4952 cpp_define (r
, gimple
? "GIMPLE=1": "GENERIC=1");
4953 cpp_define (r
, gimple
? "GENERIC=0": "GIMPLE=0");
4955 null_id
= new id_base (id_base::NULL_ID
, "null");
4957 /* Pre-seed operators. */
4958 operators
= new hash_table
<id_base
> (1024);
4959 #define DEFTREECODE(SYM, STRING, TYPE, NARGS) \
4960 add_operator (SYM, # SYM, # TYPE, NARGS);
4961 #define END_OF_BASE_TREE_CODES
4963 add_operator (CONVERT0
, "convert0", "tcc_unary", 1);
4964 add_operator (CONVERT1
, "convert1", "tcc_unary", 1);
4965 add_operator (CONVERT2
, "convert2", "tcc_unary", 1);
4966 add_operator (VIEW_CONVERT0
, "view_convert0", "tcc_unary", 1);
4967 add_operator (VIEW_CONVERT1
, "view_convert1", "tcc_unary", 1);
4968 add_operator (VIEW_CONVERT2
, "view_convert2", "tcc_unary", 1);
4969 #undef END_OF_BASE_TREE_CODES
4972 /* Pre-seed builtin functions.
4973 ??? Cannot use N (name) as that is targetm.emultls.get_address
4974 for BUILT_IN_EMUTLS_GET_ADDRESS ... */
4975 #define DEF_BUILTIN(ENUM, N, C, T, LT, B, F, NA, AT, IM, COND) \
4976 add_function (ENUM, "CFN_" # ENUM);
4977 #include "builtins.def"
4979 #define DEF_INTERNAL_FN(CODE, NAME, FNSPEC) \
4980 add_function (IFN_##CODE, "CFN_" #CODE);
4981 #include "internal-fn.def"
4987 write_header (stdout
, "gimple-match-head.c");
4989 write_header (stdout
, "generic-match-head.c");
4991 /* Go over all predicates defined with patterns and perform
4992 lowering and code generation. */
4993 for (unsigned i
= 0; i
< p
.user_predicates
.length (); ++i
)
4995 predicate_id
*pred
= p
.user_predicates
[i
];
4996 lower (pred
->matchers
, gimple
);
4999 for (unsigned i
= 0; i
< pred
->matchers
.length (); ++i
)
5000 print_matches (pred
->matchers
[i
]);
5003 for (unsigned i
= 0; i
< pred
->matchers
.length (); ++i
)
5004 dt
.insert (pred
->matchers
[i
], i
);
5009 write_predicate (stdout
, pred
, dt
, gimple
);
5012 /* Lower the main simplifiers and generate code for them. */
5013 lower (p
.simplifiers
, gimple
);
5016 for (unsigned i
= 0; i
< p
.simplifiers
.length (); ++i
)
5017 print_matches (p
.simplifiers
[i
]);
5020 for (unsigned i
= 0; i
< p
.simplifiers
.length (); ++i
)
5021 dt
.insert (p
.simplifiers
[i
], i
);
5026 dt
.gen (stdout
, gimple
);
5029 cpp_finish (r
, NULL
);