1 /* Header file for SSA iterators.
2 Copyright (C) 2013-2023 Free Software Foundation, Inc.
4 This file is part of GCC.
6 GCC is free software; you can redistribute it and/or modify it under
7 the terms of the GNU General Public License as published by the Free
8 Software Foundation; either version 3, or (at your option) any later
11 GCC is distributed in the hope that it will be useful, but WITHOUT ANY
12 WARRANTY; without even the implied warranty of MERCHANTABILITY or
13 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
16 You should have received a copy of the GNU General Public License
17 along with GCC; see the file COPYING3. If not see
18 <http://www.gnu.org/licenses/>. */
20 #ifndef GCC_SSA_ITERATORS_H
21 #define GCC_SSA_ITERATORS_H
23 /* Immediate use lists are used to directly access all uses for an SSA
24 name and get pointers to the statement for each use.
26 The structure ssa_use_operand_t consists of PREV and NEXT pointers
27 to maintain the list. A USE pointer, which points to address where
28 the use is located and a LOC pointer which can point to the
29 statement where the use is located, or, in the case of the root
30 node, it points to the SSA name itself.
32 The list is anchored by an occurrence of ssa_operand_d *in* the
33 ssa_name node itself (named 'imm_uses'). This node is uniquely
34 identified by having a NULL USE pointer. and the LOC pointer
35 pointing back to the ssa_name node itself. This node forms the
36 base for a circular list, and initially this is the only node in
39 Fast iteration allows each use to be examined, but does not allow
40 any modifications to the uses or stmts.
42 Normal iteration allows insertion, deletion, and modification. the
43 iterator manages this by inserting a marker node into the list
44 immediately before the node currently being examined in the list.
45 this marker node is uniquely identified by having null stmt *and* a
48 When iterating to the next use, the iteration routines check to see
49 if the node after the marker has changed. if it has, then the node
50 following the marker is now the next one to be visited. if not, the
51 marker node is moved past that node in the list (visualize it as
52 bumping the marker node through the list). this continues until
53 the marker node is moved to the original anchor position. the
54 marker node is then removed from the list.
56 If iteration is halted early, the marker node must be removed from
57 the list before continuing. */
58 struct imm_use_iterator
60 /* This is the current use the iterator is processing. */
61 ssa_use_operand_t
*imm_use
;
62 /* This marks the last use in the list (use node from SSA_NAME) */
63 ssa_use_operand_t
*end_p
;
64 /* This node is inserted and used to mark the end of the uses for a stmt. */
65 ssa_use_operand_t iter_node
;
66 /* This is the next ssa_name to visit. IMM_USE may get removed before
67 the next one is traversed to, so it must be cached early. */
68 ssa_use_operand_t
*next_imm_name
;
72 /* Use this iterator when simply looking at stmts. Adding, deleting or
73 modifying stmts will cause this iterator to malfunction. */
75 #define FOR_EACH_IMM_USE_FAST(DEST, ITER, SSAVAR) \
76 for ((DEST) = first_readonly_imm_use (&(ITER), (SSAVAR)); \
77 !end_readonly_imm_use_p (&(ITER)); \
78 (void) ((DEST) = next_readonly_imm_use (&(ITER))))
80 /* Forward declare for use in the class below. */
81 static inline void end_imm_use_stmt_traverse (imm_use_iterator
*);
83 /* arrange to automatically call, upon descruction, end_imm_use_stmt_traverse
84 with a given pointer to imm_use_iterator. */
85 struct auto_end_imm_use_stmt_traverse
87 imm_use_iterator
*imm
;
88 auto_end_imm_use_stmt_traverse (imm_use_iterator
*imm
)
90 ~auto_end_imm_use_stmt_traverse ()
91 { end_imm_use_stmt_traverse (imm
); }
94 /* Use this iterator to visit each stmt which has a use of SSAVAR. The
95 destructor of the auto_end_imm_use_stmt_traverse object deals with removing
96 ITER from SSAVAR's IMM_USE list even when leaving the scope early. */
98 #define FOR_EACH_IMM_USE_STMT(STMT, ITER, SSAVAR) \
99 for (struct auto_end_imm_use_stmt_traverse \
100 auto_end_imm_use_stmt_traverse \
101 ((((STMT) = first_imm_use_stmt (&(ITER), (SSAVAR))), \
103 !end_imm_use_stmt_p (&(ITER)); \
104 (void) ((STMT) = next_imm_use_stmt (&(ITER))))
106 /* Use this iterator in combination with FOR_EACH_IMM_USE_STMT to
107 get access to each occurrence of ssavar on the stmt returned by
108 that iterator.. for instance:
110 FOR_EACH_IMM_USE_STMT (stmt, iter, ssavar)
112 FOR_EACH_IMM_USE_ON_STMT (use_p, iter)
114 SET_USE (use_p, blah);
119 #define FOR_EACH_IMM_USE_ON_STMT(DEST, ITER) \
120 for ((DEST) = first_imm_use_on_stmt (&(ITER)); \
121 !end_imm_use_on_stmt_p (&(ITER)); \
122 (void) ((DEST) = next_imm_use_on_stmt (&(ITER))))
126 extern bool single_imm_use_1 (const ssa_use_operand_t
*head
,
127 use_operand_p
*use_p
, gimple
**stmt
);
130 enum ssa_op_iter_type
{
131 ssa_op_iter_none
= 0,
137 /* This structure is used in the operand iterator loops. It contains the
138 items required to determine which operand is retrieved next. During
139 optimization, this structure is scalarized, and any unused fields are
140 optimized away, resulting in little overhead. */
144 enum ssa_op_iter_type iter_type
;
153 /* NOTE: Keep these in sync with doc/tree-ssa.texi. */
154 /* These flags are used to determine which operands are returned during
155 execution of the loop. */
156 #define SSA_OP_USE 0x01 /* Real USE operands. */
157 #define SSA_OP_DEF 0x02 /* Real DEF operands. */
158 #define SSA_OP_VUSE 0x04 /* VUSE operands. */
159 #define SSA_OP_VDEF 0x08 /* VDEF operands. */
160 /* These are commonly grouped operand flags. */
161 #define SSA_OP_VIRTUAL_USES (SSA_OP_VUSE)
162 #define SSA_OP_VIRTUAL_DEFS (SSA_OP_VDEF)
163 #define SSA_OP_ALL_VIRTUALS (SSA_OP_VIRTUAL_USES | SSA_OP_VIRTUAL_DEFS)
164 #define SSA_OP_ALL_USES (SSA_OP_VIRTUAL_USES | SSA_OP_USE)
165 #define SSA_OP_ALL_DEFS (SSA_OP_VIRTUAL_DEFS | SSA_OP_DEF)
166 #define SSA_OP_ALL_OPERANDS (SSA_OP_ALL_USES | SSA_OP_ALL_DEFS)
168 /* This macro executes a loop over the operands of STMT specified in FLAG,
169 returning each operand as a 'tree' in the variable TREEVAR. ITER is an
170 ssa_op_iter structure used to control the loop. */
171 #define FOR_EACH_SSA_TREE_OPERAND(TREEVAR, STMT, ITER, FLAGS) \
172 for (TREEVAR = op_iter_init_tree (&(ITER), STMT, FLAGS); \
173 !op_iter_done (&(ITER)); \
174 (void) (TREEVAR = op_iter_next_tree (&(ITER))))
176 /* This macro executes a loop over the operands of STMT specified in FLAG,
177 returning each operand as a 'use_operand_p' in the variable USEVAR.
178 ITER is an ssa_op_iter structure used to control the loop. */
179 #define FOR_EACH_SSA_USE_OPERAND(USEVAR, STMT, ITER, FLAGS) \
180 for (USEVAR = op_iter_init_use (&(ITER), STMT, FLAGS); \
181 !op_iter_done (&(ITER)); \
182 USEVAR = op_iter_next_use (&(ITER)))
184 /* This macro executes a loop over the operands of STMT specified in FLAG,
185 returning each operand as a 'def_operand_p' in the variable DEFVAR.
186 ITER is an ssa_op_iter structure used to control the loop. */
187 #define FOR_EACH_SSA_DEF_OPERAND(DEFVAR, STMT, ITER, FLAGS) \
188 for (DEFVAR = op_iter_init_def (&(ITER), STMT, FLAGS); \
189 !op_iter_done (&(ITER)); \
190 DEFVAR = op_iter_next_def (&(ITER)))
192 /* This macro will execute a loop over all the arguments of a PHI which
193 match FLAGS. A use_operand_p is always returned via USEVAR. FLAGS
194 can be either SSA_OP_USE or SSA_OP_VIRTUAL_USES or SSA_OP_ALL_USES. */
195 #define FOR_EACH_PHI_ARG(USEVAR, STMT, ITER, FLAGS) \
196 for ((USEVAR) = op_iter_init_phiuse (&(ITER), STMT, FLAGS); \
197 !op_iter_done (&(ITER)); \
198 (USEVAR) = op_iter_next_use (&(ITER)))
201 /* This macro will execute a loop over a stmt, regardless of whether it is
202 a real stmt or a PHI node, looking at the USE nodes matching FLAGS. */
203 #define FOR_EACH_PHI_OR_STMT_USE(USEVAR, STMT, ITER, FLAGS) \
204 for ((USEVAR) = (gimple_code (STMT) == GIMPLE_PHI \
205 ? op_iter_init_phiuse (&(ITER), \
206 as_a <gphi *> (STMT), \
208 : op_iter_init_use (&(ITER), STMT, FLAGS)); \
209 !op_iter_done (&(ITER)); \
210 (USEVAR) = op_iter_next_use (&(ITER)))
212 /* This macro will execute a loop over a stmt, regardless of whether it is
213 a real stmt or a PHI node, looking at the DEF nodes matching FLAGS. */
214 #define FOR_EACH_PHI_OR_STMT_DEF(DEFVAR, STMT, ITER, FLAGS) \
215 for ((DEFVAR) = (gimple_code (STMT) == GIMPLE_PHI \
216 ? op_iter_init_phidef (&(ITER), \
217 as_a <gphi *> (STMT), \
219 : op_iter_init_def (&(ITER), STMT, FLAGS)); \
220 !op_iter_done (&(ITER)); \
221 (DEFVAR) = op_iter_next_def (&(ITER)))
223 /* This macro returns an operand in STMT as a tree if it is the ONLY
224 operand matching FLAGS. If there are 0 or more than 1 operand matching
225 FLAGS, then NULL_TREE is returned. */
226 #define SINGLE_SSA_TREE_OPERAND(STMT, FLAGS) \
227 single_ssa_tree_operand (STMT, FLAGS)
229 /* This macro returns an operand in STMT as a use_operand_p if it is the ONLY
230 operand matching FLAGS. If there are 0 or more than 1 operand matching
231 FLAGS, then NULL_USE_OPERAND_P is returned. */
232 #define SINGLE_SSA_USE_OPERAND(STMT, FLAGS) \
233 single_ssa_use_operand (STMT, FLAGS)
235 /* This macro returns an operand in STMT as a def_operand_p if it is the ONLY
236 operand matching FLAGS. If there are 0 or more than 1 operand matching
237 FLAGS, then NULL_DEF_OPERAND_P is returned. */
238 #define SINGLE_SSA_DEF_OPERAND(STMT, FLAGS) \
239 single_ssa_def_operand (STMT, FLAGS)
241 /* This macro returns TRUE if there are no operands matching FLAGS in STMT. */
242 #define ZERO_SSA_OPERANDS(STMT, FLAGS) zero_ssa_operands (STMT, FLAGS)
244 /* This macro counts the number of operands in STMT matching FLAGS. */
245 #define NUM_SSA_OPERANDS(STMT, FLAGS) num_ssa_operands (STMT, FLAGS)
248 /* Delink an immediate_uses node from its chain. */
250 delink_imm_use (ssa_use_operand_t
*linknode
)
252 /* Return if this node is not in a list. */
253 if (linknode
->prev
== NULL
)
256 linknode
->prev
->next
= linknode
->next
;
257 linknode
->next
->prev
= linknode
->prev
;
258 linknode
->prev
= NULL
;
259 linknode
->next
= NULL
;
262 /* Link ssa_imm_use node LINKNODE into the chain for LIST. */
264 link_imm_use_to_list (ssa_use_operand_t
*linknode
, ssa_use_operand_t
*list
)
266 /* Link the new node at the head of the list. If we are in the process of
267 traversing the list, we won't visit any new nodes added to it. */
268 linknode
->prev
= list
;
269 linknode
->next
= list
->next
;
270 list
->next
->prev
= linknode
;
271 list
->next
= linknode
;
274 /* Link ssa_imm_use node LINKNODE into the chain for DEF. */
276 link_imm_use (ssa_use_operand_t
*linknode
, tree def
)
278 ssa_use_operand_t
*root
;
280 if (!def
|| TREE_CODE (def
) != SSA_NAME
)
281 linknode
->prev
= NULL
;
284 root
= &(SSA_NAME_IMM_USE_NODE (def
));
286 gcc_checking_assert (*(linknode
->use
) == def
);
287 link_imm_use_to_list (linknode
, root
);
291 /* Set the value of a use pointed to by USE to VAL. */
293 set_ssa_use_from_ptr (use_operand_p use
, tree val
)
295 delink_imm_use (use
);
297 link_imm_use (use
, val
);
300 /* Link ssa_imm_use node LINKNODE into the chain for DEF, with use occurring
303 link_imm_use_stmt (ssa_use_operand_t
*linknode
, tree def
, gimple
*stmt
)
306 link_imm_use (linknode
, def
);
308 link_imm_use (linknode
, NULL
);
309 linknode
->loc
.stmt
= stmt
;
312 /* Relink a new node in place of an old node in the list. */
314 relink_imm_use (ssa_use_operand_t
*node
, ssa_use_operand_t
*old
)
316 /* The node one had better be in the same list. */
317 gcc_checking_assert (*(old
->use
) == *(node
->use
));
318 node
->prev
= old
->prev
;
319 node
->next
= old
->next
;
322 old
->prev
->next
= node
;
323 old
->next
->prev
= node
;
324 /* Remove the old node from the list. */
329 /* Relink ssa_imm_use node LINKNODE into the chain for OLD, with use occurring
332 relink_imm_use_stmt (ssa_use_operand_t
*linknode
, ssa_use_operand_t
*old
,
336 relink_imm_use (linknode
, old
);
338 link_imm_use (linknode
, NULL
);
339 linknode
->loc
.stmt
= stmt
;
343 /* Return true is IMM has reached the end of the immediate use list. */
345 end_readonly_imm_use_p (const imm_use_iterator
*imm
)
347 return (imm
->imm_use
== imm
->end_p
);
350 /* Initialize iterator IMM to process the list for VAR. */
351 static inline use_operand_p
352 first_readonly_imm_use (imm_use_iterator
*imm
, tree var
)
354 imm
->end_p
= &(SSA_NAME_IMM_USE_NODE (var
));
355 imm
->imm_use
= imm
->end_p
->next
;
356 imm
->iter_node
.next
= imm
->imm_use
->next
;
357 if (end_readonly_imm_use_p (imm
))
358 return NULL_USE_OPERAND_P
;
362 /* Bump IMM to the next use in the list. */
363 static inline use_operand_p
364 next_readonly_imm_use (imm_use_iterator
*imm
)
366 use_operand_p old
= imm
->imm_use
;
368 /* If this assertion fails, it indicates the 'next' pointer has changed
369 since the last bump. This indicates that the list is being modified
370 via stmt changes, or SET_USE, or somesuch thing, and you need to be
371 using the SAFE version of the iterator. */
374 gcc_assert (imm
->iter_node
.next
== old
->next
);
375 imm
->iter_node
.next
= old
->next
->next
;
378 imm
->imm_use
= old
->next
;
379 if (end_readonly_imm_use_p (imm
))
380 return NULL_USE_OPERAND_P
;
385 /* Return true if VAR has no nondebug uses. */
387 has_zero_uses (const_tree var
)
389 const ssa_use_operand_t
*const head
= &(SSA_NAME_IMM_USE_NODE (var
));
390 const ssa_use_operand_t
*ptr
;
392 for (ptr
= head
->next
; ptr
!= head
; ptr
= ptr
->next
)
393 if (USE_STMT (ptr
) && !is_gimple_debug (USE_STMT (ptr
)))
399 /* Return true if VAR has a single nondebug use. */
401 has_single_use (const_tree var
)
403 const ssa_use_operand_t
*const head
= &(SSA_NAME_IMM_USE_NODE (var
));
404 const ssa_use_operand_t
*ptr
;
407 for (ptr
= head
->next
; ptr
!= head
; ptr
= ptr
->next
)
408 if (USE_STMT(ptr
) && !is_gimple_debug (USE_STMT (ptr
)))
419 /* If VAR has only a single immediate nondebug use, return true, and
420 set USE_P and STMT to the use pointer and stmt of occurrence. */
422 single_imm_use (const_tree var
, use_operand_p
*use_p
, gimple
**stmt
)
424 const ssa_use_operand_t
*const ptr
= &(SSA_NAME_IMM_USE_NODE (var
));
426 /* If there aren't any uses whatsoever, we're done. */
427 if (ptr
== ptr
->next
)
430 *use_p
= NULL_USE_OPERAND_P
;
435 /* If there's a single use, check that it's not a debug stmt. */
436 if (ptr
== ptr
->next
->next
)
438 if (USE_STMT (ptr
->next
) && !is_gimple_debug (USE_STMT (ptr
->next
)))
441 *stmt
= ptr
->next
->loc
.stmt
;
448 return single_imm_use_1 (ptr
, use_p
, stmt
);
451 /* Return the number of nondebug immediate uses of VAR. */
452 static inline unsigned int
453 num_imm_uses (const_tree var
)
455 const ssa_use_operand_t
*const start
= &(SSA_NAME_IMM_USE_NODE (var
));
456 const ssa_use_operand_t
*ptr
;
457 unsigned int num
= 0;
459 if (!MAY_HAVE_DEBUG_BIND_STMTS
)
461 for (ptr
= start
->next
; ptr
!= start
; ptr
= ptr
->next
)
466 for (ptr
= start
->next
; ptr
!= start
; ptr
= ptr
->next
)
467 if (USE_STMT (ptr
) && !is_gimple_debug (USE_STMT (ptr
)))
473 /* ----------------------------------------------------------------------- */
475 /* The following set of routines are used to iterator over various type of
478 /* Return true if PTR is finished iterating. */
480 op_iter_done (const ssa_op_iter
*ptr
)
485 /* Get the next iterator use value for PTR. */
486 static inline use_operand_p
487 op_iter_next_use (ssa_op_iter
*ptr
)
490 gcc_checking_assert (ptr
->iter_type
== ssa_op_iter_use
);
493 use_p
= USE_OP_PTR (ptr
->uses
);
494 ptr
->uses
= ptr
->uses
->next
;
497 if (ptr
->i
< ptr
->numops
)
499 return PHI_ARG_DEF_PTR (ptr
->stmt
, (ptr
->i
)++);
502 return NULL_USE_OPERAND_P
;
505 /* Get the next iterator def value for PTR. */
506 static inline def_operand_p
507 op_iter_next_def (ssa_op_iter
*ptr
)
509 gcc_checking_assert (ptr
->iter_type
== ssa_op_iter_def
);
510 if (ptr
->flags
& SSA_OP_VDEF
)
513 ptr
->flags
&= ~SSA_OP_VDEF
;
514 p
= gimple_vdef_ptr (ptr
->stmt
);
518 if (ptr
->flags
& SSA_OP_DEF
)
520 while (ptr
->i
< ptr
->numops
)
522 tree
*val
= gimple_op_ptr (ptr
->stmt
, ptr
->i
);
526 if (TREE_CODE (*val
) == TREE_LIST
)
527 val
= &TREE_VALUE (*val
);
528 if (TREE_CODE (*val
) == SSA_NAME
529 || is_gimple_reg (*val
))
533 ptr
->flags
&= ~SSA_OP_DEF
;
537 return NULL_DEF_OPERAND_P
;
540 /* Get the next iterator tree value for PTR. */
542 op_iter_next_tree (ssa_op_iter
*ptr
)
545 gcc_checking_assert (ptr
->iter_type
== ssa_op_iter_tree
);
548 val
= USE_OP (ptr
->uses
);
549 ptr
->uses
= ptr
->uses
->next
;
552 if (ptr
->flags
& SSA_OP_VDEF
)
554 ptr
->flags
&= ~SSA_OP_VDEF
;
555 if ((val
= gimple_vdef (ptr
->stmt
)))
558 if (ptr
->flags
& SSA_OP_DEF
)
560 while (ptr
->i
< ptr
->numops
)
562 val
= gimple_op (ptr
->stmt
, ptr
->i
);
566 if (TREE_CODE (val
) == TREE_LIST
)
567 val
= TREE_VALUE (val
);
568 if (TREE_CODE (val
) == SSA_NAME
569 || is_gimple_reg (val
))
573 ptr
->flags
&= ~SSA_OP_DEF
;
581 /* This functions clears the iterator PTR, and marks it done. This is normally
582 used to prevent warnings in the compile about might be uninitialized
586 clear_and_done_ssa_iter (ssa_op_iter
*ptr
)
591 ptr
->iter_type
= ssa_op_iter_none
;
597 /* Initialize the iterator PTR to the virtual defs in STMT. */
599 op_iter_init (ssa_op_iter
*ptr
, gimple
*stmt
, int flags
)
601 /* PHI nodes require a different iterator initialization path. We
602 do not support iterating over virtual defs or uses without
603 iterating over defs or uses at the same time. */
604 gcc_checking_assert (gimple_code (stmt
) != GIMPLE_PHI
605 && (!(flags
& SSA_OP_VDEF
) || (flags
& SSA_OP_DEF
))
606 && (!(flags
& SSA_OP_VUSE
) || (flags
& SSA_OP_USE
)));
608 if (flags
& (SSA_OP_DEF
| SSA_OP_VDEF
))
610 switch (gimple_code (stmt
))
617 ptr
->numops
= gimple_asm_noutputs (as_a
<gasm
*> (stmt
));
619 case GIMPLE_TRANSACTION
:
621 flags
&= ~SSA_OP_DEF
;
625 flags
&= ~(SSA_OP_DEF
| SSA_OP_VDEF
);
629 ptr
->uses
= (flags
& (SSA_OP_USE
|SSA_OP_VUSE
)) ? gimple_use_ops (stmt
) : NULL
;
630 if (!(flags
& SSA_OP_VUSE
)
632 && gimple_vuse (stmt
) != NULL_TREE
)
633 ptr
->uses
= ptr
->uses
->next
;
641 /* Initialize iterator PTR to the use operands in STMT based on FLAGS. Return
643 static inline use_operand_p
644 op_iter_init_use (ssa_op_iter
*ptr
, gimple
*stmt
, int flags
)
646 gcc_checking_assert ((flags
& SSA_OP_ALL_DEFS
) == 0
647 && (flags
& SSA_OP_USE
));
648 op_iter_init (ptr
, stmt
, flags
);
649 ptr
->iter_type
= ssa_op_iter_use
;
650 return op_iter_next_use (ptr
);
653 /* Initialize iterator PTR to the def operands in STMT based on FLAGS. Return
655 static inline def_operand_p
656 op_iter_init_def (ssa_op_iter
*ptr
, gimple
*stmt
, int flags
)
658 gcc_checking_assert ((flags
& SSA_OP_ALL_USES
) == 0
659 && (flags
& SSA_OP_DEF
));
660 op_iter_init (ptr
, stmt
, flags
);
661 ptr
->iter_type
= ssa_op_iter_def
;
662 return op_iter_next_def (ptr
);
665 /* Initialize iterator PTR to the operands in STMT based on FLAGS. Return
666 the first operand as a tree. */
668 op_iter_init_tree (ssa_op_iter
*ptr
, gimple
*stmt
, int flags
)
670 op_iter_init (ptr
, stmt
, flags
);
671 ptr
->iter_type
= ssa_op_iter_tree
;
672 return op_iter_next_tree (ptr
);
676 /* If there is a single operand in STMT matching FLAGS, return it. Otherwise
679 single_ssa_tree_operand (gimple
*stmt
, int flags
)
684 var
= op_iter_init_tree (&iter
, stmt
, flags
);
685 if (op_iter_done (&iter
))
687 op_iter_next_tree (&iter
);
688 if (op_iter_done (&iter
))
694 /* If there is a single operand in STMT matching FLAGS, return it. Otherwise
696 static inline use_operand_p
697 single_ssa_use_operand (gimple
*stmt
, int flags
)
702 var
= op_iter_init_use (&iter
, stmt
, flags
);
703 if (op_iter_done (&iter
))
704 return NULL_USE_OPERAND_P
;
705 op_iter_next_use (&iter
);
706 if (op_iter_done (&iter
))
708 return NULL_USE_OPERAND_P
;
711 /* Return the single virtual use operand in STMT if present. Otherwise
713 static inline use_operand_p
714 ssa_vuse_operand (gimple
*stmt
)
716 if (! gimple_vuse (stmt
))
717 return NULL_USE_OPERAND_P
;
718 return USE_OP_PTR (gimple_use_ops (stmt
));
722 /* If there is a single operand in STMT matching FLAGS, return it. Otherwise
724 static inline def_operand_p
725 single_ssa_def_operand (gimple
*stmt
, int flags
)
730 var
= op_iter_init_def (&iter
, stmt
, flags
);
731 if (op_iter_done (&iter
))
732 return NULL_DEF_OPERAND_P
;
733 op_iter_next_def (&iter
);
734 if (op_iter_done (&iter
))
736 return NULL_DEF_OPERAND_P
;
740 /* Return true if there are zero operands in STMT matching the type
743 zero_ssa_operands (gimple
*stmt
, int flags
)
747 op_iter_init_tree (&iter
, stmt
, flags
);
748 return op_iter_done (&iter
);
752 /* Return the number of operands matching FLAGS in STMT. */
754 num_ssa_operands (gimple
*stmt
, int flags
)
760 gcc_checking_assert (gimple_code (stmt
) != GIMPLE_PHI
);
761 FOR_EACH_SSA_TREE_OPERAND (t
, stmt
, iter
, flags
)
766 /* If there is a single DEF in the PHI node which matches FLAG, return it.
767 Otherwise return NULL_DEF_OPERAND_P. */
769 single_phi_def (gphi
*stmt
, int flags
)
771 tree def
= PHI_RESULT (stmt
);
772 if ((flags
& SSA_OP_DEF
) && is_gimple_reg (def
))
774 if ((flags
& SSA_OP_VIRTUAL_DEFS
) && !is_gimple_reg (def
))
779 /* Initialize the iterator PTR for uses matching FLAGS in PHI. FLAGS should
780 be either SSA_OP_USES or SSA_OP_VIRTUAL_USES. */
781 static inline use_operand_p
782 op_iter_init_phiuse (ssa_op_iter
*ptr
, gphi
*phi
, int flags
)
784 tree phi_def
= gimple_phi_result (phi
);
787 clear_and_done_ssa_iter (ptr
);
790 gcc_checking_assert ((flags
& (SSA_OP_USE
| SSA_OP_VIRTUAL_USES
)) != 0);
792 comp
= (is_gimple_reg (phi_def
) ? SSA_OP_USE
: SSA_OP_VIRTUAL_USES
);
794 /* If the PHI node doesn't the operand type we care about, we're done. */
795 if ((flags
& comp
) == 0)
798 return NULL_USE_OPERAND_P
;
802 ptr
->numops
= gimple_phi_num_args (phi
);
803 ptr
->iter_type
= ssa_op_iter_use
;
805 return op_iter_next_use (ptr
);
809 /* Start an iterator for a PHI definition. */
811 static inline def_operand_p
812 op_iter_init_phidef (ssa_op_iter
*ptr
, gphi
*phi
, int flags
)
814 tree phi_def
= PHI_RESULT (phi
);
817 clear_and_done_ssa_iter (ptr
);
820 gcc_checking_assert ((flags
& (SSA_OP_DEF
| SSA_OP_VIRTUAL_DEFS
)) != 0);
822 comp
= (is_gimple_reg (phi_def
) ? SSA_OP_DEF
: SSA_OP_VIRTUAL_DEFS
);
824 /* If the PHI node doesn't have the operand type we care about,
826 if ((flags
& comp
) == 0)
829 return NULL_DEF_OPERAND_P
;
832 ptr
->iter_type
= ssa_op_iter_def
;
833 /* The first call to op_iter_next_def will terminate the iterator since
834 all the fields are NULL. Simply return the result here as the first and
835 therefore only result. */
836 return PHI_RESULT_PTR (phi
);
839 /* Return true is IMM has reached the end of the immediate use stmt list. */
842 end_imm_use_stmt_p (const imm_use_iterator
*imm
)
844 return (imm
->imm_use
== imm
->end_p
);
847 /* Finished the traverse of an immediate use stmt list IMM by removing the
848 placeholder node from the list. */
851 end_imm_use_stmt_traverse (imm_use_iterator
*imm
)
853 delink_imm_use (&(imm
->iter_node
));
856 /* Immediate use traversal of uses within a stmt require that all the
857 uses on a stmt be sequentially listed. This routine is used to build up
858 this sequential list by adding USE_P to the end of the current list
859 currently delimited by HEAD and LAST_P. The new LAST_P value is
862 static inline use_operand_p
863 move_use_after_head (use_operand_p use_p
, use_operand_p head
,
864 use_operand_p last_p
)
866 gcc_checking_assert (USE_FROM_PTR (use_p
) == USE_FROM_PTR (head
));
867 /* Skip head when we find it. */
870 /* If use_p is already linked in after last_p, continue. */
871 if (last_p
->next
== use_p
)
875 /* Delink from current location, and link in at last_p. */
876 delink_imm_use (use_p
);
877 link_imm_use_to_list (use_p
, last_p
);
885 /* This routine will relink all uses with the same stmt as HEAD into the list
886 immediately following HEAD for iterator IMM. */
889 link_use_stmts_after (use_operand_p head
, imm_use_iterator
*imm
)
892 use_operand_p last_p
= head
;
893 gimple
*head_stmt
= USE_STMT (head
);
894 tree use
= USE_FROM_PTR (head
);
898 /* Only look at virtual or real uses, depending on the type of HEAD. */
899 flag
= (is_gimple_reg (use
) ? SSA_OP_USE
: SSA_OP_VIRTUAL_USES
);
901 if (gphi
*phi
= dyn_cast
<gphi
*> (head_stmt
))
903 FOR_EACH_PHI_ARG (use_p
, phi
, op_iter
, flag
)
904 if (USE_FROM_PTR (use_p
) == use
)
905 last_p
= move_use_after_head (use_p
, head
, last_p
);
909 if (flag
== SSA_OP_USE
)
911 FOR_EACH_SSA_USE_OPERAND (use_p
, head_stmt
, op_iter
, flag
)
912 if (USE_FROM_PTR (use_p
) == use
)
913 last_p
= move_use_after_head (use_p
, head
, last_p
);
915 else if ((use_p
= gimple_vuse_op (head_stmt
)) != NULL_USE_OPERAND_P
)
917 if (USE_FROM_PTR (use_p
) == use
)
918 last_p
= move_use_after_head (use_p
, head
, last_p
);
921 /* Link iter node in after last_p. */
922 if (imm
->iter_node
.prev
!= NULL
)
923 delink_imm_use (&imm
->iter_node
);
924 link_imm_use_to_list (&(imm
->iter_node
), last_p
);
927 /* Initialize IMM to traverse over uses of VAR. Return the first statement. */
928 static inline gimple
*
929 first_imm_use_stmt (imm_use_iterator
*imm
, tree var
)
931 imm
->end_p
= &(SSA_NAME_IMM_USE_NODE (var
));
932 imm
->imm_use
= imm
->end_p
->next
;
933 imm
->next_imm_name
= NULL_USE_OPERAND_P
;
935 /* iter_node is used as a marker within the immediate use list to indicate
936 where the end of the current stmt's uses are. Initialize it to NULL
937 stmt and use, which indicates a marker node. */
938 imm
->iter_node
.prev
= NULL_USE_OPERAND_P
;
939 imm
->iter_node
.next
= NULL_USE_OPERAND_P
;
940 imm
->iter_node
.loc
.stmt
= NULL
;
941 imm
->iter_node
.use
= NULL
;
943 if (end_imm_use_stmt_p (imm
))
946 link_use_stmts_after (imm
->imm_use
, imm
);
948 return USE_STMT (imm
->imm_use
);
951 /* Bump IMM to the next stmt which has a use of var. */
953 static inline gimple
*
954 next_imm_use_stmt (imm_use_iterator
*imm
)
956 imm
->imm_use
= imm
->iter_node
.next
;
957 if (end_imm_use_stmt_p (imm
))
959 if (imm
->iter_node
.prev
!= NULL
)
960 delink_imm_use (&imm
->iter_node
);
964 link_use_stmts_after (imm
->imm_use
, imm
);
965 return USE_STMT (imm
->imm_use
);
968 /* This routine will return the first use on the stmt IMM currently refers
971 static inline use_operand_p
972 first_imm_use_on_stmt (imm_use_iterator
*imm
)
974 imm
->next_imm_name
= imm
->imm_use
->next
;
978 /* Return TRUE if the last use on the stmt IMM refers to has been visited. */
981 end_imm_use_on_stmt_p (const imm_use_iterator
*imm
)
983 return (imm
->imm_use
== &(imm
->iter_node
));
986 /* Bump to the next use on the stmt IMM refers to, return NULL if done. */
988 static inline use_operand_p
989 next_imm_use_on_stmt (imm_use_iterator
*imm
)
991 imm
->imm_use
= imm
->next_imm_name
;
992 if (end_imm_use_on_stmt_p (imm
))
993 return NULL_USE_OPERAND_P
;
996 imm
->next_imm_name
= imm
->imm_use
->next
;
1001 /* Delink all immediate_use information for STMT. */
1003 delink_stmt_imm_use (gimple
*stmt
)
1006 use_operand_p use_p
;
1008 if (ssa_operands_active (cfun
))
1009 FOR_EACH_PHI_OR_STMT_USE (use_p
, stmt
, iter
, SSA_OP_ALL_USES
)
1010 delink_imm_use (use_p
);
1013 #endif /* GCC_TREE_SSA_ITERATORS_H */