OSDN Git Service

Daily bump.
[pf3gnuchains/gcc-fork.git] / gcc / gimple.h
1 /* Gimple IR definitions.
2
3    Copyright 2007, 2008, 2009, 2010, 2011, 2012 Free Software Foundation, Inc.
4    Contributed by Aldy Hernandez <aldyh@redhat.com>
5
6 This file is part of GCC.
7
8 GCC is free software; you can redistribute it and/or modify it under
9 the terms of the GNU General Public License as published by the Free
10 Software Foundation; either version 3, or (at your option) any later
11 version.
12
13 GCC is distributed in the hope that it will be useful, but WITHOUT ANY
14 WARRANTY; without even the implied warranty of MERCHANTABILITY or
15 FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
16 for more details.
17
18 You should have received a copy of the GNU General Public License
19 along with GCC; see the file COPYING3.  If not see
20 <http://www.gnu.org/licenses/>.  */
21
22 #ifndef GCC_GIMPLE_H
23 #define GCC_GIMPLE_H
24
25 #include "pointer-set.h"
26 #include "vec.h"
27 #include "vecprim.h"
28 #include "vecir.h"
29 #include "ggc.h"
30 #include "basic-block.h"
31 #include "tree-ssa-operands.h"
32 #include "tree-ssa-alias.h"
33 #include "internal-fn.h"
34
35 struct gimple_seq_node_d;
36 typedef struct gimple_seq_node_d *gimple_seq_node;
37 typedef const struct gimple_seq_node_d *const_gimple_seq_node;
38
39 /* For each block, the PHI nodes that need to be rewritten are stored into
40    these vectors.  */
41 typedef VEC(gimple, heap) *gimple_vec;
42 DEF_VEC_P (gimple_vec);
43 DEF_VEC_ALLOC_P (gimple_vec, heap);
44
45 enum gimple_code {
46 #define DEFGSCODE(SYM, STRING, STRUCT)  SYM,
47 #include "gimple.def"
48 #undef DEFGSCODE
49     LAST_AND_UNUSED_GIMPLE_CODE
50 };
51
52 extern const char *const gimple_code_name[];
53 extern const unsigned char gimple_rhs_class_table[];
54
55 /* Error out if a gimple tuple is addressed incorrectly.  */
56 #if defined ENABLE_GIMPLE_CHECKING
57 #define gcc_gimple_checking_assert(EXPR) gcc_assert (EXPR)
58 extern void gimple_check_failed (const_gimple, const char *, int,          \
59                                  const char *, enum gimple_code,           \
60                                  enum tree_code) ATTRIBUTE_NORETURN;
61
62 #define GIMPLE_CHECK(GS, CODE)                                          \
63   do {                                                                  \
64     const_gimple __gs = (GS);                                           \
65     if (gimple_code (__gs) != (CODE))                                   \
66       gimple_check_failed (__gs, __FILE__, __LINE__, __FUNCTION__,      \
67                            (CODE), ERROR_MARK);                         \
68   } while (0)
69 #else  /* not ENABLE_GIMPLE_CHECKING  */
70 #define gcc_gimple_checking_assert(EXPR) ((void)(0 && (EXPR)))
71 #define GIMPLE_CHECK(GS, CODE)                  (void)0
72 #endif
73
74 /* Class of GIMPLE expressions suitable for the RHS of assignments.  See
75    get_gimple_rhs_class.  */
76 enum gimple_rhs_class
77 {
78   GIMPLE_INVALID_RHS,   /* The expression cannot be used on the RHS.  */
79   GIMPLE_TERNARY_RHS,   /* The expression is a ternary operation.  */
80   GIMPLE_BINARY_RHS,    /* The expression is a binary operation.  */
81   GIMPLE_UNARY_RHS,     /* The expression is a unary operation.  */
82   GIMPLE_SINGLE_RHS     /* The expression is a single object (an SSA
83                            name, a _DECL, a _REF, etc.  */
84 };
85
86 /* Specific flags for individual GIMPLE statements.  These flags are
87    always stored in gimple_statement_base.subcode and they may only be
88    defined for statement codes that do not use sub-codes.
89
90    Values for the masks can overlap as long as the overlapping values
91    are never used in the same statement class.
92
93    The maximum mask value that can be defined is 1 << 15 (i.e., each
94    statement code can hold up to 16 bitflags).
95
96    Keep this list sorted.  */
97 enum gf_mask {
98     GF_ASM_INPUT                = 1 << 0,
99     GF_ASM_VOLATILE             = 1 << 1,
100     GF_CALL_FROM_THUNK          = 1 << 0,
101     GF_CALL_RETURN_SLOT_OPT     = 1 << 1,
102     GF_CALL_TAILCALL            = 1 << 2,
103     GF_CALL_VA_ARG_PACK         = 1 << 3,
104     GF_CALL_NOTHROW             = 1 << 4,
105     GF_CALL_ALLOCA_FOR_VAR      = 1 << 5,
106     GF_CALL_INTERNAL            = 1 << 6,
107     GF_OMP_PARALLEL_COMBINED    = 1 << 0,
108
109     /* True on an GIMPLE_OMP_RETURN statement if the return does not require
110        a thread synchronization via some sort of barrier.  The exact barrier
111        that would otherwise be emitted is dependent on the OMP statement with
112        which this return is associated.  */
113     GF_OMP_RETURN_NOWAIT        = 1 << 0,
114
115     GF_OMP_SECTION_LAST         = 1 << 0,
116     GF_OMP_ATOMIC_NEED_VALUE    = 1 << 0,
117     GF_PREDICT_TAKEN            = 1 << 15
118 };
119
120 /* Currently, there are only two types of gimple debug stmt.  Others are
121    envisioned, for example, to enable the generation of is_stmt notes
122    in line number information, to mark sequence points, etc.  This
123    subcode is to be used to tell them apart.  */
124 enum gimple_debug_subcode {
125   GIMPLE_DEBUG_BIND = 0,
126   GIMPLE_DEBUG_SOURCE_BIND = 1
127 };
128
129 /* Masks for selecting a pass local flag (PLF) to work on.  These
130    masks are used by gimple_set_plf and gimple_plf.  */
131 enum plf_mask {
132     GF_PLF_1    = 1 << 0,
133     GF_PLF_2    = 1 << 1
134 };
135
136 /* A node in a gimple_seq_d.  */
137 struct GTY((chain_next ("%h.next"), chain_prev ("%h.prev"))) gimple_seq_node_d {
138   gimple stmt;
139   struct gimple_seq_node_d *prev;
140   struct gimple_seq_node_d *next;
141 };
142
143 /* A double-linked sequence of gimple statements.  */
144 struct GTY ((chain_next ("%h.next_free"))) gimple_seq_d {
145   /* First and last statements in the sequence.  */
146   gimple_seq_node first;
147   gimple_seq_node last;
148
149   /* Sequences are created/destroyed frequently.  To minimize
150      allocation activity, deallocated sequences are kept in a pool of
151      available sequences.  This is the pointer to the next free
152      sequence in the pool.  */
153   gimple_seq next_free;
154 };
155
156
157 /* Return the first node in GIMPLE sequence S.  */
158
159 static inline gimple_seq_node
160 gimple_seq_first (const_gimple_seq s)
161 {
162   return s ? s->first : NULL;
163 }
164
165
166 /* Return the first statement in GIMPLE sequence S.  */
167
168 static inline gimple
169 gimple_seq_first_stmt (const_gimple_seq s)
170 {
171   gimple_seq_node n = gimple_seq_first (s);
172   return (n) ? n->stmt : NULL;
173 }
174
175
176 /* Return the last node in GIMPLE sequence S.  */
177
178 static inline gimple_seq_node
179 gimple_seq_last (const_gimple_seq s)
180 {
181   return s ? s->last : NULL;
182 }
183
184
185 /* Return the last statement in GIMPLE sequence S.  */
186
187 static inline gimple
188 gimple_seq_last_stmt (const_gimple_seq s)
189 {
190   gimple_seq_node n = gimple_seq_last (s);
191   return (n) ? n->stmt : NULL;
192 }
193
194
195 /* Set the last node in GIMPLE sequence S to LAST.  */
196
197 static inline void
198 gimple_seq_set_last (gimple_seq s, gimple_seq_node last)
199 {
200   s->last = last;
201 }
202
203
204 /* Set the first node in GIMPLE sequence S to FIRST.  */
205
206 static inline void
207 gimple_seq_set_first (gimple_seq s, gimple_seq_node first)
208 {
209   s->first = first;
210 }
211
212
213 /* Return true if GIMPLE sequence S is empty.  */
214
215 static inline bool
216 gimple_seq_empty_p (const_gimple_seq s)
217 {
218   return s == NULL || s->first == NULL;
219 }
220
221
222 void gimple_seq_add_stmt (gimple_seq *, gimple);
223
224 /* Link gimple statement GS to the end of the sequence *SEQ_P.  If
225    *SEQ_P is NULL, a new sequence is allocated.  This function is
226    similar to gimple_seq_add_stmt, but does not scan the operands.
227    During gimplification, we need to manipulate statement sequences
228    before the def/use vectors have been constructed.  */
229 void gimple_seq_add_stmt_without_update (gimple_seq *, gimple);
230
231 /* Allocate a new sequence and initialize its first element with STMT.  */
232
233 static inline gimple_seq
234 gimple_seq_alloc_with_stmt (gimple stmt)
235 {
236   gimple_seq seq = NULL;
237   gimple_seq_add_stmt (&seq, stmt);
238   return seq;
239 }
240
241
242 /* Returns the sequence of statements in BB.  */
243
244 static inline gimple_seq
245 bb_seq (const_basic_block bb)
246 {
247   return (!(bb->flags & BB_RTL) && bb->il.gimple) ? bb->il.gimple->seq : NULL;
248 }
249
250
251 /* Sets the sequence of statements in BB to SEQ.  */
252
253 static inline void
254 set_bb_seq (basic_block bb, gimple_seq seq)
255 {
256   gcc_checking_assert (!(bb->flags & BB_RTL));
257   bb->il.gimple->seq = seq;
258 }
259
260 /* Iterator object for GIMPLE statement sequences.  */
261
262 typedef struct
263 {
264   /* Sequence node holding the current statement.  */
265   gimple_seq_node ptr;
266
267   /* Sequence and basic block holding the statement.  These fields
268      are necessary to handle edge cases such as when statement is
269      added to an empty basic block or when the last statement of a
270      block/sequence is removed.  */
271   gimple_seq seq;
272   basic_block bb;
273 } gimple_stmt_iterator;
274
275
276 /* Data structure definitions for GIMPLE tuples.  NOTE: word markers
277    are for 64 bit hosts.  */
278
279 struct GTY(()) gimple_statement_base {
280   /* [ WORD 1 ]
281      Main identifying code for a tuple.  */
282   ENUM_BITFIELD(gimple_code) code : 8;
283
284   /* Nonzero if a warning should not be emitted on this tuple.  */
285   unsigned int no_warning       : 1;
286
287   /* Nonzero if this tuple has been visited.  Passes are responsible
288      for clearing this bit before using it.  */
289   unsigned int visited          : 1;
290
291   /* Nonzero if this tuple represents a non-temporal move.  */
292   unsigned int nontemporal_move : 1;
293
294   /* Pass local flags.  These flags are free for any pass to use as
295      they see fit.  Passes should not assume that these flags contain
296      any useful value when the pass starts.  Any initial state that
297      the pass requires should be set on entry to the pass.  See
298      gimple_set_plf and gimple_plf for usage.  */
299   unsigned int plf              : 2;
300
301   /* Nonzero if this statement has been modified and needs to have its
302      operands rescanned.  */
303   unsigned modified             : 1;
304
305   /* Nonzero if this statement contains volatile operands.  */
306   unsigned has_volatile_ops     : 1;
307
308   /* Nonzero if this statement appears inside a transaction.  This bit
309      is calculated on de-mand and has relevant information only after
310      it has been calculated with compute_transaction_bits.  */
311   unsigned in_transaction       : 1;
312
313   /* The SUBCODE field can be used for tuple-specific flags for tuples
314      that do not require subcodes.  Note that SUBCODE should be at
315      least as wide as tree codes, as several tuples store tree codes
316      in there.  */
317   unsigned int subcode          : 16;
318
319   /* UID of this statement.  This is used by passes that want to
320      assign IDs to statements.  It must be assigned and used by each
321      pass.  By default it should be assumed to contain garbage.  */
322   unsigned uid;
323
324   /* [ WORD 2 ]
325      Locus information for debug info.  */
326   location_t location;
327
328   /* Number of operands in this tuple.  */
329   unsigned num_ops;
330
331   /* [ WORD 3 ]
332      Basic block holding this statement.  */
333   struct basic_block_def *bb;
334
335   /* [ WORD 4 ]
336      Lexical block holding this statement.  */
337   tree block;
338 };
339
340
341 /* Base structure for tuples with operands.  */
342
343 struct GTY(()) gimple_statement_with_ops_base
344 {
345   /* [ WORD 1-4 ]  */
346   struct gimple_statement_base gsbase;
347
348   /* [ WORD 5-6 ]
349      SSA operand vectors.  NOTE: It should be possible to
350      amalgamate these vectors with the operand vector OP.  However,
351      the SSA operand vectors are organized differently and contain
352      more information (like immediate use chaining).  */
353   struct def_optype_d GTY((skip (""))) *def_ops;
354   struct use_optype_d GTY((skip (""))) *use_ops;
355 };
356
357
358 /* Statements that take register operands.  */
359
360 struct GTY(()) gimple_statement_with_ops
361 {
362   /* [ WORD 1-6 ]  */
363   struct gimple_statement_with_ops_base opbase;
364
365   /* [ WORD 7 ]
366      Operand vector.  NOTE!  This must always be the last field
367      of this structure.  In particular, this means that this
368      structure cannot be embedded inside another one.  */
369   tree GTY((length ("%h.opbase.gsbase.num_ops"))) op[1];
370 };
371
372
373 /* Base for statements that take both memory and register operands.  */
374
375 struct GTY(()) gimple_statement_with_memory_ops_base
376 {
377   /* [ WORD 1-6 ]  */
378   struct gimple_statement_with_ops_base opbase;
379
380   /* [ WORD 7-8 ]
381      Virtual operands for this statement.  The GC will pick them
382      up via the ssa_names array.  */
383   tree GTY((skip (""))) vdef;
384   tree GTY((skip (""))) vuse;
385 };
386
387
388 /* Statements that take both memory and register operands.  */
389
390 struct GTY(()) gimple_statement_with_memory_ops
391 {
392   /* [ WORD 1-8 ]  */
393   struct gimple_statement_with_memory_ops_base membase;
394
395   /* [ WORD 9 ]
396      Operand vector.  NOTE!  This must always be the last field
397      of this structure.  In particular, this means that this
398      structure cannot be embedded inside another one.  */
399   tree GTY((length ("%h.membase.opbase.gsbase.num_ops"))) op[1];
400 };
401
402
403 /* Call statements that take both memory and register operands.  */
404
405 struct GTY(()) gimple_statement_call
406 {
407   /* [ WORD 1-8 ]  */
408   struct gimple_statement_with_memory_ops_base membase;
409
410   /* [ WORD 9-12 ]  */
411   struct pt_solution call_used;
412   struct pt_solution call_clobbered;
413
414   /* [ WORD 13 ]  */
415   union GTY ((desc ("%1.membase.opbase.gsbase.subcode & GF_CALL_INTERNAL"))) {
416     tree GTY ((tag ("0"))) fntype;
417     enum internal_fn GTY ((tag ("GF_CALL_INTERNAL"))) internal_fn;
418   } u;
419
420   /* [ WORD 14 ]
421      Operand vector.  NOTE!  This must always be the last field
422      of this structure.  In particular, this means that this
423      structure cannot be embedded inside another one.  */
424   tree GTY((length ("%h.membase.opbase.gsbase.num_ops"))) op[1];
425 };
426
427
428 /* OpenMP statements (#pragma omp).  */
429
430 struct GTY(()) gimple_statement_omp {
431   /* [ WORD 1-4 ]  */
432   struct gimple_statement_base gsbase;
433
434   /* [ WORD 5 ]  */
435   gimple_seq body;
436 };
437
438
439 /* GIMPLE_BIND */
440
441 struct GTY(()) gimple_statement_bind {
442   /* [ WORD 1-4 ]  */
443   struct gimple_statement_base gsbase;
444
445   /* [ WORD 5 ]
446      Variables declared in this scope.  */
447   tree vars;
448
449   /* [ WORD 6 ]
450      This is different than the BLOCK field in gimple_statement_base,
451      which is analogous to TREE_BLOCK (i.e., the lexical block holding
452      this statement).  This field is the equivalent of BIND_EXPR_BLOCK
453      in tree land (i.e., the lexical scope defined by this bind).  See
454      gimple-low.c.  */
455   tree block;
456
457   /* [ WORD 7 ]  */
458   gimple_seq body;
459 };
460
461
462 /* GIMPLE_CATCH */
463
464 struct GTY(()) gimple_statement_catch {
465   /* [ WORD 1-4 ]  */
466   struct gimple_statement_base gsbase;
467
468   /* [ WORD 5 ]  */
469   tree types;
470
471   /* [ WORD 6 ]  */
472   gimple_seq handler;
473 };
474
475
476 /* GIMPLE_EH_FILTER */
477
478 struct GTY(()) gimple_statement_eh_filter {
479   /* [ WORD 1-4 ]  */
480   struct gimple_statement_base gsbase;
481
482   /* [ WORD 5 ]
483      Filter types.  */
484   tree types;
485
486   /* [ WORD 6 ]
487      Failure actions.  */
488   gimple_seq failure;
489 };
490
491 /* GIMPLE_EH_ELSE */
492
493 struct GTY(()) gimple_statement_eh_else {
494   /* [ WORD 1-4 ]  */
495   struct gimple_statement_base gsbase;
496
497   /* [ WORD 5,6 ] */
498   gimple_seq n_body, e_body;
499 };
500
501 /* GIMPLE_EH_MUST_NOT_THROW */
502
503 struct GTY(()) gimple_statement_eh_mnt {
504   /* [ WORD 1-4 ]  */
505   struct gimple_statement_base gsbase;
506
507   /* [ WORD 5 ] Abort function decl.  */
508   tree fndecl;
509 };
510
511 /* GIMPLE_PHI */
512
513 struct GTY(()) gimple_statement_phi {
514   /* [ WORD 1-4 ]  */
515   struct gimple_statement_base gsbase;
516
517   /* [ WORD 5 ]  */
518   unsigned capacity;
519   unsigned nargs;
520
521   /* [ WORD 6 ]  */
522   tree result;
523
524   /* [ WORD 7 ]  */
525   struct phi_arg_d GTY ((length ("%h.nargs"))) args[1];
526 };
527
528
529 /* GIMPLE_RESX, GIMPLE_EH_DISPATCH */
530
531 struct GTY(()) gimple_statement_eh_ctrl
532 {
533   /* [ WORD 1-4 ]  */
534   struct gimple_statement_base gsbase;
535
536   /* [ WORD 5 ]
537      Exception region number.  */
538   int region;
539 };
540
541
542 /* GIMPLE_TRY */
543
544 struct GTY(()) gimple_statement_try {
545   /* [ WORD 1-4 ]  */
546   struct gimple_statement_base gsbase;
547
548   /* [ WORD 5 ]
549      Expression to evaluate.  */
550   gimple_seq eval;
551
552   /* [ WORD 6 ]
553      Cleanup expression.  */
554   gimple_seq cleanup;
555 };
556
557 /* Kind of GIMPLE_TRY statements.  */
558 enum gimple_try_flags
559 {
560   /* A try/catch.  */
561   GIMPLE_TRY_CATCH = 1 << 0,
562
563   /* A try/finally.  */
564   GIMPLE_TRY_FINALLY = 1 << 1,
565   GIMPLE_TRY_KIND = GIMPLE_TRY_CATCH | GIMPLE_TRY_FINALLY,
566
567   /* Analogous to TRY_CATCH_IS_CLEANUP.  */
568   GIMPLE_TRY_CATCH_IS_CLEANUP = 1 << 2
569 };
570
571 /* GIMPLE_WITH_CLEANUP_EXPR */
572
573 struct GTY(()) gimple_statement_wce {
574   /* [ WORD 1-4 ]  */
575   struct gimple_statement_base gsbase;
576
577   /* Subcode: CLEANUP_EH_ONLY.  True if the cleanup should only be
578               executed if an exception is thrown, not on normal exit of its
579               scope.  This flag is analogous to the CLEANUP_EH_ONLY flag
580               in TARGET_EXPRs.  */
581
582   /* [ WORD 5 ]
583      Cleanup expression.  */
584   gimple_seq cleanup;
585 };
586
587
588 /* GIMPLE_ASM  */
589
590 struct GTY(()) gimple_statement_asm
591 {
592   /* [ WORD 1-8 ]  */
593   struct gimple_statement_with_memory_ops_base membase;
594
595   /* [ WORD 9 ]
596      __asm__ statement.  */
597   const char *string;
598
599   /* [ WORD 10 ]
600        Number of inputs, outputs, clobbers, labels.  */
601   unsigned char ni;
602   unsigned char no;
603   unsigned char nc;
604   unsigned char nl;
605
606   /* [ WORD 11 ]
607      Operand vector.  NOTE!  This must always be the last field
608      of this structure.  In particular, this means that this
609      structure cannot be embedded inside another one.  */
610   tree GTY((length ("%h.membase.opbase.gsbase.num_ops"))) op[1];
611 };
612
613 /* GIMPLE_OMP_CRITICAL */
614
615 struct GTY(()) gimple_statement_omp_critical {
616   /* [ WORD 1-5 ]  */
617   struct gimple_statement_omp omp;
618
619   /* [ WORD 6 ]
620      Critical section name.  */
621   tree name;
622 };
623
624
625 struct GTY(()) gimple_omp_for_iter {
626   /* Condition code.  */
627   enum tree_code cond;
628
629   /* Index variable.  */
630   tree index;
631
632   /* Initial value.  */
633   tree initial;
634
635   /* Final value.  */
636   tree final;
637
638   /* Increment.  */
639   tree incr;
640 };
641
642 /* GIMPLE_OMP_FOR */
643
644 struct GTY(()) gimple_statement_omp_for {
645   /* [ WORD 1-5 ]  */
646   struct gimple_statement_omp omp;
647
648   /* [ WORD 6 ]  */
649   tree clauses;
650
651   /* [ WORD 7 ]
652      Number of elements in iter array.  */
653   size_t collapse;
654
655   /* [ WORD 8 ]  */
656   struct gimple_omp_for_iter * GTY((length ("%h.collapse"))) iter;
657
658   /* [ WORD 9 ]
659      Pre-body evaluated before the loop body begins.  */
660   gimple_seq pre_body;
661 };
662
663
664 /* GIMPLE_OMP_PARALLEL */
665
666 struct GTY(()) gimple_statement_omp_parallel {
667   /* [ WORD 1-5 ]  */
668   struct gimple_statement_omp omp;
669
670   /* [ WORD 6 ]
671      Clauses.  */
672   tree clauses;
673
674   /* [ WORD 7 ]
675      Child function holding the body of the parallel region.  */
676   tree child_fn;
677
678   /* [ WORD 8 ]
679      Shared data argument.  */
680   tree data_arg;
681 };
682
683
684 /* GIMPLE_OMP_TASK */
685
686 struct GTY(()) gimple_statement_omp_task {
687   /* [ WORD 1-8 ]  */
688   struct gimple_statement_omp_parallel par;
689
690   /* [ WORD 9 ]
691      Child function holding firstprivate initialization if needed.  */
692   tree copy_fn;
693
694   /* [ WORD 10-11 ]
695      Size and alignment in bytes of the argument data block.  */
696   tree arg_size;
697   tree arg_align;
698 };
699
700
701 /* GIMPLE_OMP_SECTION */
702 /* Uses struct gimple_statement_omp.  */
703
704
705 /* GIMPLE_OMP_SECTIONS */
706
707 struct GTY(()) gimple_statement_omp_sections {
708   /* [ WORD 1-5 ]  */
709   struct gimple_statement_omp omp;
710
711   /* [ WORD 6 ]  */
712   tree clauses;
713
714   /* [ WORD 7 ]
715      The control variable used for deciding which of the sections to
716      execute.  */
717   tree control;
718 };
719
720 /* GIMPLE_OMP_CONTINUE.
721
722    Note: This does not inherit from gimple_statement_omp, because we
723          do not need the body field.  */
724
725 struct GTY(()) gimple_statement_omp_continue {
726   /* [ WORD 1-4 ]  */
727   struct gimple_statement_base gsbase;
728
729   /* [ WORD 5 ]  */
730   tree control_def;
731
732   /* [ WORD 6 ]  */
733   tree control_use;
734 };
735
736 /* GIMPLE_OMP_SINGLE */
737
738 struct GTY(()) gimple_statement_omp_single {
739   /* [ WORD 1-5 ]  */
740   struct gimple_statement_omp omp;
741
742   /* [ WORD 6 ]  */
743   tree clauses;
744 };
745
746
747 /* GIMPLE_OMP_ATOMIC_LOAD.
748    Note: This is based on gimple_statement_base, not g_s_omp, because g_s_omp
749    contains a sequence, which we don't need here.  */
750
751 struct GTY(()) gimple_statement_omp_atomic_load {
752   /* [ WORD 1-4 ]  */
753   struct gimple_statement_base gsbase;
754
755   /* [ WORD 5-6 ]  */
756   tree rhs, lhs;
757 };
758
759 /* GIMPLE_OMP_ATOMIC_STORE.
760    See note on GIMPLE_OMP_ATOMIC_LOAD.  */
761
762 struct GTY(()) gimple_statement_omp_atomic_store {
763   /* [ WORD 1-4 ]  */
764   struct gimple_statement_base gsbase;
765
766   /* [ WORD 5 ]  */
767   tree val;
768 };
769
770 /* GIMPLE_TRANSACTION.  */
771
772 /* Bits to be stored in the GIMPLE_TRANSACTION subcode.  */
773
774 /* The __transaction_atomic was declared [[outer]] or it is
775    __transaction_relaxed.  */
776 #define GTMA_IS_OUTER                   (1u << 0)
777 #define GTMA_IS_RELAXED                 (1u << 1)
778 #define GTMA_DECLARATION_MASK           (GTMA_IS_OUTER | GTMA_IS_RELAXED)
779
780 /* The transaction is seen to not have an abort.  */
781 #define GTMA_HAVE_ABORT                 (1u << 2)
782 /* The transaction is seen to have loads or stores.  */
783 #define GTMA_HAVE_LOAD                  (1u << 3)
784 #define GTMA_HAVE_STORE                 (1u << 4)
785 /* The transaction MAY enter serial irrevocable mode in its dynamic scope.  */
786 #define GTMA_MAY_ENTER_IRREVOCABLE      (1u << 5)
787 /* The transaction WILL enter serial irrevocable mode.
788    An irrevocable block post-dominates the entire transaction, such
789    that all invocations of the transaction will go serial-irrevocable.
790    In such case, we don't bother instrumenting the transaction, and
791    tell the runtime that it should begin the transaction in
792    serial-irrevocable mode.  */
793 #define GTMA_DOES_GO_IRREVOCABLE        (1u << 6)
794
795 struct GTY(()) gimple_statement_transaction
796 {
797   /* [ WORD 1-10 ]  */
798   struct gimple_statement_with_memory_ops_base gsbase;
799
800   /* [ WORD 11 ] */
801   gimple_seq body;
802
803   /* [ WORD 12 ] */
804   tree label;
805 };
806
807 #define DEFGSSTRUCT(SYM, STRUCT, HAS_TREE_OP)   SYM,
808 enum gimple_statement_structure_enum {
809 #include "gsstruct.def"
810     LAST_GSS_ENUM
811 };
812 #undef DEFGSSTRUCT
813
814
815 /* Define the overall contents of a gimple tuple.  It may be any of the
816    structures declared above for various types of tuples.  */
817
818 union GTY ((desc ("gimple_statement_structure (&%h)"), variable_size)) gimple_statement_d {
819   struct gimple_statement_base GTY ((tag ("GSS_BASE"))) gsbase;
820   struct gimple_statement_with_ops GTY ((tag ("GSS_WITH_OPS"))) gsops;
821   struct gimple_statement_with_memory_ops_base GTY ((tag ("GSS_WITH_MEM_OPS_BASE"))) gsmembase;
822   struct gimple_statement_with_memory_ops GTY ((tag ("GSS_WITH_MEM_OPS"))) gsmem;
823   struct gimple_statement_call GTY ((tag ("GSS_CALL"))) gimple_call;
824   struct gimple_statement_omp GTY ((tag ("GSS_OMP"))) omp;
825   struct gimple_statement_bind GTY ((tag ("GSS_BIND"))) gimple_bind;
826   struct gimple_statement_catch GTY ((tag ("GSS_CATCH"))) gimple_catch;
827   struct gimple_statement_eh_filter GTY ((tag ("GSS_EH_FILTER"))) gimple_eh_filter;
828   struct gimple_statement_eh_mnt GTY ((tag ("GSS_EH_MNT"))) gimple_eh_mnt;
829   struct gimple_statement_eh_else GTY ((tag ("GSS_EH_ELSE"))) gimple_eh_else;
830   struct gimple_statement_phi GTY ((tag ("GSS_PHI"))) gimple_phi;
831   struct gimple_statement_eh_ctrl GTY ((tag ("GSS_EH_CTRL"))) gimple_eh_ctrl;
832   struct gimple_statement_try GTY ((tag ("GSS_TRY"))) gimple_try;
833   struct gimple_statement_wce GTY ((tag ("GSS_WCE"))) gimple_wce;
834   struct gimple_statement_asm GTY ((tag ("GSS_ASM"))) gimple_asm;
835   struct gimple_statement_omp_critical GTY ((tag ("GSS_OMP_CRITICAL"))) gimple_omp_critical;
836   struct gimple_statement_omp_for GTY ((tag ("GSS_OMP_FOR"))) gimple_omp_for;
837   struct gimple_statement_omp_parallel GTY ((tag ("GSS_OMP_PARALLEL"))) gimple_omp_parallel;
838   struct gimple_statement_omp_task GTY ((tag ("GSS_OMP_TASK"))) gimple_omp_task;
839   struct gimple_statement_omp_sections GTY ((tag ("GSS_OMP_SECTIONS"))) gimple_omp_sections;
840   struct gimple_statement_omp_single GTY ((tag ("GSS_OMP_SINGLE"))) gimple_omp_single;
841   struct gimple_statement_omp_continue GTY ((tag ("GSS_OMP_CONTINUE"))) gimple_omp_continue;
842   struct gimple_statement_omp_atomic_load GTY ((tag ("GSS_OMP_ATOMIC_LOAD"))) gimple_omp_atomic_load;
843   struct gimple_statement_omp_atomic_store GTY ((tag ("GSS_OMP_ATOMIC_STORE"))) gimple_omp_atomic_store;
844   struct gimple_statement_transaction GTY((tag ("GSS_TRANSACTION"))) gimple_transaction;
845 };
846
847 /* In gimple.c.  */
848
849 /* Offset in bytes to the location of the operand vector.
850    Zero if there is no operand vector for this tuple structure.  */
851 extern size_t const gimple_ops_offset_[];
852
853 /* Map GIMPLE codes to GSS codes.  */
854 extern enum gimple_statement_structure_enum const gss_for_code_[];
855
856 /* This variable holds the currently expanded gimple statement for purposes
857    of comminucating the profile info to the builtin expanders.  */
858 extern gimple currently_expanding_gimple_stmt;
859
860 gimple gimple_build_return (tree);
861
862 gimple gimple_build_assign_stat (tree, tree MEM_STAT_DECL);
863 #define gimple_build_assign(l,r) gimple_build_assign_stat (l, r MEM_STAT_INFO)
864
865 void extract_ops_from_tree_1 (tree, enum tree_code *, tree *, tree *, tree *);
866
867 gimple gimple_build_assign_with_ops_stat (enum tree_code, tree, tree,
868                                           tree, tree MEM_STAT_DECL);
869 #define gimple_build_assign_with_ops(c,o1,o2,o3)                        \
870   gimple_build_assign_with_ops_stat (c, o1, o2, o3, NULL_TREE MEM_STAT_INFO)
871 #define gimple_build_assign_with_ops3(c,o1,o2,o3,o4)                    \
872   gimple_build_assign_with_ops_stat (c, o1, o2, o3, o4 MEM_STAT_INFO)
873
874 gimple gimple_build_debug_bind_stat (tree, tree, gimple MEM_STAT_DECL);
875 #define gimple_build_debug_bind(var,val,stmt)                   \
876   gimple_build_debug_bind_stat ((var), (val), (stmt) MEM_STAT_INFO)
877 gimple gimple_build_debug_source_bind_stat (tree, tree, gimple MEM_STAT_DECL);
878 #define gimple_build_debug_source_bind(var,val,stmt)                    \
879   gimple_build_debug_source_bind_stat ((var), (val), (stmt) MEM_STAT_INFO)
880
881 gimple gimple_build_call_vec (tree, VEC(tree, heap) *);
882 gimple gimple_build_call (tree, unsigned, ...);
883 gimple gimple_build_call_valist (tree, unsigned, va_list);
884 gimple gimple_build_call_internal (enum internal_fn, unsigned, ...);
885 gimple gimple_build_call_internal_vec (enum internal_fn, VEC(tree, heap) *);
886 gimple gimple_build_call_from_tree (tree);
887 gimple gimplify_assign (tree, tree, gimple_seq *);
888 gimple gimple_build_cond (enum tree_code, tree, tree, tree, tree);
889 gimple gimple_build_label (tree label);
890 gimple gimple_build_goto (tree dest);
891 gimple gimple_build_nop (void);
892 gimple gimple_build_bind (tree, gimple_seq, tree);
893 gimple gimple_build_asm_vec (const char *, VEC(tree,gc) *, VEC(tree,gc) *,
894                              VEC(tree,gc) *, VEC(tree,gc) *);
895 gimple gimple_build_catch (tree, gimple_seq);
896 gimple gimple_build_eh_filter (tree, gimple_seq);
897 gimple gimple_build_eh_must_not_throw (tree);
898 gimple gimple_build_eh_else (gimple_seq, gimple_seq);
899 gimple gimple_build_try (gimple_seq, gimple_seq, enum gimple_try_flags);
900 gimple gimple_build_wce (gimple_seq);
901 gimple gimple_build_resx (int);
902 gimple gimple_build_eh_dispatch (int);
903 gimple gimple_build_switch_nlabels (unsigned, tree, tree);
904 gimple gimple_build_switch (unsigned, tree, tree, ...);
905 gimple gimple_build_switch_vec (tree, tree, VEC(tree,heap) *);
906 gimple gimple_build_omp_parallel (gimple_seq, tree, tree, tree);
907 gimple gimple_build_omp_task (gimple_seq, tree, tree, tree, tree, tree, tree);
908 gimple gimple_build_omp_for (gimple_seq, tree, size_t, gimple_seq);
909 gimple gimple_build_omp_critical (gimple_seq, tree);
910 gimple gimple_build_omp_section (gimple_seq);
911 gimple gimple_build_omp_continue (tree, tree);
912 gimple gimple_build_omp_master (gimple_seq);
913 gimple gimple_build_omp_return (bool);
914 gimple gimple_build_omp_ordered (gimple_seq);
915 gimple gimple_build_omp_sections (gimple_seq, tree);
916 gimple gimple_build_omp_sections_switch (void);
917 gimple gimple_build_omp_single (gimple_seq, tree);
918 gimple gimple_build_cdt (tree, tree);
919 gimple gimple_build_omp_atomic_load (tree, tree);
920 gimple gimple_build_omp_atomic_store (tree);
921 gimple gimple_build_transaction (gimple_seq, tree);
922 gimple gimple_build_predict (enum br_predictor, enum prediction);
923 enum gimple_statement_structure_enum gss_for_assign (enum tree_code);
924 void sort_case_labels (VEC(tree,heap) *);
925 void gimple_set_body (tree, gimple_seq);
926 gimple_seq gimple_body (tree);
927 bool gimple_has_body_p (tree);
928 gimple_seq gimple_seq_alloc (void);
929 void gimple_seq_free (gimple_seq);
930 void gimple_seq_add_seq (gimple_seq *, gimple_seq);
931 gimple_seq gimple_seq_copy (gimple_seq);
932 bool gimple_call_same_target_p (const_gimple, const_gimple);
933 int gimple_call_flags (const_gimple);
934 int gimple_call_return_flags (const_gimple);
935 int gimple_call_arg_flags (const_gimple, unsigned);
936 void gimple_call_reset_alias_info (gimple);
937 bool gimple_assign_copy_p (gimple);
938 bool gimple_assign_ssa_name_copy_p (gimple);
939 bool gimple_assign_unary_nop_p (gimple);
940 void gimple_set_bb (gimple, struct basic_block_def *);
941 void gimple_assign_set_rhs_from_tree (gimple_stmt_iterator *, tree);
942 void gimple_assign_set_rhs_with_ops_1 (gimple_stmt_iterator *, enum tree_code,
943                                        tree, tree, tree);
944 tree gimple_get_lhs (const_gimple);
945 void gimple_set_lhs (gimple, tree);
946 void gimple_replace_lhs (gimple, tree);
947 gimple gimple_copy (gimple);
948 void gimple_set_modified (gimple, bool);
949 void gimple_cond_get_ops_from_tree (tree, enum tree_code *, tree *, tree *);
950 gimple gimple_build_cond_from_tree (tree, tree, tree);
951 void gimple_cond_set_condition_from_tree (gimple, tree);
952 bool gimple_has_side_effects (const_gimple);
953 bool gimple_could_trap_p (gimple);
954 bool gimple_could_trap_p_1 (gimple, bool, bool);
955 bool gimple_assign_rhs_could_trap_p (gimple);
956 void gimple_regimplify_operands (gimple, gimple_stmt_iterator *);
957 bool empty_body_p (gimple_seq);
958 unsigned get_gimple_rhs_num_ops (enum tree_code);
959 #define gimple_alloc(c, n) gimple_alloc_stat (c, n MEM_STAT_INFO)
960 gimple gimple_alloc_stat (enum gimple_code, unsigned MEM_STAT_DECL);
961 const char *gimple_decl_printable_name (tree, int);
962 tree gimple_get_virt_method_for_binfo (HOST_WIDE_INT, tree);
963 void gimple_adjust_this_by_delta (gimple_stmt_iterator *, tree);
964 tree gimple_extract_devirt_binfo_from_cst (tree);
965 /* Returns true iff T is a valid GIMPLE statement.  */
966 extern bool is_gimple_stmt (tree);
967
968 /* Returns true iff T is a scalar register variable.  */
969 extern bool is_gimple_reg (tree);
970 /* Returns true iff T is any sort of variable.  */
971 extern bool is_gimple_variable (tree);
972 /* Returns true iff T is any sort of symbol.  */
973 extern bool is_gimple_id (tree);
974 /* Returns true iff T is a variable or an INDIRECT_REF (of a variable).  */
975 extern bool is_gimple_min_lval (tree);
976 /* Returns true iff T is something whose address can be taken.  */
977 extern bool is_gimple_addressable (tree);
978 /* Returns true iff T is any valid GIMPLE lvalue.  */
979 extern bool is_gimple_lvalue (tree);
980
981 /* Returns true iff T is a GIMPLE address.  */
982 bool is_gimple_address (const_tree);
983 /* Returns true iff T is a GIMPLE invariant address.  */
984 bool is_gimple_invariant_address (const_tree);
985 /* Returns true iff T is a GIMPLE invariant address at interprocedural
986    level.  */
987 bool is_gimple_ip_invariant_address (const_tree);
988 /* Returns true iff T is a valid GIMPLE constant.  */
989 bool is_gimple_constant (const_tree);
990 /* Returns true iff T is a GIMPLE restricted function invariant.  */
991 extern bool is_gimple_min_invariant (const_tree);
992 /* Returns true iff T is a GIMPLE restricted interprecodural invariant.  */
993 extern bool is_gimple_ip_invariant (const_tree);
994 /* Returns true iff T is a GIMPLE rvalue.  */
995 extern bool is_gimple_val (tree);
996 /* Returns true iff T is a GIMPLE asm statement input.  */
997 extern bool is_gimple_asm_val (tree);
998 /* Returns true iff T is a valid address operand of a MEM_REF.  */
999 bool is_gimple_mem_ref_addr (tree);
1000 /* Returns true iff T is a valid rhs for a MODIFY_EXPR where the LHS is a
1001    GIMPLE temporary, a renamed user variable, or something else,
1002    respectively.  */
1003 extern bool is_gimple_reg_rhs (tree);
1004 extern bool is_gimple_mem_rhs (tree);
1005
1006 /* Returns true iff T is a valid if-statement condition.  */
1007 extern bool is_gimple_condexpr (tree);
1008
1009 /* Returns true iff T is a valid call address expression.  */
1010 extern bool is_gimple_call_addr (tree);
1011
1012 extern void recalculate_side_effects (tree);
1013 extern bool gimple_compare_field_offset (tree, tree);
1014 extern tree gimple_register_type (tree);
1015 extern tree gimple_register_canonical_type (tree);
1016 extern void print_gimple_types_stats (void);
1017 extern void free_gimple_type_tables (void);
1018 extern tree gimple_unsigned_type (tree);
1019 extern tree gimple_signed_type (tree);
1020 extern alias_set_type gimple_get_alias_set (tree);
1021 extern void count_uses_and_derefs (tree, gimple, unsigned *, unsigned *,
1022                                    unsigned *);
1023 extern bool walk_stmt_load_store_addr_ops (gimple, void *,
1024                                            bool (*)(gimple, tree, void *),
1025                                            bool (*)(gimple, tree, void *),
1026                                            bool (*)(gimple, tree, void *));
1027 extern bool walk_stmt_load_store_ops (gimple, void *,
1028                                       bool (*)(gimple, tree, void *),
1029                                       bool (*)(gimple, tree, void *));
1030 extern bool gimple_ior_addresses_taken (bitmap, gimple);
1031 extern bool gimple_call_builtin_p (gimple, enum built_in_function);
1032 extern bool gimple_asm_clobbers_memory_p (const_gimple);
1033
1034 /* In gimplify.c  */
1035 extern tree create_tmp_var_raw (tree, const char *);
1036 extern tree create_tmp_var_name (const char *);
1037 extern tree create_tmp_var (tree, const char *);
1038 extern tree create_tmp_reg (tree, const char *);
1039 extern tree get_initialized_tmp_var (tree, gimple_seq *, gimple_seq *);
1040 extern tree get_formal_tmp_var (tree, gimple_seq *);
1041 extern void declare_vars (tree, gimple, bool);
1042 extern void annotate_all_with_location (gimple_seq, location_t);
1043
1044 /* Validation of GIMPLE expressions.  Note that these predicates only check
1045    the basic form of the expression, they don't recurse to make sure that
1046    underlying nodes are also of the right form.  */
1047 typedef bool (*gimple_predicate)(tree);
1048
1049
1050 /* FIXME we should deduce this from the predicate.  */
1051 enum fallback {
1052   fb_none = 0,          /* Do not generate a temporary.  */
1053
1054   fb_rvalue = 1,        /* Generate an rvalue to hold the result of a
1055                            gimplified expression.  */
1056
1057   fb_lvalue = 2,        /* Generate an lvalue to hold the result of a
1058                            gimplified expression.  */
1059
1060   fb_mayfail = 4,       /* Gimplification may fail.  Error issued
1061                            afterwards.  */
1062   fb_either= fb_rvalue | fb_lvalue
1063 };
1064
1065 typedef int fallback_t;
1066
1067 enum gimplify_status {
1068   GS_ERROR      = -2,   /* Something Bad Seen.  */
1069   GS_UNHANDLED  = -1,   /* A langhook result for "I dunno".  */
1070   GS_OK         = 0,    /* We did something, maybe more to do.  */
1071   GS_ALL_DONE   = 1     /* The expression is fully gimplified.  */
1072 };
1073
1074 struct gimplify_ctx
1075 {
1076   struct gimplify_ctx *prev_context;
1077
1078   VEC(gimple,heap) *bind_expr_stack;
1079   tree temps;
1080   gimple_seq conditional_cleanups;
1081   tree exit_label;
1082   tree return_temp;
1083
1084   VEC(tree,heap) *case_labels;
1085   /* The formal temporary table.  Should this be persistent?  */
1086   htab_t temp_htab;
1087
1088   int conditions;
1089   bool save_stack;
1090   bool into_ssa;
1091   bool allow_rhs_cond_expr;
1092   bool in_cleanup_point_expr;
1093 };
1094
1095 extern enum gimplify_status gimplify_expr (tree *, gimple_seq *, gimple_seq *,
1096                                            bool (*) (tree), fallback_t);
1097 extern void gimplify_type_sizes (tree, gimple_seq *);
1098 extern void gimplify_one_sizepos (tree *, gimple_seq *);
1099 extern bool gimplify_stmt (tree *, gimple_seq *);
1100 extern gimple gimplify_body (tree, bool);
1101 extern void push_gimplify_context (struct gimplify_ctx *);
1102 extern void pop_gimplify_context (gimple);
1103 extern void gimplify_and_add (tree, gimple_seq *);
1104
1105 /* Miscellaneous helpers.  */
1106 extern void gimple_add_tmp_var (tree);
1107 extern gimple gimple_current_bind_expr (void);
1108 extern VEC(gimple, heap) *gimple_bind_expr_stack (void);
1109 extern tree voidify_wrapper_expr (tree, tree);
1110 extern tree build_and_jump (tree *);
1111 extern tree force_labels_r (tree *, int *, void *);
1112 extern enum gimplify_status gimplify_va_arg_expr (tree *, gimple_seq *,
1113                                                   gimple_seq *);
1114 struct gimplify_omp_ctx;
1115 extern void omp_firstprivatize_variable (struct gimplify_omp_ctx *, tree);
1116 extern tree gimple_boolify (tree);
1117 extern gimple_predicate rhs_predicate_for (tree);
1118 extern tree canonicalize_cond_expr_cond (tree);
1119
1120 /* In omp-low.c.  */
1121 extern tree omp_reduction_init (tree, tree);
1122
1123 /* In trans-mem.c.  */
1124 extern void diagnose_tm_safe_errors (tree);
1125 extern void compute_transaction_bits (void);
1126
1127 /* In tree-nested.c.  */
1128 extern void lower_nested_functions (tree);
1129 extern void insert_field_into_struct (tree, tree);
1130
1131 /* In gimplify.c.  */
1132 extern void gimplify_function_tree (tree);
1133
1134 /* In cfgexpand.c.  */
1135 extern tree gimple_assign_rhs_to_tree (gimple);
1136
1137 /* In builtins.c  */
1138 extern bool validate_gimple_arglist (const_gimple, ...);
1139
1140 /* In tree-ssa.c  */
1141 extern bool tree_ssa_useless_type_conversion (tree);
1142 extern tree tree_ssa_strip_useless_type_conversions (tree);
1143 extern bool useless_type_conversion_p (tree, tree);
1144 extern bool types_compatible_p (tree, tree);
1145
1146 /* Return the code for GIMPLE statement G.  */
1147
1148 static inline enum gimple_code
1149 gimple_code (const_gimple g)
1150 {
1151   return g->gsbase.code;
1152 }
1153
1154
1155 /* Return the GSS code used by a GIMPLE code.  */
1156
1157 static inline enum gimple_statement_structure_enum
1158 gss_for_code (enum gimple_code code)
1159 {
1160   gcc_gimple_checking_assert ((unsigned int)code < LAST_AND_UNUSED_GIMPLE_CODE);
1161   return gss_for_code_[code];
1162 }
1163
1164
1165 /* Return which GSS code is used by GS.  */
1166
1167 static inline enum gimple_statement_structure_enum
1168 gimple_statement_structure (gimple gs)
1169 {
1170   return gss_for_code (gimple_code (gs));
1171 }
1172
1173
1174 /* Return true if statement G has sub-statements.  This is only true for
1175    High GIMPLE statements.  */
1176
1177 static inline bool
1178 gimple_has_substatements (gimple g)
1179 {
1180   switch (gimple_code (g))
1181     {
1182     case GIMPLE_BIND:
1183     case GIMPLE_CATCH:
1184     case GIMPLE_EH_FILTER:
1185     case GIMPLE_EH_ELSE:
1186     case GIMPLE_TRY:
1187     case GIMPLE_OMP_FOR:
1188     case GIMPLE_OMP_MASTER:
1189     case GIMPLE_OMP_ORDERED:
1190     case GIMPLE_OMP_SECTION:
1191     case GIMPLE_OMP_PARALLEL:
1192     case GIMPLE_OMP_TASK:
1193     case GIMPLE_OMP_SECTIONS:
1194     case GIMPLE_OMP_SINGLE:
1195     case GIMPLE_OMP_CRITICAL:
1196     case GIMPLE_WITH_CLEANUP_EXPR:
1197     case GIMPLE_TRANSACTION:
1198       return true;
1199
1200     default:
1201       return false;
1202     }
1203 }
1204
1205
1206 /* Return the basic block holding statement G.  */
1207
1208 static inline struct basic_block_def *
1209 gimple_bb (const_gimple g)
1210 {
1211   return g->gsbase.bb;
1212 }
1213
1214
1215 /* Return the lexical scope block holding statement G.  */
1216
1217 static inline tree
1218 gimple_block (const_gimple g)
1219 {
1220   return g->gsbase.block;
1221 }
1222
1223
1224 /* Set BLOCK to be the lexical scope block holding statement G.  */
1225
1226 static inline void
1227 gimple_set_block (gimple g, tree block)
1228 {
1229   g->gsbase.block = block;
1230 }
1231
1232
1233 /* Return location information for statement G.  */
1234
1235 static inline location_t
1236 gimple_location (const_gimple g)
1237 {
1238   return g->gsbase.location;
1239 }
1240
1241 /* Return pointer to location information for statement G.  */
1242
1243 static inline const location_t *
1244 gimple_location_ptr (const_gimple g)
1245 {
1246   return &g->gsbase.location;
1247 }
1248
1249
1250 /* Set location information for statement G.  */
1251
1252 static inline void
1253 gimple_set_location (gimple g, location_t location)
1254 {
1255   g->gsbase.location = location;
1256 }
1257
1258
1259 /* Return true if G contains location information.  */
1260
1261 static inline bool
1262 gimple_has_location (const_gimple g)
1263 {
1264   return gimple_location (g) != UNKNOWN_LOCATION;
1265 }
1266
1267
1268 /* Return the file name of the location of STMT.  */
1269
1270 static inline const char *
1271 gimple_filename (const_gimple stmt)
1272 {
1273   return LOCATION_FILE (gimple_location (stmt));
1274 }
1275
1276
1277 /* Return the line number of the location of STMT.  */
1278
1279 static inline int
1280 gimple_lineno (const_gimple stmt)
1281 {
1282   return LOCATION_LINE (gimple_location (stmt));
1283 }
1284
1285
1286 /* Determine whether SEQ is a singleton. */
1287
1288 static inline bool
1289 gimple_seq_singleton_p (gimple_seq seq)
1290 {
1291   return ((gimple_seq_first (seq) != NULL)
1292           && (gimple_seq_first (seq) == gimple_seq_last (seq)));
1293 }
1294
1295 /* Return true if no warnings should be emitted for statement STMT.  */
1296
1297 static inline bool
1298 gimple_no_warning_p (const_gimple stmt)
1299 {
1300   return stmt->gsbase.no_warning;
1301 }
1302
1303 /* Set the no_warning flag of STMT to NO_WARNING.  */
1304
1305 static inline void
1306 gimple_set_no_warning (gimple stmt, bool no_warning)
1307 {
1308   stmt->gsbase.no_warning = (unsigned) no_warning;
1309 }
1310
1311 /* Set the visited status on statement STMT to VISITED_P.  */
1312
1313 static inline void
1314 gimple_set_visited (gimple stmt, bool visited_p)
1315 {
1316   stmt->gsbase.visited = (unsigned) visited_p;
1317 }
1318
1319
1320 /* Return the visited status for statement STMT.  */
1321
1322 static inline bool
1323 gimple_visited_p (gimple stmt)
1324 {
1325   return stmt->gsbase.visited;
1326 }
1327
1328
1329 /* Set pass local flag PLF on statement STMT to VAL_P.  */
1330
1331 static inline void
1332 gimple_set_plf (gimple stmt, enum plf_mask plf, bool val_p)
1333 {
1334   if (val_p)
1335     stmt->gsbase.plf |= (unsigned int) plf;
1336   else
1337     stmt->gsbase.plf &= ~((unsigned int) plf);
1338 }
1339
1340
1341 /* Return the value of pass local flag PLF on statement STMT.  */
1342
1343 static inline unsigned int
1344 gimple_plf (gimple stmt, enum plf_mask plf)
1345 {
1346   return stmt->gsbase.plf & ((unsigned int) plf);
1347 }
1348
1349
1350 /* Set the UID of statement.  */
1351
1352 static inline void
1353 gimple_set_uid (gimple g, unsigned uid)
1354 {
1355   g->gsbase.uid = uid;
1356 }
1357
1358
1359 /* Return the UID of statement.  */
1360
1361 static inline unsigned
1362 gimple_uid (const_gimple g)
1363 {
1364   return g->gsbase.uid;
1365 }
1366
1367
1368 /* Return true if GIMPLE statement G has register or memory operands.  */
1369
1370 static inline bool
1371 gimple_has_ops (const_gimple g)
1372 {
1373   return gimple_code (g) >= GIMPLE_COND && gimple_code (g) <= GIMPLE_RETURN;
1374 }
1375
1376
1377 /* Return true if GIMPLE statement G has memory operands.  */
1378
1379 static inline bool
1380 gimple_has_mem_ops (const_gimple g)
1381 {
1382   return gimple_code (g) >= GIMPLE_ASSIGN && gimple_code (g) <= GIMPLE_RETURN;
1383 }
1384
1385
1386 /* Return the set of DEF operands for statement G.  */
1387
1388 static inline struct def_optype_d *
1389 gimple_def_ops (const_gimple g)
1390 {
1391   if (!gimple_has_ops (g))
1392     return NULL;
1393   return g->gsops.opbase.def_ops;
1394 }
1395
1396
1397 /* Set DEF to be the set of DEF operands for statement G.  */
1398
1399 static inline void
1400 gimple_set_def_ops (gimple g, struct def_optype_d *def)
1401 {
1402   gcc_gimple_checking_assert (gimple_has_ops (g));
1403   g->gsops.opbase.def_ops = def;
1404 }
1405
1406
1407 /* Return the set of USE operands for statement G.  */
1408
1409 static inline struct use_optype_d *
1410 gimple_use_ops (const_gimple g)
1411 {
1412   if (!gimple_has_ops (g))
1413     return NULL;
1414   return g->gsops.opbase.use_ops;
1415 }
1416
1417
1418 /* Set USE to be the set of USE operands for statement G.  */
1419
1420 static inline void
1421 gimple_set_use_ops (gimple g, struct use_optype_d *use)
1422 {
1423   gcc_gimple_checking_assert (gimple_has_ops (g));
1424   g->gsops.opbase.use_ops = use;
1425 }
1426
1427
1428 /* Return the set of VUSE operand for statement G.  */
1429
1430 static inline use_operand_p
1431 gimple_vuse_op (const_gimple g)
1432 {
1433   struct use_optype_d *ops;
1434   if (!gimple_has_mem_ops (g))
1435     return NULL_USE_OPERAND_P;
1436   ops = g->gsops.opbase.use_ops;
1437   if (ops
1438       && USE_OP_PTR (ops)->use == &g->gsmembase.vuse)
1439     return USE_OP_PTR (ops);
1440   return NULL_USE_OPERAND_P;
1441 }
1442
1443 /* Return the set of VDEF operand for statement G.  */
1444
1445 static inline def_operand_p
1446 gimple_vdef_op (const_gimple g)
1447 {
1448   struct def_optype_d *ops;
1449   if (!gimple_has_mem_ops (g))
1450     return NULL_DEF_OPERAND_P;
1451   ops = g->gsops.opbase.def_ops;
1452   if (ops
1453       && DEF_OP_PTR (ops) == &g->gsmembase.vdef)
1454     return DEF_OP_PTR (ops);
1455   return NULL_DEF_OPERAND_P;
1456 }
1457
1458
1459 /* Return the single VUSE operand of the statement G.  */
1460
1461 static inline tree
1462 gimple_vuse (const_gimple g)
1463 {
1464   if (!gimple_has_mem_ops (g))
1465     return NULL_TREE;
1466   return g->gsmembase.vuse;
1467 }
1468
1469 /* Return the single VDEF operand of the statement G.  */
1470
1471 static inline tree
1472 gimple_vdef (const_gimple g)
1473 {
1474   if (!gimple_has_mem_ops (g))
1475     return NULL_TREE;
1476   return g->gsmembase.vdef;
1477 }
1478
1479 /* Return the single VUSE operand of the statement G.  */
1480
1481 static inline tree *
1482 gimple_vuse_ptr (gimple g)
1483 {
1484   if (!gimple_has_mem_ops (g))
1485     return NULL;
1486   return &g->gsmembase.vuse;
1487 }
1488
1489 /* Return the single VDEF operand of the statement G.  */
1490
1491 static inline tree *
1492 gimple_vdef_ptr (gimple g)
1493 {
1494   if (!gimple_has_mem_ops (g))
1495     return NULL;
1496   return &g->gsmembase.vdef;
1497 }
1498
1499 /* Set the single VUSE operand of the statement G.  */
1500
1501 static inline void
1502 gimple_set_vuse (gimple g, tree vuse)
1503 {
1504   gcc_gimple_checking_assert (gimple_has_mem_ops (g));
1505   g->gsmembase.vuse = vuse;
1506 }
1507
1508 /* Set the single VDEF operand of the statement G.  */
1509
1510 static inline void
1511 gimple_set_vdef (gimple g, tree vdef)
1512 {
1513   gcc_gimple_checking_assert (gimple_has_mem_ops (g));
1514   g->gsmembase.vdef = vdef;
1515 }
1516
1517
1518 /* Return true if statement G has operands and the modified field has
1519    been set.  */
1520
1521 static inline bool
1522 gimple_modified_p (const_gimple g)
1523 {
1524   return (gimple_has_ops (g)) ? (bool) g->gsbase.modified : false;
1525 }
1526
1527
1528 /* Return the tree code for the expression computed by STMT.  This is
1529    only valid for GIMPLE_COND, GIMPLE_CALL and GIMPLE_ASSIGN.  For
1530    GIMPLE_CALL, return CALL_EXPR as the expression code for
1531    consistency.  This is useful when the caller needs to deal with the
1532    three kinds of computation that GIMPLE supports.  */
1533
1534 static inline enum tree_code
1535 gimple_expr_code (const_gimple stmt)
1536 {
1537   enum gimple_code code = gimple_code (stmt);
1538   if (code == GIMPLE_ASSIGN || code == GIMPLE_COND)
1539     return (enum tree_code) stmt->gsbase.subcode;
1540   else
1541     {
1542       gcc_gimple_checking_assert (code == GIMPLE_CALL);
1543       return CALL_EXPR;
1544     }
1545 }
1546
1547
1548 /* Mark statement S as modified, and update it.  */
1549
1550 static inline void
1551 update_stmt (gimple s)
1552 {
1553   if (gimple_has_ops (s))
1554     {
1555       gimple_set_modified (s, true);
1556       update_stmt_operands (s);
1557     }
1558 }
1559
1560 /* Update statement S if it has been optimized.  */
1561
1562 static inline void
1563 update_stmt_if_modified (gimple s)
1564 {
1565   if (gimple_modified_p (s))
1566     update_stmt_operands (s);
1567 }
1568
1569 /* Return true if statement STMT contains volatile operands.  */
1570
1571 static inline bool
1572 gimple_has_volatile_ops (const_gimple stmt)
1573 {
1574   if (gimple_has_mem_ops (stmt))
1575     return stmt->gsbase.has_volatile_ops;
1576   else
1577     return false;
1578 }
1579
1580
1581 /* Set the HAS_VOLATILE_OPS flag to VOLATILEP.  */
1582
1583 static inline void
1584 gimple_set_has_volatile_ops (gimple stmt, bool volatilep)
1585 {
1586   if (gimple_has_mem_ops (stmt))
1587     stmt->gsbase.has_volatile_ops = (unsigned) volatilep;
1588 }
1589
1590 /* Return true if STMT is in a transaction.  */
1591
1592 static inline bool
1593 gimple_in_transaction (gimple stmt)
1594 {
1595   return stmt->gsbase.in_transaction;
1596 }
1597
1598 /* Set the IN_TRANSACTION flag to TRANSACTIONP.  */
1599
1600 static inline void
1601 gimple_set_in_transaction (gimple stmt, bool transactionp)
1602 {
1603   stmt->gsbase.in_transaction = (unsigned) transactionp;
1604 }
1605
1606 /* Return true if statement STMT may access memory.  */
1607
1608 static inline bool
1609 gimple_references_memory_p (gimple stmt)
1610 {
1611   return gimple_has_mem_ops (stmt) && gimple_vuse (stmt);
1612 }
1613
1614
1615 /* Return the subcode for OMP statement S.  */
1616
1617 static inline unsigned
1618 gimple_omp_subcode (const_gimple s)
1619 {
1620   gcc_gimple_checking_assert (gimple_code (s) >= GIMPLE_OMP_ATOMIC_LOAD
1621               && gimple_code (s) <= GIMPLE_OMP_SINGLE);
1622   return s->gsbase.subcode;
1623 }
1624
1625 /* Set the subcode for OMP statement S to SUBCODE.  */
1626
1627 static inline void
1628 gimple_omp_set_subcode (gimple s, unsigned int subcode)
1629 {
1630   /* We only have 16 bits for the subcode.  Assert that we are not
1631      overflowing it.  */
1632   gcc_gimple_checking_assert (subcode < (1 << 16));
1633   s->gsbase.subcode = subcode;
1634 }
1635
1636 /* Set the nowait flag on OMP_RETURN statement S.  */
1637
1638 static inline void
1639 gimple_omp_return_set_nowait (gimple s)
1640 {
1641   GIMPLE_CHECK (s, GIMPLE_OMP_RETURN);
1642   s->gsbase.subcode |= GF_OMP_RETURN_NOWAIT;
1643 }
1644
1645
1646 /* Return true if OMP return statement G has the GF_OMP_RETURN_NOWAIT
1647    flag set.  */
1648
1649 static inline bool
1650 gimple_omp_return_nowait_p (const_gimple g)
1651 {
1652   GIMPLE_CHECK (g, GIMPLE_OMP_RETURN);
1653   return (gimple_omp_subcode (g) & GF_OMP_RETURN_NOWAIT) != 0;
1654 }
1655
1656
1657 /* Return true if OMP section statement G has the GF_OMP_SECTION_LAST
1658    flag set.  */
1659
1660 static inline bool
1661 gimple_omp_section_last_p (const_gimple g)
1662 {
1663   GIMPLE_CHECK (g, GIMPLE_OMP_SECTION);
1664   return (gimple_omp_subcode (g) & GF_OMP_SECTION_LAST) != 0;
1665 }
1666
1667
1668 /* Set the GF_OMP_SECTION_LAST flag on G.  */
1669
1670 static inline void
1671 gimple_omp_section_set_last (gimple g)
1672 {
1673   GIMPLE_CHECK (g, GIMPLE_OMP_SECTION);
1674   g->gsbase.subcode |= GF_OMP_SECTION_LAST;
1675 }
1676
1677
1678 /* Return true if OMP parallel statement G has the
1679    GF_OMP_PARALLEL_COMBINED flag set.  */
1680
1681 static inline bool
1682 gimple_omp_parallel_combined_p (const_gimple g)
1683 {
1684   GIMPLE_CHECK (g, GIMPLE_OMP_PARALLEL);
1685   return (gimple_omp_subcode (g) & GF_OMP_PARALLEL_COMBINED) != 0;
1686 }
1687
1688
1689 /* Set the GF_OMP_PARALLEL_COMBINED field in G depending on the boolean
1690    value of COMBINED_P.  */
1691
1692 static inline void
1693 gimple_omp_parallel_set_combined_p (gimple g, bool combined_p)
1694 {
1695   GIMPLE_CHECK (g, GIMPLE_OMP_PARALLEL);
1696   if (combined_p)
1697     g->gsbase.subcode |= GF_OMP_PARALLEL_COMBINED;
1698   else
1699     g->gsbase.subcode &= ~GF_OMP_PARALLEL_COMBINED;
1700 }
1701
1702
1703 /* Return true if OMP atomic load/store statement G has the
1704    GF_OMP_ATOMIC_NEED_VALUE flag set.  */
1705
1706 static inline bool
1707 gimple_omp_atomic_need_value_p (const_gimple g)
1708 {
1709   if (gimple_code (g) != GIMPLE_OMP_ATOMIC_LOAD)
1710     GIMPLE_CHECK (g, GIMPLE_OMP_ATOMIC_STORE);
1711   return (gimple_omp_subcode (g) & GF_OMP_ATOMIC_NEED_VALUE) != 0;
1712 }
1713
1714
1715 /* Set the GF_OMP_ATOMIC_NEED_VALUE flag on G.  */
1716
1717 static inline void
1718 gimple_omp_atomic_set_need_value (gimple g)
1719 {
1720   if (gimple_code (g) != GIMPLE_OMP_ATOMIC_LOAD)
1721     GIMPLE_CHECK (g, GIMPLE_OMP_ATOMIC_STORE);
1722   g->gsbase.subcode |= GF_OMP_ATOMIC_NEED_VALUE;
1723 }
1724
1725
1726 /* Return the number of operands for statement GS.  */
1727
1728 static inline unsigned
1729 gimple_num_ops (const_gimple gs)
1730 {
1731   return gs->gsbase.num_ops;
1732 }
1733
1734
1735 /* Set the number of operands for statement GS.  */
1736
1737 static inline void
1738 gimple_set_num_ops (gimple gs, unsigned num_ops)
1739 {
1740   gs->gsbase.num_ops = num_ops;
1741 }
1742
1743
1744 /* Return the array of operands for statement GS.  */
1745
1746 static inline tree *
1747 gimple_ops (gimple gs)
1748 {
1749   size_t off;
1750
1751   /* All the tuples have their operand vector at the very bottom
1752      of the structure.  Note that those structures that do not
1753      have an operand vector have a zero offset.  */
1754   off = gimple_ops_offset_[gimple_statement_structure (gs)];
1755   gcc_gimple_checking_assert (off != 0);
1756
1757   return (tree *) ((char *) gs + off);
1758 }
1759
1760
1761 /* Return operand I for statement GS.  */
1762
1763 static inline tree
1764 gimple_op (const_gimple gs, unsigned i)
1765 {
1766   if (gimple_has_ops (gs))
1767     {
1768       gcc_gimple_checking_assert (i < gimple_num_ops (gs));
1769       return gimple_ops (CONST_CAST_GIMPLE (gs))[i];
1770     }
1771   else
1772     return NULL_TREE;
1773 }
1774
1775 /* Return a pointer to operand I for statement GS.  */
1776
1777 static inline tree *
1778 gimple_op_ptr (const_gimple gs, unsigned i)
1779 {
1780   if (gimple_has_ops (gs))
1781     {
1782       gcc_gimple_checking_assert (i < gimple_num_ops (gs));
1783       return gimple_ops (CONST_CAST_GIMPLE (gs)) + i;
1784     }
1785   else
1786     return NULL;
1787 }
1788
1789 /* Set operand I of statement GS to OP.  */
1790
1791 static inline void
1792 gimple_set_op (gimple gs, unsigned i, tree op)
1793 {
1794   gcc_gimple_checking_assert (gimple_has_ops (gs) && i < gimple_num_ops (gs));
1795
1796   /* Note.  It may be tempting to assert that OP matches
1797      is_gimple_operand, but that would be wrong.  Different tuples
1798      accept slightly different sets of tree operands.  Each caller
1799      should perform its own validation.  */
1800   gimple_ops (gs)[i] = op;
1801 }
1802
1803 /* Return true if GS is a GIMPLE_ASSIGN.  */
1804
1805 static inline bool
1806 is_gimple_assign (const_gimple gs)
1807 {
1808   return gimple_code (gs) == GIMPLE_ASSIGN;
1809 }
1810
1811 /* Determine if expression CODE is one of the valid expressions that can
1812    be used on the RHS of GIMPLE assignments.  */
1813
1814 static inline enum gimple_rhs_class
1815 get_gimple_rhs_class (enum tree_code code)
1816 {
1817   return (enum gimple_rhs_class) gimple_rhs_class_table[(int) code];
1818 }
1819
1820 /* Return the LHS of assignment statement GS.  */
1821
1822 static inline tree
1823 gimple_assign_lhs (const_gimple gs)
1824 {
1825   GIMPLE_CHECK (gs, GIMPLE_ASSIGN);
1826   return gimple_op (gs, 0);
1827 }
1828
1829
1830 /* Return a pointer to the LHS of assignment statement GS.  */
1831
1832 static inline tree *
1833 gimple_assign_lhs_ptr (const_gimple gs)
1834 {
1835   GIMPLE_CHECK (gs, GIMPLE_ASSIGN);
1836   return gimple_op_ptr (gs, 0);
1837 }
1838
1839
1840 /* Set LHS to be the LHS operand of assignment statement GS.  */
1841
1842 static inline void
1843 gimple_assign_set_lhs (gimple gs, tree lhs)
1844 {
1845   GIMPLE_CHECK (gs, GIMPLE_ASSIGN);
1846   gimple_set_op (gs, 0, lhs);
1847
1848   if (lhs && TREE_CODE (lhs) == SSA_NAME)
1849     SSA_NAME_DEF_STMT (lhs) = gs;
1850 }
1851
1852
1853 /* Return the first operand on the RHS of assignment statement GS.  */
1854
1855 static inline tree
1856 gimple_assign_rhs1 (const_gimple gs)
1857 {
1858   GIMPLE_CHECK (gs, GIMPLE_ASSIGN);
1859   return gimple_op (gs, 1);
1860 }
1861
1862
1863 /* Return a pointer to the first operand on the RHS of assignment
1864    statement GS.  */
1865
1866 static inline tree *
1867 gimple_assign_rhs1_ptr (const_gimple gs)
1868 {
1869   GIMPLE_CHECK (gs, GIMPLE_ASSIGN);
1870   return gimple_op_ptr (gs, 1);
1871 }
1872
1873 /* Set RHS to be the first operand on the RHS of assignment statement GS.  */
1874
1875 static inline void
1876 gimple_assign_set_rhs1 (gimple gs, tree rhs)
1877 {
1878   GIMPLE_CHECK (gs, GIMPLE_ASSIGN);
1879
1880   gimple_set_op (gs, 1, rhs);
1881 }
1882
1883
1884 /* Return the second operand on the RHS of assignment statement GS.
1885    If GS does not have two operands, NULL is returned instead.  */
1886
1887 static inline tree
1888 gimple_assign_rhs2 (const_gimple gs)
1889 {
1890   GIMPLE_CHECK (gs, GIMPLE_ASSIGN);
1891
1892   if (gimple_num_ops (gs) >= 3)
1893     return gimple_op (gs, 2);
1894   else
1895     return NULL_TREE;
1896 }
1897
1898
1899 /* Return a pointer to the second operand on the RHS of assignment
1900    statement GS.  */
1901
1902 static inline tree *
1903 gimple_assign_rhs2_ptr (const_gimple gs)
1904 {
1905   GIMPLE_CHECK (gs, GIMPLE_ASSIGN);
1906   return gimple_op_ptr (gs, 2);
1907 }
1908
1909
1910 /* Set RHS to be the second operand on the RHS of assignment statement GS.  */
1911
1912 static inline void
1913 gimple_assign_set_rhs2 (gimple gs, tree rhs)
1914 {
1915   GIMPLE_CHECK (gs, GIMPLE_ASSIGN);
1916
1917   gimple_set_op (gs, 2, rhs);
1918 }
1919
1920 /* Return the third operand on the RHS of assignment statement GS.
1921    If GS does not have two operands, NULL is returned instead.  */
1922
1923 static inline tree
1924 gimple_assign_rhs3 (const_gimple gs)
1925 {
1926   GIMPLE_CHECK (gs, GIMPLE_ASSIGN);
1927
1928   if (gimple_num_ops (gs) >= 4)
1929     return gimple_op (gs, 3);
1930   else
1931     return NULL_TREE;
1932 }
1933
1934 /* Return a pointer to the third operand on the RHS of assignment
1935    statement GS.  */
1936
1937 static inline tree *
1938 gimple_assign_rhs3_ptr (const_gimple gs)
1939 {
1940   GIMPLE_CHECK (gs, GIMPLE_ASSIGN);
1941   return gimple_op_ptr (gs, 3);
1942 }
1943
1944
1945 /* Set RHS to be the third operand on the RHS of assignment statement GS.  */
1946
1947 static inline void
1948 gimple_assign_set_rhs3 (gimple gs, tree rhs)
1949 {
1950   GIMPLE_CHECK (gs, GIMPLE_ASSIGN);
1951
1952   gimple_set_op (gs, 3, rhs);
1953 }
1954
1955 /* A wrapper around gimple_assign_set_rhs_with_ops_1, for callers which expect
1956    to see only a maximum of two operands.  */
1957
1958 static inline void
1959 gimple_assign_set_rhs_with_ops (gimple_stmt_iterator *gsi, enum tree_code code,
1960                                 tree op1, tree op2)
1961 {
1962   gimple_assign_set_rhs_with_ops_1 (gsi, code, op1, op2, NULL);
1963 }
1964
1965 /* A wrapper around extract_ops_from_tree_1, for callers which expect
1966    to see only a maximum of two operands.  */
1967
1968 static inline void
1969 extract_ops_from_tree (tree expr, enum tree_code *code, tree *op0,
1970                        tree *op1)
1971 {
1972   tree op2;
1973   extract_ops_from_tree_1 (expr, code, op0, op1, &op2);
1974   gcc_assert (op2 == NULL_TREE);
1975 }
1976
1977 /* Returns true if GS is a nontemporal move.  */
1978
1979 static inline bool
1980 gimple_assign_nontemporal_move_p (const_gimple gs)
1981 {
1982   GIMPLE_CHECK (gs, GIMPLE_ASSIGN);
1983   return gs->gsbase.nontemporal_move;
1984 }
1985
1986 /* Sets nontemporal move flag of GS to NONTEMPORAL.  */
1987
1988 static inline void
1989 gimple_assign_set_nontemporal_move (gimple gs, bool nontemporal)
1990 {
1991   GIMPLE_CHECK (gs, GIMPLE_ASSIGN);
1992   gs->gsbase.nontemporal_move = nontemporal;
1993 }
1994
1995
1996 /* Return the code of the expression computed on the rhs of assignment
1997    statement GS.  In case that the RHS is a single object, returns the
1998    tree code of the object.  */
1999
2000 static inline enum tree_code
2001 gimple_assign_rhs_code (const_gimple gs)
2002 {
2003   enum tree_code code;
2004   GIMPLE_CHECK (gs, GIMPLE_ASSIGN);
2005
2006   code = (enum tree_code) gs->gsbase.subcode;
2007   /* While we initially set subcode to the TREE_CODE of the rhs for
2008      GIMPLE_SINGLE_RHS assigns we do not update that subcode to stay
2009      in sync when we rewrite stmts into SSA form or do SSA propagations.  */
2010   if (get_gimple_rhs_class (code) == GIMPLE_SINGLE_RHS)
2011     code = TREE_CODE (gimple_assign_rhs1 (gs));
2012
2013   return code;
2014 }
2015
2016
2017 /* Set CODE to be the code for the expression computed on the RHS of
2018    assignment S.  */
2019
2020 static inline void
2021 gimple_assign_set_rhs_code (gimple s, enum tree_code code)
2022 {
2023   GIMPLE_CHECK (s, GIMPLE_ASSIGN);
2024   s->gsbase.subcode = code;
2025 }
2026
2027
2028 /* Return the gimple rhs class of the code of the expression computed on
2029    the rhs of assignment statement GS.
2030    This will never return GIMPLE_INVALID_RHS.  */
2031
2032 static inline enum gimple_rhs_class
2033 gimple_assign_rhs_class (const_gimple gs)
2034 {
2035   return get_gimple_rhs_class (gimple_assign_rhs_code (gs));
2036 }
2037
2038 /* Return true if GS is an assignment with a singleton RHS, i.e.,
2039    there is no operator associated with the assignment itself.
2040    Unlike gimple_assign_copy_p, this predicate returns true for
2041    any RHS operand, including those that perform an operation
2042    and do not have the semantics of a copy, such as COND_EXPR.  */
2043
2044 static inline bool
2045 gimple_assign_single_p (gimple gs)
2046 {
2047   return (is_gimple_assign (gs)
2048           && gimple_assign_rhs_class (gs) == GIMPLE_SINGLE_RHS);
2049 }
2050
2051
2052 /* Return true if S is a type-cast assignment.  */
2053
2054 static inline bool
2055 gimple_assign_cast_p (gimple s)
2056 {
2057   if (is_gimple_assign (s))
2058     {
2059       enum tree_code sc = gimple_assign_rhs_code (s);
2060       return CONVERT_EXPR_CODE_P (sc)
2061              || sc == VIEW_CONVERT_EXPR
2062              || sc == FIX_TRUNC_EXPR;
2063     }
2064
2065   return false;
2066 }
2067
2068 /* Return true if S is a clobber statement.  */
2069
2070 static inline bool
2071 gimple_clobber_p (gimple s)
2072 {
2073   return gimple_assign_single_p (s)
2074          && TREE_CLOBBER_P (gimple_assign_rhs1 (s));
2075 }
2076
2077 /* Return true if GS is a GIMPLE_CALL.  */
2078
2079 static inline bool
2080 is_gimple_call (const_gimple gs)
2081 {
2082   return gimple_code (gs) == GIMPLE_CALL;
2083 }
2084
2085 /* Return the LHS of call statement GS.  */
2086
2087 static inline tree
2088 gimple_call_lhs (const_gimple gs)
2089 {
2090   GIMPLE_CHECK (gs, GIMPLE_CALL);
2091   return gimple_op (gs, 0);
2092 }
2093
2094
2095 /* Return a pointer to the LHS of call statement GS.  */
2096
2097 static inline tree *
2098 gimple_call_lhs_ptr (const_gimple gs)
2099 {
2100   GIMPLE_CHECK (gs, GIMPLE_CALL);
2101   return gimple_op_ptr (gs, 0);
2102 }
2103
2104
2105 /* Set LHS to be the LHS operand of call statement GS.  */
2106
2107 static inline void
2108 gimple_call_set_lhs (gimple gs, tree lhs)
2109 {
2110   GIMPLE_CHECK (gs, GIMPLE_CALL);
2111   gimple_set_op (gs, 0, lhs);
2112   if (lhs && TREE_CODE (lhs) == SSA_NAME)
2113     SSA_NAME_DEF_STMT (lhs) = gs;
2114 }
2115
2116
2117 /* Return true if call GS calls an internal-only function, as enumerated
2118    by internal_fn.  */
2119
2120 static inline bool
2121 gimple_call_internal_p (const_gimple gs)
2122 {
2123   GIMPLE_CHECK (gs, GIMPLE_CALL);
2124   return (gs->gsbase.subcode & GF_CALL_INTERNAL) != 0;
2125 }
2126
2127
2128 /* Return the target of internal call GS.  */
2129
2130 static inline enum internal_fn
2131 gimple_call_internal_fn (const_gimple gs)
2132 {
2133   gcc_gimple_checking_assert (gimple_call_internal_p (gs));
2134   return gs->gimple_call.u.internal_fn;
2135 }
2136
2137
2138 /* Return the function type of the function called by GS.  */
2139
2140 static inline tree
2141 gimple_call_fntype (const_gimple gs)
2142 {
2143   GIMPLE_CHECK (gs, GIMPLE_CALL);
2144   if (gimple_call_internal_p (gs))
2145     return NULL_TREE;
2146   return gs->gimple_call.u.fntype;
2147 }
2148
2149 /* Set the type of the function called by GS to FNTYPE.  */
2150
2151 static inline void
2152 gimple_call_set_fntype (gimple gs, tree fntype)
2153 {
2154   GIMPLE_CHECK (gs, GIMPLE_CALL);
2155   gcc_gimple_checking_assert (!gimple_call_internal_p (gs));
2156   gs->gimple_call.u.fntype = fntype;
2157 }
2158
2159
2160 /* Return the tree node representing the function called by call
2161    statement GS.  */
2162
2163 static inline tree
2164 gimple_call_fn (const_gimple gs)
2165 {
2166   GIMPLE_CHECK (gs, GIMPLE_CALL);
2167   return gimple_op (gs, 1);
2168 }
2169
2170 /* Return a pointer to the tree node representing the function called by call
2171    statement GS.  */
2172
2173 static inline tree *
2174 gimple_call_fn_ptr (const_gimple gs)
2175 {
2176   GIMPLE_CHECK (gs, GIMPLE_CALL);
2177   return gimple_op_ptr (gs, 1);
2178 }
2179
2180
2181 /* Set FN to be the function called by call statement GS.  */
2182
2183 static inline void
2184 gimple_call_set_fn (gimple gs, tree fn)
2185 {
2186   GIMPLE_CHECK (gs, GIMPLE_CALL);
2187   gcc_gimple_checking_assert (!gimple_call_internal_p (gs));
2188   gimple_set_op (gs, 1, fn);
2189 }
2190
2191
2192 /* Set FNDECL to be the function called by call statement GS.  */
2193
2194 static inline void
2195 gimple_call_set_fndecl (gimple gs, tree decl)
2196 {
2197   GIMPLE_CHECK (gs, GIMPLE_CALL);
2198   gcc_gimple_checking_assert (!gimple_call_internal_p (gs));
2199   gimple_set_op (gs, 1, build_fold_addr_expr_loc (gimple_location (gs), decl));
2200 }
2201
2202
2203 /* Set internal function FN to be the function called by call statement GS.  */
2204
2205 static inline void
2206 gimple_call_set_internal_fn (gimple gs, enum internal_fn fn)
2207 {
2208   GIMPLE_CHECK (gs, GIMPLE_CALL);
2209   gcc_gimple_checking_assert (gimple_call_internal_p (gs));
2210   gs->gimple_call.u.internal_fn = fn;
2211 }
2212
2213
2214 /* Given a valid GIMPLE_CALL function address return the FUNCTION_DECL
2215    associated with the callee if known.  Otherwise return NULL_TREE.  */
2216
2217 static inline tree
2218 gimple_call_addr_fndecl (const_tree fn)
2219 {
2220   if (fn && TREE_CODE (fn) == ADDR_EXPR)
2221     {
2222       tree fndecl = TREE_OPERAND (fn, 0);
2223       if (TREE_CODE (fndecl) == MEM_REF
2224           && TREE_CODE (TREE_OPERAND (fndecl, 0)) == ADDR_EXPR
2225           && integer_zerop (TREE_OPERAND (fndecl, 1)))
2226         fndecl = TREE_OPERAND (TREE_OPERAND (fndecl, 0), 0);
2227       if (TREE_CODE (fndecl) == FUNCTION_DECL)
2228         return fndecl;
2229     }
2230   return NULL_TREE;
2231 }
2232
2233 /* If a given GIMPLE_CALL's callee is a FUNCTION_DECL, return it.
2234    Otherwise return NULL.  This function is analogous to
2235    get_callee_fndecl in tree land.  */
2236
2237 static inline tree
2238 gimple_call_fndecl (const_gimple gs)
2239 {
2240   return gimple_call_addr_fndecl (gimple_call_fn (gs));
2241 }
2242
2243
2244 /* Return the type returned by call statement GS.  */
2245
2246 static inline tree
2247 gimple_call_return_type (const_gimple gs)
2248 {
2249   tree type = gimple_call_fntype (gs);
2250
2251   if (type == NULL_TREE)
2252     return TREE_TYPE (gimple_call_lhs (gs));
2253
2254   /* The type returned by a function is the type of its
2255      function type.  */
2256   return TREE_TYPE (type);
2257 }
2258
2259
2260 /* Return the static chain for call statement GS.  */
2261
2262 static inline tree
2263 gimple_call_chain (const_gimple gs)
2264 {
2265   GIMPLE_CHECK (gs, GIMPLE_CALL);
2266   return gimple_op (gs, 2);
2267 }
2268
2269
2270 /* Return a pointer to the static chain for call statement GS.  */
2271
2272 static inline tree *
2273 gimple_call_chain_ptr (const_gimple gs)
2274 {
2275   GIMPLE_CHECK (gs, GIMPLE_CALL);
2276   return gimple_op_ptr (gs, 2);
2277 }
2278
2279 /* Set CHAIN to be the static chain for call statement GS.  */
2280
2281 static inline void
2282 gimple_call_set_chain (gimple gs, tree chain)
2283 {
2284   GIMPLE_CHECK (gs, GIMPLE_CALL);
2285
2286   gimple_set_op (gs, 2, chain);
2287 }
2288
2289
2290 /* Return the number of arguments used by call statement GS.  */
2291
2292 static inline unsigned
2293 gimple_call_num_args (const_gimple gs)
2294 {
2295   unsigned num_ops;
2296   GIMPLE_CHECK (gs, GIMPLE_CALL);
2297   num_ops = gimple_num_ops (gs);
2298   return num_ops - 3;
2299 }
2300
2301
2302 /* Return the argument at position INDEX for call statement GS.  */
2303
2304 static inline tree
2305 gimple_call_arg (const_gimple gs, unsigned index)
2306 {
2307   GIMPLE_CHECK (gs, GIMPLE_CALL);
2308   return gimple_op (gs, index + 3);
2309 }
2310
2311
2312 /* Return a pointer to the argument at position INDEX for call
2313    statement GS.  */
2314
2315 static inline tree *
2316 gimple_call_arg_ptr (const_gimple gs, unsigned index)
2317 {
2318   GIMPLE_CHECK (gs, GIMPLE_CALL);
2319   return gimple_op_ptr (gs, index + 3);
2320 }
2321
2322
2323 /* Set ARG to be the argument at position INDEX for call statement GS.  */
2324
2325 static inline void
2326 gimple_call_set_arg (gimple gs, unsigned index, tree arg)
2327 {
2328   GIMPLE_CHECK (gs, GIMPLE_CALL);
2329   gimple_set_op (gs, index + 3, arg);
2330 }
2331
2332
2333 /* If TAIL_P is true, mark call statement S as being a tail call
2334    (i.e., a call just before the exit of a function).  These calls are
2335    candidate for tail call optimization.  */
2336
2337 static inline void
2338 gimple_call_set_tail (gimple s, bool tail_p)
2339 {
2340   GIMPLE_CHECK (s, GIMPLE_CALL);
2341   if (tail_p)
2342     s->gsbase.subcode |= GF_CALL_TAILCALL;
2343   else
2344     s->gsbase.subcode &= ~GF_CALL_TAILCALL;
2345 }
2346
2347
2348 /* Return true if GIMPLE_CALL S is marked as a tail call.  */
2349
2350 static inline bool
2351 gimple_call_tail_p (gimple s)
2352 {
2353   GIMPLE_CHECK (s, GIMPLE_CALL);
2354   return (s->gsbase.subcode & GF_CALL_TAILCALL) != 0;
2355 }
2356
2357
2358 /* If RETURN_SLOT_OPT_P is true mark GIMPLE_CALL S as valid for return
2359    slot optimization.  This transformation uses the target of the call
2360    expansion as the return slot for calls that return in memory.  */
2361
2362 static inline void
2363 gimple_call_set_return_slot_opt (gimple s, bool return_slot_opt_p)
2364 {
2365   GIMPLE_CHECK (s, GIMPLE_CALL);
2366   if (return_slot_opt_p)
2367     s->gsbase.subcode |= GF_CALL_RETURN_SLOT_OPT;
2368   else
2369     s->gsbase.subcode &= ~GF_CALL_RETURN_SLOT_OPT;
2370 }
2371
2372
2373 /* Return true if S is marked for return slot optimization.  */
2374
2375 static inline bool
2376 gimple_call_return_slot_opt_p (gimple s)
2377 {
2378   GIMPLE_CHECK (s, GIMPLE_CALL);
2379   return (s->gsbase.subcode & GF_CALL_RETURN_SLOT_OPT) != 0;
2380 }
2381
2382
2383 /* If FROM_THUNK_P is true, mark GIMPLE_CALL S as being the jump from a
2384    thunk to the thunked-to function.  */
2385
2386 static inline void
2387 gimple_call_set_from_thunk (gimple s, bool from_thunk_p)
2388 {
2389   GIMPLE_CHECK (s, GIMPLE_CALL);
2390   if (from_thunk_p)
2391     s->gsbase.subcode |= GF_CALL_FROM_THUNK;
2392   else
2393     s->gsbase.subcode &= ~GF_CALL_FROM_THUNK;
2394 }
2395
2396
2397 /* Return true if GIMPLE_CALL S is a jump from a thunk.  */
2398
2399 static inline bool
2400 gimple_call_from_thunk_p (gimple s)
2401 {
2402   GIMPLE_CHECK (s, GIMPLE_CALL);
2403   return (s->gsbase.subcode & GF_CALL_FROM_THUNK) != 0;
2404 }
2405
2406
2407 /* If PASS_ARG_PACK_P is true, GIMPLE_CALL S is a stdarg call that needs the
2408    argument pack in its argument list.  */
2409
2410 static inline void
2411 gimple_call_set_va_arg_pack (gimple s, bool pass_arg_pack_p)
2412 {
2413   GIMPLE_CHECK (s, GIMPLE_CALL);
2414   if (pass_arg_pack_p)
2415     s->gsbase.subcode |= GF_CALL_VA_ARG_PACK;
2416   else
2417     s->gsbase.subcode &= ~GF_CALL_VA_ARG_PACK;
2418 }
2419
2420
2421 /* Return true if GIMPLE_CALL S is a stdarg call that needs the
2422    argument pack in its argument list.  */
2423
2424 static inline bool
2425 gimple_call_va_arg_pack_p (gimple s)
2426 {
2427   GIMPLE_CHECK (s, GIMPLE_CALL);
2428   return (s->gsbase.subcode & GF_CALL_VA_ARG_PACK) != 0;
2429 }
2430
2431
2432 /* Return true if S is a noreturn call.  */
2433
2434 static inline bool
2435 gimple_call_noreturn_p (gimple s)
2436 {
2437   GIMPLE_CHECK (s, GIMPLE_CALL);
2438   return (gimple_call_flags (s) & ECF_NORETURN) != 0;
2439 }
2440
2441
2442 /* If NOTHROW_P is true, GIMPLE_CALL S is a call that is known to not throw
2443    even if the called function can throw in other cases.  */
2444
2445 static inline void
2446 gimple_call_set_nothrow (gimple s, bool nothrow_p)
2447 {
2448   GIMPLE_CHECK (s, GIMPLE_CALL);
2449   if (nothrow_p)
2450     s->gsbase.subcode |= GF_CALL_NOTHROW;
2451   else
2452     s->gsbase.subcode &= ~GF_CALL_NOTHROW;
2453 }
2454
2455 /* Return true if S is a nothrow call.  */
2456
2457 static inline bool
2458 gimple_call_nothrow_p (gimple s)
2459 {
2460   GIMPLE_CHECK (s, GIMPLE_CALL);
2461   return (gimple_call_flags (s) & ECF_NOTHROW) != 0;
2462 }
2463
2464 /* If FOR_VAR is true, GIMPLE_CALL S is a call to builtin_alloca that
2465    is known to be emitted for VLA objects.  Those are wrapped by
2466    stack_save/stack_restore calls and hence can't lead to unbounded
2467    stack growth even when they occur in loops.  */
2468
2469 static inline void
2470 gimple_call_set_alloca_for_var (gimple s, bool for_var)
2471 {
2472   GIMPLE_CHECK (s, GIMPLE_CALL);
2473   if (for_var)
2474     s->gsbase.subcode |= GF_CALL_ALLOCA_FOR_VAR;
2475   else
2476     s->gsbase.subcode &= ~GF_CALL_ALLOCA_FOR_VAR;
2477 }
2478
2479 /* Return true of S is a call to builtin_alloca emitted for VLA objects.  */
2480
2481 static inline bool
2482 gimple_call_alloca_for_var_p (gimple s)
2483 {
2484   GIMPLE_CHECK (s, GIMPLE_CALL);
2485   return (s->gsbase.subcode & GF_CALL_ALLOCA_FOR_VAR) != 0;
2486 }
2487
2488 /* Copy all the GF_CALL_* flags from ORIG_CALL to DEST_CALL.  */
2489
2490 static inline void
2491 gimple_call_copy_flags (gimple dest_call, gimple orig_call)
2492 {
2493   GIMPLE_CHECK (dest_call, GIMPLE_CALL);
2494   GIMPLE_CHECK (orig_call, GIMPLE_CALL);
2495   dest_call->gsbase.subcode = orig_call->gsbase.subcode;
2496 }
2497
2498
2499 /* Return a pointer to the points-to solution for the set of call-used
2500    variables of the call CALL.  */
2501
2502 static inline struct pt_solution *
2503 gimple_call_use_set (gimple call)
2504 {
2505   GIMPLE_CHECK (call, GIMPLE_CALL);
2506   return &call->gimple_call.call_used;
2507 }
2508
2509
2510 /* Return a pointer to the points-to solution for the set of call-used
2511    variables of the call CALL.  */
2512
2513 static inline struct pt_solution *
2514 gimple_call_clobber_set (gimple call)
2515 {
2516   GIMPLE_CHECK (call, GIMPLE_CALL);
2517   return &call->gimple_call.call_clobbered;
2518 }
2519
2520
2521 /* Returns true if this is a GIMPLE_ASSIGN or a GIMPLE_CALL with a
2522    non-NULL lhs.  */
2523
2524 static inline bool
2525 gimple_has_lhs (gimple stmt)
2526 {
2527   return (is_gimple_assign (stmt)
2528           || (is_gimple_call (stmt)
2529               && gimple_call_lhs (stmt) != NULL_TREE));
2530 }
2531
2532
2533 /* Return the code of the predicate computed by conditional statement GS.  */
2534
2535 static inline enum tree_code
2536 gimple_cond_code (const_gimple gs)
2537 {
2538   GIMPLE_CHECK (gs, GIMPLE_COND);
2539   return (enum tree_code) gs->gsbase.subcode;
2540 }
2541
2542
2543 /* Set CODE to be the predicate code for the conditional statement GS.  */
2544
2545 static inline void
2546 gimple_cond_set_code (gimple gs, enum tree_code code)
2547 {
2548   GIMPLE_CHECK (gs, GIMPLE_COND);
2549   gs->gsbase.subcode = code;
2550 }
2551
2552
2553 /* Return the LHS of the predicate computed by conditional statement GS.  */
2554
2555 static inline tree
2556 gimple_cond_lhs (const_gimple gs)
2557 {
2558   GIMPLE_CHECK (gs, GIMPLE_COND);
2559   return gimple_op (gs, 0);
2560 }
2561
2562 /* Return the pointer to the LHS of the predicate computed by conditional
2563    statement GS.  */
2564
2565 static inline tree *
2566 gimple_cond_lhs_ptr (const_gimple gs)
2567 {
2568   GIMPLE_CHECK (gs, GIMPLE_COND);
2569   return gimple_op_ptr (gs, 0);
2570 }
2571
2572 /* Set LHS to be the LHS operand of the predicate computed by
2573    conditional statement GS.  */
2574
2575 static inline void
2576 gimple_cond_set_lhs (gimple gs, tree lhs)
2577 {
2578   GIMPLE_CHECK (gs, GIMPLE_COND);
2579   gimple_set_op (gs, 0, lhs);
2580 }
2581
2582
2583 /* Return the RHS operand of the predicate computed by conditional GS.  */
2584
2585 static inline tree
2586 gimple_cond_rhs (const_gimple gs)
2587 {
2588   GIMPLE_CHECK (gs, GIMPLE_COND);
2589   return gimple_op (gs, 1);
2590 }
2591
2592 /* Return the pointer to the RHS operand of the predicate computed by
2593    conditional GS.  */
2594
2595 static inline tree *
2596 gimple_cond_rhs_ptr (const_gimple gs)
2597 {
2598   GIMPLE_CHECK (gs, GIMPLE_COND);
2599   return gimple_op_ptr (gs, 1);
2600 }
2601
2602
2603 /* Set RHS to be the RHS operand of the predicate computed by
2604    conditional statement GS.  */
2605
2606 static inline void
2607 gimple_cond_set_rhs (gimple gs, tree rhs)
2608 {
2609   GIMPLE_CHECK (gs, GIMPLE_COND);
2610   gimple_set_op (gs, 1, rhs);
2611 }
2612
2613
2614 /* Return the label used by conditional statement GS when its
2615    predicate evaluates to true.  */
2616
2617 static inline tree
2618 gimple_cond_true_label (const_gimple gs)
2619 {
2620   GIMPLE_CHECK (gs, GIMPLE_COND);
2621   return gimple_op (gs, 2);
2622 }
2623
2624
2625 /* Set LABEL to be the label used by conditional statement GS when its
2626    predicate evaluates to true.  */
2627
2628 static inline void
2629 gimple_cond_set_true_label (gimple gs, tree label)
2630 {
2631   GIMPLE_CHECK (gs, GIMPLE_COND);
2632   gimple_set_op (gs, 2, label);
2633 }
2634
2635
2636 /* Set LABEL to be the label used by conditional statement GS when its
2637    predicate evaluates to false.  */
2638
2639 static inline void
2640 gimple_cond_set_false_label (gimple gs, tree label)
2641 {
2642   GIMPLE_CHECK (gs, GIMPLE_COND);
2643   gimple_set_op (gs, 3, label);
2644 }
2645
2646
2647 /* Return the label used by conditional statement GS when its
2648    predicate evaluates to false.  */
2649
2650 static inline tree
2651 gimple_cond_false_label (const_gimple gs)
2652 {
2653   GIMPLE_CHECK (gs, GIMPLE_COND);
2654   return gimple_op (gs, 3);
2655 }
2656
2657
2658 /* Set the conditional COND_STMT to be of the form 'if (1 == 0)'.  */
2659
2660 static inline void
2661 gimple_cond_make_false (gimple gs)
2662 {
2663   gimple_cond_set_lhs (gs, boolean_true_node);
2664   gimple_cond_set_rhs (gs, boolean_false_node);
2665   gs->gsbase.subcode = EQ_EXPR;
2666 }
2667
2668
2669 /* Set the conditional COND_STMT to be of the form 'if (1 == 1)'.  */
2670
2671 static inline void
2672 gimple_cond_make_true (gimple gs)
2673 {
2674   gimple_cond_set_lhs (gs, boolean_true_node);
2675   gimple_cond_set_rhs (gs, boolean_true_node);
2676   gs->gsbase.subcode = EQ_EXPR;
2677 }
2678
2679 /* Check if conditional statemente GS is of the form 'if (1 == 1)',
2680   'if (0 == 0)', 'if (1 != 0)' or 'if (0 != 1)' */
2681
2682 static inline bool
2683 gimple_cond_true_p (const_gimple gs)
2684 {
2685   tree lhs = gimple_cond_lhs (gs);
2686   tree rhs = gimple_cond_rhs (gs);
2687   enum tree_code code = gimple_cond_code (gs);
2688
2689   if (lhs != boolean_true_node && lhs != boolean_false_node)
2690     return false;
2691
2692   if (rhs != boolean_true_node && rhs != boolean_false_node)
2693     return false;
2694
2695   if (code == NE_EXPR && lhs != rhs)
2696     return true;
2697
2698   if (code == EQ_EXPR && lhs == rhs)
2699       return true;
2700
2701   return false;
2702 }
2703
2704 /* Check if conditional statement GS is of the form 'if (1 != 1)',
2705    'if (0 != 0)', 'if (1 == 0)' or 'if (0 == 1)' */
2706
2707 static inline bool
2708 gimple_cond_false_p (const_gimple gs)
2709 {
2710   tree lhs = gimple_cond_lhs (gs);
2711   tree rhs = gimple_cond_rhs (gs);
2712   enum tree_code code = gimple_cond_code (gs);
2713
2714   if (lhs != boolean_true_node && lhs != boolean_false_node)
2715     return false;
2716
2717   if (rhs != boolean_true_node && rhs != boolean_false_node)
2718     return false;
2719
2720   if (code == NE_EXPR && lhs == rhs)
2721     return true;
2722
2723   if (code == EQ_EXPR && lhs != rhs)
2724       return true;
2725
2726   return false;
2727 }
2728
2729 /* Check if conditional statement GS is of the form 'if (var != 0)' or
2730    'if (var == 1)' */
2731
2732 static inline bool
2733 gimple_cond_single_var_p (gimple gs)
2734 {
2735   if (gimple_cond_code (gs) == NE_EXPR
2736       && gimple_cond_rhs (gs) == boolean_false_node)
2737     return true;
2738
2739   if (gimple_cond_code (gs) == EQ_EXPR
2740       && gimple_cond_rhs (gs) == boolean_true_node)
2741     return true;
2742
2743   return false;
2744 }
2745
2746 /* Set the code, LHS and RHS of GIMPLE_COND STMT from CODE, LHS and RHS.  */
2747
2748 static inline void
2749 gimple_cond_set_condition (gimple stmt, enum tree_code code, tree lhs, tree rhs)
2750 {
2751   gimple_cond_set_code (stmt, code);
2752   gimple_cond_set_lhs (stmt, lhs);
2753   gimple_cond_set_rhs (stmt, rhs);
2754 }
2755
2756 /* Return the LABEL_DECL node used by GIMPLE_LABEL statement GS.  */
2757
2758 static inline tree
2759 gimple_label_label (const_gimple gs)
2760 {
2761   GIMPLE_CHECK (gs, GIMPLE_LABEL);
2762   return gimple_op (gs, 0);
2763 }
2764
2765
2766 /* Set LABEL to be the LABEL_DECL node used by GIMPLE_LABEL statement
2767    GS.  */
2768
2769 static inline void
2770 gimple_label_set_label (gimple gs, tree label)
2771 {
2772   GIMPLE_CHECK (gs, GIMPLE_LABEL);
2773   gimple_set_op (gs, 0, label);
2774 }
2775
2776
2777 /* Return the destination of the unconditional jump GS.  */
2778
2779 static inline tree
2780 gimple_goto_dest (const_gimple gs)
2781 {
2782   GIMPLE_CHECK (gs, GIMPLE_GOTO);
2783   return gimple_op (gs, 0);
2784 }
2785
2786
2787 /* Set DEST to be the destination of the unconditonal jump GS.  */
2788
2789 static inline void
2790 gimple_goto_set_dest (gimple gs, tree dest)
2791 {
2792   GIMPLE_CHECK (gs, GIMPLE_GOTO);
2793   gimple_set_op (gs, 0, dest);
2794 }
2795
2796
2797 /* Return the variables declared in the GIMPLE_BIND statement GS.  */
2798
2799 static inline tree
2800 gimple_bind_vars (const_gimple gs)
2801 {
2802   GIMPLE_CHECK (gs, GIMPLE_BIND);
2803   return gs->gimple_bind.vars;
2804 }
2805
2806
2807 /* Set VARS to be the set of variables declared in the GIMPLE_BIND
2808    statement GS.  */
2809
2810 static inline void
2811 gimple_bind_set_vars (gimple gs, tree vars)
2812 {
2813   GIMPLE_CHECK (gs, GIMPLE_BIND);
2814   gs->gimple_bind.vars = vars;
2815 }
2816
2817
2818 /* Append VARS to the set of variables declared in the GIMPLE_BIND
2819    statement GS.  */
2820
2821 static inline void
2822 gimple_bind_append_vars (gimple gs, tree vars)
2823 {
2824   GIMPLE_CHECK (gs, GIMPLE_BIND);
2825   gs->gimple_bind.vars = chainon (gs->gimple_bind.vars, vars);
2826 }
2827
2828
2829 /* Return the GIMPLE sequence contained in the GIMPLE_BIND statement GS.  */
2830
2831 static inline gimple_seq
2832 gimple_bind_body (gimple gs)
2833 {
2834   GIMPLE_CHECK (gs, GIMPLE_BIND);
2835   return gs->gimple_bind.body;
2836 }
2837
2838
2839 /* Set SEQ to be the GIMPLE sequence contained in the GIMPLE_BIND
2840    statement GS.  */
2841
2842 static inline void
2843 gimple_bind_set_body (gimple gs, gimple_seq seq)
2844 {
2845   GIMPLE_CHECK (gs, GIMPLE_BIND);
2846   gs->gimple_bind.body = seq;
2847 }
2848
2849
2850 /* Append a statement to the end of a GIMPLE_BIND's body.  */
2851
2852 static inline void
2853 gimple_bind_add_stmt (gimple gs, gimple stmt)
2854 {
2855   GIMPLE_CHECK (gs, GIMPLE_BIND);
2856   gimple_seq_add_stmt (&gs->gimple_bind.body, stmt);
2857 }
2858
2859
2860 /* Append a sequence of statements to the end of a GIMPLE_BIND's body.  */
2861
2862 static inline void
2863 gimple_bind_add_seq (gimple gs, gimple_seq seq)
2864 {
2865   GIMPLE_CHECK (gs, GIMPLE_BIND);
2866   gimple_seq_add_seq (&gs->gimple_bind.body, seq);
2867 }
2868
2869
2870 /* Return the TREE_BLOCK node associated with GIMPLE_BIND statement
2871    GS.  This is analogous to the BIND_EXPR_BLOCK field in trees.  */
2872
2873 static inline tree
2874 gimple_bind_block (const_gimple gs)
2875 {
2876   GIMPLE_CHECK (gs, GIMPLE_BIND);
2877   return gs->gimple_bind.block;
2878 }
2879
2880
2881 /* Set BLOCK to be the TREE_BLOCK node associated with GIMPLE_BIND
2882    statement GS.  */
2883
2884 static inline void
2885 gimple_bind_set_block (gimple gs, tree block)
2886 {
2887   GIMPLE_CHECK (gs, GIMPLE_BIND);
2888   gcc_gimple_checking_assert (block == NULL_TREE
2889                               || TREE_CODE (block) == BLOCK);
2890   gs->gimple_bind.block = block;
2891 }
2892
2893
2894 /* Return the number of input operands for GIMPLE_ASM GS.  */
2895
2896 static inline unsigned
2897 gimple_asm_ninputs (const_gimple gs)
2898 {
2899   GIMPLE_CHECK (gs, GIMPLE_ASM);
2900   return gs->gimple_asm.ni;
2901 }
2902
2903
2904 /* Return the number of output operands for GIMPLE_ASM GS.  */
2905
2906 static inline unsigned
2907 gimple_asm_noutputs (const_gimple gs)
2908 {
2909   GIMPLE_CHECK (gs, GIMPLE_ASM);
2910   return gs->gimple_asm.no;
2911 }
2912
2913
2914 /* Return the number of clobber operands for GIMPLE_ASM GS.  */
2915
2916 static inline unsigned
2917 gimple_asm_nclobbers (const_gimple gs)
2918 {
2919   GIMPLE_CHECK (gs, GIMPLE_ASM);
2920   return gs->gimple_asm.nc;
2921 }
2922
2923 /* Return the number of label operands for GIMPLE_ASM GS.  */
2924
2925 static inline unsigned
2926 gimple_asm_nlabels (const_gimple gs)
2927 {
2928   GIMPLE_CHECK (gs, GIMPLE_ASM);
2929   return gs->gimple_asm.nl;
2930 }
2931
2932 /* Return input operand INDEX of GIMPLE_ASM GS.  */
2933
2934 static inline tree
2935 gimple_asm_input_op (const_gimple gs, unsigned index)
2936 {
2937   GIMPLE_CHECK (gs, GIMPLE_ASM);
2938   gcc_gimple_checking_assert (index <= gs->gimple_asm.ni);
2939   return gimple_op (gs, index);
2940 }
2941
2942 /* Return a pointer to input operand INDEX of GIMPLE_ASM GS.  */
2943
2944 static inline tree *
2945 gimple_asm_input_op_ptr (const_gimple gs, unsigned index)
2946 {
2947   GIMPLE_CHECK (gs, GIMPLE_ASM);
2948   gcc_gimple_checking_assert (index <= gs->gimple_asm.ni);
2949   return gimple_op_ptr (gs, index);
2950 }
2951
2952
2953 /* Set IN_OP to be input operand INDEX in GIMPLE_ASM GS.  */
2954
2955 static inline void
2956 gimple_asm_set_input_op (gimple gs, unsigned index, tree in_op)
2957 {
2958   GIMPLE_CHECK (gs, GIMPLE_ASM);
2959   gcc_gimple_checking_assert (index <= gs->gimple_asm.ni
2960                               && TREE_CODE (in_op) == TREE_LIST);
2961   gimple_set_op (gs, index, in_op);
2962 }
2963
2964
2965 /* Return output operand INDEX of GIMPLE_ASM GS.  */
2966
2967 static inline tree
2968 gimple_asm_output_op (const_gimple gs, unsigned index)
2969 {
2970   GIMPLE_CHECK (gs, GIMPLE_ASM);
2971   gcc_gimple_checking_assert (index <= gs->gimple_asm.no);
2972   return gimple_op (gs, index + gs->gimple_asm.ni);
2973 }
2974
2975 /* Return a pointer to output operand INDEX of GIMPLE_ASM GS.  */
2976
2977 static inline tree *
2978 gimple_asm_output_op_ptr (const_gimple gs, unsigned index)
2979 {
2980   GIMPLE_CHECK (gs, GIMPLE_ASM);
2981   gcc_gimple_checking_assert (index <= gs->gimple_asm.no);
2982   return gimple_op_ptr (gs, index + gs->gimple_asm.ni);
2983 }
2984
2985
2986 /* Set OUT_OP to be output operand INDEX in GIMPLE_ASM GS.  */
2987
2988 static inline void
2989 gimple_asm_set_output_op (gimple gs, unsigned index, tree out_op)
2990 {
2991   GIMPLE_CHECK (gs, GIMPLE_ASM);
2992   gcc_gimple_checking_assert (index <= gs->gimple_asm.no
2993                               && TREE_CODE (out_op) == TREE_LIST);
2994   gimple_set_op (gs, index + gs->gimple_asm.ni, out_op);
2995 }
2996
2997
2998 /* Return clobber operand INDEX of GIMPLE_ASM GS.  */
2999
3000 static inline tree
3001 gimple_asm_clobber_op (const_gimple gs, unsigned index)
3002 {
3003   GIMPLE_CHECK (gs, GIMPLE_ASM);
3004   gcc_gimple_checking_assert (index <= gs->gimple_asm.nc);
3005   return gimple_op (gs, index + gs->gimple_asm.ni + gs->gimple_asm.no);
3006 }
3007
3008
3009 /* Set CLOBBER_OP to be clobber operand INDEX in GIMPLE_ASM GS.  */
3010
3011 static inline void
3012 gimple_asm_set_clobber_op (gimple gs, unsigned index, tree clobber_op)
3013 {
3014   GIMPLE_CHECK (gs, GIMPLE_ASM);
3015   gcc_gimple_checking_assert (index <= gs->gimple_asm.nc
3016                               && TREE_CODE (clobber_op) == TREE_LIST);
3017   gimple_set_op (gs, index + gs->gimple_asm.ni + gs->gimple_asm.no, clobber_op);
3018 }
3019
3020 /* Return label operand INDEX of GIMPLE_ASM GS.  */
3021
3022 static inline tree
3023 gimple_asm_label_op (const_gimple gs, unsigned index)
3024 {
3025   GIMPLE_CHECK (gs, GIMPLE_ASM);
3026   gcc_gimple_checking_assert (index <= gs->gimple_asm.nl);
3027   return gimple_op (gs, index + gs->gimple_asm.ni + gs->gimple_asm.nc);
3028 }
3029
3030 /* Set LABEL_OP to be label operand INDEX in GIMPLE_ASM GS.  */
3031
3032 static inline void
3033 gimple_asm_set_label_op (gimple gs, unsigned index, tree label_op)
3034 {
3035   GIMPLE_CHECK (gs, GIMPLE_ASM);
3036   gcc_gimple_checking_assert (index <= gs->gimple_asm.nl
3037                               && TREE_CODE (label_op) == TREE_LIST);
3038   gimple_set_op (gs, index + gs->gimple_asm.ni + gs->gimple_asm.nc, label_op);
3039 }
3040
3041 /* Return the string representing the assembly instruction in
3042    GIMPLE_ASM GS.  */
3043
3044 static inline const char *
3045 gimple_asm_string (const_gimple gs)
3046 {
3047   GIMPLE_CHECK (gs, GIMPLE_ASM);
3048   return gs->gimple_asm.string;
3049 }
3050
3051
3052 /* Return true if GS is an asm statement marked volatile.  */
3053
3054 static inline bool
3055 gimple_asm_volatile_p (const_gimple gs)
3056 {
3057   GIMPLE_CHECK (gs, GIMPLE_ASM);
3058   return (gs->gsbase.subcode & GF_ASM_VOLATILE) != 0;
3059 }
3060
3061
3062 /* If VOLATLE_P is true, mark asm statement GS as volatile.  */
3063
3064 static inline void
3065 gimple_asm_set_volatile (gimple gs, bool volatile_p)
3066 {
3067   GIMPLE_CHECK (gs, GIMPLE_ASM);
3068   if (volatile_p)
3069     gs->gsbase.subcode |= GF_ASM_VOLATILE;
3070   else
3071     gs->gsbase.subcode &= ~GF_ASM_VOLATILE;
3072 }
3073
3074
3075 /* If INPUT_P is true, mark asm GS as an ASM_INPUT.  */
3076
3077 static inline void
3078 gimple_asm_set_input (gimple gs, bool input_p)
3079 {
3080   GIMPLE_CHECK (gs, GIMPLE_ASM);
3081   if (input_p)
3082     gs->gsbase.subcode |= GF_ASM_INPUT;
3083   else
3084     gs->gsbase.subcode &= ~GF_ASM_INPUT;
3085 }
3086
3087
3088 /* Return true if asm GS is an ASM_INPUT.  */
3089
3090 static inline bool
3091 gimple_asm_input_p (const_gimple gs)
3092 {
3093   GIMPLE_CHECK (gs, GIMPLE_ASM);
3094   return (gs->gsbase.subcode & GF_ASM_INPUT) != 0;
3095 }
3096
3097
3098 /* Return the types handled by GIMPLE_CATCH statement GS.  */
3099
3100 static inline tree
3101 gimple_catch_types (const_gimple gs)
3102 {
3103   GIMPLE_CHECK (gs, GIMPLE_CATCH);
3104   return gs->gimple_catch.types;
3105 }
3106
3107
3108 /* Return a pointer to the types handled by GIMPLE_CATCH statement GS.  */
3109
3110 static inline tree *
3111 gimple_catch_types_ptr (gimple gs)
3112 {
3113   GIMPLE_CHECK (gs, GIMPLE_CATCH);
3114   return &gs->gimple_catch.types;
3115 }
3116
3117
3118 /* Return the GIMPLE sequence representing the body of the handler of
3119    GIMPLE_CATCH statement GS.  */
3120
3121 static inline gimple_seq
3122 gimple_catch_handler (gimple gs)
3123 {
3124   GIMPLE_CHECK (gs, GIMPLE_CATCH);
3125   return gs->gimple_catch.handler;
3126 }
3127
3128
3129 /* Return a pointer to the GIMPLE sequence representing the body of
3130    the handler of GIMPLE_CATCH statement GS.  */
3131
3132 static inline gimple_seq *
3133 gimple_catch_handler_ptr (gimple gs)
3134 {
3135   GIMPLE_CHECK (gs, GIMPLE_CATCH);
3136   return &gs->gimple_catch.handler;
3137 }
3138
3139
3140 /* Set T to be the set of types handled by GIMPLE_CATCH GS.  */
3141
3142 static inline void
3143 gimple_catch_set_types (gimple gs, tree t)
3144 {
3145   GIMPLE_CHECK (gs, GIMPLE_CATCH);
3146   gs->gimple_catch.types = t;
3147 }
3148
3149
3150 /* Set HANDLER to be the body of GIMPLE_CATCH GS.  */
3151
3152 static inline void
3153 gimple_catch_set_handler (gimple gs, gimple_seq handler)
3154 {
3155   GIMPLE_CHECK (gs, GIMPLE_CATCH);
3156   gs->gimple_catch.handler = handler;
3157 }
3158
3159
3160 /* Return the types handled by GIMPLE_EH_FILTER statement GS.  */
3161
3162 static inline tree
3163 gimple_eh_filter_types (const_gimple gs)
3164 {
3165   GIMPLE_CHECK (gs, GIMPLE_EH_FILTER);
3166   return gs->gimple_eh_filter.types;
3167 }
3168
3169
3170 /* Return a pointer to the types handled by GIMPLE_EH_FILTER statement
3171    GS.  */
3172
3173 static inline tree *
3174 gimple_eh_filter_types_ptr (gimple gs)
3175 {
3176   GIMPLE_CHECK (gs, GIMPLE_EH_FILTER);
3177   return &gs->gimple_eh_filter.types;
3178 }
3179
3180
3181 /* Return the sequence of statement to execute when GIMPLE_EH_FILTER
3182    statement fails.  */
3183
3184 static inline gimple_seq
3185 gimple_eh_filter_failure (gimple gs)
3186 {
3187   GIMPLE_CHECK (gs, GIMPLE_EH_FILTER);
3188   return gs->gimple_eh_filter.failure;
3189 }
3190
3191
3192 /* Set TYPES to be the set of types handled by GIMPLE_EH_FILTER GS.  */
3193
3194 static inline void
3195 gimple_eh_filter_set_types (gimple gs, tree types)
3196 {
3197   GIMPLE_CHECK (gs, GIMPLE_EH_FILTER);
3198   gs->gimple_eh_filter.types = types;
3199 }
3200
3201
3202 /* Set FAILURE to be the sequence of statements to execute on failure
3203    for GIMPLE_EH_FILTER GS.  */
3204
3205 static inline void
3206 gimple_eh_filter_set_failure (gimple gs, gimple_seq failure)
3207 {
3208   GIMPLE_CHECK (gs, GIMPLE_EH_FILTER);
3209   gs->gimple_eh_filter.failure = failure;
3210 }
3211
3212 /* Get the function decl to be called by the MUST_NOT_THROW region.  */
3213
3214 static inline tree
3215 gimple_eh_must_not_throw_fndecl (gimple gs)
3216 {
3217   GIMPLE_CHECK (gs, GIMPLE_EH_MUST_NOT_THROW);
3218   return gs->gimple_eh_mnt.fndecl;
3219 }
3220
3221 /* Set the function decl to be called by GS to DECL.  */
3222
3223 static inline void
3224 gimple_eh_must_not_throw_set_fndecl (gimple gs, tree decl)
3225 {
3226   GIMPLE_CHECK (gs, GIMPLE_EH_MUST_NOT_THROW);
3227   gs->gimple_eh_mnt.fndecl = decl;
3228 }
3229
3230 /* GIMPLE_EH_ELSE accessors.  */
3231
3232 static inline gimple_seq
3233 gimple_eh_else_n_body (gimple gs)
3234 {
3235   GIMPLE_CHECK (gs, GIMPLE_EH_ELSE);
3236   return gs->gimple_eh_else.n_body;
3237 }
3238
3239 static inline gimple_seq
3240 gimple_eh_else_e_body (gimple gs)
3241 {
3242   GIMPLE_CHECK (gs, GIMPLE_EH_ELSE);
3243   return gs->gimple_eh_else.e_body;
3244 }
3245
3246 static inline void
3247 gimple_eh_else_set_n_body (gimple gs, gimple_seq seq)
3248 {
3249   GIMPLE_CHECK (gs, GIMPLE_EH_ELSE);
3250   gs->gimple_eh_else.n_body = seq;
3251 }
3252
3253 static inline void
3254 gimple_eh_else_set_e_body (gimple gs, gimple_seq seq)
3255 {
3256   GIMPLE_CHECK (gs, GIMPLE_EH_ELSE);
3257   gs->gimple_eh_else.e_body = seq;
3258 }
3259
3260 /* GIMPLE_TRY accessors. */
3261
3262 /* Return the kind of try block represented by GIMPLE_TRY GS.  This is
3263    either GIMPLE_TRY_CATCH or GIMPLE_TRY_FINALLY.  */
3264
3265 static inline enum gimple_try_flags
3266 gimple_try_kind (const_gimple gs)
3267 {
3268   GIMPLE_CHECK (gs, GIMPLE_TRY);
3269   return (enum gimple_try_flags) (gs->gsbase.subcode & GIMPLE_TRY_KIND);
3270 }
3271
3272
3273 /* Set the kind of try block represented by GIMPLE_TRY GS.  */
3274
3275 static inline void
3276 gimple_try_set_kind (gimple gs, enum gimple_try_flags kind)
3277 {
3278   GIMPLE_CHECK (gs, GIMPLE_TRY);
3279   gcc_gimple_checking_assert (kind == GIMPLE_TRY_CATCH
3280                               || kind == GIMPLE_TRY_FINALLY);
3281   if (gimple_try_kind (gs) != kind)
3282     gs->gsbase.subcode = (unsigned int) kind;
3283 }
3284
3285
3286 /* Return the GIMPLE_TRY_CATCH_IS_CLEANUP flag.  */
3287
3288 static inline bool
3289 gimple_try_catch_is_cleanup (const_gimple gs)
3290 {
3291   gcc_gimple_checking_assert (gimple_try_kind (gs) == GIMPLE_TRY_CATCH);
3292   return (gs->gsbase.subcode & GIMPLE_TRY_CATCH_IS_CLEANUP) != 0;
3293 }
3294
3295
3296 /* Return the sequence of statements used as the body for GIMPLE_TRY GS.  */
3297
3298 static inline gimple_seq
3299 gimple_try_eval (gimple gs)
3300 {
3301   GIMPLE_CHECK (gs, GIMPLE_TRY);
3302   return gs->gimple_try.eval;
3303 }
3304
3305
3306 /* Return the sequence of statements used as the cleanup body for
3307    GIMPLE_TRY GS.  */
3308
3309 static inline gimple_seq
3310 gimple_try_cleanup (gimple gs)
3311 {
3312   GIMPLE_CHECK (gs, GIMPLE_TRY);
3313   return gs->gimple_try.cleanup;
3314 }
3315
3316
3317 /* Set the GIMPLE_TRY_CATCH_IS_CLEANUP flag.  */
3318
3319 static inline void
3320 gimple_try_set_catch_is_cleanup (gimple g, bool catch_is_cleanup)
3321 {
3322   gcc_gimple_checking_assert (gimple_try_kind (g) == GIMPLE_TRY_CATCH);
3323   if (catch_is_cleanup)
3324     g->gsbase.subcode |= GIMPLE_TRY_CATCH_IS_CLEANUP;
3325   else
3326     g->gsbase.subcode &= ~GIMPLE_TRY_CATCH_IS_CLEANUP;
3327 }
3328
3329
3330 /* Set EVAL to be the sequence of statements to use as the body for
3331    GIMPLE_TRY GS.  */
3332
3333 static inline void
3334 gimple_try_set_eval (gimple gs, gimple_seq eval)
3335 {
3336   GIMPLE_CHECK (gs, GIMPLE_TRY);
3337   gs->gimple_try.eval = eval;
3338 }
3339
3340
3341 /* Set CLEANUP to be the sequence of statements to use as the cleanup
3342    body for GIMPLE_TRY GS.  */
3343
3344 static inline void
3345 gimple_try_set_cleanup (gimple gs, gimple_seq cleanup)
3346 {
3347   GIMPLE_CHECK (gs, GIMPLE_TRY);
3348   gs->gimple_try.cleanup = cleanup;
3349 }
3350
3351
3352 /* Return the cleanup sequence for cleanup statement GS.  */
3353
3354 static inline gimple_seq
3355 gimple_wce_cleanup (gimple gs)
3356 {
3357   GIMPLE_CHECK (gs, GIMPLE_WITH_CLEANUP_EXPR);
3358   return gs->gimple_wce.cleanup;
3359 }
3360
3361
3362 /* Set CLEANUP to be the cleanup sequence for GS.  */
3363
3364 static inline void
3365 gimple_wce_set_cleanup (gimple gs, gimple_seq cleanup)
3366 {
3367   GIMPLE_CHECK (gs, GIMPLE_WITH_CLEANUP_EXPR);
3368   gs->gimple_wce.cleanup = cleanup;
3369 }
3370
3371
3372 /* Return the CLEANUP_EH_ONLY flag for a WCE tuple.  */
3373
3374 static inline bool
3375 gimple_wce_cleanup_eh_only (const_gimple gs)
3376 {
3377   GIMPLE_CHECK (gs, GIMPLE_WITH_CLEANUP_EXPR);
3378   return gs->gsbase.subcode != 0;
3379 }
3380
3381
3382 /* Set the CLEANUP_EH_ONLY flag for a WCE tuple.  */
3383
3384 static inline void
3385 gimple_wce_set_cleanup_eh_only (gimple gs, bool eh_only_p)
3386 {
3387   GIMPLE_CHECK (gs, GIMPLE_WITH_CLEANUP_EXPR);
3388   gs->gsbase.subcode = (unsigned int) eh_only_p;
3389 }
3390
3391
3392 /* Return the maximum number of arguments supported by GIMPLE_PHI GS.  */
3393
3394 static inline unsigned
3395 gimple_phi_capacity (const_gimple gs)
3396 {
3397   GIMPLE_CHECK (gs, GIMPLE_PHI);
3398   return gs->gimple_phi.capacity;
3399 }
3400
3401
3402 /* Return the number of arguments in GIMPLE_PHI GS.  This must always
3403    be exactly the number of incoming edges for the basic block holding
3404    GS.  */
3405
3406 static inline unsigned
3407 gimple_phi_num_args (const_gimple gs)
3408 {
3409   GIMPLE_CHECK (gs, GIMPLE_PHI);
3410   return gs->gimple_phi.nargs;
3411 }
3412
3413
3414 /* Return the SSA name created by GIMPLE_PHI GS.  */
3415
3416 static inline tree
3417 gimple_phi_result (const_gimple gs)
3418 {
3419   GIMPLE_CHECK (gs, GIMPLE_PHI);
3420   return gs->gimple_phi.result;
3421 }
3422
3423 /* Return a pointer to the SSA name created by GIMPLE_PHI GS.  */
3424
3425 static inline tree *
3426 gimple_phi_result_ptr (gimple gs)
3427 {
3428   GIMPLE_CHECK (gs, GIMPLE_PHI);
3429   return &gs->gimple_phi.result;
3430 }
3431
3432 /* Set RESULT to be the SSA name created by GIMPLE_PHI GS.  */
3433
3434 static inline void
3435 gimple_phi_set_result (gimple gs, tree result)
3436 {
3437   GIMPLE_CHECK (gs, GIMPLE_PHI);
3438   gs->gimple_phi.result = result;
3439 }
3440
3441
3442 /* Return the PHI argument corresponding to incoming edge INDEX for
3443    GIMPLE_PHI GS.  */
3444
3445 static inline struct phi_arg_d *
3446 gimple_phi_arg (gimple gs, unsigned index)
3447 {
3448   GIMPLE_CHECK (gs, GIMPLE_PHI);
3449   gcc_gimple_checking_assert (index <= gs->gimple_phi.capacity);
3450   return &(gs->gimple_phi.args[index]);
3451 }
3452
3453 /* Set PHIARG to be the argument corresponding to incoming edge INDEX
3454    for GIMPLE_PHI GS.  */
3455
3456 static inline void
3457 gimple_phi_set_arg (gimple gs, unsigned index, struct phi_arg_d * phiarg)
3458 {
3459   GIMPLE_CHECK (gs, GIMPLE_PHI);
3460   gcc_gimple_checking_assert (index <= gs->gimple_phi.nargs);
3461   gs->gimple_phi.args[index] = *phiarg;
3462 }
3463
3464 /* Return the region number for GIMPLE_RESX GS.  */
3465
3466 static inline int
3467 gimple_resx_region (const_gimple gs)
3468 {
3469   GIMPLE_CHECK (gs, GIMPLE_RESX);
3470   return gs->gimple_eh_ctrl.region;
3471 }
3472
3473 /* Set REGION to be the region number for GIMPLE_RESX GS.  */
3474
3475 static inline void
3476 gimple_resx_set_region (gimple gs, int region)
3477 {
3478   GIMPLE_CHECK (gs, GIMPLE_RESX);
3479   gs->gimple_eh_ctrl.region = region;
3480 }
3481
3482 /* Return the region number for GIMPLE_EH_DISPATCH GS.  */
3483
3484 static inline int
3485 gimple_eh_dispatch_region (const_gimple gs)
3486 {
3487   GIMPLE_CHECK (gs, GIMPLE_EH_DISPATCH);
3488   return gs->gimple_eh_ctrl.region;
3489 }
3490
3491 /* Set REGION to be the region number for GIMPLE_EH_DISPATCH GS.  */
3492
3493 static inline void
3494 gimple_eh_dispatch_set_region (gimple gs, int region)
3495 {
3496   GIMPLE_CHECK (gs, GIMPLE_EH_DISPATCH);
3497   gs->gimple_eh_ctrl.region = region;
3498 }
3499
3500 /* Return the number of labels associated with the switch statement GS.  */
3501
3502 static inline unsigned
3503 gimple_switch_num_labels (const_gimple gs)
3504 {
3505   unsigned num_ops;
3506   GIMPLE_CHECK (gs, GIMPLE_SWITCH);
3507   num_ops = gimple_num_ops (gs);
3508   gcc_gimple_checking_assert (num_ops > 1);
3509   return num_ops - 1;
3510 }
3511
3512
3513 /* Set NLABELS to be the number of labels for the switch statement GS.  */
3514
3515 static inline void
3516 gimple_switch_set_num_labels (gimple g, unsigned nlabels)
3517 {
3518   GIMPLE_CHECK (g, GIMPLE_SWITCH);
3519   gimple_set_num_ops (g, nlabels + 1);
3520 }
3521
3522
3523 /* Return the index variable used by the switch statement GS.  */
3524
3525 static inline tree
3526 gimple_switch_index (const_gimple gs)
3527 {
3528   GIMPLE_CHECK (gs, GIMPLE_SWITCH);
3529   return gimple_op (gs, 0);
3530 }
3531
3532
3533 /* Return a pointer to the index variable for the switch statement GS.  */
3534
3535 static inline tree *
3536 gimple_switch_index_ptr (const_gimple gs)
3537 {
3538   GIMPLE_CHECK (gs, GIMPLE_SWITCH);
3539   return gimple_op_ptr (gs, 0);
3540 }
3541
3542
3543 /* Set INDEX to be the index variable for switch statement GS.  */
3544
3545 static inline void
3546 gimple_switch_set_index (gimple gs, tree index)
3547 {
3548   GIMPLE_CHECK (gs, GIMPLE_SWITCH);
3549   gcc_gimple_checking_assert (SSA_VAR_P (index) || CONSTANT_CLASS_P (index));
3550   gimple_set_op (gs, 0, index);
3551 }
3552
3553
3554 /* Return the label numbered INDEX.  The default label is 0, followed by any
3555    labels in a switch statement.  */
3556
3557 static inline tree
3558 gimple_switch_label (const_gimple gs, unsigned index)
3559 {
3560   GIMPLE_CHECK (gs, GIMPLE_SWITCH);
3561   gcc_gimple_checking_assert (gimple_num_ops (gs) > index + 1);
3562   return gimple_op (gs, index + 1);
3563 }
3564
3565 /* Set the label number INDEX to LABEL.  0 is always the default label.  */
3566
3567 static inline void
3568 gimple_switch_set_label (gimple gs, unsigned index, tree label)
3569 {
3570   GIMPLE_CHECK (gs, GIMPLE_SWITCH);
3571   gcc_gimple_checking_assert (gimple_num_ops (gs) > index + 1
3572                               && (label == NULL_TREE
3573                                   || TREE_CODE (label) == CASE_LABEL_EXPR));
3574   gimple_set_op (gs, index + 1, label);
3575 }
3576
3577 /* Return the default label for a switch statement.  */
3578
3579 static inline tree
3580 gimple_switch_default_label (const_gimple gs)
3581 {
3582   return gimple_switch_label (gs, 0);
3583 }
3584
3585 /* Set the default label for a switch statement.  */
3586
3587 static inline void
3588 gimple_switch_set_default_label (gimple gs, tree label)
3589 {
3590   gimple_switch_set_label (gs, 0, label);
3591 }
3592
3593 /* Return true if GS is a GIMPLE_DEBUG statement.  */
3594
3595 static inline bool
3596 is_gimple_debug (const_gimple gs)
3597 {
3598   return gimple_code (gs) == GIMPLE_DEBUG;
3599 }
3600
3601 /* Return true if S is a GIMPLE_DEBUG BIND statement.  */
3602
3603 static inline bool
3604 gimple_debug_bind_p (const_gimple s)
3605 {
3606   if (is_gimple_debug (s))
3607     return s->gsbase.subcode == GIMPLE_DEBUG_BIND;
3608
3609   return false;
3610 }
3611
3612 /* Return the variable bound in a GIMPLE_DEBUG bind statement.  */
3613
3614 static inline tree
3615 gimple_debug_bind_get_var (gimple dbg)
3616 {
3617   GIMPLE_CHECK (dbg, GIMPLE_DEBUG);
3618   gcc_gimple_checking_assert (gimple_debug_bind_p (dbg));
3619   return gimple_op (dbg, 0);
3620 }
3621
3622 /* Return the value bound to the variable in a GIMPLE_DEBUG bind
3623    statement.  */
3624
3625 static inline tree
3626 gimple_debug_bind_get_value (gimple dbg)
3627 {
3628   GIMPLE_CHECK (dbg, GIMPLE_DEBUG);
3629   gcc_gimple_checking_assert (gimple_debug_bind_p (dbg));
3630   return gimple_op (dbg, 1);
3631 }
3632
3633 /* Return a pointer to the value bound to the variable in a
3634    GIMPLE_DEBUG bind statement.  */
3635
3636 static inline tree *
3637 gimple_debug_bind_get_value_ptr (gimple dbg)
3638 {
3639   GIMPLE_CHECK (dbg, GIMPLE_DEBUG);
3640   gcc_gimple_checking_assert (gimple_debug_bind_p (dbg));
3641   return gimple_op_ptr (dbg, 1);
3642 }
3643
3644 /* Set the variable bound in a GIMPLE_DEBUG bind statement.  */
3645
3646 static inline void
3647 gimple_debug_bind_set_var (gimple dbg, tree var)
3648 {
3649   GIMPLE_CHECK (dbg, GIMPLE_DEBUG);
3650   gcc_gimple_checking_assert (gimple_debug_bind_p (dbg));
3651   gimple_set_op (dbg, 0, var);
3652 }
3653
3654 /* Set the value bound to the variable in a GIMPLE_DEBUG bind
3655    statement.  */
3656
3657 static inline void
3658 gimple_debug_bind_set_value (gimple dbg, tree value)
3659 {
3660   GIMPLE_CHECK (dbg, GIMPLE_DEBUG);
3661   gcc_gimple_checking_assert (gimple_debug_bind_p (dbg));
3662   gimple_set_op (dbg, 1, value);
3663 }
3664
3665 /* The second operand of a GIMPLE_DEBUG_BIND, when the value was
3666    optimized away.  */
3667 #define GIMPLE_DEBUG_BIND_NOVALUE NULL_TREE /* error_mark_node */
3668
3669 /* Remove the value bound to the variable in a GIMPLE_DEBUG bind
3670    statement.  */
3671
3672 static inline void
3673 gimple_debug_bind_reset_value (gimple dbg)
3674 {
3675   GIMPLE_CHECK (dbg, GIMPLE_DEBUG);
3676   gcc_gimple_checking_assert (gimple_debug_bind_p (dbg));
3677   gimple_set_op (dbg, 1, GIMPLE_DEBUG_BIND_NOVALUE);
3678 }
3679
3680 /* Return true if the GIMPLE_DEBUG bind statement is bound to a
3681    value.  */
3682
3683 static inline bool
3684 gimple_debug_bind_has_value_p (gimple dbg)
3685 {
3686   GIMPLE_CHECK (dbg, GIMPLE_DEBUG);
3687   gcc_gimple_checking_assert (gimple_debug_bind_p (dbg));
3688   return gimple_op (dbg, 1) != GIMPLE_DEBUG_BIND_NOVALUE;
3689 }
3690
3691 #undef GIMPLE_DEBUG_BIND_NOVALUE
3692
3693 /* Return true if S is a GIMPLE_DEBUG SOURCE BIND statement.  */
3694
3695 static inline bool
3696 gimple_debug_source_bind_p (const_gimple s)
3697 {
3698   if (is_gimple_debug (s))
3699     return s->gsbase.subcode == GIMPLE_DEBUG_SOURCE_BIND;
3700
3701   return false;
3702 }
3703
3704 /* Return the variable bound in a GIMPLE_DEBUG source bind statement.  */
3705
3706 static inline tree
3707 gimple_debug_source_bind_get_var (gimple dbg)
3708 {
3709   GIMPLE_CHECK (dbg, GIMPLE_DEBUG);
3710   gcc_gimple_checking_assert (gimple_debug_source_bind_p (dbg));
3711   return gimple_op (dbg, 0);
3712 }
3713
3714 /* Return the value bound to the variable in a GIMPLE_DEBUG source bind
3715    statement.  */
3716
3717 static inline tree
3718 gimple_debug_source_bind_get_value (gimple dbg)
3719 {
3720   GIMPLE_CHECK (dbg, GIMPLE_DEBUG);
3721   gcc_gimple_checking_assert (gimple_debug_source_bind_p (dbg));
3722   return gimple_op (dbg, 1);
3723 }
3724
3725 /* Return a pointer to the value bound to the variable in a
3726    GIMPLE_DEBUG source bind statement.  */
3727
3728 static inline tree *
3729 gimple_debug_source_bind_get_value_ptr (gimple dbg)
3730 {
3731   GIMPLE_CHECK (dbg, GIMPLE_DEBUG);
3732   gcc_gimple_checking_assert (gimple_debug_source_bind_p (dbg));
3733   return gimple_op_ptr (dbg, 1);
3734 }
3735
3736 /* Set the variable bound in a GIMPLE_DEBUG source bind statement.  */
3737
3738 static inline void
3739 gimple_debug_source_bind_set_var (gimple dbg, tree var)
3740 {
3741   GIMPLE_CHECK (dbg, GIMPLE_DEBUG);
3742   gcc_gimple_checking_assert (gimple_debug_source_bind_p (dbg));
3743   gimple_set_op (dbg, 0, var);
3744 }
3745
3746 /* Set the value bound to the variable in a GIMPLE_DEBUG source bind
3747    statement.  */
3748
3749 static inline void
3750 gimple_debug_source_bind_set_value (gimple dbg, tree value)
3751 {
3752   GIMPLE_CHECK (dbg, GIMPLE_DEBUG);
3753   gcc_gimple_checking_assert (gimple_debug_source_bind_p (dbg));
3754   gimple_set_op (dbg, 1, value);
3755 }
3756
3757 /* Return the body for the OMP statement GS.  */
3758
3759 static inline gimple_seq
3760 gimple_omp_body (gimple gs)
3761 {
3762   return gs->omp.body;
3763 }
3764
3765 /* Set BODY to be the body for the OMP statement GS.  */
3766
3767 static inline void
3768 gimple_omp_set_body (gimple gs, gimple_seq body)
3769 {
3770   gs->omp.body = body;
3771 }
3772
3773
3774 /* Return the name associated with OMP_CRITICAL statement GS.  */
3775
3776 static inline tree
3777 gimple_omp_critical_name (const_gimple gs)
3778 {
3779   GIMPLE_CHECK (gs, GIMPLE_OMP_CRITICAL);
3780   return gs->gimple_omp_critical.name;
3781 }
3782
3783
3784 /* Return a pointer to the name associated with OMP critical statement GS.  */
3785
3786 static inline tree *
3787 gimple_omp_critical_name_ptr (gimple gs)
3788 {
3789   GIMPLE_CHECK (gs, GIMPLE_OMP_CRITICAL);
3790   return &gs->gimple_omp_critical.name;
3791 }
3792
3793
3794 /* Set NAME to be the name associated with OMP critical statement GS.  */
3795
3796 static inline void
3797 gimple_omp_critical_set_name (gimple gs, tree name)
3798 {
3799   GIMPLE_CHECK (gs, GIMPLE_OMP_CRITICAL);
3800   gs->gimple_omp_critical.name = name;
3801 }
3802
3803
3804 /* Return the clauses associated with OMP_FOR GS.  */
3805
3806 static inline tree
3807 gimple_omp_for_clauses (const_gimple gs)
3808 {
3809   GIMPLE_CHECK (gs, GIMPLE_OMP_FOR);
3810   return gs->gimple_omp_for.clauses;
3811 }
3812
3813
3814 /* Return a pointer to the OMP_FOR GS.  */
3815
3816 static inline tree *
3817 gimple_omp_for_clauses_ptr (gimple gs)
3818 {
3819   GIMPLE_CHECK (gs, GIMPLE_OMP_FOR);
3820   return &gs->gimple_omp_for.clauses;
3821 }
3822
3823
3824 /* Set CLAUSES to be the list of clauses associated with OMP_FOR GS.  */
3825
3826 static inline void
3827 gimple_omp_for_set_clauses (gimple gs, tree clauses)
3828 {
3829   GIMPLE_CHECK (gs, GIMPLE_OMP_FOR);
3830   gs->gimple_omp_for.clauses = clauses;
3831 }
3832
3833
3834 /* Get the collapse count of OMP_FOR GS.  */
3835
3836 static inline size_t
3837 gimple_omp_for_collapse (gimple gs)
3838 {
3839   GIMPLE_CHECK (gs, GIMPLE_OMP_FOR);
3840   return gs->gimple_omp_for.collapse;
3841 }
3842
3843
3844 /* Return the index variable for OMP_FOR GS.  */
3845
3846 static inline tree
3847 gimple_omp_for_index (const_gimple gs, size_t i)
3848 {
3849   GIMPLE_CHECK (gs, GIMPLE_OMP_FOR);
3850   gcc_gimple_checking_assert (i < gs->gimple_omp_for.collapse);
3851   return gs->gimple_omp_for.iter[i].index;
3852 }
3853
3854
3855 /* Return a pointer to the index variable for OMP_FOR GS.  */
3856
3857 static inline tree *
3858 gimple_omp_for_index_ptr (gimple gs, size_t i)
3859 {
3860   GIMPLE_CHECK (gs, GIMPLE_OMP_FOR);
3861   gcc_gimple_checking_assert (i < gs->gimple_omp_for.collapse);
3862   return &gs->gimple_omp_for.iter[i].index;
3863 }
3864
3865
3866 /* Set INDEX to be the index variable for OMP_FOR GS.  */
3867
3868 static inline void
3869 gimple_omp_for_set_index (gimple gs, size_t i, tree index)
3870 {
3871   GIMPLE_CHECK (gs, GIMPLE_OMP_FOR);
3872   gcc_gimple_checking_assert (i < gs->gimple_omp_for.collapse);
3873   gs->gimple_omp_for.iter[i].index = index;
3874 }
3875
3876
3877 /* Return the initial value for OMP_FOR GS.  */
3878
3879 static inline tree
3880 gimple_omp_for_initial (const_gimple gs, size_t i)
3881 {
3882   GIMPLE_CHECK (gs, GIMPLE_OMP_FOR);
3883   gcc_gimple_checking_assert (i < gs->gimple_omp_for.collapse);
3884   return gs->gimple_omp_for.iter[i].initial;
3885 }
3886
3887
3888 /* Return a pointer to the initial value for OMP_FOR GS.  */
3889
3890 static inline tree *
3891 gimple_omp_for_initial_ptr (gimple gs, size_t i)
3892 {
3893   GIMPLE_CHECK (gs, GIMPLE_OMP_FOR);
3894   gcc_gimple_checking_assert (i < gs->gimple_omp_for.collapse);
3895   return &gs->gimple_omp_for.iter[i].initial;
3896 }
3897
3898
3899 /* Set INITIAL to be the initial value for OMP_FOR GS.  */
3900
3901 static inline void
3902 gimple_omp_for_set_initial (gimple gs, size_t i, tree initial)
3903 {
3904   GIMPLE_CHECK (gs, GIMPLE_OMP_FOR);
3905   gcc_gimple_checking_assert (i < gs->gimple_omp_for.collapse);
3906   gs->gimple_omp_for.iter[i].initial = initial;
3907 }
3908
3909
3910 /* Return the final value for OMP_FOR GS.  */
3911
3912 static inline tree
3913 gimple_omp_for_final (const_gimple gs, size_t i)
3914 {
3915   GIMPLE_CHECK (gs, GIMPLE_OMP_FOR);
3916   gcc_gimple_checking_assert (i < gs->gimple_omp_for.collapse);
3917   return gs->gimple_omp_for.iter[i].final;
3918 }
3919
3920
3921 /* Return a pointer to the final value for OMP_FOR GS.  */
3922
3923 static inline tree *
3924 gimple_omp_for_final_ptr (gimple gs, size_t i)
3925 {
3926   GIMPLE_CHECK (gs, GIMPLE_OMP_FOR);
3927   gcc_gimple_checking_assert (i < gs->gimple_omp_for.collapse);
3928   return &gs->gimple_omp_for.iter[i].final;
3929 }
3930
3931
3932 /* Set FINAL to be the final value for OMP_FOR GS.  */
3933
3934 static inline void
3935 gimple_omp_for_set_final (gimple gs, size_t i, tree final)
3936 {
3937   GIMPLE_CHECK (gs, GIMPLE_OMP_FOR);
3938   gcc_gimple_checking_assert (i < gs->gimple_omp_for.collapse);
3939   gs->gimple_omp_for.iter[i].final = final;
3940 }
3941
3942
3943 /* Return the increment value for OMP_FOR GS.  */
3944
3945 static inline tree
3946 gimple_omp_for_incr (const_gimple gs, size_t i)
3947 {
3948   GIMPLE_CHECK (gs, GIMPLE_OMP_FOR);
3949   gcc_gimple_checking_assert (i < gs->gimple_omp_for.collapse);
3950   return gs->gimple_omp_for.iter[i].incr;
3951 }
3952
3953
3954 /* Return a pointer to the increment value for OMP_FOR GS.  */
3955
3956 static inline tree *
3957 gimple_omp_for_incr_ptr (gimple gs, size_t i)
3958 {
3959   GIMPLE_CHECK (gs, GIMPLE_OMP_FOR);
3960   gcc_gimple_checking_assert (i < gs->gimple_omp_for.collapse);
3961   return &gs->gimple_omp_for.iter[i].incr;
3962 }
3963
3964
3965 /* Set INCR to be the increment value for OMP_FOR GS.  */
3966
3967 static inline void
3968 gimple_omp_for_set_incr (gimple gs, size_t i, tree incr)
3969 {
3970   GIMPLE_CHECK (gs, GIMPLE_OMP_FOR);
3971   gcc_gimple_checking_assert (i < gs->gimple_omp_for.collapse);
3972   gs->gimple_omp_for.iter[i].incr = incr;
3973 }
3974
3975
3976 /* Return the sequence of statements to execute before the OMP_FOR
3977    statement GS starts.  */
3978
3979 static inline gimple_seq
3980 gimple_omp_for_pre_body (gimple gs)
3981 {
3982   GIMPLE_CHECK (gs, GIMPLE_OMP_FOR);
3983   return gs->gimple_omp_for.pre_body;
3984 }
3985
3986
3987 /* Set PRE_BODY to be the sequence of statements to execute before the
3988    OMP_FOR statement GS starts.  */
3989
3990 static inline void
3991 gimple_omp_for_set_pre_body (gimple gs, gimple_seq pre_body)
3992 {
3993   GIMPLE_CHECK (gs, GIMPLE_OMP_FOR);
3994   gs->gimple_omp_for.pre_body = pre_body;
3995 }
3996
3997
3998 /* Return the clauses associated with OMP_PARALLEL GS.  */
3999
4000 static inline tree
4001 gimple_omp_parallel_clauses (const_gimple gs)
4002 {
4003   GIMPLE_CHECK (gs, GIMPLE_OMP_PARALLEL);
4004   return gs->gimple_omp_parallel.clauses;
4005 }
4006
4007
4008 /* Return a pointer to the clauses associated with OMP_PARALLEL GS.  */
4009
4010 static inline tree *
4011 gimple_omp_parallel_clauses_ptr (gimple gs)
4012 {
4013   GIMPLE_CHECK (gs, GIMPLE_OMP_PARALLEL);
4014   return &gs->gimple_omp_parallel.clauses;
4015 }
4016
4017
4018 /* Set CLAUSES to be the list of clauses associated with OMP_PARALLEL
4019    GS.  */
4020
4021 static inline void
4022 gimple_omp_parallel_set_clauses (gimple gs, tree clauses)
4023 {
4024   GIMPLE_CHECK (gs, GIMPLE_OMP_PARALLEL);
4025   gs->gimple_omp_parallel.clauses = clauses;
4026 }
4027
4028
4029 /* Return the child function used to hold the body of OMP_PARALLEL GS.  */
4030
4031 static inline tree
4032 gimple_omp_parallel_child_fn (const_gimple gs)
4033 {
4034   GIMPLE_CHECK (gs, GIMPLE_OMP_PARALLEL);
4035   return gs->gimple_omp_parallel.child_fn;
4036 }
4037
4038 /* Return a pointer to the child function used to hold the body of
4039    OMP_PARALLEL GS.  */
4040
4041 static inline tree *
4042 gimple_omp_parallel_child_fn_ptr (gimple gs)
4043 {
4044   GIMPLE_CHECK (gs, GIMPLE_OMP_PARALLEL);
4045   return &gs->gimple_omp_parallel.child_fn;
4046 }
4047
4048
4049 /* Set CHILD_FN to be the child function for OMP_PARALLEL GS.  */
4050
4051 static inline void
4052 gimple_omp_parallel_set_child_fn (gimple gs, tree child_fn)
4053 {
4054   GIMPLE_CHECK (gs, GIMPLE_OMP_PARALLEL);
4055   gs->gimple_omp_parallel.child_fn = child_fn;
4056 }
4057
4058
4059 /* Return the artificial argument used to send variables and values
4060    from the parent to the children threads in OMP_PARALLEL GS.  */
4061
4062 static inline tree
4063 gimple_omp_parallel_data_arg (const_gimple gs)
4064 {
4065   GIMPLE_CHECK (gs, GIMPLE_OMP_PARALLEL);
4066   return gs->gimple_omp_parallel.data_arg;
4067 }
4068
4069
4070 /* Return a pointer to the data argument for OMP_PARALLEL GS.  */
4071
4072 static inline tree *
4073 gimple_omp_parallel_data_arg_ptr (gimple gs)
4074 {
4075   GIMPLE_CHECK (gs, GIMPLE_OMP_PARALLEL);
4076   return &gs->gimple_omp_parallel.data_arg;
4077 }
4078
4079
4080 /* Set DATA_ARG to be the data argument for OMP_PARALLEL GS.  */
4081
4082 static inline void
4083 gimple_omp_parallel_set_data_arg (gimple gs, tree data_arg)
4084 {
4085   GIMPLE_CHECK (gs, GIMPLE_OMP_PARALLEL);
4086   gs->gimple_omp_parallel.data_arg = data_arg;
4087 }
4088
4089
4090 /* Return the clauses associated with OMP_TASK GS.  */
4091
4092 static inline tree
4093 gimple_omp_task_clauses (const_gimple gs)
4094 {
4095   GIMPLE_CHECK (gs, GIMPLE_OMP_TASK);
4096   return gs->gimple_omp_parallel.clauses;
4097 }
4098
4099
4100 /* Return a pointer to the clauses associated with OMP_TASK GS.  */
4101
4102 static inline tree *
4103 gimple_omp_task_clauses_ptr (gimple gs)
4104 {
4105   GIMPLE_CHECK (gs, GIMPLE_OMP_TASK);
4106   return &gs->gimple_omp_parallel.clauses;
4107 }
4108
4109
4110 /* Set CLAUSES to be the list of clauses associated with OMP_TASK
4111    GS.  */
4112
4113 static inline void
4114 gimple_omp_task_set_clauses (gimple gs, tree clauses)
4115 {
4116   GIMPLE_CHECK (gs, GIMPLE_OMP_TASK);
4117   gs->gimple_omp_parallel.clauses = clauses;
4118 }
4119
4120
4121 /* Return the child function used to hold the body of OMP_TASK GS.  */
4122
4123 static inline tree
4124 gimple_omp_task_child_fn (const_gimple gs)
4125 {
4126   GIMPLE_CHECK (gs, GIMPLE_OMP_TASK);
4127   return gs->gimple_omp_parallel.child_fn;
4128 }
4129
4130 /* Return a pointer to the child function used to hold the body of
4131    OMP_TASK GS.  */
4132
4133 static inline tree *
4134 gimple_omp_task_child_fn_ptr (gimple gs)
4135 {
4136   GIMPLE_CHECK (gs, GIMPLE_OMP_TASK);
4137   return &gs->gimple_omp_parallel.child_fn;
4138 }
4139
4140
4141 /* Set CHILD_FN to be the child function for OMP_TASK GS.  */
4142
4143 static inline void
4144 gimple_omp_task_set_child_fn (gimple gs, tree child_fn)
4145 {
4146   GIMPLE_CHECK (gs, GIMPLE_OMP_TASK);
4147   gs->gimple_omp_parallel.child_fn = child_fn;
4148 }
4149
4150
4151 /* Return the artificial argument used to send variables and values
4152    from the parent to the children threads in OMP_TASK GS.  */
4153
4154 static inline tree
4155 gimple_omp_task_data_arg (const_gimple gs)
4156 {
4157   GIMPLE_CHECK (gs, GIMPLE_OMP_TASK);
4158   return gs->gimple_omp_parallel.data_arg;
4159 }
4160
4161
4162 /* Return a pointer to the data argument for OMP_TASK GS.  */
4163
4164 static inline tree *
4165 gimple_omp_task_data_arg_ptr (gimple gs)
4166 {
4167   GIMPLE_CHECK (gs, GIMPLE_OMP_TASK);
4168   return &gs->gimple_omp_parallel.data_arg;
4169 }
4170
4171
4172 /* Set DATA_ARG to be the data argument for OMP_TASK GS.  */
4173
4174 static inline void
4175 gimple_omp_task_set_data_arg (gimple gs, tree data_arg)
4176 {
4177   GIMPLE_CHECK (gs, GIMPLE_OMP_TASK);
4178   gs->gimple_omp_parallel.data_arg = data_arg;
4179 }
4180
4181
4182 /* Return the clauses associated with OMP_TASK GS.  */
4183
4184 static inline tree
4185 gimple_omp_taskreg_clauses (const_gimple gs)
4186 {
4187   if (gimple_code (gs) != GIMPLE_OMP_PARALLEL)
4188     GIMPLE_CHECK (gs, GIMPLE_OMP_TASK);
4189   return gs->gimple_omp_parallel.clauses;
4190 }
4191
4192
4193 /* Return a pointer to the clauses associated with OMP_TASK GS.  */
4194
4195 static inline tree *
4196 gimple_omp_taskreg_clauses_ptr (gimple gs)
4197 {
4198   if (gimple_code (gs) != GIMPLE_OMP_PARALLEL)
4199     GIMPLE_CHECK (gs, GIMPLE_OMP_TASK);
4200   return &gs->gimple_omp_parallel.clauses;
4201 }
4202
4203
4204 /* Set CLAUSES to be the list of clauses associated with OMP_TASK
4205    GS.  */
4206
4207 static inline void
4208 gimple_omp_taskreg_set_clauses (gimple gs, tree clauses)
4209 {
4210   if (gimple_code (gs) != GIMPLE_OMP_PARALLEL)
4211     GIMPLE_CHECK (gs, GIMPLE_OMP_TASK);
4212   gs->gimple_omp_parallel.clauses = clauses;
4213 }
4214
4215
4216 /* Return the child function used to hold the body of OMP_TASK GS.  */
4217
4218 static inline tree
4219 gimple_omp_taskreg_child_fn (const_gimple gs)
4220 {
4221   if (gimple_code (gs) != GIMPLE_OMP_PARALLEL)
4222     GIMPLE_CHECK (gs, GIMPLE_OMP_TASK);
4223   return gs->gimple_omp_parallel.child_fn;
4224 }
4225
4226 /* Return a pointer to the child function used to hold the body of
4227    OMP_TASK GS.  */
4228
4229 static inline tree *
4230 gimple_omp_taskreg_child_fn_ptr (gimple gs)
4231 {
4232   if (gimple_code (gs) != GIMPLE_OMP_PARALLEL)
4233     GIMPLE_CHECK (gs, GIMPLE_OMP_TASK);
4234   return &gs->gimple_omp_parallel.child_fn;
4235 }
4236
4237
4238 /* Set CHILD_FN to be the child function for OMP_TASK GS.  */
4239
4240 static inline void
4241 gimple_omp_taskreg_set_child_fn (gimple gs, tree child_fn)
4242 {
4243   if (gimple_code (gs) != GIMPLE_OMP_PARALLEL)
4244     GIMPLE_CHECK (gs, GIMPLE_OMP_TASK);
4245   gs->gimple_omp_parallel.child_fn = child_fn;
4246 }
4247
4248
4249 /* Return the artificial argument used to send variables and values
4250    from the parent to the children threads in OMP_TASK GS.  */
4251
4252 static inline tree
4253 gimple_omp_taskreg_data_arg (const_gimple gs)
4254 {
4255   if (gimple_code (gs) != GIMPLE_OMP_PARALLEL)
4256     GIMPLE_CHECK (gs, GIMPLE_OMP_TASK);
4257   return gs->gimple_omp_parallel.data_arg;
4258 }
4259
4260
4261 /* Return a pointer to the data argument for OMP_TASK GS.  */
4262
4263 static inline tree *
4264 gimple_omp_taskreg_data_arg_ptr (gimple gs)
4265 {
4266   if (gimple_code (gs) != GIMPLE_OMP_PARALLEL)
4267     GIMPLE_CHECK (gs, GIMPLE_OMP_TASK);
4268   return &gs->gimple_omp_parallel.data_arg;
4269 }
4270
4271
4272 /* Set DATA_ARG to be the data argument for OMP_TASK GS.  */
4273
4274 static inline void
4275 gimple_omp_taskreg_set_data_arg (gimple gs, tree data_arg)
4276 {
4277   if (gimple_code (gs) != GIMPLE_OMP_PARALLEL)
4278     GIMPLE_CHECK (gs, GIMPLE_OMP_TASK);
4279   gs->gimple_omp_parallel.data_arg = data_arg;
4280 }
4281
4282
4283 /* Return the copy function used to hold the body of OMP_TASK GS.  */
4284
4285 static inline tree
4286 gimple_omp_task_copy_fn (const_gimple gs)
4287 {
4288   GIMPLE_CHECK (gs, GIMPLE_OMP_TASK);
4289   return gs->gimple_omp_task.copy_fn;
4290 }
4291
4292 /* Return a pointer to the copy function used to hold the body of
4293    OMP_TASK GS.  */
4294
4295 static inline tree *
4296 gimple_omp_task_copy_fn_ptr (gimple gs)
4297 {
4298   GIMPLE_CHECK (gs, GIMPLE_OMP_TASK);
4299   return &gs->gimple_omp_task.copy_fn;
4300 }
4301
4302
4303 /* Set CHILD_FN to be the copy function for OMP_TASK GS.  */
4304
4305 static inline void
4306 gimple_omp_task_set_copy_fn (gimple gs, tree copy_fn)
4307 {
4308   GIMPLE_CHECK (gs, GIMPLE_OMP_TASK);
4309   gs->gimple_omp_task.copy_fn = copy_fn;
4310 }
4311
4312
4313 /* Return size of the data block in bytes in OMP_TASK GS.  */
4314
4315 static inline tree
4316 gimple_omp_task_arg_size (const_gimple gs)
4317 {
4318   GIMPLE_CHECK (gs, GIMPLE_OMP_TASK);
4319   return gs->gimple_omp_task.arg_size;
4320 }
4321
4322
4323 /* Return a pointer to the data block size for OMP_TASK GS.  */
4324
4325 static inline tree *
4326 gimple_omp_task_arg_size_ptr (gimple gs)
4327 {
4328   GIMPLE_CHECK (gs, GIMPLE_OMP_TASK);
4329   return &gs->gimple_omp_task.arg_size;
4330 }
4331
4332
4333 /* Set ARG_SIZE to be the data block size for OMP_TASK GS.  */
4334
4335 static inline void
4336 gimple_omp_task_set_arg_size (gimple gs, tree arg_size)
4337 {
4338   GIMPLE_CHECK (gs, GIMPLE_OMP_TASK);
4339   gs->gimple_omp_task.arg_size = arg_size;
4340 }
4341
4342
4343 /* Return align of the data block in bytes in OMP_TASK GS.  */
4344
4345 static inline tree
4346 gimple_omp_task_arg_align (const_gimple gs)
4347 {
4348   GIMPLE_CHECK (gs, GIMPLE_OMP_TASK);
4349   return gs->gimple_omp_task.arg_align;
4350 }
4351
4352
4353 /* Return a pointer to the data block align for OMP_TASK GS.  */
4354
4355 static inline tree *
4356 gimple_omp_task_arg_align_ptr (gimple gs)
4357 {
4358   GIMPLE_CHECK (gs, GIMPLE_OMP_TASK);
4359   return &gs->gimple_omp_task.arg_align;
4360 }
4361
4362
4363 /* Set ARG_SIZE to be the data block align for OMP_TASK GS.  */
4364
4365 static inline void
4366 gimple_omp_task_set_arg_align (gimple gs, tree arg_align)
4367 {
4368   GIMPLE_CHECK (gs, GIMPLE_OMP_TASK);
4369   gs->gimple_omp_task.arg_align = arg_align;
4370 }
4371
4372
4373 /* Return the clauses associated with OMP_SINGLE GS.  */
4374
4375 static inline tree
4376 gimple_omp_single_clauses (const_gimple gs)
4377 {
4378   GIMPLE_CHECK (gs, GIMPLE_OMP_SINGLE);
4379   return gs->gimple_omp_single.clauses;
4380 }
4381
4382
4383 /* Return a pointer to the clauses associated with OMP_SINGLE GS.  */
4384
4385 static inline tree *
4386 gimple_omp_single_clauses_ptr (gimple gs)
4387 {
4388   GIMPLE_CHECK (gs, GIMPLE_OMP_SINGLE);
4389   return &gs->gimple_omp_single.clauses;
4390 }
4391
4392
4393 /* Set CLAUSES to be the clauses associated with OMP_SINGLE GS.  */
4394
4395 static inline void
4396 gimple_omp_single_set_clauses (gimple gs, tree clauses)
4397 {
4398   GIMPLE_CHECK (gs, GIMPLE_OMP_SINGLE);
4399   gs->gimple_omp_single.clauses = clauses;
4400 }
4401
4402
4403 /* Return the clauses associated with OMP_SECTIONS GS.  */
4404
4405 static inline tree
4406 gimple_omp_sections_clauses (const_gimple gs)
4407 {
4408   GIMPLE_CHECK (gs, GIMPLE_OMP_SECTIONS);
4409   return gs->gimple_omp_sections.clauses;
4410 }
4411
4412
4413 /* Return a pointer to the clauses associated with OMP_SECTIONS GS.  */
4414
4415 static inline tree *
4416 gimple_omp_sections_clauses_ptr (gimple gs)
4417 {
4418   GIMPLE_CHECK (gs, GIMPLE_OMP_SECTIONS);
4419   return &gs->gimple_omp_sections.clauses;
4420 }
4421
4422
4423 /* Set CLAUSES to be the set of clauses associated with OMP_SECTIONS
4424    GS.  */
4425
4426 static inline void
4427 gimple_omp_sections_set_clauses (gimple gs, tree clauses)
4428 {
4429   GIMPLE_CHECK (gs, GIMPLE_OMP_SECTIONS);
4430   gs->gimple_omp_sections.clauses = clauses;
4431 }
4432
4433
4434 /* Return the control variable associated with the GIMPLE_OMP_SECTIONS
4435    in GS.  */
4436
4437 static inline tree
4438 gimple_omp_sections_control (const_gimple gs)
4439 {
4440   GIMPLE_CHECK (gs, GIMPLE_OMP_SECTIONS);
4441   return gs->gimple_omp_sections.control;
4442 }
4443
4444
4445 /* Return a pointer to the clauses associated with the GIMPLE_OMP_SECTIONS
4446    GS.  */
4447
4448 static inline tree *
4449 gimple_omp_sections_control_ptr (gimple gs)
4450 {
4451   GIMPLE_CHECK (gs, GIMPLE_OMP_SECTIONS);
4452   return &gs->gimple_omp_sections.control;
4453 }
4454
4455
4456 /* Set CONTROL to be the set of clauses associated with the
4457    GIMPLE_OMP_SECTIONS in GS.  */
4458
4459 static inline void
4460 gimple_omp_sections_set_control (gimple gs, tree control)
4461 {
4462   GIMPLE_CHECK (gs, GIMPLE_OMP_SECTIONS);
4463   gs->gimple_omp_sections.control = control;
4464 }
4465
4466
4467 /* Set COND to be the condition code for OMP_FOR GS.  */
4468
4469 static inline void
4470 gimple_omp_for_set_cond (gimple gs, size_t i, enum tree_code cond)
4471 {
4472   GIMPLE_CHECK (gs, GIMPLE_OMP_FOR);
4473   gcc_gimple_checking_assert (TREE_CODE_CLASS (cond) == tcc_comparison
4474                               && i < gs->gimple_omp_for.collapse);
4475   gs->gimple_omp_for.iter[i].cond = cond;
4476 }
4477
4478
4479 /* Return the condition code associated with OMP_FOR GS.  */
4480
4481 static inline enum tree_code
4482 gimple_omp_for_cond (const_gimple gs, size_t i)
4483 {
4484   GIMPLE_CHECK (gs, GIMPLE_OMP_FOR);
4485   gcc_gimple_checking_assert (i < gs->gimple_omp_for.collapse);
4486   return gs->gimple_omp_for.iter[i].cond;
4487 }
4488
4489
4490 /* Set the value being stored in an atomic store.  */
4491
4492 static inline void
4493 gimple_omp_atomic_store_set_val (gimple g, tree val)
4494 {
4495   GIMPLE_CHECK (g, GIMPLE_OMP_ATOMIC_STORE);
4496   g->gimple_omp_atomic_store.val = val;
4497 }
4498
4499
4500 /* Return the value being stored in an atomic store.  */
4501
4502 static inline tree
4503 gimple_omp_atomic_store_val (const_gimple g)
4504 {
4505   GIMPLE_CHECK (g, GIMPLE_OMP_ATOMIC_STORE);
4506   return g->gimple_omp_atomic_store.val;
4507 }
4508
4509
4510 /* Return a pointer to the value being stored in an atomic store.  */
4511
4512 static inline tree *
4513 gimple_omp_atomic_store_val_ptr (gimple g)
4514 {
4515   GIMPLE_CHECK (g, GIMPLE_OMP_ATOMIC_STORE);
4516   return &g->gimple_omp_atomic_store.val;
4517 }
4518
4519
4520 /* Set the LHS of an atomic load.  */
4521
4522 static inline void
4523 gimple_omp_atomic_load_set_lhs (gimple g, tree lhs)
4524 {
4525   GIMPLE_CHECK (g, GIMPLE_OMP_ATOMIC_LOAD);
4526   g->gimple_omp_atomic_load.lhs = lhs;
4527 }
4528
4529
4530 /* Get the LHS of an atomic load.  */
4531
4532 static inline tree
4533 gimple_omp_atomic_load_lhs (const_gimple g)
4534 {
4535   GIMPLE_CHECK (g, GIMPLE_OMP_ATOMIC_LOAD);
4536   return g->gimple_omp_atomic_load.lhs;
4537 }
4538
4539
4540 /* Return a pointer to the LHS of an atomic load.  */
4541
4542 static inline tree *
4543 gimple_omp_atomic_load_lhs_ptr (gimple g)
4544 {
4545   GIMPLE_CHECK (g, GIMPLE_OMP_ATOMIC_LOAD);
4546   return &g->gimple_omp_atomic_load.lhs;
4547 }
4548
4549
4550 /* Set the RHS of an atomic load.  */
4551
4552 static inline void
4553 gimple_omp_atomic_load_set_rhs (gimple g, tree rhs)
4554 {
4555   GIMPLE_CHECK (g, GIMPLE_OMP_ATOMIC_LOAD);
4556   g->gimple_omp_atomic_load.rhs = rhs;
4557 }
4558
4559
4560 /* Get the RHS of an atomic load.  */
4561
4562 static inline tree
4563 gimple_omp_atomic_load_rhs (const_gimple g)
4564 {
4565   GIMPLE_CHECK (g, GIMPLE_OMP_ATOMIC_LOAD);
4566   return g->gimple_omp_atomic_load.rhs;
4567 }
4568
4569
4570 /* Return a pointer to the RHS of an atomic load.  */
4571
4572 static inline tree *
4573 gimple_omp_atomic_load_rhs_ptr (gimple g)
4574 {
4575   GIMPLE_CHECK (g, GIMPLE_OMP_ATOMIC_LOAD);
4576   return &g->gimple_omp_atomic_load.rhs;
4577 }
4578
4579
4580 /* Get the definition of the control variable in a GIMPLE_OMP_CONTINUE.  */
4581
4582 static inline tree
4583 gimple_omp_continue_control_def (const_gimple g)
4584 {
4585   GIMPLE_CHECK (g, GIMPLE_OMP_CONTINUE);
4586   return g->gimple_omp_continue.control_def;
4587 }
4588
4589 /* The same as above, but return the address.  */
4590
4591 static inline tree *
4592 gimple_omp_continue_control_def_ptr (gimple g)
4593 {
4594   GIMPLE_CHECK (g, GIMPLE_OMP_CONTINUE);
4595   return &g->gimple_omp_continue.control_def;
4596 }
4597
4598 /* Set the definition of the control variable in a GIMPLE_OMP_CONTINUE.  */
4599
4600 static inline void
4601 gimple_omp_continue_set_control_def (gimple g, tree def)
4602 {
4603   GIMPLE_CHECK (g, GIMPLE_OMP_CONTINUE);
4604   g->gimple_omp_continue.control_def = def;
4605 }
4606
4607
4608 /* Get the use of the control variable in a GIMPLE_OMP_CONTINUE.  */
4609
4610 static inline tree
4611 gimple_omp_continue_control_use (const_gimple g)
4612 {
4613   GIMPLE_CHECK (g, GIMPLE_OMP_CONTINUE);
4614   return g->gimple_omp_continue.control_use;
4615 }
4616
4617
4618 /* The same as above, but return the address.  */
4619
4620 static inline tree *
4621 gimple_omp_continue_control_use_ptr (gimple g)
4622 {
4623   GIMPLE_CHECK (g, GIMPLE_OMP_CONTINUE);
4624   return &g->gimple_omp_continue.control_use;
4625 }
4626
4627
4628 /* Set the use of the control variable in a GIMPLE_OMP_CONTINUE.  */
4629
4630 static inline void
4631 gimple_omp_continue_set_control_use (gimple g, tree use)
4632 {
4633   GIMPLE_CHECK (g, GIMPLE_OMP_CONTINUE);
4634   g->gimple_omp_continue.control_use = use;
4635 }
4636
4637 /* Return the body for the GIMPLE_TRANSACTION statement GS.  */
4638
4639 static inline gimple_seq
4640 gimple_transaction_body (gimple gs)
4641 {
4642   GIMPLE_CHECK (gs, GIMPLE_TRANSACTION);
4643   return gs->gimple_transaction.body;
4644 }
4645
4646 /* Return the label associated with a GIMPLE_TRANSACTION.  */
4647
4648 static inline tree
4649 gimple_transaction_label (const_gimple gs)
4650 {
4651   GIMPLE_CHECK (gs, GIMPLE_TRANSACTION);
4652   return gs->gimple_transaction.label;
4653 }
4654
4655 static inline tree *
4656 gimple_transaction_label_ptr (gimple gs)
4657 {
4658   GIMPLE_CHECK (gs, GIMPLE_TRANSACTION);
4659   return &gs->gimple_transaction.label;
4660 }
4661
4662 /* Return the subcode associated with a GIMPLE_TRANSACTION.  */
4663
4664 static inline unsigned int
4665 gimple_transaction_subcode (const_gimple gs)
4666 {
4667   GIMPLE_CHECK (gs, GIMPLE_TRANSACTION);
4668   return gs->gsbase.subcode;
4669 }
4670
4671 /* Set BODY to be the body for the GIMPLE_TRANSACTION statement GS.  */
4672
4673 static inline void
4674 gimple_transaction_set_body (gimple gs, gimple_seq body)
4675 {
4676   GIMPLE_CHECK (gs, GIMPLE_TRANSACTION);
4677   gs->gimple_transaction.body = body;
4678 }
4679
4680 /* Set the label associated with a GIMPLE_TRANSACTION.  */
4681
4682 static inline void
4683 gimple_transaction_set_label (gimple gs, tree label)
4684 {
4685   GIMPLE_CHECK (gs, GIMPLE_TRANSACTION);
4686   gs->gimple_transaction.label = label;
4687 }
4688
4689 /* Set the subcode associated with a GIMPLE_TRANSACTION.  */
4690
4691 static inline void
4692 gimple_transaction_set_subcode (gimple gs, unsigned int subcode)
4693 {
4694   GIMPLE_CHECK (gs, GIMPLE_TRANSACTION);
4695   gs->gsbase.subcode = subcode;
4696 }
4697
4698
4699 /* Return a pointer to the return value for GIMPLE_RETURN GS.  */
4700
4701 static inline tree *
4702 gimple_return_retval_ptr (const_gimple gs)
4703 {
4704   GIMPLE_CHECK (gs, GIMPLE_RETURN);
4705   return gimple_op_ptr (gs, 0);
4706 }
4707
4708 /* Return the return value for GIMPLE_RETURN GS.  */
4709
4710 static inline tree
4711 gimple_return_retval (const_gimple gs)
4712 {
4713   GIMPLE_CHECK (gs, GIMPLE_RETURN);
4714   return gimple_op (gs, 0);
4715 }
4716
4717
4718 /* Set RETVAL to be the return value for GIMPLE_RETURN GS.  */
4719
4720 static inline void
4721 gimple_return_set_retval (gimple gs, tree retval)
4722 {
4723   GIMPLE_CHECK (gs, GIMPLE_RETURN);
4724   gimple_set_op (gs, 0, retval);
4725 }
4726
4727
4728 /* Returns true when the gimple statment STMT is any of the OpenMP types.  */
4729
4730 #define CASE_GIMPLE_OMP                         \
4731     case GIMPLE_OMP_PARALLEL:                   \
4732     case GIMPLE_OMP_TASK:                       \
4733     case GIMPLE_OMP_FOR:                        \
4734     case GIMPLE_OMP_SECTIONS:                   \
4735     case GIMPLE_OMP_SECTIONS_SWITCH:            \
4736     case GIMPLE_OMP_SINGLE:                     \
4737     case GIMPLE_OMP_SECTION:                    \
4738     case GIMPLE_OMP_MASTER:                     \
4739     case GIMPLE_OMP_ORDERED:                    \
4740     case GIMPLE_OMP_CRITICAL:                   \
4741     case GIMPLE_OMP_RETURN:                     \
4742     case GIMPLE_OMP_ATOMIC_LOAD:                \
4743     case GIMPLE_OMP_ATOMIC_STORE:               \
4744     case GIMPLE_OMP_CONTINUE
4745
4746 static inline bool
4747 is_gimple_omp (const_gimple stmt)
4748 {
4749   switch (gimple_code (stmt))
4750     {
4751     CASE_GIMPLE_OMP:
4752       return true;
4753     default:
4754       return false;
4755     }
4756 }
4757
4758
4759 /* Returns TRUE if statement G is a GIMPLE_NOP.  */
4760
4761 static inline bool
4762 gimple_nop_p (const_gimple g)
4763 {
4764   return gimple_code (g) == GIMPLE_NOP;
4765 }
4766
4767
4768 /* Return true if GS is a GIMPLE_RESX.  */
4769
4770 static inline bool
4771 is_gimple_resx (const_gimple gs)
4772 {
4773   return gimple_code (gs) == GIMPLE_RESX;
4774 }
4775
4776 /* Return the predictor of GIMPLE_PREDICT statement GS.  */
4777
4778 static inline enum br_predictor
4779 gimple_predict_predictor (gimple gs)
4780 {
4781   GIMPLE_CHECK (gs, GIMPLE_PREDICT);
4782   return (enum br_predictor) (gs->gsbase.subcode & ~GF_PREDICT_TAKEN);
4783 }
4784
4785
4786 /* Set the predictor of GIMPLE_PREDICT statement GS to PREDICT.  */
4787
4788 static inline void
4789 gimple_predict_set_predictor (gimple gs, enum br_predictor predictor)
4790 {
4791   GIMPLE_CHECK (gs, GIMPLE_PREDICT);
4792   gs->gsbase.subcode = (gs->gsbase.subcode & GF_PREDICT_TAKEN)
4793                        | (unsigned) predictor;
4794 }
4795
4796
4797 /* Return the outcome of GIMPLE_PREDICT statement GS.  */
4798
4799 static inline enum prediction
4800 gimple_predict_outcome (gimple gs)
4801 {
4802   GIMPLE_CHECK (gs, GIMPLE_PREDICT);
4803   return (gs->gsbase.subcode & GF_PREDICT_TAKEN) ? TAKEN : NOT_TAKEN;
4804 }
4805
4806
4807 /* Set the outcome of GIMPLE_PREDICT statement GS to OUTCOME.  */
4808
4809 static inline void
4810 gimple_predict_set_outcome (gimple gs, enum prediction outcome)
4811 {
4812   GIMPLE_CHECK (gs, GIMPLE_PREDICT);
4813   if (outcome == TAKEN)
4814     gs->gsbase.subcode |= GF_PREDICT_TAKEN;
4815   else
4816     gs->gsbase.subcode &= ~GF_PREDICT_TAKEN;
4817 }
4818
4819
4820 /* Return the type of the main expression computed by STMT.  Return
4821    void_type_node if the statement computes nothing.  */
4822
4823 static inline tree
4824 gimple_expr_type (const_gimple stmt)
4825 {
4826   enum gimple_code code = gimple_code (stmt);
4827
4828   if (code == GIMPLE_ASSIGN || code == GIMPLE_CALL)
4829     {
4830       tree type;
4831       /* In general we want to pass out a type that can be substituted
4832          for both the RHS and the LHS types if there is a possibly
4833          useless conversion involved.  That means returning the
4834          original RHS type as far as we can reconstruct it.  */
4835       if (code == GIMPLE_CALL)
4836         type = gimple_call_return_type (stmt);
4837       else
4838         switch (gimple_assign_rhs_code (stmt))
4839           {
4840           case POINTER_PLUS_EXPR:
4841             type = TREE_TYPE (gimple_assign_rhs1 (stmt));
4842             break;
4843
4844           default:
4845             /* As fallback use the type of the LHS.  */
4846             type = TREE_TYPE (gimple_get_lhs (stmt));
4847             break;
4848           }
4849       return type;
4850     }
4851   else if (code == GIMPLE_COND)
4852     return boolean_type_node;
4853   else
4854     return void_type_node;
4855 }
4856
4857 /* Return true if TYPE is a suitable type for a scalar register variable.  */
4858
4859 static inline bool
4860 is_gimple_reg_type (tree type)
4861 {
4862   return !AGGREGATE_TYPE_P (type);
4863 }
4864
4865 /* Return a new iterator pointing to GIMPLE_SEQ's first statement.  */
4866
4867 static inline gimple_stmt_iterator
4868 gsi_start (gimple_seq seq)
4869 {
4870   gimple_stmt_iterator i;
4871
4872   i.ptr = gimple_seq_first (seq);
4873   i.seq = seq;
4874   i.bb = (i.ptr && i.ptr->stmt) ? gimple_bb (i.ptr->stmt) : NULL;
4875
4876   return i;
4877 }
4878
4879
4880 /* Return a new iterator pointing to the first statement in basic block BB.  */
4881
4882 static inline gimple_stmt_iterator
4883 gsi_start_bb (basic_block bb)
4884 {
4885   gimple_stmt_iterator i;
4886   gimple_seq seq;
4887
4888   seq = bb_seq (bb);
4889   i.ptr = gimple_seq_first (seq);
4890   i.seq = seq;
4891   i.bb = bb;
4892
4893   return i;
4894 }
4895
4896
4897 /* Return a new iterator initially pointing to GIMPLE_SEQ's last statement.  */
4898
4899 static inline gimple_stmt_iterator
4900 gsi_last (gimple_seq seq)
4901 {
4902   gimple_stmt_iterator i;
4903
4904   i.ptr = gimple_seq_last (seq);
4905   i.seq = seq;
4906   i.bb = (i.ptr && i.ptr->stmt) ? gimple_bb (i.ptr->stmt) : NULL;
4907
4908   return i;
4909 }
4910
4911
4912 /* Return a new iterator pointing to the last statement in basic block BB.  */
4913
4914 static inline gimple_stmt_iterator
4915 gsi_last_bb (basic_block bb)
4916 {
4917   gimple_stmt_iterator i;
4918   gimple_seq seq;
4919
4920   seq = bb_seq (bb);
4921   i.ptr = gimple_seq_last (seq);
4922   i.seq = seq;
4923   i.bb = bb;
4924
4925   return i;
4926 }
4927
4928
4929 /* Return true if I is at the end of its sequence.  */
4930
4931 static inline bool
4932 gsi_end_p (gimple_stmt_iterator i)
4933 {
4934   return i.ptr == NULL;
4935 }
4936
4937
4938 /* Return true if I is one statement before the end of its sequence.  */
4939
4940 static inline bool
4941 gsi_one_before_end_p (gimple_stmt_iterator i)
4942 {
4943   return i.ptr != NULL && i.ptr->next == NULL;
4944 }
4945
4946
4947 /* Advance the iterator to the next gimple statement.  */
4948
4949 static inline void
4950 gsi_next (gimple_stmt_iterator *i)
4951 {
4952   i->ptr = i->ptr->next;
4953 }
4954
4955 /* Advance the iterator to the previous gimple statement.  */
4956
4957 static inline void
4958 gsi_prev (gimple_stmt_iterator *i)
4959 {
4960   i->ptr = i->ptr->prev;
4961 }
4962
4963 /* Return the current stmt.  */
4964
4965 static inline gimple
4966 gsi_stmt (gimple_stmt_iterator i)
4967 {
4968   return i.ptr->stmt;
4969 }
4970
4971 /* Return a block statement iterator that points to the first non-label
4972    statement in block BB.  */
4973
4974 static inline gimple_stmt_iterator
4975 gsi_after_labels (basic_block bb)
4976 {
4977   gimple_stmt_iterator gsi = gsi_start_bb (bb);
4978
4979   while (!gsi_end_p (gsi) && gimple_code (gsi_stmt (gsi)) == GIMPLE_LABEL)
4980     gsi_next (&gsi);
4981
4982   return gsi;
4983 }
4984
4985 /* Advance the iterator to the next non-debug gimple statement.  */
4986
4987 static inline void
4988 gsi_next_nondebug (gimple_stmt_iterator *i)
4989 {
4990   do
4991     {
4992       gsi_next (i);
4993     }
4994   while (!gsi_end_p (*i) && is_gimple_debug (gsi_stmt (*i)));
4995 }
4996
4997 /* Advance the iterator to the next non-debug gimple statement.  */
4998
4999 static inline void
5000 gsi_prev_nondebug (gimple_stmt_iterator *i)
5001 {
5002   do
5003     {
5004       gsi_prev (i);
5005     }
5006   while (!gsi_end_p (*i) && is_gimple_debug (gsi_stmt (*i)));
5007 }
5008
5009 /* Return a new iterator pointing to the first non-debug statement in
5010    basic block BB.  */
5011
5012 static inline gimple_stmt_iterator
5013 gsi_start_nondebug_bb (basic_block bb)
5014 {
5015   gimple_stmt_iterator i = gsi_start_bb (bb);
5016
5017   if (!gsi_end_p (i) && is_gimple_debug (gsi_stmt (i)))
5018     gsi_next_nondebug (&i);
5019
5020   return i;
5021 }
5022
5023 /* Return a new iterator pointing to the last non-debug statement in
5024    basic block BB.  */
5025
5026 static inline gimple_stmt_iterator
5027 gsi_last_nondebug_bb (basic_block bb)
5028 {
5029   gimple_stmt_iterator i = gsi_last_bb (bb);
5030
5031   if (!gsi_end_p (i) && is_gimple_debug (gsi_stmt (i)))
5032     gsi_prev_nondebug (&i);
5033
5034   return i;
5035 }
5036
5037 /* Return a pointer to the current stmt.
5038
5039   NOTE: You may want to use gsi_replace on the iterator itself,
5040   as this performs additional bookkeeping that will not be done
5041   if you simply assign through a pointer returned by gsi_stmt_ptr.  */
5042
5043 static inline gimple *
5044 gsi_stmt_ptr (gimple_stmt_iterator *i)
5045 {
5046   return &i->ptr->stmt;
5047 }
5048
5049
5050 /* Return the basic block associated with this iterator.  */
5051
5052 static inline basic_block
5053 gsi_bb (gimple_stmt_iterator i)
5054 {
5055   return i.bb;
5056 }
5057
5058
5059 /* Return the sequence associated with this iterator.  */
5060
5061 static inline gimple_seq
5062 gsi_seq (gimple_stmt_iterator i)
5063 {
5064   return i.seq;
5065 }
5066
5067
5068 enum gsi_iterator_update
5069 {
5070   GSI_NEW_STMT,         /* Only valid when single statement is added, move
5071                            iterator to it.  */
5072   GSI_SAME_STMT,        /* Leave the iterator at the same statement.  */
5073   GSI_CONTINUE_LINKING  /* Move iterator to whatever position is suitable
5074                            for linking other statements in the same
5075                            direction.  */
5076 };
5077
5078 /* In gimple-iterator.c  */
5079 gimple_stmt_iterator gsi_start_phis (basic_block);
5080 gimple_seq gsi_split_seq_after (gimple_stmt_iterator);
5081 gimple_seq gsi_split_seq_before (gimple_stmt_iterator *);
5082 void gsi_replace (gimple_stmt_iterator *, gimple, bool);
5083 void gsi_insert_before (gimple_stmt_iterator *, gimple,
5084                         enum gsi_iterator_update);
5085 void gsi_insert_before_without_update (gimple_stmt_iterator *, gimple,
5086                                        enum gsi_iterator_update);
5087 void gsi_insert_seq_before (gimple_stmt_iterator *, gimple_seq,
5088                             enum gsi_iterator_update);
5089 void gsi_insert_seq_before_without_update (gimple_stmt_iterator *, gimple_seq,
5090                                            enum gsi_iterator_update);
5091 void gsi_insert_after (gimple_stmt_iterator *, gimple,
5092                        enum gsi_iterator_update);
5093 void gsi_insert_after_without_update (gimple_stmt_iterator *, gimple,
5094                                       enum gsi_iterator_update);
5095 void gsi_insert_seq_after (gimple_stmt_iterator *, gimple_seq,
5096                            enum gsi_iterator_update);
5097 void gsi_insert_seq_after_without_update (gimple_stmt_iterator *, gimple_seq,
5098                                           enum gsi_iterator_update);
5099 void gsi_remove (gimple_stmt_iterator *, bool);
5100 gimple_stmt_iterator gsi_for_stmt (gimple);
5101 void gsi_move_after (gimple_stmt_iterator *, gimple_stmt_iterator *);
5102 void gsi_move_before (gimple_stmt_iterator *, gimple_stmt_iterator *);
5103 void gsi_move_to_bb_end (gimple_stmt_iterator *, struct basic_block_def *);
5104 void gsi_insert_on_edge (edge, gimple);
5105 void gsi_insert_seq_on_edge (edge, gimple_seq);
5106 basic_block gsi_insert_on_edge_immediate (edge, gimple);
5107 basic_block gsi_insert_seq_on_edge_immediate (edge, gimple_seq);
5108 void gsi_commit_one_edge_insert (edge, basic_block *);
5109 void gsi_commit_edge_inserts (void);
5110 gimple gimple_call_copy_skip_args (gimple, bitmap);
5111
5112
5113 /* Convenience routines to walk all statements of a gimple function.
5114    Note that this is useful exclusively before the code is converted
5115    into SSA form.  Once the program is in SSA form, the standard
5116    operand interface should be used to analyze/modify statements.  */
5117 struct walk_stmt_info
5118 {
5119   /* Points to the current statement being walked.  */
5120   gimple_stmt_iterator gsi;
5121
5122   /* Additional data that the callback functions may want to carry
5123      through the recursion.  */
5124   void *info;
5125
5126   /* Pointer map used to mark visited tree nodes when calling
5127      walk_tree on each operand.  If set to NULL, duplicate tree nodes
5128      will be visited more than once.  */
5129   struct pointer_set_t *pset;
5130
5131   /* Operand returned by the callbacks.  This is set when calling
5132      walk_gimple_seq.  If the walk_stmt_fn or walk_tree_fn callback
5133      returns non-NULL, this field will contain the tree returned by
5134      the last callback.  */
5135   tree callback_result;
5136
5137   /* Indicates whether the operand being examined may be replaced
5138      with something that matches is_gimple_val (if true) or something
5139      slightly more complicated (if false).  "Something" technically
5140      means the common subset of is_gimple_lvalue and is_gimple_rhs,
5141      but we never try to form anything more complicated than that, so
5142      we don't bother checking.
5143
5144      Also note that CALLBACK should update this flag while walking the
5145      sub-expressions of a statement.  For instance, when walking the
5146      statement 'foo (&var)', the flag VAL_ONLY will initially be set
5147      to true, however, when walking &var, the operand of that
5148      ADDR_EXPR does not need to be a GIMPLE value.  */
5149   BOOL_BITFIELD val_only : 1;
5150
5151   /* True if we are currently walking the LHS of an assignment.  */
5152   BOOL_BITFIELD is_lhs : 1;
5153
5154   /* Optional.  Set to true by the callback functions if they made any
5155      changes.  */
5156   BOOL_BITFIELD changed : 1;
5157
5158   /* True if we're interested in location information.  */
5159   BOOL_BITFIELD want_locations : 1;
5160
5161   /* True if we've removed the statement that was processed.  */
5162   BOOL_BITFIELD removed_stmt : 1;
5163 };
5164
5165 /* Callback for walk_gimple_stmt.  Called for every statement found
5166    during traversal.  The first argument points to the statement to
5167    walk.  The second argument is a flag that the callback sets to
5168    'true' if it the callback handled all the operands and
5169    sub-statements of the statement (the default value of this flag is
5170    'false').  The third argument is an anonymous pointer to data
5171    to be used by the callback.  */
5172 typedef tree (*walk_stmt_fn) (gimple_stmt_iterator *, bool *,
5173                               struct walk_stmt_info *);
5174
5175 gimple walk_gimple_seq (gimple_seq, walk_stmt_fn, walk_tree_fn,
5176                         struct walk_stmt_info *);
5177 tree walk_gimple_stmt (gimple_stmt_iterator *, walk_stmt_fn, walk_tree_fn,
5178                        struct walk_stmt_info *);
5179 tree walk_gimple_op (gimple, walk_tree_fn, struct walk_stmt_info *);
5180
5181 #ifdef GATHER_STATISTICS
5182 /* Enum and arrays used for allocation stats.  Keep in sync with
5183    gimple.c:gimple_alloc_kind_names.  */
5184 enum gimple_alloc_kind
5185 {
5186   gimple_alloc_kind_assign,     /* Assignments.  */
5187   gimple_alloc_kind_phi,        /* PHI nodes.  */
5188   gimple_alloc_kind_cond,       /* Conditionals.  */
5189   gimple_alloc_kind_seq,        /* Sequences.  */
5190   gimple_alloc_kind_rest,       /* Everything else.  */
5191   gimple_alloc_kind_all
5192 };
5193
5194 extern int gimple_alloc_counts[];
5195 extern int gimple_alloc_sizes[];
5196
5197 /* Return the allocation kind for a given stmt CODE.  */
5198 static inline enum gimple_alloc_kind
5199 gimple_alloc_kind (enum gimple_code code)
5200 {
5201   switch (code)
5202     {
5203       case GIMPLE_ASSIGN:
5204         return gimple_alloc_kind_assign;
5205       case GIMPLE_PHI:
5206         return gimple_alloc_kind_phi;
5207       case GIMPLE_COND:
5208         return gimple_alloc_kind_cond;
5209       default:
5210         return gimple_alloc_kind_rest;
5211     }
5212 }
5213 #endif /* GATHER_STATISTICS */
5214
5215 extern void dump_gimple_statistics (void);
5216
5217 /* In gimple-fold.c.  */
5218 void gimplify_and_update_call_from_tree (gimple_stmt_iterator *, tree);
5219 tree gimple_fold_builtin (gimple);
5220 bool fold_stmt (gimple_stmt_iterator *);
5221 bool fold_stmt_inplace (gimple_stmt_iterator *);
5222 tree get_symbol_constant_value (tree);
5223 tree canonicalize_constructor_val (tree);
5224 extern tree maybe_fold_and_comparisons (enum tree_code, tree, tree, 
5225                                         enum tree_code, tree, tree);
5226 extern tree maybe_fold_or_comparisons (enum tree_code, tree, tree,
5227                                        enum tree_code, tree, tree);
5228
5229 bool gimple_val_nonnegative_real_p (tree);
5230 #endif  /* GCC_GIMPLE_H */