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