* tree-ssa-operands.c (get_call_expr_operands): Add VUSE operands for
[official-gcc.git] / gcc / tree-ssa-operands.c
blob5e49683f0f709c91972b8bfee585d7350cdbc4f5
1 /* SSA operands management for trees.
2 Copyright (C) 2003 Free Software Foundation, Inc.
4 This file is part of GCC.
6 GCC is free software; you can redistribute it and/or modify
7 it under the terms of the GNU General Public License as published by
8 the Free Software Foundation; either version 2, or (at your option)
9 any later version.
11 GCC is distributed in the hope that it will be useful,
12 but WITHOUT ANY WARRANTY; without even the implied warranty of
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 GNU General Public License for more details.
16 You should have received a copy of the GNU General Public License
17 along with GCC; see the file COPYING. If not, write to
18 the Free Software Foundation, 59 Temple Place - Suite 330,
19 Boston, MA 02111-1307, USA. */
21 #include "config.h"
22 #include "system.h"
23 #include "coretypes.h"
24 #include "tm.h"
25 #include "tree.h"
26 #include "flags.h"
27 #include "function.h"
28 #include "diagnostic.h"
29 #include "tree-flow.h"
30 #include "tree-inline.h"
31 #include "tree-pass.h"
32 #include "ggc.h"
33 #include "timevar.h"
36 /* This file contains the code required to mnage the operands cache of the
37 SSA optimizer. For every stmt, we maintain an operand cache in the stmt
38 annotation. This cache contains operands that will be of interets to
39 optimizers and other passes wishing to manipulate the IL.
41 The operand type are broken up into REAL and VIRTUAL operands. The real
42 operands are represented as pointers into the stmt's operand tree. Thus
43 any manipulation of the real operands will be reflected in the actual tree.
44 Virtual operands are represented solely in the cache, although the base
45 variable for the SSA_NAME may, or may not occur in the stmt's tree.
46 Manipulation of the virtual operands will not be reflected in the stmt tree.
48 The routines in this file are concerned with creating this operand cache
49 from a stmt tree.
51 get_stmt_operands() in the primary entry point.
53 The operand tree is the parsed by the various get_* routines which look
54 through the stmt tree for the occurence of operands which may be of
55 interest, and calls are made to the append_* routines whenever one is
56 found. There are 5 of these routines, each representing one of the
57 5 types of operands. Defs, Uses, Virtual Uses, Virtual May Defs, and
58 Virtual Must Defs.
60 The append_* routines check for duplication, and simply keep a list of
61 unique objects for each operand type in the build_* extendable vectors.
63 Once the stmt tree is completely parsed, the finalize_ssa_operands()
64 routine is called, which proceeds to perform the finalization routine
65 on each of the 5 operand vectors which have been built up.
67 If the stmt had a previous operand cache, the finalization routines
68 attempt to match up the new operands with the old ones. If its a perfect
69 match, the old vector is simply reused. If it isn't a perfect match, then
70 a new vector is created and the new operands are placed there. For
71 virtual operands, if the previous cache had SSA_NAME version of a
72 variable, and that same variable occurs in the same operands cache, then
73 the new cache vector will also get the same SSA_NAME.
75 ie, if a stmt had a VUSE of 'a_5', and 'a' occurs in the new operand
76 vector for VUSE, then the new vector will also be modified such that
77 it contains 'a_5' rather than 'a'.
82 /* Flags to describe operand properties in get_stmt_operands and helpers. */
84 /* By default, operands are loaded. */
85 #define opf_none 0
87 /* Operand is the target of an assignment expression or a
88 call-clobbered variable */
89 #define opf_is_def (1 << 0)
91 /* Operand is the target of an assignment expression. */
92 #define opf_kill_def (1 << 1)
94 /* No virtual operands should be created in the expression. This is used
95 when traversing ADDR_EXPR nodes which have different semantics than
96 other expressions. Inside an ADDR_EXPR node, the only operands that we
97 need to consider are indices into arrays. For instance, &a.b[i] should
98 generate a USE of 'i' but it should not generate a VUSE for 'a' nor a
99 VUSE for 'b'. */
100 #define opf_no_vops (1 << 2)
102 /* Array for building all the def operands. */
103 static GTY (()) varray_type build_defs;
105 /* Array for building all the use operands. */
106 static GTY (()) varray_type build_uses;
108 /* Array for building all the v_may_def operands. */
109 static GTY (()) varray_type build_v_may_defs;
111 /* Array for building all the vuse operands. */
112 static GTY (()) varray_type build_vuses;
114 /* Array for building all the v_must_def operands. */
115 static GTY (()) varray_type build_v_must_defs;
117 #ifdef ENABLE_CHECKING
118 /* Used to make sure operand construction is working on the proper stmt. */
119 tree check_build_stmt;
120 #endif
122 static void note_addressable (tree, stmt_ann_t);
123 static void get_expr_operands (tree, tree *, int);
124 static void get_asm_expr_operands (tree);
125 static void get_indirect_ref_operands (tree, tree, int);
126 static void get_call_expr_operands (tree, tree);
127 static inline void append_def (tree *);
128 static inline void append_use (tree *);
129 static void append_v_may_def (tree);
130 static void append_v_must_def (tree);
131 static void add_call_clobber_ops (tree);
132 static void add_call_read_ops (tree);
133 static void add_stmt_operand (tree *, tree, int);
135 /* Return a vector of contiguous memory for NUM def operands. */
137 static inline def_optype
138 allocate_def_optype (unsigned num)
140 def_optype def_ops;
141 unsigned size;
142 size = sizeof (struct def_optype_d) + sizeof (tree *) * (num - 1);
143 def_ops = ggc_alloc (size);
144 def_ops->num_defs = num;
145 return def_ops;
149 /* Return a vector of contiguous memory for NUM use operands. */
151 static inline use_optype
152 allocate_use_optype (unsigned num)
154 use_optype use_ops;
155 unsigned size;
156 size = sizeof (struct use_optype_d) + sizeof (tree *) * (num - 1);
157 use_ops = ggc_alloc (size);
158 use_ops->num_uses = num;
159 return use_ops;
163 /* Return a vector of contiguous memory for NUM v_may_def operands. */
165 static inline v_may_def_optype
166 allocate_v_may_def_optype (unsigned num)
168 v_may_def_optype v_may_def_ops;
169 unsigned size;
170 size = sizeof (struct v_may_def_optype_d)
171 + sizeof (v_may_def_operand_type_t) * (num - 1);
172 v_may_def_ops = ggc_alloc (size);
173 v_may_def_ops->num_v_may_defs = num;
174 return v_may_def_ops;
178 /* Return a vector of contiguous memory for NUM v_use operands. */
180 static inline vuse_optype
181 allocate_vuse_optype (unsigned num)
183 vuse_optype vuse_ops;
184 unsigned size;
185 size = sizeof (struct vuse_optype_d) + sizeof (tree) * (num - 1);
186 vuse_ops = ggc_alloc (size);
187 vuse_ops->num_vuses = num;
188 return vuse_ops;
192 /* Return a vector of contiguous memory for NUM v_must_def operands. */
194 static inline v_must_def_optype
195 allocate_v_must_def_optype (unsigned num)
197 v_must_def_optype v_must_def_ops;
198 unsigned size;
199 size = sizeof (struct v_must_def_optype_d) + sizeof (tree) * (num - 1);
200 v_must_def_ops = ggc_alloc (size);
201 v_must_def_ops->num_v_must_defs = num;
202 return v_must_def_ops;
206 /* Free memory for USES. */
208 static inline void
209 free_uses (use_optype *uses)
211 if (*uses)
213 ggc_free (*uses);
214 *uses = NULL;
219 /* Free memory for DEFS. */
221 static inline void
222 free_defs (def_optype *defs)
224 if (*defs)
226 ggc_free (*defs);
227 *defs = NULL;
232 /* Free memory for VUSES. */
234 static inline void
235 free_vuses (vuse_optype *vuses)
237 if (*vuses)
239 ggc_free (*vuses);
240 *vuses = NULL;
245 /* Free memory for V_MAY_DEFS. */
247 static inline void
248 free_v_may_defs (v_may_def_optype *v_may_defs)
250 if (*v_may_defs)
252 ggc_free (*v_may_defs);
253 *v_may_defs = NULL;
258 /* Free memory for V_MUST_DEFS. */
260 static inline void
261 free_v_must_defs (v_must_def_optype *v_must_defs)
263 if (*v_must_defs)
265 ggc_free (*v_must_defs);
266 *v_must_defs = NULL;
271 /* Initialize the operand cache routines. */
273 void
274 init_ssa_operands (void)
276 VARRAY_TREE_PTR_INIT (build_defs, 5, "build defs");
277 VARRAY_TREE_PTR_INIT (build_uses, 10, "build uses");
278 VARRAY_TREE_INIT (build_v_may_defs, 10, "build v_may_defs");
279 VARRAY_TREE_INIT (build_vuses, 10, "build vuses");
280 VARRAY_TREE_INIT (build_v_must_defs, 10, "build v_must_defs");
284 /* Dispose of anything required by the operand routines. */
286 void
287 fini_ssa_operands (void)
292 /* All the finalize_ssa_* routines do the work required to turn the build_
293 VARRAY into an operand_vector of the appropriate type. The original vector,
294 if any, is passed in for comparison and virtual SSA_NAME reuse. If the
295 old vector is reused, the pointer passed in is set to NULL so that
296 the memory is not freed when the old operands are freed. */
298 /* Return a new def operand vector for STMT, comparing to OLD_OPS_P. */
300 static def_optype
301 finalize_ssa_defs (def_optype *old_ops_p, tree stmt ATTRIBUTE_UNUSED)
303 unsigned num, x;
304 def_optype def_ops, old_ops;
305 bool build_diff;
307 num = VARRAY_ACTIVE_SIZE (build_defs);
308 if (num == 0)
309 return NULL;
311 #ifdef ENABLE_CHECKING
312 /* There should only be a single real definition per assignment. */
313 if (TREE_CODE (stmt) == MODIFY_EXPR && num > 1)
314 abort ();
315 #endif
317 old_ops = *old_ops_p;
319 /* Compare old vector and new array. */
320 build_diff = true;
321 if (old_ops && old_ops->num_defs == num)
323 build_diff = false;
324 for (x = 0; x < num; x++)
325 if (old_ops->defs[x].def != VARRAY_TREE_PTR (build_defs, x))
327 build_diff = true;
328 break;
332 if (!build_diff)
334 def_ops = old_ops;
335 *old_ops_p = NULL;
337 else
339 def_ops = allocate_def_optype (num);
340 for (x = 0; x < num ; x++)
341 def_ops->defs[x].def = VARRAY_TREE_PTR (build_defs, x);
344 VARRAY_POP_ALL (build_defs);
346 return def_ops;
350 /* Return a new use operand vector for STMT, comparing to OLD_OPS_P. */
352 static use_optype
353 finalize_ssa_uses (use_optype *old_ops_p, tree stmt ATTRIBUTE_UNUSED)
355 unsigned num, x;
356 use_optype use_ops, old_ops;
357 bool build_diff;
359 num = VARRAY_ACTIVE_SIZE (build_uses);
360 if (num == 0)
361 return NULL;
363 #ifdef ENABLE_CHECKING
365 unsigned x;
366 /* If the pointer to the operand is the statement itself, something is
367 wrong. It means that we are pointing to a local variable (the
368 initial call to get_stmt_operands does not pass a pointer to a
369 statement). */
370 for (x = 0; x < num; x++)
371 if (*(VARRAY_TREE_PTR (build_uses, x)) == stmt)
372 abort ();
374 #endif
375 old_ops = *old_ops_p;
377 /* Check if the old vector and the new array are the same. */
378 build_diff = true;
379 if (old_ops && old_ops->num_uses == num)
381 build_diff = false;
382 for (x = 0; x < num; x++)
383 if (old_ops->uses[x].use != VARRAY_TREE_PTR (build_uses, x))
385 build_diff = true;
386 break;
390 if (!build_diff)
392 use_ops = old_ops;
393 *old_ops_p = NULL;
395 else
397 use_ops = allocate_use_optype (num);
398 for (x = 0; x < num ; x++)
399 use_ops->uses[x].use = VARRAY_TREE_PTR (build_uses, x);
401 VARRAY_POP_ALL (build_uses);
403 return use_ops;
407 /* Return a new v_may_def operand vector for STMT, comparing to OLD_OPS_P. */
409 static v_may_def_optype
410 finalize_ssa_v_may_defs (v_may_def_optype *old_ops_p)
412 unsigned num, x, i, old_num;
413 v_may_def_optype v_may_def_ops, old_ops;
414 tree result, var;
415 bool build_diff;
417 num = VARRAY_ACTIVE_SIZE (build_v_may_defs);
418 if (num == 0)
419 return NULL;
421 old_ops = *old_ops_p;
423 /* Check if the old vector and the new array are the same. */
424 build_diff = true;
425 if (old_ops && old_ops->num_v_may_defs == num)
427 old_num = num;
428 build_diff = false;
429 for (x = 0; x < num; x++)
431 var = old_ops->v_may_defs[x].def;
432 if (TREE_CODE (var) == SSA_NAME)
433 var = SSA_NAME_VAR (var);
434 if (var != VARRAY_TREE (build_v_may_defs, x))
436 build_diff = true;
437 break;
441 else
442 old_num = (old_ops ? old_ops->num_v_may_defs : 0);
444 if (!build_diff)
446 v_may_def_ops = old_ops;
447 *old_ops_p = NULL;
449 else
451 v_may_def_ops = allocate_v_may_def_optype (num);
452 for (x = 0; x < num; x++)
454 var = VARRAY_TREE (build_v_may_defs, x);
455 /* Look for VAR in the old operands vector. */
456 for (i = 0; i < old_num; i++)
458 result = old_ops->v_may_defs[i].def;
459 if (TREE_CODE (result) == SSA_NAME)
460 result = SSA_NAME_VAR (result);
461 if (result == var)
463 v_may_def_ops->v_may_defs[x] = old_ops->v_may_defs[i];
464 break;
467 if (i == old_num)
469 v_may_def_ops->v_may_defs[x].def = var;
470 v_may_def_ops->v_may_defs[x].use = var;
475 /* Empty the V_MAY_DEF build vector after VUSES have been processed. */
477 return v_may_def_ops;
481 /* Return a new vuse operand vector, comparing to OLD_OPS_P. */
483 static vuse_optype
484 finalize_ssa_vuses (vuse_optype *old_ops_p)
486 unsigned num, x, i, num_v_may_defs, old_num;
487 vuse_optype vuse_ops, old_ops;
488 bool build_diff;
490 num = VARRAY_ACTIVE_SIZE (build_vuses);
491 if (num == 0)
493 VARRAY_POP_ALL (build_v_may_defs);
494 return NULL;
497 /* Remove superfluous VUSE operands. If the statement already has a
498 V_MAY_DEF operation for a variable 'a', then a VUSE for 'a' is not
499 needed because V_MAY_DEFs imply a VUSE of the variable. For instance,
500 suppose that variable 'a' is aliased:
502 # VUSE <a_2>
503 # a_3 = V_MAY_DEF <a_2>
504 a = a + 1;
506 The VUSE <a_2> is superfluous because it is implied by the V_MAY_DEF
507 operation. */
509 num_v_may_defs = VARRAY_ACTIVE_SIZE (build_v_may_defs);
511 if (num_v_may_defs > 0)
513 size_t i, j;
514 tree vuse;
515 for (i = 0; i < VARRAY_ACTIVE_SIZE (build_vuses); i++)
517 vuse = VARRAY_TREE (build_vuses, i);
518 for (j = 0; j < num_v_may_defs; j++)
520 if (vuse == VARRAY_TREE (build_v_may_defs, j))
521 break;
524 /* If we found a useless VUSE operand, remove it from the
525 operand array by replacing it with the last active element
526 in the operand array (unless the useless VUSE was the
527 last operand, in which case we simply remove it. */
528 if (j != num_v_may_defs)
530 if (i != VARRAY_ACTIVE_SIZE (build_vuses) - 1)
532 VARRAY_TREE (build_vuses, i)
533 = VARRAY_TREE (build_vuses,
534 VARRAY_ACTIVE_SIZE (build_vuses) - 1);
536 VARRAY_POP (build_vuses);
538 /* We want to rescan the element at this index, unless
539 this was the last element, in which case the loop
540 terminates. */
541 i--;
546 num = VARRAY_ACTIVE_SIZE (build_vuses);
547 /* We could have reduced the size to zero now, however. */
548 if (num == 0)
550 VARRAY_POP_ALL (build_v_may_defs);
551 return NULL;
554 old_ops = *old_ops_p;
556 /* Determine whether vuses is the same as the old vector. */
557 build_diff = true;
558 if (old_ops && old_ops->num_vuses == num)
560 old_num = num;
561 build_diff = false;
562 for (x = 0; x < num ; x++)
564 tree v;
565 v = old_ops->vuses[x];
566 if (TREE_CODE (v) == SSA_NAME)
567 v = SSA_NAME_VAR (v);
568 if (v != VARRAY_TREE (build_vuses, x))
570 build_diff = true;
571 break;
575 else
576 old_num = (old_ops ? old_ops->num_vuses : 0);
578 if (!build_diff)
580 vuse_ops = old_ops;
581 *old_ops_p = NULL;
583 else
585 vuse_ops = allocate_vuse_optype (num);
586 for (x = 0; x < num; x++)
588 tree result, var = VARRAY_TREE (build_vuses, x);
589 /* Look for VAR in the old vector, and use that SSA_NAME. */
590 for (i = 0; i < old_num; i++)
592 result = old_ops->vuses[i];
593 if (TREE_CODE (result) == SSA_NAME)
594 result = SSA_NAME_VAR (result);
595 if (result == var)
597 vuse_ops->vuses[x] = old_ops->vuses[i];
598 break;
601 if (i == old_num)
602 vuse_ops->vuses[x] = var;
606 /* The v_may_def build vector wasn't freed because we needed it here.
607 Free it now with the vuses build vector. */
608 VARRAY_POP_ALL (build_vuses);
609 VARRAY_POP_ALL (build_v_may_defs);
611 return vuse_ops;
615 /* Return a new v_must_def operand vector for STMT, comparing to OLD_OPS_P. */
617 static v_must_def_optype
618 finalize_ssa_v_must_defs (v_must_def_optype *old_ops_p,
619 tree stmt ATTRIBUTE_UNUSED)
621 unsigned num, x, i, old_num = 0;
622 v_must_def_optype v_must_def_ops, old_ops;
623 bool build_diff;
625 num = VARRAY_ACTIVE_SIZE (build_v_must_defs);
626 if (num == 0)
627 return NULL;
629 #ifdef ENABLE_CHECKING
630 /* There should only be a single V_MUST_DEF per assignment. */
631 if (TREE_CODE (stmt) == MODIFY_EXPR && num > 1)
632 abort ();
633 #endif
635 old_ops = *old_ops_p;
637 /* Check if the old vector and the new array are the same. */
638 build_diff = true;
639 if (old_ops && old_ops->num_v_must_defs == num)
641 old_num = num;
642 build_diff = false;
643 for (x = 0; x < num; x++)
645 tree var = old_ops->v_must_defs[x];
646 if (TREE_CODE (var) == SSA_NAME)
647 var = SSA_NAME_VAR (var);
648 if (var != VARRAY_TREE (build_v_must_defs, x))
650 build_diff = true;
651 break;
655 else
656 old_num = (old_ops ? old_ops->num_v_must_defs : 0);
658 if (!build_diff)
660 v_must_def_ops = old_ops;
661 *old_ops_p = NULL;
663 else
665 v_must_def_ops = allocate_v_must_def_optype (num);
666 for (x = 0; x < num ; x++)
668 tree result, var = VARRAY_TREE (build_v_must_defs, x);
669 /* Look for VAR in the original vector. */
670 for (i = 0; i < old_num; i++)
672 result = old_ops->v_must_defs[i];
673 if (TREE_CODE (result) == SSA_NAME)
674 result = SSA_NAME_VAR (result);
675 if (result == var)
677 v_must_def_ops->v_must_defs[x] = old_ops->v_must_defs[i];
678 break;
681 if (i == old_num)
682 v_must_def_ops->v_must_defs[x] = var;
685 VARRAY_POP_ALL (build_v_must_defs);
687 return v_must_def_ops;
691 /* Finalize all the build vectors, fill the new ones into INFO. */
693 static inline void
694 finalize_ssa_stmt_operands (tree stmt, stmt_operands_p old_ops,
695 stmt_operands_p new_ops)
697 new_ops->def_ops = finalize_ssa_defs (&(old_ops->def_ops), stmt);
698 new_ops->use_ops = finalize_ssa_uses (&(old_ops->use_ops), stmt);
699 new_ops->v_must_def_ops
700 = finalize_ssa_v_must_defs (&(old_ops->v_must_def_ops), stmt);
701 new_ops->v_may_def_ops = finalize_ssa_v_may_defs (&(old_ops->v_may_def_ops));
702 new_ops->vuse_ops = finalize_ssa_vuses (&(old_ops->vuse_ops));
706 /* Start the process of building up operands vectors in INFO. */
708 static inline void
709 start_ssa_stmt_operands (void)
711 #ifdef ENABLE_CHECKING
712 if (VARRAY_ACTIVE_SIZE (build_defs) > 0
713 || VARRAY_ACTIVE_SIZE (build_uses) > 0
714 || VARRAY_ACTIVE_SIZE (build_vuses) > 0
715 || VARRAY_ACTIVE_SIZE (build_v_may_defs) > 0
716 || VARRAY_ACTIVE_SIZE (build_v_must_defs) > 0)
717 abort ();
718 #endif
722 /* Add DEF_P to the list of pointers to operands. */
724 static inline void
725 append_def (tree *def_p)
727 VARRAY_PUSH_TREE_PTR (build_defs, def_p);
731 /* Add USE_P to the list of pointers to operands. */
733 static inline void
734 append_use (tree *use_p)
736 VARRAY_PUSH_TREE_PTR (build_uses, use_p);
740 /* Add a new virtual may def for variable VAR to the build array. */
742 static inline void
743 append_v_may_def (tree var)
745 unsigned i;
747 /* Don't allow duplicate entries. */
748 for (i = 0; i < VARRAY_ACTIVE_SIZE (build_v_may_defs); i++)
749 if (var == VARRAY_TREE (build_v_may_defs, i))
750 return;
752 VARRAY_PUSH_TREE (build_v_may_defs, var);
756 /* Add VAR to the list of virtual uses. */
758 static inline void
759 append_vuse (tree var)
761 size_t i;
763 /* Don't allow duplicate entries. */
764 for (i = 0; i < VARRAY_ACTIVE_SIZE (build_vuses); i++)
765 if (var == VARRAY_TREE (build_vuses, i))
766 return;
768 VARRAY_PUSH_TREE (build_vuses, var);
772 /* Add VAR to the list of virtual must definitions for INFO. */
774 static inline void
775 append_v_must_def (tree var)
777 unsigned i;
779 /* Don't allow duplicate entries. */
780 for (i = 0; i < VARRAY_ACTIVE_SIZE (build_v_must_defs); i++)
781 if (var == VARRAY_TREE (build_v_must_defs, i))
782 return;
784 VARRAY_PUSH_TREE (build_v_must_defs, var);
787 /* Create an operands cache for STMT, returning it in NEW_OPS. OLD_OPS are the
788 original operands, and if ANN is non-null, appropriate stmt flags are set
789 in the stmt's annotation. Note that some fields in old_ops may
790 change to NULL, although none of the memory they originally pointed to
791 will be destroyed. It is appropriate to call free_stmt_operands() on
792 the value returned in old_ops.
794 The rationale for this: Certain optimizations wish to exmaine the difference
795 between new_ops and old_ops after processing. If a set of operands don't
796 change, new_ops will simply assume the pointer in old_ops, and the old_ops
797 pointer will be set to NULL, indicating no memory needs to be cleared.
798 Usage might appear something like:
800 old_ops_copy = old_ops = stmt_ann(stmt)->operands;
801 build_ssa_operands (stmt, NULL, &old_ops, &new_ops);
802 <* compare old_ops_copy and new_ops *>
803 free_ssa_operands (old_ops); */
805 void
806 build_ssa_operands (tree stmt, stmt_ann_t ann, stmt_operands_p old_ops,
807 stmt_operands_p new_ops)
809 enum tree_code code;
810 tree_ann_t saved_ann = stmt->common.ann;
812 /* Replace stmt's annotation with the one passed in for the duration
813 of the operand building process. This allows "fake" stmts to be built
814 and not be included in other data structures which can be built here. */
815 stmt->common.ann = (tree_ann_t) ann;
817 /* Initially assume that the statement has no volatile operands, nor
818 makes aliased loads or stores. */
819 if (ann)
821 ann->has_volatile_ops = false;
822 ann->makes_aliased_stores = false;
823 ann->makes_aliased_loads = false;
826 start_ssa_stmt_operands ();
828 code = TREE_CODE (stmt);
829 switch (code)
831 case MODIFY_EXPR:
832 get_expr_operands (stmt, &TREE_OPERAND (stmt, 1), opf_none);
833 if (TREE_CODE (TREE_OPERAND (stmt, 0)) == ARRAY_REF
834 || TREE_CODE (TREE_OPERAND (stmt, 0)) == ARRAY_RANGE_REF
835 || TREE_CODE (TREE_OPERAND (stmt, 0)) == COMPONENT_REF
836 || TREE_CODE (TREE_OPERAND (stmt, 0)) == REALPART_EXPR
837 || TREE_CODE (TREE_OPERAND (stmt, 0)) == IMAGPART_EXPR
838 /* Use a V_MAY_DEF if the RHS might throw, as the LHS won't be
839 modified in that case. FIXME we should represent somehow
840 that it is killed on the fallthrough path. */
841 || tree_could_throw_p (TREE_OPERAND (stmt, 1)))
842 get_expr_operands (stmt, &TREE_OPERAND (stmt, 0), opf_is_def);
843 else
844 get_expr_operands (stmt, &TREE_OPERAND (stmt, 0),
845 opf_is_def | opf_kill_def);
846 break;
848 case COND_EXPR:
849 get_expr_operands (stmt, &COND_EXPR_COND (stmt), opf_none);
850 break;
852 case SWITCH_EXPR:
853 get_expr_operands (stmt, &SWITCH_COND (stmt), opf_none);
854 break;
856 case ASM_EXPR:
857 get_asm_expr_operands (stmt);
858 break;
860 case RETURN_EXPR:
861 get_expr_operands (stmt, &TREE_OPERAND (stmt, 0), opf_none);
862 break;
864 case GOTO_EXPR:
865 get_expr_operands (stmt, &GOTO_DESTINATION (stmt), opf_none);
866 break;
868 case LABEL_EXPR:
869 get_expr_operands (stmt, &LABEL_EXPR_LABEL (stmt), opf_none);
870 break;
872 /* These nodes contain no variable references. */
873 case BIND_EXPR:
874 case CASE_LABEL_EXPR:
875 case TRY_CATCH_EXPR:
876 case TRY_FINALLY_EXPR:
877 case EH_FILTER_EXPR:
878 case CATCH_EXPR:
879 case RESX_EXPR:
880 break;
882 default:
883 /* Notice that if get_expr_operands tries to use &STMT as the operand
884 pointer (which may only happen for USE operands), we will abort in
885 append_use. This default will handle statements like empty
886 statements, or CALL_EXPRs that may appear on the RHS of a statement
887 or as statements themselves. */
888 get_expr_operands (stmt, &stmt, opf_none);
889 break;
892 finalize_ssa_stmt_operands (stmt, old_ops, new_ops);
893 stmt->common.ann = saved_ann;
897 /* Free any operands vectors in OPS. */
899 static void
900 free_ssa_operands (stmt_operands_p ops)
902 if (ops->def_ops)
903 free_defs (&(ops->def_ops));
904 if (ops->use_ops)
905 free_uses (&(ops->use_ops));
906 if (ops->vuse_ops)
907 free_vuses (&(ops->vuse_ops));
908 if (ops->v_may_def_ops)
909 free_v_may_defs (&(ops->v_may_def_ops));
910 if (ops->v_must_def_ops)
911 free_v_must_defs (&(ops->v_must_def_ops));
915 /* Get the operands of statement STMT. Note that repeated calls to
916 get_stmt_operands for the same statement will do nothing until the
917 statement is marked modified by a call to modify_stmt(). */
919 void
920 get_stmt_operands (tree stmt)
922 stmt_ann_t ann;
923 stmt_operands_t old_operands;
925 #if defined ENABLE_CHECKING
926 /* The optimizers cannot handle statements that are nothing but a
927 _DECL. This indicates a bug in the gimplifier. */
928 if (SSA_VAR_P (stmt))
929 abort ();
930 #endif
932 /* Ignore error statements. */
933 if (TREE_CODE (stmt) == ERROR_MARK)
934 return;
936 ann = get_stmt_ann (stmt);
938 /* If the statement has not been modified, the operands are still valid. */
939 if (!ann->modified)
940 return;
942 timevar_push (TV_TREE_OPS);
944 old_operands = ann->operands;
945 memset (&(ann->operands), 0, sizeof (stmt_operands_t));
947 build_ssa_operands (stmt, ann, &old_operands, &(ann->operands));
948 free_ssa_operands (&old_operands);
950 /* Clear the modified bit for STMT. Subsequent calls to
951 get_stmt_operands for this statement will do nothing until the
952 statement is marked modified by a call to modify_stmt(). */
953 ann->modified = 0;
955 timevar_pop (TV_TREE_OPS);
959 /* Recursively scan the expression pointed by EXPR_P in statement referred to
960 by INFO. FLAGS is one of the OPF_* constants modifying how to interpret the
961 operands found. */
963 static void
964 get_expr_operands (tree stmt, tree *expr_p, int flags)
966 enum tree_code code;
967 char class;
968 tree expr = *expr_p;
970 if (expr == NULL || expr == error_mark_node)
971 return;
973 code = TREE_CODE (expr);
974 class = TREE_CODE_CLASS (code);
976 switch (code)
978 case ADDR_EXPR:
979 /* We could have the address of a component, array member,
980 etc which has interesting variable references. */
981 /* Taking the address of a variable does not represent a
982 reference to it, but the fact that the stmt takes its address will be
983 of interest to some passes (e.g. alias resolution). */
984 add_stmt_operand (expr_p, stmt, 0);
986 /* If the address is invariant, there may be no interesting variable
987 references inside. */
988 if (is_gimple_min_invariant (expr))
989 return;
991 /* There should be no VUSEs created, since the referenced objects are
992 not really accessed. The only operands that we should find here
993 are ARRAY_REF indices which will always be real operands (GIMPLE
994 does not allow non-registers as array indices). */
995 flags |= opf_no_vops;
997 get_expr_operands (stmt, &TREE_OPERAND (expr, 0), flags);
998 return;
1000 case SSA_NAME:
1001 case VAR_DECL:
1002 case PARM_DECL:
1003 case RESULT_DECL:
1004 /* If we found a variable, add it to DEFS or USES depending
1005 on the operand flags. */
1006 add_stmt_operand (expr_p, stmt, flags);
1007 return;
1009 case INDIRECT_REF:
1010 get_indirect_ref_operands (stmt, expr, flags);
1011 return;
1013 case ARRAY_REF:
1014 case ARRAY_RANGE_REF:
1015 /* Treat array references as references to the virtual variable
1016 representing the array. The virtual variable for an ARRAY_REF
1017 is the VAR_DECL for the array. */
1019 /* Add the virtual variable for the ARRAY_REF to VDEFS or VUSES
1020 according to the value of IS_DEF. Recurse if the LHS of the
1021 ARRAY_REF node is not a regular variable. */
1022 if (SSA_VAR_P (TREE_OPERAND (expr, 0)))
1023 add_stmt_operand (expr_p, stmt, flags);
1024 else
1025 get_expr_operands (stmt, &TREE_OPERAND (expr, 0), flags);
1027 get_expr_operands (stmt, &TREE_OPERAND (expr, 1), opf_none);
1028 get_expr_operands (stmt, &TREE_OPERAND (expr, 2), opf_none);
1029 get_expr_operands (stmt, &TREE_OPERAND (expr, 3), opf_none);
1030 return;
1032 case COMPONENT_REF:
1033 case REALPART_EXPR:
1034 case IMAGPART_EXPR:
1035 /* Similarly to arrays, references to compound variables (complex
1036 types and structures/unions) are globbed.
1038 FIXME: This means that
1040 a.x = 6;
1041 a.y = 7;
1042 foo (a.x, a.y);
1044 will not be constant propagated because the two partial
1045 definitions to 'a' will kill each other. Note that SRA may be
1046 able to fix this problem if 'a' can be scalarized. */
1048 /* If the LHS of the compound reference is not a regular variable,
1049 recurse to keep looking for more operands in the subexpression. */
1050 if (SSA_VAR_P (TREE_OPERAND (expr, 0)))
1051 add_stmt_operand (expr_p, stmt, flags);
1052 else
1053 get_expr_operands (stmt, &TREE_OPERAND (expr, 0), flags);
1055 if (code == COMPONENT_REF)
1056 get_expr_operands (stmt, &TREE_OPERAND (expr, 2), opf_none);
1057 return;
1059 case WITH_SIZE_EXPR:
1060 /* WITH_SIZE_EXPR is a pass-through reference to its first argument,
1061 and an rvalue reference to its second argument. */
1062 get_expr_operands (stmt, &TREE_OPERAND (expr, 1), opf_none);
1063 get_expr_operands (stmt, &TREE_OPERAND (expr, 0), flags);
1064 return;
1066 case CALL_EXPR:
1067 get_call_expr_operands (stmt, expr);
1068 return;
1070 case MODIFY_EXPR:
1072 int subflags;
1073 tree op;
1075 get_expr_operands (stmt, &TREE_OPERAND (expr, 1), opf_none);
1077 op = TREE_OPERAND (expr, 0);
1078 if (TREE_CODE (op) == WITH_SIZE_EXPR)
1079 op = TREE_OPERAND (expr, 0);
1080 if (TREE_CODE (op) == ARRAY_REF
1081 || TREE_CODE (op) == ARRAY_RANGE_REF
1082 || TREE_CODE (op) == COMPONENT_REF
1083 || TREE_CODE (op) == REALPART_EXPR
1084 || TREE_CODE (op) == IMAGPART_EXPR)
1085 subflags = opf_is_def;
1086 else
1087 subflags = opf_is_def | opf_kill_def;
1089 get_expr_operands (stmt, &TREE_OPERAND (expr, 0), subflags);
1090 return;
1093 case CONSTRUCTOR:
1095 /* General aggregate CONSTRUCTORs have been decomposed, but they
1096 are still in use as the COMPLEX_EXPR equivalent for vectors. */
1098 tree t;
1099 for (t = TREE_OPERAND (expr, 0); t ; t = TREE_CHAIN (t))
1100 get_expr_operands (stmt, &TREE_VALUE (t), opf_none);
1102 return;
1105 case TRUTH_NOT_EXPR:
1106 case BIT_FIELD_REF:
1107 case VIEW_CONVERT_EXPR:
1108 do_unary:
1109 get_expr_operands (stmt, &TREE_OPERAND (expr, 0), flags);
1110 return;
1112 case TRUTH_AND_EXPR:
1113 case TRUTH_OR_EXPR:
1114 case TRUTH_XOR_EXPR:
1115 case COMPOUND_EXPR:
1116 case OBJ_TYPE_REF:
1117 do_binary:
1119 tree op0 = TREE_OPERAND (expr, 0);
1120 tree op1 = TREE_OPERAND (expr, 1);
1122 /* If it would be profitable to swap the operands, then do so to
1123 canonicalize the statement, enabling better optimization.
1125 By placing canonicalization of such expressions here we
1126 transparently keep statements in canonical form, even
1127 when the statement is modified. */
1128 if (tree_swap_operands_p (op0, op1, false))
1130 /* For relationals we need to swap the operands
1131 and change the code. */
1132 if (code == LT_EXPR
1133 || code == GT_EXPR
1134 || code == LE_EXPR
1135 || code == GE_EXPR)
1137 TREE_SET_CODE (expr, swap_tree_comparison (code));
1138 TREE_OPERAND (expr, 0) = op1;
1139 TREE_OPERAND (expr, 1) = op0;
1142 /* For a commutative operator we can just swap the operands. */
1143 else if (commutative_tree_code (code))
1145 TREE_OPERAND (expr, 0) = op1;
1146 TREE_OPERAND (expr, 1) = op0;
1150 get_expr_operands (stmt, &TREE_OPERAND (expr, 0), flags);
1151 get_expr_operands (stmt, &TREE_OPERAND (expr, 1), flags);
1152 return;
1155 case BLOCK:
1156 case FUNCTION_DECL:
1157 case EXC_PTR_EXPR:
1158 case FILTER_EXPR:
1159 case LABEL_DECL:
1160 /* Expressions that make no memory references. */
1161 return;
1163 default:
1164 if (class == '1')
1165 goto do_unary;
1166 if (class == '2' || class == '<')
1167 goto do_binary;
1168 if (class == 'c' || class == 't')
1169 return;
1172 /* If we get here, something has gone wrong. */
1173 fprintf (stderr, "unhandled expression in get_expr_operands():\n");
1174 debug_tree (expr);
1175 fputs ("\n", stderr);
1176 abort ();
1180 /* Scan operands in the ASM_EXPR stmt refered to in INFO. */
1182 static void
1183 get_asm_expr_operands (tree stmt)
1185 stmt_ann_t s_ann = stmt_ann (stmt);
1186 int noutputs = list_length (ASM_OUTPUTS (stmt));
1187 const char **oconstraints
1188 = (const char **) alloca ((noutputs) * sizeof (const char *));
1189 int i;
1190 tree link;
1191 const char *constraint;
1192 bool allows_mem, allows_reg, is_inout;
1194 for (i=0, link = ASM_OUTPUTS (stmt); link; ++i, link = TREE_CHAIN (link))
1196 oconstraints[i] = constraint
1197 = TREE_STRING_POINTER (TREE_VALUE (TREE_PURPOSE (link)));
1198 parse_output_constraint (&constraint, i, 0, 0,
1199 &allows_mem, &allows_reg, &is_inout);
1201 #if defined ENABLE_CHECKING
1202 /* This should have been split in gimplify_asm_expr. */
1203 if (allows_reg && is_inout)
1204 abort ();
1205 #endif
1207 /* Memory operands are addressable. Note that STMT needs the
1208 address of this operand. */
1209 if (!allows_reg && allows_mem)
1211 tree t = get_base_address (TREE_VALUE (link));
1212 if (t && DECL_P (t))
1213 note_addressable (t, s_ann);
1216 get_expr_operands (stmt, &TREE_VALUE (link), opf_is_def);
1219 for (link = ASM_INPUTS (stmt); link; link = TREE_CHAIN (link))
1221 constraint
1222 = TREE_STRING_POINTER (TREE_VALUE (TREE_PURPOSE (link)));
1223 parse_input_constraint (&constraint, 0, 0, noutputs, 0,
1224 oconstraints, &allows_mem, &allows_reg);
1226 /* Memory operands are addressable. Note that STMT needs the
1227 address of this operand. */
1228 if (!allows_reg && allows_mem)
1230 tree t = get_base_address (TREE_VALUE (link));
1231 if (t && DECL_P (t))
1232 note_addressable (t, s_ann);
1235 get_expr_operands (stmt, &TREE_VALUE (link), 0);
1239 /* Clobber memory for asm ("" : : : "memory"); */
1240 for (link = ASM_CLOBBERS (stmt); link; link = TREE_CHAIN (link))
1241 if (strcmp (TREE_STRING_POINTER (TREE_VALUE (link)), "memory") == 0)
1243 size_t i;
1245 /* Clobber all call-clobbered variables (or .GLOBAL_VAR if we
1246 decided to group them). */
1247 if (global_var)
1248 add_stmt_operand (&global_var, stmt, opf_is_def);
1249 else
1250 EXECUTE_IF_SET_IN_BITMAP (call_clobbered_vars, 0, i,
1252 tree var = referenced_var (i);
1253 add_stmt_operand (&var, stmt, opf_is_def);
1256 /* Now clobber all addressables. */
1257 EXECUTE_IF_SET_IN_BITMAP (addressable_vars, 0, i,
1259 tree var = referenced_var (i);
1260 add_stmt_operand (&var, stmt, opf_is_def);
1263 break;
1267 /* A subroutine of get_expr_operands to handle INDIRECT_REF. */
1269 static void
1270 get_indirect_ref_operands (tree stmt, tree expr, int flags)
1272 tree *pptr = &TREE_OPERAND (expr, 0);
1273 tree ptr = *pptr;
1274 stmt_ann_t ann = stmt_ann (stmt);
1276 /* Stores into INDIRECT_REF operands are never killing definitions. */
1277 flags &= ~opf_kill_def;
1279 if (SSA_VAR_P (ptr))
1281 struct ptr_info_def *pi = NULL;
1283 /* If PTR has flow-sensitive points-to information, use it. */
1284 if (TREE_CODE (ptr) == SSA_NAME
1285 && (pi = SSA_NAME_PTR_INFO (ptr)) != NULL
1286 && pi->name_mem_tag)
1288 /* PTR has its own memory tag. Use it. */
1289 add_stmt_operand (&pi->name_mem_tag, stmt, flags);
1291 else
1293 /* If PTR is not an SSA_NAME or it doesn't have a name
1294 tag, use its type memory tag. */
1295 var_ann_t ann;
1297 /* If we are emitting debugging dumps, display a warning if
1298 PTR is an SSA_NAME with no flow-sensitive alias
1299 information. That means that we may need to compute
1300 aliasing again. */
1301 if (dump_file
1302 && TREE_CODE (ptr) == SSA_NAME
1303 && pi == NULL)
1305 fprintf (dump_file,
1306 "NOTE: no flow-sensitive alias info for ");
1307 print_generic_expr (dump_file, ptr, dump_flags);
1308 fprintf (dump_file, " in ");
1309 print_generic_stmt (dump_file, stmt, dump_flags);
1312 if (TREE_CODE (ptr) == SSA_NAME)
1313 ptr = SSA_NAME_VAR (ptr);
1314 ann = var_ann (ptr);
1315 if (ann->type_mem_tag)
1316 add_stmt_operand (&ann->type_mem_tag, stmt, flags);
1320 /* If a constant is used as a pointer, we can't generate a real
1321 operand for it but we mark the statement volatile to prevent
1322 optimizations from messing things up. */
1323 else if (TREE_CODE (ptr) == INTEGER_CST)
1325 if (ann)
1326 ann->has_volatile_ops = true;
1327 return;
1330 /* Everything else *should* have been folded elsewhere, but users
1331 are smarter than we in finding ways to write invalid code. We
1332 cannot just abort here. If we were absolutely certain that we
1333 do handle all valid cases, then we could just do nothing here.
1334 That seems optimistic, so attempt to do something logical... */
1335 else if ((TREE_CODE (ptr) == PLUS_EXPR || TREE_CODE (ptr) == MINUS_EXPR)
1336 && TREE_CODE (TREE_OPERAND (ptr, 0)) == ADDR_EXPR
1337 && TREE_CODE (TREE_OPERAND (ptr, 1)) == INTEGER_CST)
1339 /* Make sure we know the object is addressable. */
1340 pptr = &TREE_OPERAND (ptr, 0);
1341 add_stmt_operand (pptr, stmt, 0);
1343 /* Mark the object itself with a VUSE. */
1344 pptr = &TREE_OPERAND (*pptr, 0);
1345 get_expr_operands (stmt, pptr, flags);
1346 return;
1349 /* Ok, this isn't even is_gimple_min_invariant. Something's broke. */
1350 else
1351 abort ();
1353 /* Add a USE operand for the base pointer. */
1354 get_expr_operands (stmt, pptr, opf_none);
1357 /* A subroutine of get_expr_operands to handle CALL_EXPR. */
1359 static void
1360 get_call_expr_operands (tree stmt, tree expr)
1362 tree op;
1363 int call_flags = call_expr_flags (expr);
1365 /* Find uses in the called function. */
1366 get_expr_operands (stmt, &TREE_OPERAND (expr, 0), opf_none);
1368 for (op = TREE_OPERAND (expr, 1); op; op = TREE_CHAIN (op))
1369 get_expr_operands (stmt, &TREE_VALUE (op), opf_none);
1371 get_expr_operands (stmt, &TREE_OPERAND (expr, 2), opf_none);
1373 if (bitmap_first_set_bit (call_clobbered_vars) >= 0)
1375 /* A 'pure' or a 'const' functions never call clobber anything.
1376 A 'noreturn' function might, but since we don't return anyway
1377 there is no point in recording that. */
1378 if (TREE_SIDE_EFFECTS (expr)
1379 && !(call_flags & (ECF_PURE | ECF_CONST | ECF_NORETURN)))
1380 add_call_clobber_ops (stmt);
1381 else if (!(call_flags & ECF_CONST))
1382 add_call_read_ops (stmt);
1387 /* Add *VAR_P to the appropriate operand array for INFO. FLAGS is as in
1388 get_expr_operands. If *VAR_P is a GIMPLE register, it will be added to
1389 the statement's real operands, otherwise it is added to virtual
1390 operands. */
1392 static void
1393 add_stmt_operand (tree *var_p, tree stmt, int flags)
1395 bool is_real_op;
1396 tree var, sym;
1397 stmt_ann_t s_ann = stmt_ann (stmt);
1398 var_ann_t v_ann;
1400 var = *var_p;
1401 STRIP_NOPS (var);
1403 /* If the operand is an ADDR_EXPR, add its operand to the list of
1404 variables that have had their address taken in this statement. */
1405 if (TREE_CODE (var) == ADDR_EXPR)
1407 note_addressable (TREE_OPERAND (var, 0), s_ann);
1408 return;
1411 /* If the original variable is not a scalar, it will be added to the list
1412 of virtual operands. In that case, use its base symbol as the virtual
1413 variable representing it. */
1414 is_real_op = is_gimple_reg (var);
1415 if (!is_real_op && !DECL_P (var))
1416 var = get_virtual_var (var);
1418 /* If VAR is not a variable that we care to optimize, do nothing. */
1419 if (var == NULL_TREE || !SSA_VAR_P (var))
1420 return;
1422 sym = (TREE_CODE (var) == SSA_NAME ? SSA_NAME_VAR (var) : var);
1423 v_ann = var_ann (sym);
1425 /* Don't expose volatile variables to the optimizers. */
1426 if (TREE_THIS_VOLATILE (sym))
1428 if (s_ann)
1429 s_ann->has_volatile_ops = true;
1430 return;
1433 if (is_real_op)
1435 /* The variable is a GIMPLE register. Add it to real operands. */
1436 if (flags & opf_is_def)
1437 append_def (var_p);
1438 else
1439 append_use (var_p);
1441 else
1443 varray_type aliases;
1445 /* The variable is not a GIMPLE register. Add it (or its aliases) to
1446 virtual operands, unless the caller has specifically requested
1447 not to add virtual operands (used when adding operands inside an
1448 ADDR_EXPR expression). */
1449 if (flags & opf_no_vops)
1450 return;
1452 aliases = v_ann->may_aliases;
1454 if (aliases == NULL)
1456 /* The variable is not aliased or it is an alias tag. */
1457 if (flags & opf_is_def)
1459 if (v_ann->is_alias_tag)
1461 /* Alias tagged vars get V_MAY_DEF to avoid breaking
1462 def-def chains with the other variables in their
1463 alias sets. */
1464 if (s_ann)
1465 s_ann->makes_aliased_stores = 1;
1466 append_v_may_def (var);
1468 else if (flags & opf_kill_def)
1470 #if defined ENABLE_CHECKING
1471 /* Only regular variables may get a V_MUST_DEF
1472 operand. */
1473 if (v_ann->mem_tag_kind != NOT_A_TAG)
1474 abort ();
1475 #endif
1476 /* V_MUST_DEF for non-aliased, non-GIMPLE register
1477 variable definitions. */
1478 append_v_must_def (var);
1480 else
1482 /* Add a V_MAY_DEF for call-clobbered variables and
1483 memory tags. */
1484 append_v_may_def (var);
1487 else
1489 append_vuse (var);
1490 if (s_ann && v_ann->is_alias_tag)
1491 s_ann->makes_aliased_loads = 1;
1494 else
1496 size_t i;
1498 /* The variable is aliased. Add its aliases to the virtual
1499 operands. */
1500 #if defined ENABLE_CHECKING
1501 if (VARRAY_ACTIVE_SIZE (aliases) == 0)
1502 abort ();
1503 #endif
1505 if (flags & opf_is_def)
1507 /* If the variable is also an alias tag, add a virtual
1508 operand for it, otherwise we will miss representing
1509 references to the members of the variable's alias set.
1510 This fixes the bug in gcc.c-torture/execute/20020503-1.c. */
1511 if (v_ann->is_alias_tag)
1512 append_v_may_def (var);
1514 for (i = 0; i < VARRAY_ACTIVE_SIZE (aliases); i++)
1515 append_v_may_def (VARRAY_TREE (aliases, i));
1517 if (s_ann)
1518 s_ann->makes_aliased_stores = 1;
1520 else
1522 /* Similarly, append a virtual uses for VAR itself, when
1523 it is an alias tag. */
1524 if (v_ann->is_alias_tag)
1525 append_vuse (var);
1527 for (i = 0; i < VARRAY_ACTIVE_SIZE (aliases); i++)
1528 append_vuse (VARRAY_TREE (aliases, i));
1530 if (s_ann)
1531 s_ann->makes_aliased_loads = 1;
1538 /* Record that VAR had its address taken in the statement with annotations
1539 S_ANN. */
1541 static void
1542 note_addressable (tree var, stmt_ann_t s_ann)
1544 if (!s_ann)
1545 return;
1547 var = get_base_address (var);
1548 if (var && SSA_VAR_P (var))
1550 if (s_ann->addresses_taken == NULL)
1551 s_ann->addresses_taken = BITMAP_GGC_ALLOC ();
1552 bitmap_set_bit (s_ann->addresses_taken, var_ann (var)->uid);
1557 /* Add clobbering definitions for .GLOBAL_VAR or for each of the call
1558 clobbered variables in the function. */
1560 static void
1561 add_call_clobber_ops (tree stmt)
1563 /* Functions that are not const, pure or never return may clobber
1564 call-clobbered variables. */
1565 if (stmt_ann (stmt))
1566 stmt_ann (stmt)->makes_clobbering_call = true;
1568 /* If we had created .GLOBAL_VAR earlier, use it. Otherwise, add
1569 a V_MAY_DEF operand for every call clobbered variable. See
1570 compute_may_aliases for the heuristic used to decide whether
1571 to create .GLOBAL_VAR or not. */
1572 if (global_var)
1573 add_stmt_operand (&global_var, stmt, opf_is_def);
1574 else
1576 size_t i;
1578 EXECUTE_IF_SET_IN_BITMAP (call_clobbered_vars, 0, i,
1580 tree var = referenced_var (i);
1582 /* If VAR is read-only, don't add a V_MAY_DEF, just a
1583 VUSE operand. */
1584 if (!TREE_READONLY (var))
1585 add_stmt_operand (&var, stmt, opf_is_def);
1586 else
1587 add_stmt_operand (&var, stmt, opf_none);
1593 /* Add VUSE operands for .GLOBAL_VAR or all call clobbered variables in the
1594 function. */
1596 static void
1597 add_call_read_ops (tree stmt)
1599 /* Otherwise, if the function is not pure, it may reference memory. Add
1600 a VUSE for .GLOBAL_VAR if it has been created. Otherwise, add a VUSE
1601 for each call-clobbered variable. See add_referenced_var for the
1602 heuristic used to decide whether to create .GLOBAL_VAR. */
1603 if (global_var)
1604 add_stmt_operand (&global_var, stmt, opf_none);
1605 else
1607 size_t i;
1609 EXECUTE_IF_SET_IN_BITMAP (call_clobbered_vars, 0, i,
1611 tree var = referenced_var (i);
1612 add_stmt_operand (&var, stmt, opf_none);
1617 /* Copies virtual operands from SRC to DST. */
1619 void
1620 copy_virtual_operands (tree dst, tree src)
1622 unsigned i;
1623 vuse_optype vuses = STMT_VUSE_OPS (src);
1624 v_may_def_optype v_may_defs = STMT_V_MAY_DEF_OPS (src);
1625 v_must_def_optype v_must_defs = STMT_V_MUST_DEF_OPS (src);
1626 vuse_optype *vuses_new = &stmt_ann (dst)->operands.vuse_ops;
1627 v_may_def_optype *v_may_defs_new = &stmt_ann (dst)->operands.v_may_def_ops;
1628 v_must_def_optype *v_must_defs_new = &stmt_ann (dst)->operands.v_must_def_ops;
1630 if (vuses)
1632 *vuses_new = allocate_vuse_optype (NUM_VUSES (vuses));
1633 for (i = 0; i < NUM_VUSES (vuses); i++)
1634 SET_VUSE_OP (*vuses_new, i, VUSE_OP (vuses, i));
1637 if (v_may_defs)
1639 *v_may_defs_new = allocate_v_may_def_optype (NUM_V_MAY_DEFS (v_may_defs));
1640 for (i = 0; i < NUM_V_MAY_DEFS (v_may_defs); i++)
1642 SET_V_MAY_DEF_OP (*v_may_defs_new, i, V_MAY_DEF_OP (v_may_defs, i));
1643 SET_V_MAY_DEF_RESULT (*v_may_defs_new, i,
1644 V_MAY_DEF_RESULT (v_may_defs, i));
1648 if (v_must_defs)
1650 *v_must_defs_new = allocate_v_must_def_optype (NUM_V_MUST_DEFS (v_must_defs));
1651 for (i = 0; i < NUM_V_MUST_DEFS (v_must_defs); i++)
1652 SET_V_MUST_DEF_OP (*v_must_defs_new, i, V_MUST_DEF_OP (v_must_defs, i));
1657 /* Specifically for use in DOM's expression analysis. Given a store, we
1658 create an artifical stmt which looks like a load from the store, this can
1659 be used to eliminate redundant loads. OLD_OPS are the operands from the
1660 store stmt, and NEW_STMT is the new load which reperesent a load of the
1661 values stored. */
1663 void
1664 create_ssa_artficial_load_stmt (stmt_operands_p old_ops, tree new_stmt)
1666 stmt_ann_t ann;
1667 tree op;
1668 stmt_operands_t tmp;
1669 unsigned j;
1671 memset (&tmp, 0, sizeof (stmt_operands_t));
1672 ann = get_stmt_ann (new_stmt);
1674 /* Free operands just in case is was an existing stmt. */
1675 free_ssa_operands (&(ann->operands));
1677 build_ssa_operands (new_stmt, NULL, &tmp, &(ann->operands));
1678 free_vuses (&(ann->operands.vuse_ops));
1679 free_v_may_defs (&(ann->operands.v_may_def_ops));
1680 free_v_must_defs (&(ann->operands.v_must_def_ops));
1682 /* For each VDEF on the original statement, we want to create a
1683 VUSE of the V_MAY_DEF result or V_MUST_DEF op on the new
1684 statement. */
1685 for (j = 0; j < NUM_V_MAY_DEFS (old_ops->v_may_def_ops); j++)
1687 op = V_MAY_DEF_RESULT (old_ops->v_may_def_ops, j);
1688 append_vuse (op);
1691 for (j = 0; j < NUM_V_MUST_DEFS (old_ops->v_must_def_ops); j++)
1693 op = V_MUST_DEF_OP (old_ops->v_must_def_ops, j);
1694 append_vuse (op);
1697 /* Now set the vuses for this new stmt. */
1698 ann->operands.vuse_ops = finalize_ssa_vuses (&(tmp.vuse_ops));
1701 #include "gt-tree-ssa-operands.h"