LCOV - code coverage report
Current view: top level - gcc - tree.h (source / functions) Coverage Total Hit
Test: gcc.info Lines: 91.5 % 647 592
Test Date: 2024-12-21 13:15:12 Functions: 97.1 % 138 134
Legend: Lines: hit not hit | Branches: + taken - not taken # not executed Branches: - 0 0

             Branch data     Line data    Source code
       1                 :             : /* Definitions for the ubiquitous 'tree' type for GNU compilers.
       2                 :             :    Copyright (C) 1989-2024 Free Software Foundation, Inc.
       3                 :             : 
       4                 :             : This file is part of GCC.
       5                 :             : 
       6                 :             : GCC is free software; you can redistribute it and/or modify it under
       7                 :             : the terms of the GNU General Public License as published by the Free
       8                 :             : Software Foundation; either version 3, or (at your option) any later
       9                 :             : version.
      10                 :             : 
      11                 :             : GCC is distributed in the hope that it will be useful, but WITHOUT ANY
      12                 :             : WARRANTY; without even the implied warranty of MERCHANTABILITY or
      13                 :             : FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
      14                 :             : for more details.
      15                 :             : 
      16                 :             : You should have received a copy of the GNU General Public License
      17                 :             : along with GCC; see the file COPYING3.  If not see
      18                 :             : <http://www.gnu.org/licenses/>.  */
      19                 :             : 
      20                 :             : #ifndef GCC_TREE_H
      21                 :             : #define GCC_TREE_H
      22                 :             : 
      23                 :             : #include "tree-core.h"
      24                 :             : #include "options.h"
      25                 :             : 
      26                 :             : /* Convert a target-independent built-in function code to a combined_fn.  */
      27                 :             : 
      28                 :             : inline combined_fn
      29                 :             : as_combined_fn (built_in_function fn)
      30                 :             : {
      31                 :             :   return combined_fn (int (fn));
      32                 :             : }
      33                 :             : 
      34                 :             : /* Convert an internal function code to a combined_fn.  */
      35                 :             : 
      36                 :             : inline combined_fn
      37                 :    64911893 : as_combined_fn (internal_fn fn)
      38                 :             : {
      39                 :    64713897 :   return combined_fn (int (fn) + int (END_BUILTINS));
      40                 :             : }
      41                 :             : 
      42                 :             : /* Return true if CODE is a target-independent built-in function.  */
      43                 :             : 
      44                 :             : inline bool
      45                 :        4129 : builtin_fn_p (combined_fn code)
      46                 :             : {
      47                 :        4129 :   return int (code) < int (END_BUILTINS);
      48                 :             : }
      49                 :             : 
      50                 :             : /* Return the target-independent built-in function represented by CODE.
      51                 :             :    Only valid if builtin_fn_p (CODE).  */
      52                 :             : 
      53                 :             : inline built_in_function
      54                 :             : as_builtin_fn (combined_fn code)
      55                 :             : {
      56                 :    13366680 :   gcc_checking_assert (builtin_fn_p (code));
      57                 :             :   return built_in_function (int (code));
      58                 :             : }
      59                 :             : 
      60                 :             : /* Return true if CODE is an internal function.  */
      61                 :             : 
      62                 :             : inline bool
      63                 :    51412653 : internal_fn_p (combined_fn code)
      64                 :             : {
      65                 :    33638979 :   return int (code) >= int (END_BUILTINS);
      66                 :             : }
      67                 :             : 
      68                 :             : /* Return the internal function represented by CODE.  Only valid if
      69                 :             :    internal_fn_p (CODE).  */
      70                 :             : 
      71                 :             : inline internal_fn
      72                 :    20315255 : as_internal_fn (combined_fn code)
      73                 :             : {
      74                 :    20322422 :   gcc_checking_assert (internal_fn_p (code));
      75                 :    20315255 :   return internal_fn (int (code) - int (END_BUILTINS));
      76                 :             : }
      77                 :             : 
      78                 :             : /* Helper to transparently allow tree codes and builtin function codes
      79                 :             :    exist in one storage entity.  */
      80                 :             : class code_helper
      81                 :             : {
      82                 :             : public:
      83                 :  1308801296 :   code_helper () {}
      84                 :  3084665034 :   code_helper (tree_code code) : rep ((int) code) {}
      85                 :    33359718 :   code_helper (combined_fn fn) : rep (-(int) fn) {}
      86                 :    55468909 :   code_helper (internal_fn fn) : rep (-(int) as_combined_fn (fn)) {}
      87                 :   286356285 :   explicit operator tree_code () const { return (tree_code) rep; }
      88                 :    11413445 :   explicit operator combined_fn () const { return (combined_fn) -rep; }
      89                 :             :   explicit operator internal_fn () const;
      90                 :             :   explicit operator built_in_function () const;
      91                 :   826653314 :   bool is_tree_code () const { return rep > 0; }
      92                 :     1849182 :   bool is_fn_code () const { return rep < 0; }
      93                 :             :   bool is_internal_fn () const;
      94                 :             :   bool is_builtin_fn () const;
      95                 :   616508374 :   int get_rep () const { return rep; }
      96                 :             :   tree_code safe_as_tree_code () const;
      97                 :             :   combined_fn safe_as_fn_code () const;
      98                 :             :   bool operator== (const code_helper &other) { return rep == other.rep; }
      99                 :    83619594 :   bool operator!= (const code_helper &other) { return rep != other.rep; }
     100                 :    72487109 :   bool operator== (tree_code c) { return rep == code_helper (c).rep; }
     101                 :   103951768 :   bool operator!= (tree_code c) { return rep != code_helper (c).rep; }
     102                 :             : 
     103                 :             : private:
     104                 :             :   int rep;
     105                 :             : };
     106                 :             : 
     107                 :             : /* Helper function that returns the tree_code representation of THIS
     108                 :             :    code_helper if it is a tree_code and MAX_TREE_CODES otherwise.  This is
     109                 :             :    useful when passing a code_helper to a tree_code only check.  */
     110                 :             : 
     111                 :             : inline tree_code
     112                 :      902379 : code_helper::safe_as_tree_code () const
     113                 :             : {
     114                 :     1097130 :   return is_tree_code () ? (tree_code) *this : MAX_TREE_CODES;
     115                 :             : }
     116                 :             : 
     117                 :             : /* Helper function that returns the combined_fn representation of THIS
     118                 :             :    code_helper if it is a fn_code and CFN_LAST otherwise.  This is useful when
     119                 :             :    passing a code_helper to a combined_fn only check.  */
     120                 :             : 
     121                 :             : inline combined_fn
     122                 :             : code_helper::safe_as_fn_code () const {
     123                 :             :   return is_fn_code () ? (combined_fn) *this : CFN_LAST;
     124                 :             : }
     125                 :             : 
     126                 :     2359044 : inline code_helper::operator internal_fn () const
     127                 :             : {
     128                 :     2359044 :   return as_internal_fn (combined_fn (*this));
     129                 :             : }
     130                 :             : 
     131                 :             : inline code_helper::operator built_in_function () const
     132                 :             : {
     133                 :             :   return as_builtin_fn (combined_fn (*this));
     134                 :             : }
     135                 :             : 
     136                 :             : inline bool
     137                 :   587652529 : code_helper::is_internal_fn () const
     138                 :             : {
     139                 :   587649477 :   return is_fn_code () && internal_fn_p (combined_fn (*this));
     140                 :             : }
     141                 :             : 
     142                 :             : inline bool
     143                 :             : code_helper::is_builtin_fn () const
     144                 :             : {
     145                 :             :   return is_fn_code () && builtin_fn_p (combined_fn (*this));
     146                 :             : }
     147                 :             : 
     148                 :             : /* Macros for initializing `tree_contains_struct'.  */
     149                 :             : #define MARK_TS_BASE(C)                                 \
     150                 :             :   (tree_contains_struct[C][TS_BASE] = true)
     151                 :             : 
     152                 :             : #define MARK_TS_TYPED(C)                                \
     153                 :             :   (MARK_TS_BASE (C),                                    \
     154                 :             :    tree_contains_struct[C][TS_TYPED] = true)
     155                 :             : 
     156                 :             : #define MARK_TS_COMMON(C)                               \
     157                 :             :   (MARK_TS_TYPED (C),                                   \
     158                 :             :    tree_contains_struct[C][TS_COMMON] = true)
     159                 :             : 
     160                 :             : #define MARK_TS_TYPE_COMMON(C)                          \
     161                 :             :   (MARK_TS_COMMON (C),                                  \
     162                 :             :    tree_contains_struct[C][TS_TYPE_COMMON] = true)
     163                 :             : 
     164                 :             : #define MARK_TS_TYPE_WITH_LANG_SPECIFIC(C)              \
     165                 :             :   (MARK_TS_TYPE_COMMON (C),                             \
     166                 :             :    tree_contains_struct[C][TS_TYPE_WITH_LANG_SPECIFIC] = true)
     167                 :             : 
     168                 :             : #define MARK_TS_TYPE_NON_COMMON(C)                      \
     169                 :             :   (MARK_TS_TYPE_WITH_LANG_SPECIFIC (C),                 \
     170                 :             :    tree_contains_struct[C][TS_TYPE_NON_COMMON] = true)  \
     171                 :             : 
     172                 :             : #define MARK_TS_DECL_MINIMAL(C)                         \
     173                 :             :   (MARK_TS_COMMON (C),                                  \
     174                 :             :    tree_contains_struct[C][TS_DECL_MINIMAL] = true)
     175                 :             : 
     176                 :             : #define MARK_TS_DECL_COMMON(C)                          \
     177                 :             :   (MARK_TS_DECL_MINIMAL (C),                            \
     178                 :             :    tree_contains_struct[C][TS_DECL_COMMON] = true)
     179                 :             : 
     180                 :             : #define MARK_TS_DECL_WRTL(C)                            \
     181                 :             :   (MARK_TS_DECL_COMMON (C),                             \
     182                 :             :    tree_contains_struct[C][TS_DECL_WRTL] = true)
     183                 :             : 
     184                 :             : #define MARK_TS_DECL_WITH_VIS(C)                        \
     185                 :             :   (MARK_TS_DECL_WRTL (C),                               \
     186                 :             :    tree_contains_struct[C][TS_DECL_WITH_VIS] = true)
     187                 :             : 
     188                 :             : #define MARK_TS_DECL_NON_COMMON(C)                      \
     189                 :             :   (MARK_TS_DECL_WITH_VIS (C),                           \
     190                 :             :    tree_contains_struct[C][TS_DECL_NON_COMMON] = true)
     191                 :             : 
     192                 :             : #define MARK_TS_EXP(C)                                  \
     193                 :             :   (MARK_TS_TYPED (C),                                   \
     194                 :             :    tree_contains_struct[C][TS_EXP] = true)
     195                 :             : 
     196                 :             : /* Returns the string representing CLASS.  */
     197                 :             : 
     198                 :             : #define TREE_CODE_CLASS_STRING(CLASS)\
     199                 :             :         tree_code_class_strings[(int) (CLASS)]
     200                 :             : 
     201                 :             : #if __cpp_inline_variables < 201606L
     202                 :             : #define TREE_CODE_CLASS(CODE)   \
     203                 :             :   tree_code_type_tmpl <0>::tree_code_type[(int) (CODE)]
     204                 :             : #else
     205                 :             : #define TREE_CODE_CLASS(CODE)   tree_code_type[(int) (CODE)]
     206                 :             : #endif
     207                 :             : 
     208                 :             : /* Nonzero if NODE represents an exceptional code.  */
     209                 :             : 
     210                 :             : #define EXCEPTIONAL_CLASS_P(NODE)\
     211                 :             :         (TREE_CODE_CLASS (TREE_CODE (NODE)) == tcc_exceptional)
     212                 :             : 
     213                 :             : /* Nonzero if NODE represents a constant.  */
     214                 :             : 
     215                 :             : #define CONSTANT_CLASS_P(NODE)\
     216                 :             :         (TREE_CODE_CLASS (TREE_CODE (NODE)) == tcc_constant)
     217                 :             : 
     218                 :             : /* Nonzero if NODE represents a constant, or is a location wrapper
     219                 :             :    around such a node.  */
     220                 :             : 
     221                 :             : #define CONSTANT_CLASS_OR_WRAPPER_P(NODE)\
     222                 :             :         (CONSTANT_CLASS_P (tree_strip_any_location_wrapper (NODE)))
     223                 :             : 
     224                 :             : /* Nonzero if NODE represents a type.  */
     225                 :             : 
     226                 :             : #define TYPE_P(NODE)\
     227                 :             :         (TREE_CODE_CLASS (TREE_CODE (NODE)) == tcc_type)
     228                 :             : 
     229                 :             : /* Nonzero if NODE represents a declaration.  */
     230                 :             : 
     231                 :             : #define DECL_P(NODE)\
     232                 :             :         (TREE_CODE_CLASS (TREE_CODE (NODE)) == tcc_declaration)
     233                 :             : 
     234                 :             : /* True if NODE designates a variable declaration.  */
     235                 :             : #define VAR_P(NODE) \
     236                 :             :   (TREE_CODE (NODE) == VAR_DECL)
     237                 :             : 
     238                 :             : /* Nonzero if DECL represents a VAR_DECL or FUNCTION_DECL.  */
     239                 :             : 
     240                 :             : #define VAR_OR_FUNCTION_DECL_P(DECL)\
     241                 :             :   (TREE_CODE (DECL) == VAR_DECL || TREE_CODE (DECL) == FUNCTION_DECL)
     242                 :             : 
     243                 :             : /* Nonzero if NODE represents a INDIRECT_REF.  Keep these checks in
     244                 :             :    ascending code order.  */
     245                 :             : 
     246                 :             : #define INDIRECT_REF_P(NODE)\
     247                 :             :   (TREE_CODE (NODE) == INDIRECT_REF)
     248                 :             : 
     249                 :             : /* Nonzero if NODE represents a reference.  */
     250                 :             : 
     251                 :             : #define REFERENCE_CLASS_P(NODE)\
     252                 :             :         (TREE_CODE_CLASS (TREE_CODE (NODE)) == tcc_reference)
     253                 :             : 
     254                 :             : /* Nonzero if NODE represents a comparison.  */
     255                 :             : 
     256                 :             : #define COMPARISON_CLASS_P(NODE)\
     257                 :             :         (TREE_CODE_CLASS (TREE_CODE (NODE)) == tcc_comparison)
     258                 :             : 
     259                 :             : /* Nonzero if NODE represents a unary arithmetic expression.  */
     260                 :             : 
     261                 :             : #define UNARY_CLASS_P(NODE)\
     262                 :             :         (TREE_CODE_CLASS (TREE_CODE (NODE)) == tcc_unary)
     263                 :             : 
     264                 :             : /* Nonzero if NODE represents a binary arithmetic expression.  */
     265                 :             : 
     266                 :             : #define BINARY_CLASS_P(NODE)\
     267                 :             :         (TREE_CODE_CLASS (TREE_CODE (NODE)) == tcc_binary)
     268                 :             : 
     269                 :             : /* Nonzero if NODE represents a statement expression.  */
     270                 :             : 
     271                 :             : #define STATEMENT_CLASS_P(NODE)\
     272                 :             :         (TREE_CODE_CLASS (TREE_CODE (NODE)) == tcc_statement)
     273                 :             : 
     274                 :             : /* Nonzero if NODE represents a function call-like expression with a
     275                 :             :    variable-length operand vector.  */
     276                 :             : 
     277                 :             : #define VL_EXP_CLASS_P(NODE)\
     278                 :             :         (TREE_CODE_CLASS (TREE_CODE (NODE)) == tcc_vl_exp)
     279                 :             : 
     280                 :             : /* Nonzero if NODE represents any other expression.  */
     281                 :             : 
     282                 :             : #define EXPRESSION_CLASS_P(NODE)\
     283                 :             :         (TREE_CODE_CLASS (TREE_CODE (NODE)) == tcc_expression)
     284                 :             : 
     285                 :             : /* Returns nonzero iff NODE represents a type or declaration.  */
     286                 :             : 
     287                 :             : #define IS_TYPE_OR_DECL_P(NODE)\
     288                 :             :         (TYPE_P (NODE) || DECL_P (NODE))
     289                 :             : 
     290                 :             : /* Returns nonzero iff CLASS is the tree-code class of an
     291                 :             :    expression.  */
     292                 :             : 
     293                 :             : #define IS_EXPR_CODE_CLASS(CLASS)\
     294                 :             :         ((CLASS) >= tcc_reference && (CLASS) <= tcc_expression)
     295                 :             : 
     296                 :             : /* Returns nonzero iff NODE is an expression of some kind.  */
     297                 :             : 
     298                 :             : #define EXPR_P(NODE) IS_EXPR_CODE_CLASS (TREE_CODE_CLASS (TREE_CODE (NODE)))
     299                 :             : 
     300                 :             : #if __cpp_inline_variables < 201606L
     301                 :             : #define TREE_CODE_LENGTH(CODE)  \
     302                 :             :   tree_code_length_tmpl <0>::tree_code_length[(int) (CODE)]
     303                 :             : #else
     304                 :             : #define TREE_CODE_LENGTH(CODE)  tree_code_length[(int) (CODE)]
     305                 :             : #endif
     306                 :             : 
     307                 :             : 
     308                 :             : /* Helper macros for math builtins.  */
     309                 :             : 
     310                 :             : #define CASE_FLT_FN(FN) case FN: case FN##F: case FN##L
     311                 :             : #define CASE_FLT_FN_FLOATN_NX(FN)                          \
     312                 :             :   case FN##F16: case FN##F32: case FN##F64: case FN##F128: \
     313                 :             :   case FN##F32X: case FN##F64X: case FN##F128X
     314                 :             : #define CASE_FLT_FN_REENT(FN) case FN##_R: case FN##F_R: case FN##L_R
     315                 :             : #define CASE_INT_FN(FN) case FN: case FN##L: case FN##LL: case FN##IMAX
     316                 :             : 
     317                 :             : #define NULL_TREE (tree) NULL
     318                 :             : 
     319                 :             : /* Define accessors for the fields that all tree nodes have
     320                 :             :    (though some fields are not used for all kinds of nodes).  */
     321                 :             : 
     322                 :             : /* The tree-code says what kind of node it is.
     323                 :             :    Codes are defined in tree.def.  */
     324                 :             : #define TREE_CODE(NODE) ((enum tree_code) (NODE)->base.code)
     325                 :             : #define TREE_SET_CODE(NODE, VALUE) ((NODE)->base.code = (VALUE))
     326                 :             : 
     327                 :             : /* When checking is enabled, errors will be generated if a tree node
     328                 :             :    is accessed incorrectly. The macros die with a fatal error.  */
     329                 :             : #if defined ENABLE_TREE_CHECKING && (GCC_VERSION >= 2007)
     330                 :             : 
     331                 :             : #define TREE_CHECK(T, CODE) \
     332                 :             : (tree_check ((T), __FILE__, __LINE__, __FUNCTION__, (CODE)))
     333                 :             : 
     334                 :             : #define TREE_NOT_CHECK(T, CODE) \
     335                 :             : (tree_not_check ((T), __FILE__, __LINE__, __FUNCTION__, (CODE)))
     336                 :             : 
     337                 :             : #define TREE_CHECK2(T, CODE1, CODE2) \
     338                 :             : (tree_check2 ((T), __FILE__, __LINE__, __FUNCTION__, (CODE1), (CODE2)))
     339                 :             : 
     340                 :             : #define TREE_NOT_CHECK2(T, CODE1, CODE2) \
     341                 :             : (tree_not_check2 ((T), __FILE__, __LINE__, __FUNCTION__, (CODE1), (CODE2)))
     342                 :             : 
     343                 :             : #define TREE_CHECK3(T, CODE1, CODE2, CODE3) \
     344                 :             : (tree_check3 ((T), __FILE__, __LINE__, __FUNCTION__, (CODE1), (CODE2), (CODE3)))
     345                 :             : 
     346                 :             : #define TREE_NOT_CHECK3(T, CODE1, CODE2, CODE3) \
     347                 :             : (tree_not_check3 ((T), __FILE__, __LINE__, __FUNCTION__, \
     348                 :             :                                (CODE1), (CODE2), (CODE3)))
     349                 :             : 
     350                 :             : #define TREE_CHECK4(T, CODE1, CODE2, CODE3, CODE4) \
     351                 :             : (tree_check4 ((T), __FILE__, __LINE__, __FUNCTION__, \
     352                 :             :                            (CODE1), (CODE2), (CODE3), (CODE4)))
     353                 :             : 
     354                 :             : #define TREE_NOT_CHECK4(T, CODE1, CODE2, CODE3, CODE4) \
     355                 :             : (tree_not_check4 ((T), __FILE__, __LINE__, __FUNCTION__, \
     356                 :             :                                (CODE1), (CODE2), (CODE3), (CODE4)))
     357                 :             : 
     358                 :             : #define TREE_CHECK5(T, CODE1, CODE2, CODE3, CODE4, CODE5) \
     359                 :             : (tree_check5 ((T), __FILE__, __LINE__, __FUNCTION__, \
     360                 :             :                            (CODE1), (CODE2), (CODE3), (CODE4), (CODE5)))
     361                 :             : 
     362                 :             : #define TREE_NOT_CHECK5(T, CODE1, CODE2, CODE3, CODE4, CODE5) \
     363                 :             : (tree_not_check5 ((T), __FILE__, __LINE__, __FUNCTION__, \
     364                 :             :                                (CODE1), (CODE2), (CODE3), (CODE4), (CODE5)))
     365                 :             : 
     366                 :             : #define TREE_CHECK6(T, CODE1, CODE2, CODE3, CODE4, CODE5, CODE6) \
     367                 :             : (tree_check6 ((T), __FILE__, __LINE__, __FUNCTION__, \
     368                 :             :                         (CODE1), (CODE2), (CODE3), (CODE4), (CODE5), (CODE6)))
     369                 :             : 
     370                 :             : #define TREE_NOT_CHECK6(T, CODE1, CODE2, CODE3, CODE4, CODE5, CODE6) \
     371                 :             : (tree_not_check6 ((T), __FILE__, __LINE__, __FUNCTION__, \
     372                 :             :                         (CODE1), (CODE2), (CODE3), (CODE4), (CODE5), (CODE6)))
     373                 :             : 
     374                 :             : #define CONTAINS_STRUCT_CHECK(T, STRUCT) \
     375                 :             : (contains_struct_check ((T), (STRUCT), __FILE__, __LINE__, __FUNCTION__))
     376                 :             : 
     377                 :             : #define TREE_CLASS_CHECK(T, CLASS) \
     378                 :             : (tree_class_check ((T), (CLASS), __FILE__, __LINE__, __FUNCTION__))
     379                 :             : 
     380                 :             : #define TREE_RANGE_CHECK(T, CODE1, CODE2) \
     381                 :             : (tree_range_check ((T), (CODE1), (CODE2), __FILE__, __LINE__, __FUNCTION__))
     382                 :             : 
     383                 :             : #define OMP_CLAUSE_SUBCODE_CHECK(T, CODE) \
     384                 :             : (omp_clause_subcode_check ((T), (CODE), __FILE__, __LINE__, __FUNCTION__))
     385                 :             : 
     386                 :             : #define OMP_CLAUSE_RANGE_CHECK(T, CODE1, CODE2) \
     387                 :             : (omp_clause_range_check ((T), (CODE1), (CODE2), \
     388                 :             :                                       __FILE__, __LINE__, __FUNCTION__))
     389                 :             : 
     390                 :             : /* These checks have to be special cased.  */
     391                 :             : #define EXPR_CHECK(T) \
     392                 :             : (expr_check ((T), __FILE__, __LINE__, __FUNCTION__))
     393                 :             : 
     394                 :             : /* These checks have to be special cased.  */
     395                 :             : #define NON_TYPE_CHECK(T) \
     396                 :             : (non_type_check ((T), __FILE__, __LINE__, __FUNCTION__))
     397                 :             : 
     398                 :             : /* These checks have to be special cased.  */
     399                 :             : #define ANY_INTEGRAL_TYPE_CHECK(T) \
     400                 :             : (any_integral_type_check ((T), __FILE__, __LINE__, __FUNCTION__))
     401                 :             : 
     402                 :             : #define TREE_INT_CST_ELT_CHECK(T, I) \
     403                 :             : (*tree_int_cst_elt_check ((T), (I), __FILE__, __LINE__, __FUNCTION__))
     404                 :             : 
     405                 :             : #define TREE_VEC_ELT_CHECK(T, I) \
     406                 :             : (*(CONST_CAST2 (tree *, typeof (T)*, \
     407                 :             :      tree_vec_elt_check ((T), (I), __FILE__, __LINE__, __FUNCTION__))))
     408                 :             : 
     409                 :             : #define OMP_CLAUSE_ELT_CHECK(T, I) \
     410                 :             : (*(omp_clause_elt_check ((T), (I), __FILE__, __LINE__, __FUNCTION__)))
     411                 :             : 
     412                 :             : /* Special checks for TREE_OPERANDs.  */
     413                 :             : #define TREE_OPERAND_CHECK(T, I) \
     414                 :             : (*(CONST_CAST2 (tree*, typeof (T)*, \
     415                 :             :      tree_operand_check ((T), (I), __FILE__, __LINE__, __FUNCTION__))))
     416                 :             : 
     417                 :             : #define TREE_OPERAND_CHECK_CODE(T, CODE, I) \
     418                 :             : (*(tree_operand_check_code ((T), (CODE), (I), \
     419                 :             :                                          __FILE__, __LINE__, __FUNCTION__)))
     420                 :             : 
     421                 :             : /* Nodes are chained together for many purposes.
     422                 :             :    Types are chained together to record them for being output to the debugger
     423                 :             :    (see the function `chain_type').
     424                 :             :    Decls in the same scope are chained together to record the contents
     425                 :             :    of the scope.
     426                 :             :    Statement nodes for successive statements used to be chained together.
     427                 :             :    Often lists of things are represented by TREE_LIST nodes that
     428                 :             :    are chained together.  */
     429                 :             : 
     430                 :             : #define TREE_CHAIN(NODE) \
     431                 :             : (CONTAINS_STRUCT_CHECK (NODE, TS_COMMON)->common.chain)
     432                 :             : 
     433                 :             : /* In all nodes that are expressions, this is the data type of the expression.
     434                 :             :    In POINTER_TYPE nodes, this is the type that the pointer points to.
     435                 :             :    In ARRAY_TYPE nodes, this is the type of the elements.
     436                 :             :    In VECTOR_TYPE nodes, this is the type of the elements.  */
     437                 :             : #define TREE_TYPE(NODE) \
     438                 :             : (CONTAINS_STRUCT_CHECK (NODE, TS_TYPED)->typed.type)
     439                 :             : 
     440                 :             : extern void tree_contains_struct_check_failed (const_tree,
     441                 :             :                                                const enum tree_node_structure_enum,
     442                 :             :                                                const char *, int, const char *)
     443                 :             :   ATTRIBUTE_NORETURN ATTRIBUTE_COLD;
     444                 :             : 
     445                 :             : extern void tree_check_failed (const_tree, const char *, int, const char *,
     446                 :             :                                ...) ATTRIBUTE_NORETURN ATTRIBUTE_COLD;
     447                 :             : extern void tree_not_check_failed (const_tree, const char *, int, const char *,
     448                 :             :                                    ...) ATTRIBUTE_NORETURN ATTRIBUTE_COLD;
     449                 :             : extern void tree_class_check_failed (const_tree, const enum tree_code_class,
     450                 :             :                                      const char *, int, const char *)
     451                 :             :     ATTRIBUTE_NORETURN ATTRIBUTE_COLD;
     452                 :             : extern void tree_range_check_failed (const_tree, const char *, int,
     453                 :             :                                      const char *, enum tree_code,
     454                 :             :                                      enum tree_code)
     455                 :             :     ATTRIBUTE_NORETURN ATTRIBUTE_COLD;
     456                 :             : extern void tree_not_class_check_failed (const_tree,
     457                 :             :                                          const enum tree_code_class,
     458                 :             :                                          const char *, int, const char *)
     459                 :             :     ATTRIBUTE_NORETURN ATTRIBUTE_COLD;
     460                 :             : extern void tree_int_cst_elt_check_failed (int, int, const char *,
     461                 :             :                                            int, const char *)
     462                 :             :     ATTRIBUTE_NORETURN ATTRIBUTE_COLD;
     463                 :             : extern void tree_vec_elt_check_failed (int, int, const char *,
     464                 :             :                                        int, const char *)
     465                 :             :     ATTRIBUTE_NORETURN ATTRIBUTE_COLD;
     466                 :             : extern void phi_node_elt_check_failed (int, int, const char *,
     467                 :             :                                        int, const char *)
     468                 :             :     ATTRIBUTE_NORETURN ATTRIBUTE_COLD;
     469                 :             : extern void tree_operand_check_failed (int, const_tree,
     470                 :             :                                        const char *, int, const char *)
     471                 :             :     ATTRIBUTE_NORETURN ATTRIBUTE_COLD;
     472                 :             : extern void omp_clause_check_failed (const_tree, const char *, int,
     473                 :             :                                      const char *, enum omp_clause_code)
     474                 :             :     ATTRIBUTE_NORETURN ATTRIBUTE_COLD;
     475                 :             : extern void omp_clause_operand_check_failed (int, const_tree, const char *,
     476                 :             :                                              int, const char *)
     477                 :             :     ATTRIBUTE_NORETURN ATTRIBUTE_COLD;
     478                 :             : extern void omp_clause_range_check_failed (const_tree, const char *, int,
     479                 :             :                                const char *, enum omp_clause_code,
     480                 :             :                                enum omp_clause_code)
     481                 :             :     ATTRIBUTE_NORETURN ATTRIBUTE_COLD;
     482                 :             : 
     483                 :             : #else /* not ENABLE_TREE_CHECKING, or not gcc */
     484                 :             : 
     485                 :             : #define CONTAINS_STRUCT_CHECK(T, ENUM)          (T)
     486                 :             : #define TREE_CHECK(T, CODE)                     (T)
     487                 :             : #define TREE_NOT_CHECK(T, CODE)                 (T)
     488                 :             : #define TREE_CHECK2(T, CODE1, CODE2)            (T)
     489                 :             : #define TREE_NOT_CHECK2(T, CODE1, CODE2)        (T)
     490                 :             : #define TREE_CHECK3(T, CODE1, CODE2, CODE3)     (T)
     491                 :             : #define TREE_NOT_CHECK3(T, CODE1, CODE2, CODE3) (T)
     492                 :             : #define TREE_CHECK4(T, CODE1, CODE2, CODE3, CODE4) (T)
     493                 :             : #define TREE_NOT_CHECK4(T, CODE1, CODE2, CODE3, CODE4) (T)
     494                 :             : #define TREE_CHECK5(T, CODE1, CODE2, CODE3, CODE4, CODE5) (T)
     495                 :             : #define TREE_NOT_CHECK5(T, CODE1, CODE2, CODE3, CODE4, CODE5) (T)
     496                 :             : #define TREE_CHECK6(T, CODE1, CODE2, CODE3, CODE4, CODE5, CODE6) (T)
     497                 :             : #define TREE_NOT_CHECK6(T, CODE1, CODE2, CODE3, CODE4, CODE5, CODE6) (T)
     498                 :             : #define TREE_CLASS_CHECK(T, CODE)               (T)
     499                 :             : #define TREE_RANGE_CHECK(T, CODE1, CODE2)       (T)
     500                 :             : #define EXPR_CHECK(T)                           (T)
     501                 :             : #define NON_TYPE_CHECK(T)                       (T)
     502                 :             : #define TREE_INT_CST_ELT_CHECK(T, I)            ((T)->int_cst.val[I])
     503                 :             : #define TREE_VEC_ELT_CHECK(T, I)                ((T)->vec.a[I])
     504                 :             : #define TREE_OPERAND_CHECK(T, I)                ((T)->exp.operands[I])
     505                 :             : #define TREE_OPERAND_CHECK_CODE(T, CODE, I)     ((T)->exp.operands[I])
     506                 :             : #define OMP_CLAUSE_ELT_CHECK(T, i)              ((T)->omp_clause.ops[i])
     507                 :             : #define OMP_CLAUSE_RANGE_CHECK(T, CODE1, CODE2) (T)
     508                 :             : #define OMP_CLAUSE_SUBCODE_CHECK(T, CODE)       (T)
     509                 :             : #define ANY_INTEGRAL_TYPE_CHECK(T)              (T)
     510                 :             : 
     511                 :             : #define TREE_CHAIN(NODE) ((NODE)->common.chain)
     512                 :             : #define TREE_TYPE(NODE) ((NODE)->typed.type)
     513                 :             : 
     514                 :             : #endif
     515                 :             : 
     516                 :             : #define TREE_BLOCK(NODE)                (tree_block (NODE))
     517                 :             : #define TREE_SET_BLOCK(T, B)            (tree_set_block ((T), (B)))
     518                 :             : 
     519                 :             : #include "tree-check.h"
     520                 :             : 
     521                 :             : #define TYPE_CHECK(T)           TREE_CLASS_CHECK (T, tcc_type)
     522                 :             : #define DECL_MINIMAL_CHECK(T)   CONTAINS_STRUCT_CHECK (T, TS_DECL_MINIMAL)
     523                 :             : #define DECL_COMMON_CHECK(T)    CONTAINS_STRUCT_CHECK (T, TS_DECL_COMMON)
     524                 :             : #define DECL_WRTL_CHECK(T)      CONTAINS_STRUCT_CHECK (T, TS_DECL_WRTL)
     525                 :             : #define DECL_WITH_VIS_CHECK(T)  CONTAINS_STRUCT_CHECK (T, TS_DECL_WITH_VIS)
     526                 :             : #define DECL_NON_COMMON_CHECK(T) CONTAINS_STRUCT_CHECK (T, TS_DECL_NON_COMMON)
     527                 :             : #define CST_CHECK(T)            TREE_CLASS_CHECK (T, tcc_constant)
     528                 :             : #define STMT_CHECK(T)           TREE_CLASS_CHECK (T, tcc_statement)
     529                 :             : #define VL_EXP_CHECK(T)         TREE_CLASS_CHECK (T, tcc_vl_exp)
     530                 :             : #define FUNC_OR_METHOD_CHECK(T) TREE_CHECK2 (T, FUNCTION_TYPE, METHOD_TYPE)
     531                 :             : #define PTR_OR_REF_CHECK(T)     TREE_CHECK2 (T, POINTER_TYPE, REFERENCE_TYPE)
     532                 :             : 
     533                 :             : #define RECORD_OR_UNION_CHECK(T)        \
     534                 :             :   TREE_CHECK3 (T, RECORD_TYPE, UNION_TYPE, QUAL_UNION_TYPE)
     535                 :             : #define NOT_RECORD_OR_UNION_CHECK(T) \
     536                 :             :   TREE_NOT_CHECK3 (T, RECORD_TYPE, UNION_TYPE, QUAL_UNION_TYPE)
     537                 :             : #define ARRAY_OR_INTEGER_TYPE_CHECK(T)  \
     538                 :             :   TREE_CHECK2 (T, ARRAY_TYPE, INTEGER_TYPE)
     539                 :             : 
     540                 :             : #define NUMERICAL_TYPE_CHECK(T)                                 \
     541                 :             :   TREE_CHECK6 (T, INTEGER_TYPE, ENUMERAL_TYPE, BOOLEAN_TYPE, REAL_TYPE, \
     542                 :             :                FIXED_POINT_TYPE, BITINT_TYPE)
     543                 :             : 
     544                 :             : /* Here is how primitive or already-canonicalized types' hash codes
     545                 :             :    are made.  */
     546                 :             : #define TYPE_HASH(TYPE) (TYPE_UID (TYPE))
     547                 :             : 
     548                 :             : /* A simple hash function for an arbitrary tree node.  This must not be
     549                 :             :    used in hash tables which are saved to a PCH.  */
     550                 :             : #define TREE_HASH(NODE) ((size_t) (NODE) & 0777777)
     551                 :             : 
     552                 :             : /* Tests if CODE is a conversion expr (NOP_EXPR or CONVERT_EXPR).  */
     553                 :             : #define CONVERT_EXPR_CODE_P(CODE)                               \
     554                 :             :   ((CODE) == NOP_EXPR || (CODE) == CONVERT_EXPR)
     555                 :             : 
     556                 :             : /* Similarly, but accept an expression instead of a tree code.  */
     557                 :             : #define CONVERT_EXPR_P(EXP)     CONVERT_EXPR_CODE_P (TREE_CODE (EXP))
     558                 :             : 
     559                 :             : /* Generate case for NOP_EXPR, CONVERT_EXPR.  */
     560                 :             : 
     561                 :             : #define CASE_CONVERT                                            \
     562                 :             :   case NOP_EXPR:                                                \
     563                 :             :   case CONVERT_EXPR
     564                 :             : 
     565                 :             : /* Given an expression as a tree, strip any conversion that generates
     566                 :             :    no instruction.  Accepts both tree and const_tree arguments since
     567                 :             :    we are not modifying the tree itself.  */
     568                 :             : 
     569                 :             : #define STRIP_NOPS(EXP) \
     570                 :             :   (EXP) = tree_strip_nop_conversions (CONST_CAST_TREE (EXP))
     571                 :             : 
     572                 :             : /* Like STRIP_NOPS, but don't let the signedness change either.  */
     573                 :             : 
     574                 :             : #define STRIP_SIGN_NOPS(EXP) \
     575                 :             :   (EXP) = tree_strip_sign_nop_conversions (CONST_CAST_TREE (EXP))
     576                 :             : 
     577                 :             : /* Like STRIP_NOPS, but don't alter the TREE_TYPE either.  */
     578                 :             : 
     579                 :             : #define STRIP_TYPE_NOPS(EXP) \
     580                 :             :   while ((CONVERT_EXPR_P (EXP)                                  \
     581                 :             :           || TREE_CODE (EXP) == NON_LVALUE_EXPR)                \
     582                 :             :          && TREE_OPERAND (EXP, 0) != error_mark_node            \
     583                 :             :          && (TREE_TYPE (EXP)                                    \
     584                 :             :              == TREE_TYPE (TREE_OPERAND (EXP, 0))))             \
     585                 :             :     (EXP) = TREE_OPERAND (EXP, 0)
     586                 :             : 
     587                 :             : /* Remove unnecessary type conversions according to
     588                 :             :    tree_ssa_useless_type_conversion.  */
     589                 :             : 
     590                 :             : #define STRIP_USELESS_TYPE_CONVERSION(EXP) \
     591                 :             :   (EXP) = tree_ssa_strip_useless_type_conversions (EXP)
     592                 :             : 
     593                 :             : /* Remove any VIEW_CONVERT_EXPR or NON_LVALUE_EXPR that's purely
     594                 :             :    in use to provide a location_t.  */
     595                 :             : 
     596                 :             : #define STRIP_ANY_LOCATION_WRAPPER(EXP) \
     597                 :             :   (EXP) = tree_strip_any_location_wrapper (CONST_CAST_TREE (EXP))
     598                 :             : 
     599                 :             : /* Nonzero if TYPE represents a vector type.  */
     600                 :             : 
     601                 :             : #define VECTOR_TYPE_P(TYPE) (TREE_CODE (TYPE) == VECTOR_TYPE)
     602                 :             : 
     603                 :             : /* Nonzero if TYPE represents a vector of booleans.  */
     604                 :             : 
     605                 :             : #define VECTOR_BOOLEAN_TYPE_P(TYPE)                             \
     606                 :             :   (TREE_CODE (TYPE) == VECTOR_TYPE                      \
     607                 :             :    && TREE_CODE (TREE_TYPE (TYPE)) == BOOLEAN_TYPE)
     608                 :             : 
     609                 :             : /* Nonzero if TYPE represents an integral type.  Note that we do not
     610                 :             :    include COMPLEX types here.  Keep these checks in ascending code
     611                 :             :    order.  */
     612                 :             : 
     613                 :             : #define INTEGRAL_TYPE_P(TYPE)  \
     614                 :             :   (TREE_CODE (TYPE) == ENUMERAL_TYPE  \
     615                 :             :    || TREE_CODE (TYPE) == BOOLEAN_TYPE \
     616                 :             :    || TREE_CODE (TYPE) == INTEGER_TYPE \
     617                 :             :    || TREE_CODE (TYPE) == BITINT_TYPE)
     618                 :             : 
     619                 :             : /* Nonzero if TYPE represents an integral type, including complex
     620                 :             :    and vector integer types.  */
     621                 :             : 
     622                 :             : #define ANY_INTEGRAL_TYPE_P(TYPE)               \
     623                 :             :   (INTEGRAL_TYPE_P (TYPE)                       \
     624                 :             :    || ((TREE_CODE (TYPE) == COMPLEX_TYPE        \
     625                 :             :         || VECTOR_TYPE_P (TYPE))                \
     626                 :             :        && INTEGRAL_TYPE_P (TREE_TYPE (TYPE))))
     627                 :             : 
     628                 :             : /* Nonzero if TYPE is bit-precise integer type.  */
     629                 :             : 
     630                 :             : #define BITINT_TYPE_P(TYPE) (TREE_CODE (TYPE) == BITINT_TYPE)
     631                 :             : 
     632                 :             : /* Nonzero if TYPE represents a non-saturating fixed-point type.  */
     633                 :             : 
     634                 :             : #define NON_SAT_FIXED_POINT_TYPE_P(TYPE) \
     635                 :             :   (TREE_CODE (TYPE) == FIXED_POINT_TYPE && !TYPE_SATURATING (TYPE))
     636                 :             : 
     637                 :             : /* Nonzero if TYPE represents a saturating fixed-point type.  */
     638                 :             : 
     639                 :             : #define SAT_FIXED_POINT_TYPE_P(TYPE) \
     640                 :             :   (TREE_CODE (TYPE) == FIXED_POINT_TYPE && TYPE_SATURATING (TYPE))
     641                 :             : 
     642                 :             : /* Nonzero if TYPE represents a fixed-point type.  */
     643                 :             : 
     644                 :             : #define FIXED_POINT_TYPE_P(TYPE)        (TREE_CODE (TYPE) == FIXED_POINT_TYPE)
     645                 :             : 
     646                 :             : /* Nonzero if TYPE represents a scalar floating-point type.  */
     647                 :             : 
     648                 :             : #define SCALAR_FLOAT_TYPE_P(TYPE) (TREE_CODE (TYPE) == REAL_TYPE)
     649                 :             : 
     650                 :             : /* Nonzero if TYPE represents a complex floating-point type.  */
     651                 :             : 
     652                 :             : #define COMPLEX_FLOAT_TYPE_P(TYPE)      \
     653                 :             :   (TREE_CODE (TYPE) == COMPLEX_TYPE     \
     654                 :             :    && TREE_CODE (TREE_TYPE (TYPE)) == REAL_TYPE)
     655                 :             : 
     656                 :             : /* Nonzero if TYPE represents a vector integer type.  */
     657                 :             : 
     658                 :             : #define VECTOR_INTEGER_TYPE_P(TYPE)                     \
     659                 :             :   (VECTOR_TYPE_P (TYPE)                                 \
     660                 :             :    && TREE_CODE (TREE_TYPE (TYPE)) == INTEGER_TYPE)
     661                 :             : 
     662                 :             : 
     663                 :             : /* Nonzero if TYPE represents a vector floating-point type.  */
     664                 :             : 
     665                 :             : #define VECTOR_FLOAT_TYPE_P(TYPE)       \
     666                 :             :   (VECTOR_TYPE_P (TYPE)                 \
     667                 :             :    && TREE_CODE (TREE_TYPE (TYPE)) == REAL_TYPE)
     668                 :             : 
     669                 :             : /* Nonzero if TYPE represents a floating-point type, including complex
     670                 :             :    and vector floating-point types.  The vector and complex check does
     671                 :             :    not use the previous two macros to enable early folding.  */
     672                 :             : 
     673                 :             : #define FLOAT_TYPE_P(TYPE)                      \
     674                 :             :   (SCALAR_FLOAT_TYPE_P (TYPE)                   \
     675                 :             :    || ((TREE_CODE (TYPE) == COMPLEX_TYPE        \
     676                 :             :         || VECTOR_TYPE_P (TYPE))                \
     677                 :             :        && SCALAR_FLOAT_TYPE_P (TREE_TYPE (TYPE))))
     678                 :             : 
     679                 :             : /* Nonzero if TYPE represents a decimal floating-point type.  */
     680                 :             : #define DECIMAL_FLOAT_TYPE_P(TYPE)              \
     681                 :             :   (SCALAR_FLOAT_TYPE_P (TYPE)                   \
     682                 :             :    && DECIMAL_FLOAT_MODE_P (TYPE_MODE (TYPE)))
     683                 :             : 
     684                 :             : /* Nonzero if TYPE is a record or union type.  */
     685                 :             : #define RECORD_OR_UNION_TYPE_P(TYPE)            \
     686                 :             :   (TREE_CODE (TYPE) == RECORD_TYPE              \
     687                 :             :    || TREE_CODE (TYPE) == UNION_TYPE            \
     688                 :             :    || TREE_CODE (TYPE) == QUAL_UNION_TYPE)
     689                 :             : 
     690                 :             : /* Nonzero if TYPE represents an aggregate (multi-component) type.
     691                 :             :    Keep these checks in ascending code order.  */
     692                 :             : 
     693                 :             : #define AGGREGATE_TYPE_P(TYPE) \
     694                 :             :   (TREE_CODE (TYPE) == ARRAY_TYPE || RECORD_OR_UNION_TYPE_P (TYPE))
     695                 :             : 
     696                 :             : /* Nonzero if TYPE represents a pointer or reference type.
     697                 :             :    (It should be renamed to INDIRECT_TYPE_P.)  Keep these checks in
     698                 :             :    ascending code order.  */
     699                 :             : 
     700                 :             : #define POINTER_TYPE_P(TYPE) \
     701                 :             :   (TREE_CODE (TYPE) == POINTER_TYPE || TREE_CODE (TYPE) == REFERENCE_TYPE)
     702                 :             : 
     703                 :             : /* Nonzero if TYPE represents a pointer to function.  */
     704                 :             : #define FUNCTION_POINTER_TYPE_P(TYPE) \
     705                 :             :   (POINTER_TYPE_P (TYPE) && TREE_CODE (TREE_TYPE (TYPE)) == FUNCTION_TYPE)
     706                 :             : 
     707                 :             : /* Nonzero if this type is a complete type.  */
     708                 :             : #define COMPLETE_TYPE_P(NODE) (TYPE_SIZE (NODE) != NULL_TREE)
     709                 :             : 
     710                 :             : /* Nonzero if this type is the (possibly qualified) void type.  */
     711                 :             : #define VOID_TYPE_P(NODE) (TREE_CODE (NODE) == VOID_TYPE)
     712                 :             : 
     713                 :             : /* Nonzero if this type is complete or is cv void.  */
     714                 :             : #define COMPLETE_OR_VOID_TYPE_P(NODE) \
     715                 :             :   (COMPLETE_TYPE_P (NODE) || VOID_TYPE_P (NODE))
     716                 :             : 
     717                 :             : /* Nonzero if this type is complete or is an array with unspecified bound.  */
     718                 :             : #define COMPLETE_OR_UNBOUND_ARRAY_TYPE_P(NODE) \
     719                 :             :   (COMPLETE_TYPE_P (TREE_CODE (NODE) == ARRAY_TYPE ? TREE_TYPE (NODE) : (NODE)))
     720                 :             : 
     721                 :             : #define FUNC_OR_METHOD_TYPE_P(NODE) \
     722                 :             :   (TREE_CODE (NODE) == FUNCTION_TYPE || TREE_CODE (NODE) == METHOD_TYPE)
     723                 :             : 
     724                 :             : #define OPAQUE_TYPE_P(NODE) \
     725                 :             :     (TREE_CODE (NODE) == OPAQUE_TYPE)
     726                 :             : 
     727                 :             : /* Define many boolean fields that all tree nodes have.  */
     728                 :             : 
     729                 :             : /* In VAR_DECL, PARM_DECL and RESULT_DECL nodes, nonzero means address
     730                 :             :    of this is needed.  So it cannot be in a register.
     731                 :             :    In a FUNCTION_DECL it has no meaning.
     732                 :             :    In LABEL_DECL nodes, it means a goto for this label has been seen
     733                 :             :    from a place outside all binding contours that restore stack levels.
     734                 :             :    In an artificial SSA_NAME that points to a stack partition with at least
     735                 :             :    two variables, it means that at least one variable has TREE_ADDRESSABLE.
     736                 :             :    In ..._TYPE nodes, it means that objects of this type must be fully
     737                 :             :    addressable.  This means that pieces of this object cannot go into
     738                 :             :    register parameters, for example.  If this a function type, this
     739                 :             :    means that the value must be returned in memory.
     740                 :             :    In CONSTRUCTOR nodes, it means object constructed must be in memory.
     741                 :             :    In IDENTIFIER_NODEs, this means that some extern decl for this name
     742                 :             :    had its address taken.  That matters for inline functions.
     743                 :             :    In a STMT_EXPR, it means we want the result of the enclosed expression.  */
     744                 :             : #define TREE_ADDRESSABLE(NODE) ((NODE)->base.addressable_flag)
     745                 :             : 
     746                 :             : /* Set on a CALL_EXPR if the call is in a tail position, ie. just before the
     747                 :             :    exit of a function.  Calls for which this is true are candidates for tail
     748                 :             :    call optimizations.  */
     749                 :             : #define CALL_EXPR_TAILCALL(NODE) \
     750                 :             :   (CALL_EXPR_CHECK (NODE)->base.addressable_flag)
     751                 :             : 
     752                 :             : /* Set on a CALL_EXPR if the call has been marked as requiring tail call
     753                 :             :    optimization for correctness.  */
     754                 :             : #define CALL_EXPR_MUST_TAIL_CALL(NODE) \
     755                 :             :   (CALL_EXPR_CHECK (NODE)->base.static_flag)
     756                 :             : 
     757                 :             : /* Used as a temporary field on a CASE_LABEL_EXPR to indicate that the
     758                 :             :    CASE_LOW operand has been processed.  */
     759                 :             : #define CASE_LOW_SEEN(NODE) \
     760                 :             :   (CASE_LABEL_EXPR_CHECK (NODE)->base.addressable_flag)
     761                 :             : 
     762                 :             : #define PREDICT_EXPR_OUTCOME(NODE) \
     763                 :             :   ((enum prediction) (PREDICT_EXPR_CHECK (NODE)->base.addressable_flag))
     764                 :             : #define SET_PREDICT_EXPR_OUTCOME(NODE, OUTCOME) \
     765                 :             :   (PREDICT_EXPR_CHECK (NODE)->base.addressable_flag = (int) OUTCOME)
     766                 :             : #define PREDICT_EXPR_PREDICTOR(NODE) \
     767                 :             :   ((enum br_predictor)tree_to_shwi (TREE_OPERAND (PREDICT_EXPR_CHECK (NODE), 0)))
     768                 :             : 
     769                 :             : /* In a VAR_DECL, nonzero means allocate static storage.
     770                 :             :    In a FUNCTION_DECL, nonzero if function has been defined.
     771                 :             :    In a CONSTRUCTOR, nonzero means allocate static storage.  */
     772                 :             : #define TREE_STATIC(NODE) ((NODE)->base.static_flag)
     773                 :             : 
     774                 :             : /* In an ADDR_EXPR, nonzero means do not use a trampoline.  */
     775                 :             : #define TREE_NO_TRAMPOLINE(NODE) (ADDR_EXPR_CHECK (NODE)->base.static_flag)
     776                 :             : 
     777                 :             : /* In a TARGET_EXPR or WITH_CLEANUP_EXPR, means that the pertinent cleanup
     778                 :             :    should only be executed if an exception is thrown, not on normal exit
     779                 :             :    of its scope.  */
     780                 :             : #define CLEANUP_EH_ONLY(NODE) ((NODE)->base.static_flag)
     781                 :             : 
     782                 :             : /* In a TRY_CATCH_EXPR, means that the handler should be considered a
     783                 :             :    separate cleanup in honor_protect_cleanup_actions.  */
     784                 :             : #define TRY_CATCH_IS_CLEANUP(NODE) \
     785                 :             :   (TRY_CATCH_EXPR_CHECK (NODE)->base.static_flag)
     786                 :             : 
     787                 :             : /* Used as a temporary field on a CASE_LABEL_EXPR to indicate that the
     788                 :             :    CASE_HIGH operand has been processed.  */
     789                 :             : #define CASE_HIGH_SEEN(NODE) \
     790                 :             :   (CASE_LABEL_EXPR_CHECK (NODE)->base.static_flag)
     791                 :             : 
     792                 :             : /* Used to mark scoped enums.  */
     793                 :             : #define ENUM_IS_SCOPED(NODE) (ENUMERAL_TYPE_CHECK (NODE)->base.static_flag)
     794                 :             : 
     795                 :             : /* Determines whether an ENUMERAL_TYPE has defined the list of constants. */
     796                 :             : #define ENUM_IS_OPAQUE(NODE) (ENUMERAL_TYPE_CHECK (NODE)->base.private_flag)
     797                 :             : 
     798                 :             : /* In an expr node (usually a conversion) this means the node was made
     799                 :             :    implicitly and should not lead to any sort of warning.  In a decl node,
     800                 :             :    warnings concerning the decl should be suppressed.  This is used at
     801                 :             :    least for used-before-set warnings, and it set after one warning is
     802                 :             :    emitted.  */
     803                 :             : #define TREE_NO_WARNING(NODE) ((NODE)->base.nowarning_flag)
     804                 :             : 
     805                 :             : /* Nonzero if we should warn about the change in empty class parameter
     806                 :             :    passing ABI in this TU.  */
     807                 :             : #define TRANSLATION_UNIT_WARN_EMPTY_P(NODE) \
     808                 :             :   (TRANSLATION_UNIT_DECL_CHECK (NODE)->decl_common.decl_flag_0)
     809                 :             : 
     810                 :             : /* Nonzero if this type is "empty" according to the particular psABI.  */
     811                 :             : #define TYPE_EMPTY_P(NODE) (TYPE_CHECK (NODE)->type_common.empty_flag)
     812                 :             : 
     813                 :             : /* Used to indicate that this TYPE represents a compiler-generated entity.  */
     814                 :             : #define TYPE_ARTIFICIAL(NODE) (TYPE_CHECK (NODE)->base.nowarning_flag)
     815                 :             : 
     816                 :             : /* True if the type is indivisible at the source level, i.e. if its
     817                 :             :    component parts cannot be accessed directly.  This is used to suppress
     818                 :             :    normal GNU extensions for target-specific vector types.  */
     819                 :             : #define TYPE_INDIVISIBLE_P(NODE) (TYPE_CHECK (NODE)->type_common.indivisible_p)
     820                 :             : 
     821                 :             : /* True if this is a stdarg function with no named arguments (C23
     822                 :             :    (...) prototype, where arguments can be accessed with va_start and
     823                 :             :    va_arg), as opposed to an unprototyped function.  */
     824                 :             : #define TYPE_NO_NAMED_ARGS_STDARG_P(NODE) \
     825                 :             :   (FUNC_OR_METHOD_CHECK (NODE)->type_common.no_named_args_stdarg_p)
     826                 :             : 
     827                 :             : /* True if this RECORD_TYPE or UNION_TYPE includes a flexible array member
     828                 :             :    as the last field recursively.  */
     829                 :             : #define TYPE_INCLUDES_FLEXARRAY(NODE) \
     830                 :             :   (RECORD_OR_UNION_CHECK (NODE)->type_common.no_named_args_stdarg_p)
     831                 :             : 
     832                 :             : /* In an IDENTIFIER_NODE, this means that assemble_name was called with
     833                 :             :    this string as an argument.  */
     834                 :             : #define TREE_SYMBOL_REFERENCED(NODE) \
     835                 :             :   (IDENTIFIER_NODE_CHECK (NODE)->base.static_flag)
     836                 :             : 
     837                 :             : /* Nonzero in a pointer or reference type means the data pointed to
     838                 :             :    by this type can alias anything.  */
     839                 :             : #define TYPE_REF_CAN_ALIAS_ALL(NODE) \
     840                 :             :   (PTR_OR_REF_CHECK (NODE)->base.static_flag)
     841                 :             : 
     842                 :             : /* In an INTEGER_CST, REAL_CST, or COMPLEX_CST, this means
     843                 :             :    there was an overflow in folding.  */
     844                 :             : 
     845                 :             : #define TREE_OVERFLOW(NODE) (CST_CHECK (NODE)->base.public_flag)
     846                 :             : 
     847                 :             : /* TREE_OVERFLOW can only be true for EXPR of CONSTANT_CLASS_P.  */
     848                 :             : 
     849                 :             : #define TREE_OVERFLOW_P(EXPR) \
     850                 :             :  (CONSTANT_CLASS_P (EXPR) && TREE_OVERFLOW (EXPR))
     851                 :             : 
     852                 :             : /* In a VAR_DECL, FUNCTION_DECL, NAMESPACE_DECL or TYPE_DECL,
     853                 :             :    nonzero means name is to be accessible from outside this translation unit.
     854                 :             :    In an IDENTIFIER_NODE, nonzero means an external declaration
     855                 :             :    accessible from outside this translation unit was previously seen
     856                 :             :    for this name in an inner scope.  */
     857                 :             : #define TREE_PUBLIC(NODE) ((NODE)->base.public_flag)
     858                 :             : 
     859                 :             : /* In a _TYPE, indicates whether TYPE_CACHED_VALUES contains a vector
     860                 :             :    of cached values, or is something else.  */
     861                 :             : #define TYPE_CACHED_VALUES_P(NODE) (TYPE_CHECK (NODE)->base.public_flag)
     862                 :             : 
     863                 :             : /* In a SAVE_EXPR, indicates that the original expression has already
     864                 :             :    been substituted with a VAR_DECL that contains the value.  */
     865                 :             : #define SAVE_EXPR_RESOLVED_P(NODE) \
     866                 :             :   (SAVE_EXPR_CHECK (NODE)->base.public_flag)
     867                 :             : 
     868                 :             : /* Set on a CALL_EXPR if this stdarg call should be passed the argument
     869                 :             :    pack.  */
     870                 :             : #define CALL_EXPR_VA_ARG_PACK(NODE) \
     871                 :             :   (CALL_EXPR_CHECK (NODE)->base.public_flag)
     872                 :             : 
     873                 :             : /* In any expression, decl, or constant, nonzero means it has side effects or
     874                 :             :    reevaluation of the whole expression could produce a different value.
     875                 :             :    This is set if any subexpression is a function call, a side effect or a
     876                 :             :    reference to a volatile variable.  In a ..._DECL, this is set only if the
     877                 :             :    declaration said `volatile'.  This will never be set for a constant.  */
     878                 :             : #define TREE_SIDE_EFFECTS(NODE) \
     879                 :             :   (NON_TYPE_CHECK (NODE)->base.side_effects_flag)
     880                 :             : 
     881                 :             : /* In a LABEL_DECL, nonzero means this label had its address taken
     882                 :             :    and therefore can never be deleted and is a jump target for
     883                 :             :    computed gotos.  */
     884                 :             : #define FORCED_LABEL(NODE) (LABEL_DECL_CHECK (NODE)->base.side_effects_flag)
     885                 :             : 
     886                 :             : /* Whether a case or a user-defined label is allowed to fall through to.
     887                 :             :    This is used to implement -Wimplicit-fallthrough.  */
     888                 :             : #define FALLTHROUGH_LABEL_P(NODE) \
     889                 :             :   (LABEL_DECL_CHECK (NODE)->base.private_flag)
     890                 :             : 
     891                 :             : /* Set on the artificial label created for break; stmt from a switch.
     892                 :             :    This is used to implement -Wimplicit-fallthrough.  */
     893                 :             : #define SWITCH_BREAK_LABEL_P(NODE) \
     894                 :             :   (LABEL_DECL_CHECK (NODE)->base.protected_flag)
     895                 :             : 
     896                 :             : /* Set on label that is known not to be jumped to, it can be only
     897                 :             :    reached by falling through from previous statements.
     898                 :             :    This is used to implement -Wimplicit-fallthrough.  */
     899                 :             : #define UNUSED_LABEL_P(NODE) \
     900                 :             :   (LABEL_DECL_CHECK (NODE)->base.default_def_flag)
     901                 :             : 
     902                 :             : /* Nonzero means this expression is volatile in the C sense:
     903                 :             :    its address should be of type `volatile WHATEVER *'.
     904                 :             :    In other words, the declared item is volatile qualified.
     905                 :             :    This is used in _DECL nodes and _REF nodes.
     906                 :             :    On a FUNCTION_DECL node, this means the function does not
     907                 :             :    return normally.  This is the same effect as setting
     908                 :             :    the attribute noreturn on the function in C.
     909                 :             : 
     910                 :             :    In a ..._TYPE node, means this type is volatile-qualified.
     911                 :             :    But use TYPE_VOLATILE instead of this macro when the node is a type,
     912                 :             :    because eventually we may make that a different bit.
     913                 :             : 
     914                 :             :    If this bit is set in an expression, so is TREE_SIDE_EFFECTS.  */
     915                 :             : #define TREE_THIS_VOLATILE(NODE) ((NODE)->base.volatile_flag)
     916                 :             : 
     917                 :             : /* Nonzero means this node will not trap.  In an INDIRECT_REF, means
     918                 :             :    accessing the memory pointed to won't generate a trap.  However,
     919                 :             :    this only applies to an object when used appropriately: it doesn't
     920                 :             :    mean that writing a READONLY mem won't trap.
     921                 :             : 
     922                 :             :    In ARRAY_REF and ARRAY_RANGE_REF means that we know that the index
     923                 :             :    (or slice of the array) always belongs to the range of the array.
     924                 :             :    I.e. that the access will not trap, provided that the access to
     925                 :             :    the base to the array will not trap.  */
     926                 :             : #define TREE_THIS_NOTRAP(NODE) \
     927                 :             :   (TREE_CHECK5 (NODE, INDIRECT_REF, MEM_REF, TARGET_MEM_REF, ARRAY_REF, \
     928                 :             :                 ARRAY_RANGE_REF)->base.nothrow_flag)
     929                 :             : 
     930                 :             : /* In a VAR_DECL, PARM_DECL or FIELD_DECL, or any kind of ..._REF node,
     931                 :             :    nonzero means it may not be the lhs of an assignment.
     932                 :             :    Nonzero in a FUNCTION_DECL means this function should be treated
     933                 :             :    as "const" function (can only read its arguments).  */
     934                 :             : #define TREE_READONLY(NODE) (NON_TYPE_CHECK (NODE)->base.readonly_flag)
     935                 :             : 
     936                 :             : /* Value of expression is constant.  Always on in all ..._CST nodes.  May
     937                 :             :    also appear in an expression or decl where the value is constant.  */
     938                 :             : #define TREE_CONSTANT(NODE) (NON_TYPE_CHECK (NODE)->base.constant_flag)
     939                 :             : 
     940                 :             : /* Nonzero if NODE, a type, has had its sizes gimplified.  */
     941                 :             : #define TYPE_SIZES_GIMPLIFIED(NODE) \
     942                 :             :   (TYPE_CHECK (NODE)->base.constant_flag)
     943                 :             : 
     944                 :             : /* In a decl (most significantly a FIELD_DECL), means an unsigned field.  */
     945                 :             : #define DECL_UNSIGNED(NODE) \
     946                 :             :   (DECL_COMMON_CHECK (NODE)->base.u.bits.unsigned_flag)
     947                 :             : 
     948                 :             : /* In integral and pointer types, means an unsigned type.  */
     949                 :             : #define TYPE_UNSIGNED(NODE) (TYPE_CHECK (NODE)->base.u.bits.unsigned_flag)
     950                 :             : 
     951                 :             : /* Same as TYPE_UNSIGNED but converted to SIGNOP.  */
     952                 :             : #define TYPE_SIGN(NODE) ((signop) TYPE_UNSIGNED (NODE))
     953                 :             : 
     954                 :             : /* True if overflow wraps around for the given integral or pointer type.  That
     955                 :             :    is, TYPE_MAX + 1 == TYPE_MIN.  */
     956                 :             : #define TYPE_OVERFLOW_WRAPS(TYPE) \
     957                 :             :   (POINTER_TYPE_P (TYPE)                                        \
     958                 :             :    ? flag_wrapv_pointer                                         \
     959                 :             :    : (ANY_INTEGRAL_TYPE_CHECK(TYPE)->base.u.bits.unsigned_flag       \
     960                 :             :       || flag_wrapv))
     961                 :             : 
     962                 :             : /* True if overflow is undefined for the given integral or pointer type.
     963                 :             :    We may optimize on the assumption that values in the type never overflow.
     964                 :             : 
     965                 :             :    IMPORTANT NOTE: Any optimization based on TYPE_OVERFLOW_UNDEFINED
     966                 :             :    must issue a warning based on warn_strict_overflow.  In some cases
     967                 :             :    it will be appropriate to issue the warning immediately, and in
     968                 :             :    other cases it will be appropriate to simply set a flag and let the
     969                 :             :    caller decide whether a warning is appropriate or not.  */
     970                 :             : #define TYPE_OVERFLOW_UNDEFINED(TYPE)                           \
     971                 :             :   (POINTER_TYPE_P (TYPE)                                        \
     972                 :             :    ? !flag_wrapv_pointer                                        \
     973                 :             :    : (!ANY_INTEGRAL_TYPE_CHECK(TYPE)->base.u.bits.unsigned_flag      \
     974                 :             :       && !flag_wrapv && !flag_trapv))
     975                 :             : 
     976                 :             : /* True if overflow for the given integral type should issue a
     977                 :             :    trap.  */
     978                 :             : #define TYPE_OVERFLOW_TRAPS(TYPE) \
     979                 :             :   (!ANY_INTEGRAL_TYPE_CHECK(TYPE)->base.u.bits.unsigned_flag && flag_trapv)
     980                 :             : 
     981                 :             : /* True if an overflow is to be preserved for sanitization.  */
     982                 :             : #define TYPE_OVERFLOW_SANITIZED(TYPE)                   \
     983                 :             :   (INTEGRAL_TYPE_P (TYPE)                               \
     984                 :             :    && !TYPE_OVERFLOW_WRAPS (TYPE)                       \
     985                 :             :    && (flag_sanitize & SANITIZE_SI_OVERFLOW))
     986                 :             : 
     987                 :             : /* Nonzero in a VAR_DECL or STRING_CST means assembler code has been written.
     988                 :             :    Nonzero in a FUNCTION_DECL means that the function has been compiled.
     989                 :             :    This is interesting in an inline function, since it might not need
     990                 :             :    to be compiled separately.
     991                 :             :    Nonzero in a RECORD_TYPE, UNION_TYPE, QUAL_UNION_TYPE, ENUMERAL_TYPE
     992                 :             :    or TYPE_DECL if the debugging info for the type has been written.
     993                 :             :    In a BLOCK node, nonzero if reorder_blocks has already seen this block.
     994                 :             :    In an SSA_NAME node, nonzero if the SSA_NAME occurs in an abnormal
     995                 :             :    PHI node.  */
     996                 :             : #define TREE_ASM_WRITTEN(NODE) ((NODE)->base.asm_written_flag)
     997                 :             : 
     998                 :             : /* Nonzero in a _DECL if the name is used in its scope.
     999                 :             :    Nonzero in an expr node means inhibit warning if value is unused.
    1000                 :             :    In IDENTIFIER_NODEs, this means that some extern decl for this name
    1001                 :             :    was used.
    1002                 :             :    In a BLOCK, this means that the block contains variables that are used.  */
    1003                 :             : #define TREE_USED(NODE) ((NODE)->base.used_flag)
    1004                 :             : 
    1005                 :             : /* In a FUNCTION_DECL, nonzero means a call to the function cannot
    1006                 :             :    throw an exception.  In a CALL_EXPR, nonzero means the call cannot
    1007                 :             :    throw.  We can't easily check the node type here as the C++
    1008                 :             :    frontend also uses this flag (for AGGR_INIT_EXPR).  */
    1009                 :             : #define TREE_NOTHROW(NODE) ((NODE)->base.nothrow_flag)
    1010                 :             : 
    1011                 :             : /* In a CALL_EXPR, means that it's safe to use the target of the call
    1012                 :             :    expansion as the return slot for a call that returns in memory.  */
    1013                 :             : #define CALL_EXPR_RETURN_SLOT_OPT(NODE) \
    1014                 :             :   (CALL_EXPR_CHECK (NODE)->base.private_flag)
    1015                 :             : 
    1016                 :             : /* In a RESULT_DECL, PARM_DECL and VAR_DECL, means that it is
    1017                 :             :    passed by invisible reference (and the TREE_TYPE is a pointer to the true
    1018                 :             :    type).  */
    1019                 :             : #define DECL_BY_REFERENCE(NODE) \
    1020                 :             :   (TREE_CHECK3 (NODE, VAR_DECL, PARM_DECL, \
    1021                 :             :                 RESULT_DECL)->decl_common.decl_by_reference_flag)
    1022                 :             : 
    1023                 :             : /* In VAR_DECL and PARM_DECL, set when the decl has been used except for
    1024                 :             :    being set.  */
    1025                 :             : #define DECL_READ_P(NODE) \
    1026                 :             :   (TREE_CHECK2 (NODE, VAR_DECL, PARM_DECL)->decl_common.decl_read_flag)
    1027                 :             : 
    1028                 :             : /* In VAR_DECL or RESULT_DECL, set when significant code movement precludes
    1029                 :             :    attempting to share the stack slot with some other variable.  */
    1030                 :             : #define DECL_NONSHAREABLE(NODE) \
    1031                 :             :   (TREE_CHECK2 (NODE, VAR_DECL, \
    1032                 :             :                 RESULT_DECL)->decl_common.decl_nonshareable_flag)
    1033                 :             : 
    1034                 :             : /* In a PARM_DECL, set for Fortran hidden string length arguments that some
    1035                 :             :    buggy callers don't pass to the callee.  */
    1036                 :             : #define DECL_HIDDEN_STRING_LENGTH(NODE) \
    1037                 :             :   (TREE_CHECK (NODE, PARM_DECL)->decl_common.decl_nonshareable_flag)
    1038                 :             : 
    1039                 :             : /* In a CALL_EXPR, means that the call is the jump from a thunk to the
    1040                 :             :    thunked-to function.  Be careful to avoid using this macro when one of the
    1041                 :             :    next two applies instead.  */
    1042                 :             : #define CALL_FROM_THUNK_P(NODE) (CALL_EXPR_CHECK (NODE)->base.protected_flag)
    1043                 :             : 
    1044                 :             : /* In a CALL_EXPR, if the function being called is BUILT_IN_ALLOCA, means that
    1045                 :             :    it has been built for the declaration of a variable-sized object and, if the
    1046                 :             :    function being called is BUILT_IN_MEMCPY, means that it has been built for
    1047                 :             :    the assignment of a variable-sized object.  */
    1048                 :             : #define CALL_ALLOCA_FOR_VAR_P(NODE) \
    1049                 :             :   (CALL_EXPR_CHECK (NODE)->base.protected_flag)
    1050                 :             : 
    1051                 :             : /* In a CALL_EXPR, if the function being called is DECL_IS_OPERATOR_NEW_P or
    1052                 :             :    DECL_IS_OPERATOR_DELETE_P, true for allocator calls from C++ new or delete
    1053                 :             :    expressions.  Not set for C++20 destroying delete operators.  */
    1054                 :             : #define CALL_FROM_NEW_OR_DELETE_P(NODE) \
    1055                 :             :   (CALL_EXPR_CHECK (NODE)->base.protected_flag)
    1056                 :             : 
    1057                 :             : /* Used in classes in C++.  */
    1058                 :             : #define TREE_PRIVATE(NODE) ((NODE)->base.private_flag)
    1059                 :             : /* Used in classes in C++. */
    1060                 :             : #define TREE_PROTECTED(NODE) ((NODE)->base.protected_flag)
    1061                 :             : 
    1062                 :             : /* True if reference type NODE is a C++ rvalue reference.  */
    1063                 :             : #define TYPE_REF_IS_RVALUE(NODE) \
    1064                 :             :   (REFERENCE_TYPE_CHECK (NODE)->base.private_flag)
    1065                 :             : 
    1066                 :             : /* Nonzero in a _DECL if the use of the name is defined as a
    1067                 :             :    deprecated feature by __attribute__((deprecated)).  */
    1068                 :             : #define TREE_DEPRECATED(NODE) \
    1069                 :             :   ((NODE)->base.deprecated_flag)
    1070                 :             : 
    1071                 :             : /* Nonzero in a _DECL if the use of the name is defined as an
    1072                 :             :    unavailable feature by __attribute__((unavailable)).  */
    1073                 :             : #define TREE_UNAVAILABLE(NODE) \
    1074                 :             :   ((NODE)->base.u.bits.unavailable_flag)
    1075                 :             : 
    1076                 :             : /* Nonzero indicates an IDENTIFIER_NODE that names an anonymous
    1077                 :             :    aggregate, (as created by anon_aggr_name_format).  */
    1078                 :             : #define IDENTIFIER_ANON_P(NODE) \
    1079                 :             :   (IDENTIFIER_NODE_CHECK (NODE)->base.private_flag)
    1080                 :             : 
    1081                 :             : /* Nonzero in an IDENTIFIER_NODE if the name is a local alias, whose
    1082                 :             :    uses are to be substituted for uses of the TREE_CHAINed identifier.  */
    1083                 :             : #define IDENTIFIER_TRANSPARENT_ALIAS(NODE) \
    1084                 :             :   (IDENTIFIER_NODE_CHECK (NODE)->base.deprecated_flag)
    1085                 :             : 
    1086                 :             : /* In an aggregate type, indicates that the scalar fields of the type are
    1087                 :             :    stored in reverse order from the target order.  This effectively
    1088                 :             :    toggles BYTES_BIG_ENDIAN and WORDS_BIG_ENDIAN within the type.  */
    1089                 :             : #define TYPE_REVERSE_STORAGE_ORDER(NODE) \
    1090                 :             :   (TREE_CHECK4 (NODE, RECORD_TYPE, UNION_TYPE, QUAL_UNION_TYPE, ARRAY_TYPE)->base.u.bits.saturating_flag)
    1091                 :             : 
    1092                 :             : /* In a non-aggregate type, indicates a saturating type.  */
    1093                 :             : #define TYPE_SATURATING(NODE) \
    1094                 :             :   (TREE_NOT_CHECK4 (NODE, RECORD_TYPE, UNION_TYPE, QUAL_UNION_TYPE, ARRAY_TYPE)->base.u.bits.saturating_flag)
    1095                 :             : 
    1096                 :             : /* In a BIT_FIELD_REF and MEM_REF, indicates that the reference is to a group
    1097                 :             :    of bits stored in reverse order from the target order.  This effectively
    1098                 :             :    toggles both BYTES_BIG_ENDIAN and WORDS_BIG_ENDIAN for the reference.
    1099                 :             : 
    1100                 :             :    The overall strategy is to preserve the invariant that every scalar in
    1101                 :             :    memory is associated with a single storage order, i.e. all accesses to
    1102                 :             :    this scalar are done with the same storage order.  This invariant makes
    1103                 :             :    it possible to factor out the storage order in most transformations, as
    1104                 :             :    only the address and/or the value (in target order) matter for them.
    1105                 :             :    But, of course, the storage order must be preserved when the accesses
    1106                 :             :    themselves are rewritten or transformed.  */
    1107                 :             : #define REF_REVERSE_STORAGE_ORDER(NODE) \
    1108                 :             :   (TREE_CHECK2 (NODE, BIT_FIELD_REF, MEM_REF)->base.default_def_flag)
    1109                 :             : 
    1110                 :             :   /* In an ADDR_EXPR, indicates that this is a pointer to nested function
    1111                 :             :    represented by a descriptor instead of a trampoline.  */
    1112                 :             : #define FUNC_ADDR_BY_DESCRIPTOR(NODE) \
    1113                 :             :   (TREE_CHECK (NODE, ADDR_EXPR)->base.default_def_flag)
    1114                 :             : 
    1115                 :             : /* In a CALL_EXPR, indicates that this is an indirect call for which
    1116                 :             :    pointers to nested function are descriptors instead of trampolines.  */
    1117                 :             : #define CALL_EXPR_BY_DESCRIPTOR(NODE) \
    1118                 :             :   (TREE_CHECK (NODE, CALL_EXPR)->base.default_def_flag)
    1119                 :             : 
    1120                 :             : /* These flags are available for each language front end to use internally.  */
    1121                 :             : #define TREE_LANG_FLAG_0(NODE) \
    1122                 :             :   (TREE_NOT_CHECK2 (NODE, TREE_VEC, SSA_NAME)->base.u.bits.lang_flag_0)
    1123                 :             : #define TREE_LANG_FLAG_1(NODE) \
    1124                 :             :   (TREE_NOT_CHECK2 (NODE, TREE_VEC, SSA_NAME)->base.u.bits.lang_flag_1)
    1125                 :             : #define TREE_LANG_FLAG_2(NODE) \
    1126                 :             :   (TREE_NOT_CHECK2 (NODE, TREE_VEC, SSA_NAME)->base.u.bits.lang_flag_2)
    1127                 :             : #define TREE_LANG_FLAG_3(NODE) \
    1128                 :             :   (TREE_NOT_CHECK2 (NODE, TREE_VEC, SSA_NAME)->base.u.bits.lang_flag_3)
    1129                 :             : #define TREE_LANG_FLAG_4(NODE) \
    1130                 :             :   (TREE_NOT_CHECK2 (NODE, TREE_VEC, SSA_NAME)->base.u.bits.lang_flag_4)
    1131                 :             : #define TREE_LANG_FLAG_5(NODE) \
    1132                 :             :   (TREE_NOT_CHECK2 (NODE, TREE_VEC, SSA_NAME)->base.u.bits.lang_flag_5)
    1133                 :             : #define TREE_LANG_FLAG_6(NODE) \
    1134                 :             :   (TREE_NOT_CHECK2 (NODE, TREE_VEC, SSA_NAME)->base.u.bits.lang_flag_6)
    1135                 :             : 
    1136                 :             : /* Define additional fields and accessors for nodes representing constants.  */
    1137                 :             : 
    1138                 :             : #define TREE_INT_CST_NUNITS(NODE) \
    1139                 :             :   (INTEGER_CST_CHECK (NODE)->base.u.int_length.unextended)
    1140                 :             : #define TREE_INT_CST_EXT_NUNITS(NODE) \
    1141                 :             :   (INTEGER_CST_CHECK (NODE)->base.u.int_length.extended)
    1142                 :             : #define TREE_INT_CST_ELT(NODE, I) TREE_INT_CST_ELT_CHECK (NODE, I)
    1143                 :             : #define TREE_INT_CST_LOW(NODE) \
    1144                 :             :   ((unsigned HOST_WIDE_INT) TREE_INT_CST_ELT (NODE, 0))
    1145                 :             : 
    1146                 :             : /* Return true if NODE is a POLY_INT_CST.  This is only ever true on
    1147                 :             :    targets with variable-sized modes.  */
    1148                 :             : #define POLY_INT_CST_P(NODE) \
    1149                 :             :   (NUM_POLY_INT_COEFFS > 1 && TREE_CODE (NODE) == POLY_INT_CST)
    1150                 :             : 
    1151                 :             : /* In a POLY_INT_CST node.  */
    1152                 :             : #define POLY_INT_CST_COEFF(NODE, I) \
    1153                 :             :   (POLY_INT_CST_CHECK (NODE)->poly_int_cst.coeffs[I])
    1154                 :             : 
    1155                 :             : #define TREE_REAL_CST_PTR(NODE) (&REAL_CST_CHECK (NODE)->real_cst.value)
    1156                 :             : #define TREE_REAL_CST(NODE) (*TREE_REAL_CST_PTR (NODE))
    1157                 :             : 
    1158                 :             : #define TREE_FIXED_CST_PTR(NODE) \
    1159                 :             :   (FIXED_CST_CHECK (NODE)->fixed_cst.fixed_cst_ptr)
    1160                 :             : #define TREE_FIXED_CST(NODE) (*TREE_FIXED_CST_PTR (NODE))
    1161                 :             : 
    1162                 :             : /* In a STRING_CST */
    1163                 :             : /* In C terms, this is sizeof, not strlen.  */
    1164                 :             : #define TREE_STRING_LENGTH(NODE) (STRING_CST_CHECK (NODE)->string.length)
    1165                 :             : #define TREE_STRING_POINTER(NODE) \
    1166                 :             :   ((const char *)(STRING_CST_CHECK (NODE)->string.str))
    1167                 :             : 
    1168                 :             : /* In a RAW_DATA_CST */
    1169                 :             : #define RAW_DATA_LENGTH(NODE) \
    1170                 :             :   (RAW_DATA_CST_CHECK (NODE)->raw_data_cst.length)
    1171                 :             : #define RAW_DATA_POINTER(NODE) \
    1172                 :             :   (RAW_DATA_CST_CHECK (NODE)->raw_data_cst.str)
    1173                 :             : #define RAW_DATA_OWNER(NODE) \
    1174                 :             :   (RAW_DATA_CST_CHECK (NODE)->raw_data_cst.owner)
    1175                 :             : #define RAW_DATA_UCHAR_ELT(NODE, I) \
    1176                 :             :   (((const unsigned char *) RAW_DATA_POINTER (NODE))[I])
    1177                 :             : #define RAW_DATA_SCHAR_ELT(NODE, I) \
    1178                 :             :   (((const signed char *) RAW_DATA_POINTER (NODE))[I])
    1179                 :             : 
    1180                 :             : /* In a COMPLEX_CST node.  */
    1181                 :             : #define TREE_REALPART(NODE) (COMPLEX_CST_CHECK (NODE)->complex.real)
    1182                 :             : #define TREE_IMAGPART(NODE) (COMPLEX_CST_CHECK (NODE)->complex.imag)
    1183                 :             : 
    1184                 :             : /* In a VECTOR_CST node.  See generic.texi for details.  */
    1185                 :             : #define VECTOR_CST_NELTS(NODE) (TYPE_VECTOR_SUBPARTS (TREE_TYPE (NODE)))
    1186                 :             : #define VECTOR_CST_ELT(NODE,IDX) vector_cst_elt (NODE, IDX)
    1187                 :             : 
    1188                 :             : #define VECTOR_CST_LOG2_NPATTERNS(NODE) \
    1189                 :             :   (VECTOR_CST_CHECK (NODE)->base.u.vector_cst.log2_npatterns)
    1190                 :             : #define VECTOR_CST_NPATTERNS(NODE) \
    1191                 :             :   (1U << VECTOR_CST_LOG2_NPATTERNS (NODE))
    1192                 :             : #define VECTOR_CST_NELTS_PER_PATTERN(NODE) \
    1193                 :             :   (VECTOR_CST_CHECK (NODE)->base.u.vector_cst.nelts_per_pattern)
    1194                 :             : #define VECTOR_CST_DUPLICATE_P(NODE) \
    1195                 :             :   (VECTOR_CST_NELTS_PER_PATTERN (NODE) == 1)
    1196                 :             : #define VECTOR_CST_STEPPED_P(NODE) \
    1197                 :             :   (VECTOR_CST_NELTS_PER_PATTERN (NODE) == 3)
    1198                 :             : #define VECTOR_CST_ENCODED_ELTS(NODE) \
    1199                 :             :   (VECTOR_CST_CHECK (NODE)->vector.elts)
    1200                 :             : #define VECTOR_CST_ENCODED_ELT(NODE, ELT) \
    1201                 :             :   (VECTOR_CST_CHECK (NODE)->vector.elts[ELT])
    1202                 :             : 
    1203                 :             : /* Define fields and accessors for some special-purpose tree nodes.  */
    1204                 :             : 
    1205                 :             : /* Unlike STRING_CST, in C terms this is strlen, not sizeof.  */
    1206                 :             : #define IDENTIFIER_LENGTH(NODE) \
    1207                 :             :   (IDENTIFIER_NODE_CHECK (NODE)->identifier.id.len)
    1208                 :             : #define IDENTIFIER_POINTER(NODE) \
    1209                 :             :   ((const char *) IDENTIFIER_NODE_CHECK (NODE)->identifier.id.str)
    1210                 :             : #define IDENTIFIER_HASH_VALUE(NODE) \
    1211                 :             :   (IDENTIFIER_NODE_CHECK (NODE)->identifier.id.hash_value)
    1212                 :             : 
    1213                 :             : /* Translate a hash table identifier pointer to a tree_identifier
    1214                 :             :    pointer, and vice versa.  */
    1215                 :             : 
    1216                 :             : #define HT_IDENT_TO_GCC_IDENT(NODE) \
    1217                 :             :   ((tree) ((char *) (NODE) - sizeof (struct tree_common)))
    1218                 :             : #define GCC_IDENT_TO_HT_IDENT(NODE) (&((struct tree_identifier *) (NODE))->id)
    1219                 :             : 
    1220                 :             : /* In a TREE_LIST node.  */
    1221                 :             : #define TREE_PURPOSE(NODE) (TREE_LIST_CHECK (NODE)->list.purpose)
    1222                 :             : #define TREE_VALUE(NODE) (TREE_LIST_CHECK (NODE)->list.value)
    1223                 :             : 
    1224                 :             : /* In a TREE_VEC node.  */
    1225                 :             : #define TREE_VEC_LENGTH(NODE) (TREE_VEC_CHECK (NODE)->base.u.length)
    1226                 :             : #define TREE_VEC_BEGIN(NODE) (&TREE_VEC_CHECK (NODE)->vec.a[0])
    1227                 :             : #define TREE_VEC_END(NODE) \
    1228                 :             :   ((void) TREE_VEC_CHECK (NODE), &((NODE)->vec.a[(NODE)->base.u.length]))
    1229                 :             : 
    1230                 :             : #define TREE_VEC_ELT(NODE,I) TREE_VEC_ELT_CHECK (NODE, I)
    1231                 :             : 
    1232                 :             : /* In a CONSTRUCTOR node.  */
    1233                 :             : #define CONSTRUCTOR_ELTS(NODE) (CONSTRUCTOR_CHECK (NODE)->constructor.elts)
    1234                 :             : #define CONSTRUCTOR_ELT(NODE,IDX) \
    1235                 :             :   (&(*CONSTRUCTOR_ELTS (NODE))[IDX])
    1236                 :             : #define CONSTRUCTOR_NELTS(NODE) \
    1237                 :             :   (vec_safe_length (CONSTRUCTOR_ELTS (NODE)))
    1238                 :             : #define CONSTRUCTOR_NO_CLEARING(NODE) \
    1239                 :             :   (CONSTRUCTOR_CHECK (NODE)->base.public_flag)
    1240                 :             : /* True if even padding bits should be zeroed during initialization.  */
    1241                 :             : #define CONSTRUCTOR_ZERO_PADDING_BITS(NODE) \
    1242                 :             :   (CONSTRUCTOR_CHECK (NODE)->base.default_def_flag)
    1243                 :             : 
    1244                 :             : /* Iterate through the vector V of CONSTRUCTOR_ELT elements, yielding the
    1245                 :             :    value of each element (stored within VAL). IX must be a scratch variable
    1246                 :             :    of unsigned integer type.  */
    1247                 :             : #define FOR_EACH_CONSTRUCTOR_VALUE(V, IX, VAL) \
    1248                 :             :   for (IX = 0; (IX >= vec_safe_length (V)) \
    1249                 :             :                ? false \
    1250                 :             :                : ((VAL = (*(V))[IX].value), \
    1251                 :             :                true); \
    1252                 :             :        (IX)++)
    1253                 :             : 
    1254                 :             : /* Iterate through the vector V of CONSTRUCTOR_ELT elements, yielding both
    1255                 :             :    the value of each element (stored within VAL) and its index (stored
    1256                 :             :    within INDEX). IX must be a scratch variable of unsigned integer type.  */
    1257                 :             : #define FOR_EACH_CONSTRUCTOR_ELT(V, IX, INDEX, VAL) \
    1258                 :             :   for (IX = 0; (IX >= vec_safe_length (V)) \
    1259                 :             :                ? false \
    1260                 :             :                : (((void) (VAL = (*V)[IX].value)), \
    1261                 :             :                   (INDEX = (*V)[IX].index), \
    1262                 :             :                   true); \
    1263                 :             :        (IX)++)
    1264                 :             : 
    1265                 :             : /* Append a new constructor element to V, with the specified INDEX and VAL.  */
    1266                 :             : #define CONSTRUCTOR_APPEND_ELT(V, INDEX, VALUE) \
    1267                 :             :   do { \
    1268                 :             :     constructor_elt _ce___ = {INDEX, VALUE}; \
    1269                 :             :     vec_safe_push ((V), _ce___); \
    1270                 :             :   } while (0)
    1271                 :             : 
    1272                 :             : /* True if NODE, a FIELD_DECL, is to be processed as a bitfield for
    1273                 :             :    constructor output purposes.  */
    1274                 :             : #define CONSTRUCTOR_BITFIELD_P(NODE) \
    1275                 :             :   (DECL_BIT_FIELD (FIELD_DECL_CHECK (NODE)) \
    1276                 :             :    && (DECL_MODE (NODE) != BLKmode \
    1277                 :             :        || TREE_CODE (TREE_TYPE (NODE)) == BITINT_TYPE))
    1278                 :             : 
    1279                 :             : /* True if NODE is a clobber right hand side, an expression of indeterminate
    1280                 :             :    value that clobbers the LHS in a copy instruction.  We use a volatile
    1281                 :             :    empty CONSTRUCTOR for this, as it matches most of the necessary semantic.
    1282                 :             :    In particular the volatile flag causes us to not prematurely remove
    1283                 :             :    such clobber instructions.  */
    1284                 :             : #define TREE_CLOBBER_P(NODE) \
    1285                 :             :   (TREE_CODE (NODE) == CONSTRUCTOR && TREE_THIS_VOLATILE (NODE))
    1286                 :             : 
    1287                 :             : /* Return the clobber_kind of a CLOBBER CONSTRUCTOR.  */
    1288                 :             : #define CLOBBER_KIND(NODE) \
    1289                 :             :   (CONSTRUCTOR_CHECK (NODE)->base.u.bits.address_space)
    1290                 :             : 
    1291                 :             : /* Define fields and accessors for some nodes that represent expressions.  */
    1292                 :             : 
    1293                 :             : /* Nonzero if NODE is an empty statement (NOP_EXPR <0>).  */
    1294                 :             : #define IS_EMPTY_STMT(NODE)     (TREE_CODE (NODE) == NOP_EXPR \
    1295                 :             :                                  && VOID_TYPE_P (TREE_TYPE (NODE)) \
    1296                 :             :                                  && integer_zerop (TREE_OPERAND (NODE, 0)))
    1297                 :             : 
    1298                 :             : /* In ordinary expression nodes.  */
    1299                 :             : #define TREE_OPERAND_LENGTH(NODE) tree_operand_length (NODE)
    1300                 :             : #define TREE_OPERAND(NODE, I) TREE_OPERAND_CHECK (NODE, I)
    1301                 :             : 
    1302                 :             : /* In a tcc_vl_exp node, operand 0 is an INT_CST node holding the operand
    1303                 :             :    length.  Its value includes the length operand itself; that is,
    1304                 :             :    the minimum valid length is 1.
    1305                 :             :    Note that we have to bypass the use of TREE_OPERAND to access
    1306                 :             :    that field to avoid infinite recursion in expanding the macros.  */
    1307                 :             : #define VL_EXP_OPERAND_LENGTH(NODE) \
    1308                 :             :   ((int)TREE_INT_CST_LOW (VL_EXP_CHECK (NODE)->exp.operands[0]))
    1309                 :             : 
    1310                 :             : /* Nonzero if gimple_debug_nonbind_marker_p() may possibly hold.  */
    1311                 :             : #define MAY_HAVE_DEBUG_MARKER_STMTS debug_nonbind_markers_p
    1312                 :             : /* Nonzero if gimple_debug_bind_p() (and thus
    1313                 :             :    gimple_debug_source_bind_p()) may possibly hold.  */
    1314                 :             : #define MAY_HAVE_DEBUG_BIND_STMTS flag_var_tracking_assignments
    1315                 :             : /* Nonzero if is_gimple_debug() may possibly hold.  */
    1316                 :             : #define MAY_HAVE_DEBUG_STMTS                                    \
    1317                 :             :   (MAY_HAVE_DEBUG_MARKER_STMTS || MAY_HAVE_DEBUG_BIND_STMTS)
    1318                 :             : 
    1319                 :             : /* In a LOOP_EXPR node.  */
    1320                 :             : #define LOOP_EXPR_BODY(NODE) TREE_OPERAND_CHECK_CODE (NODE, LOOP_EXPR, 0)
    1321                 :             : 
    1322                 :             : /* The source location of this expression.  Non-tree_exp nodes such as
    1323                 :             :    decls and constants can be shared among multiple locations, so
    1324                 :             :    return nothing.  */
    1325                 :             : #define EXPR_LOCATION(NODE) \
    1326                 :             :   (CAN_HAVE_LOCATION_P ((NODE)) ? (NODE)->exp.locus : UNKNOWN_LOCATION)
    1327                 :             : #define SET_EXPR_LOCATION(NODE, LOCUS) EXPR_CHECK ((NODE))->exp.locus = (LOCUS)
    1328                 :             : #define EXPR_HAS_LOCATION(NODE) (LOCATION_LOCUS (EXPR_LOCATION (NODE))  \
    1329                 :             :   != UNKNOWN_LOCATION)
    1330                 :             : /* The location to be used in a diagnostic about this expression.  Do not
    1331                 :             :    use this macro if the location will be assigned to other expressions.  */
    1332                 :             : #define EXPR_LOC_OR_LOC(NODE, LOCUS) (EXPR_HAS_LOCATION (NODE) \
    1333                 :             :                                       ? (NODE)->exp.locus : (LOCUS))
    1334                 :             : #define EXPR_FILENAME(NODE) LOCATION_FILE (EXPR_CHECK ((NODE))->exp.locus)
    1335                 :             : #define EXPR_LINENO(NODE) LOCATION_LINE (EXPR_CHECK (NODE)->exp.locus)
    1336                 :             : 
    1337                 :             : #define CAN_HAVE_RANGE_P(NODE) (CAN_HAVE_LOCATION_P (NODE))
    1338                 :             : #define EXPR_LOCATION_RANGE(NODE) (get_expr_source_range (EXPR_CHECK ((NODE))))
    1339                 :             : 
    1340                 :             : #define EXPR_HAS_RANGE(NODE) \
    1341                 :             :     (CAN_HAVE_RANGE_P (NODE) \
    1342                 :             :      ? EXPR_LOCATION_RANGE (NODE).m_start != UNKNOWN_LOCATION \
    1343                 :             :      : false)
    1344                 :             : 
    1345                 :             : /* True if a tree is an expression or statement that can have a
    1346                 :             :    location.  */
    1347                 :             : #define CAN_HAVE_LOCATION_P(NODE) ((NODE) && EXPR_P (NODE))
    1348                 :             : 
    1349                 :             : inline source_range
    1350                 :   262520785 : get_expr_source_range (tree expr)
    1351                 :             : {
    1352                 :   262520785 :   location_t loc = EXPR_LOCATION (expr);
    1353                 :   262520785 :   return get_range_from_loc (line_table, loc);
    1354                 :             : }
    1355                 :             : 
    1356                 :             : extern void protected_set_expr_location (tree, location_t);
    1357                 :             : extern void protected_set_expr_location_if_unset (tree, location_t);
    1358                 :             : ATTRIBUTE_WARN_UNUSED_RESULT
    1359                 :             : extern tree protected_set_expr_location_unshare (tree, location_t);
    1360                 :             : 
    1361                 :             : WARN_UNUSED_RESULT extern tree maybe_wrap_with_location (tree, location_t);
    1362                 :             : 
    1363                 :             : extern int suppress_location_wrappers;
    1364                 :             : 
    1365                 :             : /* A class for suppressing the creation of location wrappers.
    1366                 :             :    Location wrappers will not be created during the lifetime
    1367                 :             :    of an instance of this class.  */
    1368                 :             : 
    1369                 :             : class auto_suppress_location_wrappers
    1370                 :             : {
    1371                 :             :  public:
    1372                 :  1421891034 :   auto_suppress_location_wrappers () { ++suppress_location_wrappers; }
    1373                 :       24523 :   ~auto_suppress_location_wrappers () { --suppress_location_wrappers; }
    1374                 :             : };
    1375                 :             : 
    1376                 :             : /* In a TARGET_EXPR node.  */
    1377                 :             : #define TARGET_EXPR_SLOT(NODE) TREE_OPERAND_CHECK_CODE (NODE, TARGET_EXPR, 0)
    1378                 :             : #define TARGET_EXPR_INITIAL(NODE) TREE_OPERAND_CHECK_CODE (NODE, TARGET_EXPR, 1)
    1379                 :             : #define TARGET_EXPR_CLEANUP(NODE) TREE_OPERAND_CHECK_CODE (NODE, TARGET_EXPR, 2)
    1380                 :             : /* Don't elide the initialization of TARGET_EXPR_SLOT for this TARGET_EXPR
    1381                 :             :    on rhs of MODIFY_EXPR.  */
    1382                 :             : #define TARGET_EXPR_NO_ELIDE(NODE) (TARGET_EXPR_CHECK (NODE)->base.private_flag)
    1383                 :             : 
    1384                 :             : /* DECL_EXPR accessor. This gives access to the DECL associated with
    1385                 :             :    the given declaration statement.  */
    1386                 :             : #define DECL_EXPR_DECL(NODE)    TREE_OPERAND (DECL_EXPR_CHECK (NODE), 0)
    1387                 :             : 
    1388                 :             : #define EXIT_EXPR_COND(NODE)         TREE_OPERAND (EXIT_EXPR_CHECK (NODE), 0)
    1389                 :             : 
    1390                 :             : /* COMPOUND_LITERAL_EXPR accessors.  */
    1391                 :             : #define COMPOUND_LITERAL_EXPR_DECL_EXPR(NODE)           \
    1392                 :             :   TREE_OPERAND (COMPOUND_LITERAL_EXPR_CHECK (NODE), 0)
    1393                 :             : #define COMPOUND_LITERAL_EXPR_DECL(NODE)                        \
    1394                 :             :   DECL_EXPR_DECL (COMPOUND_LITERAL_EXPR_DECL_EXPR (NODE))
    1395                 :             : 
    1396                 :             : /* SWITCH_EXPR accessors. These give access to the condition and body.  */
    1397                 :             : #define SWITCH_COND(NODE)       TREE_OPERAND (SWITCH_EXPR_CHECK (NODE), 0)
    1398                 :             : #define SWITCH_BODY(NODE)       TREE_OPERAND (SWITCH_EXPR_CHECK (NODE), 1)
    1399                 :             : /* True if there are case labels for all possible values of SWITCH_COND, either
    1400                 :             :    because there is a default: case label or because the case label ranges cover
    1401                 :             :    all values.  */
    1402                 :             : #define SWITCH_ALL_CASES_P(NODE) (SWITCH_EXPR_CHECK (NODE)->base.private_flag)
    1403                 :             : 
    1404                 :             : /* CASE_LABEL_EXPR accessors. These give access to the high and low values
    1405                 :             :    of a case label, respectively.  */
    1406                 :             : #define CASE_LOW(NODE)                  TREE_OPERAND (CASE_LABEL_EXPR_CHECK (NODE), 0)
    1407                 :             : #define CASE_HIGH(NODE)                 TREE_OPERAND (CASE_LABEL_EXPR_CHECK (NODE), 1)
    1408                 :             : #define CASE_LABEL(NODE)                TREE_OPERAND (CASE_LABEL_EXPR_CHECK (NODE), 2)
    1409                 :             : #define CASE_CHAIN(NODE)                TREE_OPERAND (CASE_LABEL_EXPR_CHECK (NODE), 3)
    1410                 :             : 
    1411                 :             : /* The operands of a TARGET_MEM_REF.  Operands 0 and 1 have to match
    1412                 :             :    corresponding MEM_REF operands.  */
    1413                 :             : #define TMR_BASE(NODE) (TREE_OPERAND (TARGET_MEM_REF_CHECK (NODE), 0))
    1414                 :             : #define TMR_OFFSET(NODE) (TREE_OPERAND (TARGET_MEM_REF_CHECK (NODE), 1))
    1415                 :             : #define TMR_INDEX(NODE) (TREE_OPERAND (TARGET_MEM_REF_CHECK (NODE), 2))
    1416                 :             : #define TMR_STEP(NODE) (TREE_OPERAND (TARGET_MEM_REF_CHECK (NODE), 3))
    1417                 :             : #define TMR_INDEX2(NODE) (TREE_OPERAND (TARGET_MEM_REF_CHECK (NODE), 4))
    1418                 :             : 
    1419                 :             : #define MR_DEPENDENCE_CLIQUE(NODE) \
    1420                 :             :   (TREE_CHECK2 (NODE, MEM_REF, TARGET_MEM_REF)->base.u.dependence_info.clique)
    1421                 :             : #define MR_DEPENDENCE_BASE(NODE) \
    1422                 :             :   (TREE_CHECK2 (NODE, MEM_REF, TARGET_MEM_REF)->base.u.dependence_info.base)
    1423                 :             : 
    1424                 :             : /* The operands of a BIND_EXPR.  */
    1425                 :             : #define BIND_EXPR_VARS(NODE) (TREE_OPERAND (BIND_EXPR_CHECK (NODE), 0))
    1426                 :             : #define BIND_EXPR_BODY(NODE) (TREE_OPERAND (BIND_EXPR_CHECK (NODE), 1))
    1427                 :             : #define BIND_EXPR_BLOCK(NODE) (TREE_OPERAND (BIND_EXPR_CHECK (NODE), 2))
    1428                 :             : 
    1429                 :             : /* GOTO_EXPR accessor. This gives access to the label associated with
    1430                 :             :    a goto statement.  */
    1431                 :             : #define GOTO_DESTINATION(NODE)  TREE_OPERAND (GOTO_EXPR_CHECK (NODE), 0)
    1432                 :             : 
    1433                 :             : /* ASM_EXPR accessors. ASM_STRING returns a STRING_CST for the
    1434                 :             :    instruction (e.g., "mov x, y"). ASM_OUTPUTS, ASM_INPUTS, and
    1435                 :             :    ASM_CLOBBERS represent the outputs, inputs, and clobbers for the
    1436                 :             :    statement.  */
    1437                 :             : #define ASM_STRING(NODE)        TREE_OPERAND (ASM_EXPR_CHECK (NODE), 0)
    1438                 :             : #define ASM_OUTPUTS(NODE)       TREE_OPERAND (ASM_EXPR_CHECK (NODE), 1)
    1439                 :             : #define ASM_INPUTS(NODE)        TREE_OPERAND (ASM_EXPR_CHECK (NODE), 2)
    1440                 :             : #define ASM_CLOBBERS(NODE)      TREE_OPERAND (ASM_EXPR_CHECK (NODE), 3)
    1441                 :             : #define ASM_LABELS(NODE)        TREE_OPERAND (ASM_EXPR_CHECK (NODE), 4)
    1442                 :             : /* Nonzero if the asm is a basic asm, zero if it is an extended asm.
    1443                 :             :    Basic asms use a plain ASM_INPUT insn pattern whereas extended asms
    1444                 :             :    use an ASM_OPERANDS insn pattern.  */
    1445                 :             : #define ASM_BASIC_P(NODE)       (ASM_EXPR_CHECK (NODE)->base.static_flag)
    1446                 :             : #define ASM_VOLATILE_P(NODE)    (ASM_EXPR_CHECK (NODE)->base.public_flag)
    1447                 :             : /* Nonzero if we want to consider this asm as minimum length and cost
    1448                 :             :    for inlining decisions.  */
    1449                 :             : #define ASM_INLINE_P(NODE)      (ASM_EXPR_CHECK (NODE)->base.protected_flag)
    1450                 :             : 
    1451                 :             : /* COND_EXPR accessors.  */
    1452                 :             : #define COND_EXPR_COND(NODE)    (TREE_OPERAND (COND_EXPR_CHECK (NODE), 0))
    1453                 :             : #define COND_EXPR_THEN(NODE)    (TREE_OPERAND (COND_EXPR_CHECK (NODE), 1))
    1454                 :             : #define COND_EXPR_ELSE(NODE)    (TREE_OPERAND (COND_EXPR_CHECK (NODE), 2))
    1455                 :             : 
    1456                 :             : /* Accessors for the chains of recurrences.  */
    1457                 :             : #define CHREC_LEFT(NODE)        TREE_OPERAND (POLYNOMIAL_CHREC_CHECK (NODE), 0)
    1458                 :             : #define CHREC_RIGHT(NODE)       TREE_OPERAND (POLYNOMIAL_CHREC_CHECK (NODE), 1)
    1459                 :             : #define CHREC_VARIABLE(NODE)    POLYNOMIAL_CHREC_CHECK (NODE)->base.u.chrec_var
    1460                 :             : /* Nonzero if this chrec doesn't overflow (i.e., nonwrapping).  */
    1461                 :             : #define CHREC_NOWRAP(NODE)      POLYNOMIAL_CHREC_CHECK (NODE)->base.nothrow_flag
    1462                 :             : 
    1463                 :             : /* LABEL_EXPR accessor. This gives access to the label associated with
    1464                 :             :    the given label expression.  */
    1465                 :             : #define LABEL_EXPR_LABEL(NODE)  TREE_OPERAND (LABEL_EXPR_CHECK (NODE), 0)
    1466                 :             : 
    1467                 :             : /* CATCH_EXPR accessors.  */
    1468                 :             : #define CATCH_TYPES(NODE)       TREE_OPERAND (CATCH_EXPR_CHECK (NODE), 0)
    1469                 :             : #define CATCH_BODY(NODE)        TREE_OPERAND (CATCH_EXPR_CHECK (NODE), 1)
    1470                 :             : 
    1471                 :             : /* EH_FILTER_EXPR accessors.  */
    1472                 :             : #define EH_FILTER_TYPES(NODE)   TREE_OPERAND (EH_FILTER_EXPR_CHECK (NODE), 0)
    1473                 :             : #define EH_FILTER_FAILURE(NODE) TREE_OPERAND (EH_FILTER_EXPR_CHECK (NODE), 1)
    1474                 :             : 
    1475                 :             : /* OBJ_TYPE_REF accessors.  */
    1476                 :             : #define OBJ_TYPE_REF_EXPR(NODE)   TREE_OPERAND (OBJ_TYPE_REF_CHECK (NODE), 0)
    1477                 :             : #define OBJ_TYPE_REF_OBJECT(NODE) TREE_OPERAND (OBJ_TYPE_REF_CHECK (NODE), 1)
    1478                 :             : #define OBJ_TYPE_REF_TOKEN(NODE)  TREE_OPERAND (OBJ_TYPE_REF_CHECK (NODE), 2)
    1479                 :             : 
    1480                 :             : /* CALL_EXPR accessors.  */
    1481                 :             : #define CALL_EXPR_FN(NODE) TREE_OPERAND (CALL_EXPR_CHECK (NODE), 1)
    1482                 :             : #define CALL_EXPR_STATIC_CHAIN(NODE) TREE_OPERAND (CALL_EXPR_CHECK (NODE), 2)
    1483                 :             : #define CALL_EXPR_ARG(NODE, I) TREE_OPERAND (CALL_EXPR_CHECK (NODE), (I) + 3)
    1484                 :             : #define call_expr_nargs(NODE) (VL_EXP_OPERAND_LENGTH (NODE) - 3)
    1485                 :             : #define CALL_EXPR_IFN(NODE) (CALL_EXPR_CHECK (NODE)->base.u.ifn)
    1486                 :             : 
    1487                 :             : /* CALL_EXPR_ARGP returns a pointer to the argument vector for NODE.
    1488                 :             :    We can't use &CALL_EXPR_ARG (NODE, 0) because that will complain if
    1489                 :             :    the argument count is zero when checking is enabled.  Instead, do
    1490                 :             :    the pointer arithmetic to advance past the 3 fixed operands in a
    1491                 :             :    CALL_EXPR.  That produces a valid pointer to just past the end of the
    1492                 :             :    operand array, even if it's not valid to dereference it.  */
    1493                 :             : #define CALL_EXPR_ARGP(NODE) \
    1494                 :             :   (&(TREE_OPERAND (CALL_EXPR_CHECK (NODE), 0)) + 3)
    1495                 :             : 
    1496                 :             : /* TM directives and accessors.  */
    1497                 :             : #define TRANSACTION_EXPR_BODY(NODE) \
    1498                 :             :   TREE_OPERAND (TRANSACTION_EXPR_CHECK (NODE), 0)
    1499                 :             : #define TRANSACTION_EXPR_OUTER(NODE) \
    1500                 :             :   (TRANSACTION_EXPR_CHECK (NODE)->base.static_flag)
    1501                 :             : #define TRANSACTION_EXPR_RELAXED(NODE) \
    1502                 :             :   (TRANSACTION_EXPR_CHECK (NODE)->base.public_flag)
    1503                 :             : 
    1504                 :             : /* OpenMP and OpenACC directive and clause accessors.  */
    1505                 :             : 
    1506                 :             : /* Generic accessors for OMP nodes that keep the body as operand 0, and clauses
    1507                 :             :    as operand 1.  */
    1508                 :             : #define OMP_BODY(NODE) \
    1509                 :             :   TREE_OPERAND (TREE_RANGE_CHECK (NODE, OACC_PARALLEL, OMP_MASTER), 0)
    1510                 :             : #define OMP_CLAUSES(NODE) \
    1511                 :             :   TREE_OPERAND (TREE_RANGE_CHECK (NODE, OACC_PARALLEL, OMP_SCAN), 1)
    1512                 :             : 
    1513                 :             : /* Generic accessors for OMP nodes that keep clauses as operand 0.  */
    1514                 :             : #define OMP_STANDALONE_CLAUSES(NODE) \
    1515                 :             :   TREE_OPERAND (TREE_RANGE_CHECK (NODE, OACC_CACHE, OMP_TARGET_EXIT_DATA), 0)
    1516                 :             : 
    1517                 :             : #define OACC_DATA_BODY(NODE) \
    1518                 :             :   TREE_OPERAND (OACC_DATA_CHECK (NODE), 0)
    1519                 :             : #define OACC_DATA_CLAUSES(NODE) \
    1520                 :             :   TREE_OPERAND (OACC_DATA_CHECK (NODE), 1)
    1521                 :             : 
    1522                 :             : #define OACC_HOST_DATA_BODY(NODE) \
    1523                 :             :   TREE_OPERAND (OACC_HOST_DATA_CHECK (NODE), 0)
    1524                 :             : #define OACC_HOST_DATA_CLAUSES(NODE) \
    1525                 :             :   TREE_OPERAND (OACC_HOST_DATA_CHECK (NODE), 1)
    1526                 :             : 
    1527                 :             : #define OACC_CACHE_CLAUSES(NODE) \
    1528                 :             :   TREE_OPERAND (OACC_CACHE_CHECK (NODE), 0)
    1529                 :             : 
    1530                 :             : #define OACC_DECLARE_CLAUSES(NODE) \
    1531                 :             :   TREE_OPERAND (OACC_DECLARE_CHECK (NODE), 0)
    1532                 :             : 
    1533                 :             : #define OACC_ENTER_DATA_CLAUSES(NODE) \
    1534                 :             :   TREE_OPERAND (OACC_ENTER_DATA_CHECK (NODE), 0)
    1535                 :             : 
    1536                 :             : #define OACC_EXIT_DATA_CLAUSES(NODE) \
    1537                 :             :   TREE_OPERAND (OACC_EXIT_DATA_CHECK (NODE), 0)
    1538                 :             : 
    1539                 :             : #define OACC_UPDATE_CLAUSES(NODE) \
    1540                 :             :   TREE_OPERAND (OACC_UPDATE_CHECK (NODE), 0)
    1541                 :             : 
    1542                 :             : #define OMP_PARALLEL_BODY(NODE)    TREE_OPERAND (OMP_PARALLEL_CHECK (NODE), 0)
    1543                 :             : #define OMP_PARALLEL_CLAUSES(NODE) TREE_OPERAND (OMP_PARALLEL_CHECK (NODE), 1)
    1544                 :             : 
    1545                 :             : #define OMP_TASK_BODY(NODE)        TREE_OPERAND (OMP_TASK_CHECK (NODE), 0)
    1546                 :             : #define OMP_TASK_CLAUSES(NODE)     TREE_OPERAND (OMP_TASK_CHECK (NODE), 1)
    1547                 :             : 
    1548                 :             : #define OMP_TASKREG_CHECK(NODE)   TREE_RANGE_CHECK (NODE, OMP_PARALLEL, OMP_TASK)
    1549                 :             : #define OMP_TASKREG_BODY(NODE)    TREE_OPERAND (OMP_TASKREG_CHECK (NODE), 0)
    1550                 :             : #define OMP_TASKREG_CLAUSES(NODE) TREE_OPERAND (OMP_TASKREG_CHECK (NODE), 1)
    1551                 :             : 
    1552                 :             : #define OMP_LOOPING_CHECK(NODE) TREE_RANGE_CHECK (NODE, OMP_FOR, OACC_LOOP)
    1553                 :             : #define OMP_FOR_BODY(NODE)         TREE_OPERAND (OMP_LOOPING_CHECK (NODE), 0)
    1554                 :             : #define OMP_FOR_CLAUSES(NODE)      TREE_OPERAND (OMP_LOOPING_CHECK (NODE), 1)
    1555                 :             : #define OMP_FOR_INIT(NODE)         TREE_OPERAND (OMP_LOOPING_CHECK (NODE), 2)
    1556                 :             : #define OMP_FOR_COND(NODE)         TREE_OPERAND (OMP_LOOPING_CHECK (NODE), 3)
    1557                 :             : #define OMP_FOR_INCR(NODE)         TREE_OPERAND (OMP_LOOPING_CHECK (NODE), 4)
    1558                 :             : #define OMP_FOR_PRE_BODY(NODE)     TREE_OPERAND (OMP_LOOPING_CHECK (NODE), 5)
    1559                 :             : #define OMP_FOR_ORIG_DECLS(NODE)   TREE_OPERAND (OMP_LOOPING_CHECK (NODE), 6)
    1560                 :             : 
    1561                 :             : #define OMP_INTEROP_CLAUSES(NODE)\
    1562                 :             :   TREE_OPERAND (OMP_INTEROP_CHECK (NODE), 0)
    1563                 :             : 
    1564                 :             : #define OMP_LOOPXFORM_CHECK(NODE) TREE_RANGE_CHECK (NODE, OMP_TILE, OMP_UNROLL)
    1565                 :             : #define OMP_LOOPXFORM_LOWERED(NODE) \
    1566                 :             :   (OMP_LOOPXFORM_CHECK (NODE)->base.public_flag)
    1567                 :             : 
    1568                 :             : #define OMP_SECTIONS_BODY(NODE)    TREE_OPERAND (OMP_SECTIONS_CHECK (NODE), 0)
    1569                 :             : #define OMP_SECTIONS_CLAUSES(NODE) TREE_OPERAND (OMP_SECTIONS_CHECK (NODE), 1)
    1570                 :             : 
    1571                 :             : #define OMP_SECTION_BODY(NODE)     TREE_OPERAND (OMP_SECTION_CHECK (NODE), 0)
    1572                 :             : 
    1573                 :             : #define OMP_STRUCTURED_BLOCK_BODY(NODE) \
    1574                 :             :   TREE_OPERAND (OMP_STRUCTURED_BLOCK_CHECK (NODE), 0)
    1575                 :             : 
    1576                 :             : #define OMP_SINGLE_BODY(NODE)      TREE_OPERAND (OMP_SINGLE_CHECK (NODE), 0)
    1577                 :             : #define OMP_SINGLE_CLAUSES(NODE)   TREE_OPERAND (OMP_SINGLE_CHECK (NODE), 1)
    1578                 :             : 
    1579                 :             : #define OMP_SCOPE_BODY(NODE)       TREE_OPERAND (OMP_SCOPE_CHECK (NODE), 0)
    1580                 :             : #define OMP_SCOPE_CLAUSES(NODE)    TREE_OPERAND (OMP_SCOPE_CHECK (NODE), 1)
    1581                 :             : 
    1582                 :             : #define OMP_MASTER_BODY(NODE)      TREE_OPERAND (OMP_MASTER_CHECK (NODE), 0)
    1583                 :             : 
    1584                 :             : #define OMP_MASKED_BODY(NODE)      TREE_OPERAND (OMP_MASKED_CHECK (NODE), 0)
    1585                 :             : #define OMP_MASKED_CLAUSES(NODE)   TREE_OPERAND (OMP_MASKED_CHECK (NODE), 1)
    1586                 :             : 
    1587                 :             : #define OMP_TASKGROUP_BODY(NODE)   TREE_OPERAND (OMP_TASKGROUP_CHECK (NODE), 0)
    1588                 :             : #define OMP_TASKGROUP_CLAUSES(NODE) \
    1589                 :             :   TREE_OPERAND (OMP_TASKGROUP_CHECK (NODE), 1)
    1590                 :             : 
    1591                 :             : #define OMP_ORDERED_BODY(NODE)     TREE_OPERAND (OMP_ORDERED_CHECK (NODE), 0)
    1592                 :             : #define OMP_ORDERED_CLAUSES(NODE)  TREE_OPERAND (OMP_ORDERED_CHECK (NODE), 1)
    1593                 :             : 
    1594                 :             : #define OMP_CRITICAL_BODY(NODE)    TREE_OPERAND (OMP_CRITICAL_CHECK (NODE), 0)
    1595                 :             : #define OMP_CRITICAL_CLAUSES(NODE) TREE_OPERAND (OMP_CRITICAL_CHECK (NODE), 1)
    1596                 :             : #define OMP_CRITICAL_NAME(NODE)    TREE_OPERAND (OMP_CRITICAL_CHECK (NODE), 2)
    1597                 :             : 
    1598                 :             : #define OMP_TEAMS_BODY(NODE)       TREE_OPERAND (OMP_TEAMS_CHECK (NODE), 0)
    1599                 :             : #define OMP_TEAMS_CLAUSES(NODE)    TREE_OPERAND (OMP_TEAMS_CHECK (NODE), 1)
    1600                 :             : 
    1601                 :             : #define OMP_TARGET_DATA_BODY(NODE) \
    1602                 :             :   TREE_OPERAND (OMP_TARGET_DATA_CHECK (NODE), 0)
    1603                 :             : #define OMP_TARGET_DATA_CLAUSES(NODE)\
    1604                 :             :   TREE_OPERAND (OMP_TARGET_DATA_CHECK (NODE), 1)
    1605                 :             : 
    1606                 :             : #define OMP_TARGET_BODY(NODE)      TREE_OPERAND (OMP_TARGET_CHECK (NODE), 0)
    1607                 :             : #define OMP_TARGET_CLAUSES(NODE)   TREE_OPERAND (OMP_TARGET_CHECK (NODE), 1)
    1608                 :             : 
    1609                 :             : #define OMP_TARGET_UPDATE_CLAUSES(NODE)\
    1610                 :             :   TREE_OPERAND (OMP_TARGET_UPDATE_CHECK (NODE), 0)
    1611                 :             : 
    1612                 :             : #define OMP_TARGET_ENTER_DATA_CLAUSES(NODE)\
    1613                 :             :   TREE_OPERAND (OMP_TARGET_ENTER_DATA_CHECK (NODE), 0)
    1614                 :             : 
    1615                 :             : #define OMP_TARGET_EXIT_DATA_CLAUSES(NODE)\
    1616                 :             :   TREE_OPERAND (OMP_TARGET_EXIT_DATA_CHECK (NODE), 0)
    1617                 :             : 
    1618                 :             : #define OMP_SCAN_BODY(NODE)     TREE_OPERAND (OMP_SCAN_CHECK (NODE), 0)
    1619                 :             : #define OMP_SCAN_CLAUSES(NODE)  TREE_OPERAND (OMP_SCAN_CHECK (NODE), 1)
    1620                 :             : 
    1621                 :             : #define OMP_DISPATCH_BODY(NODE) TREE_OPERAND (OMP_DISPATCH_CHECK (NODE), 0)
    1622                 :             : #define OMP_DISPATCH_CLAUSES(NODE) TREE_OPERAND (OMP_DISPATCH_CHECK (NODE), 1)
    1623                 :             : 
    1624                 :             : #define OMP_CLAUSE_SIZE(NODE)                                           \
    1625                 :             :   OMP_CLAUSE_OPERAND (OMP_CLAUSE_RANGE_CHECK (OMP_CLAUSE_CHECK (NODE),  \
    1626                 :             :                                               OMP_CLAUSE_FROM,          \
    1627                 :             :                                               OMP_CLAUSE__CACHE_), 1)
    1628                 :             : 
    1629                 :             : #define OMP_CLAUSE_CHAIN(NODE)     TREE_CHAIN (OMP_CLAUSE_CHECK (NODE))
    1630                 :             : #define OMP_CLAUSE_DECL(NODE)                                           \
    1631                 :             :   OMP_CLAUSE_OPERAND (OMP_CLAUSE_RANGE_CHECK (OMP_CLAUSE_CHECK (NODE),  \
    1632                 :             :                                               OMP_CLAUSE_PRIVATE,       \
    1633                 :             :                                               OMP_CLAUSE__SCANTEMP_), 0)
    1634                 :             : #define OMP_CLAUSE_HAS_LOCATION(NODE) \
    1635                 :             :   (LOCATION_LOCUS ((OMP_CLAUSE_CHECK (NODE))->omp_clause.locus)              \
    1636                 :             :   != UNKNOWN_LOCATION)
    1637                 :             : #define OMP_CLAUSE_LOCATION(NODE)  (OMP_CLAUSE_CHECK (NODE))->omp_clause.locus
    1638                 :             : 
    1639                 :             : /* True on OMP_FOR and other OpenMP/OpenACC looping constructs if the loop nest
    1640                 :             :    is non-rectangular.  */
    1641                 :             : #define OMP_FOR_NON_RECTANGULAR(NODE) \
    1642                 :             :   (OMP_LOOPING_CHECK (NODE)->base.private_flag)
    1643                 :             : 
    1644                 :             : /* True on an OMP_SECTION statement that was the last lexical member.
    1645                 :             :    This status is meaningful in the implementation of lastprivate.  */
    1646                 :             : #define OMP_SECTION_LAST(NODE) \
    1647                 :             :   (OMP_SECTION_CHECK (NODE)->base.private_flag)
    1648                 :             : 
    1649                 :             : /* True on an OMP_PARALLEL statement if it represents an explicit
    1650                 :             :    combined parallel work-sharing constructs.  */
    1651                 :             : #define OMP_PARALLEL_COMBINED(NODE) \
    1652                 :             :   (OMP_PARALLEL_CHECK (NODE)->base.private_flag)
    1653                 :             : 
    1654                 :             : /* True on an OMP_TEAMS statement if it represents an explicit
    1655                 :             :    combined teams distribute constructs.  */
    1656                 :             : #define OMP_TEAMS_COMBINED(NODE) \
    1657                 :             :   (OMP_TEAMS_CHECK (NODE)->base.private_flag)
    1658                 :             : 
    1659                 :             : /* True on an OMP_TARGET statement if it represents explicit
    1660                 :             :    combined target teams, target parallel or target simd constructs.  */
    1661                 :             : #define OMP_TARGET_COMBINED(NODE) \
    1662                 :             :   (OMP_TARGET_CHECK (NODE)->base.private_flag)
    1663                 :             : 
    1664                 :             : /* True on an OMP_MASTER statement if it represents an explicit
    1665                 :             :    combined master constructs.  */
    1666                 :             : #define OMP_MASTER_COMBINED(NODE) \
    1667                 :             :   (OMP_MASTER_CHECK (NODE)->base.private_flag)
    1668                 :             : 
    1669                 :             : /* True on an OMP_MASKED statement if it represents an explicit
    1670                 :             :    combined masked constructs.  */
    1671                 :             : #define OMP_MASKED_COMBINED(NODE) \
    1672                 :             :   (OMP_MASKED_CHECK (NODE)->base.private_flag)
    1673                 :             : 
    1674                 :             : /* Memory order for OMP_ATOMIC*.  */
    1675                 :             : #define OMP_ATOMIC_MEMORY_ORDER(NODE) \
    1676                 :             :   (TREE_RANGE_CHECK (NODE, OMP_ATOMIC, \
    1677                 :             :                      OMP_ATOMIC_CAPTURE_NEW)->base.u.omp_atomic_memory_order)
    1678                 :             : 
    1679                 :             : /* Weak clause on OMP_ATOMIC*.  */
    1680                 :             : #define OMP_ATOMIC_WEAK(NODE) \
    1681                 :             :   (TREE_RANGE_CHECK (NODE, OMP_ATOMIC, \
    1682                 :             :                      OMP_ATOMIC_CAPTURE_NEW)->base.public_flag)
    1683                 :             : 
    1684                 :             : /* True on a PRIVATE clause if its decl is kept around for debugging
    1685                 :             :    information only and its DECL_VALUE_EXPR is supposed to point
    1686                 :             :    to what it has been remapped to.  */
    1687                 :             : #define OMP_CLAUSE_PRIVATE_DEBUG(NODE) \
    1688                 :             :   (OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_PRIVATE)->base.public_flag)
    1689                 :             : 
    1690                 :             : /* True on a PRIVATE clause if ctor needs access to outer region's
    1691                 :             :    variable.  */
    1692                 :             : #define OMP_CLAUSE_PRIVATE_OUTER_REF(NODE) \
    1693                 :             :   TREE_PRIVATE (OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_PRIVATE))
    1694                 :             : 
    1695                 :             : /* True if a PRIVATE clause is for a C++ class IV on taskloop construct
    1696                 :             :    (thus should be private on the outer taskloop and firstprivate on
    1697                 :             :    task).  */
    1698                 :             : #define OMP_CLAUSE_PRIVATE_TASKLOOP_IV(NODE) \
    1699                 :             :   TREE_PROTECTED (OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_PRIVATE))
    1700                 :             : 
    1701                 :             : /* True on a FIRSTPRIVATE clause if it has been added implicitly.  */
    1702                 :             : #define OMP_CLAUSE_FIRSTPRIVATE_IMPLICIT(NODE) \
    1703                 :             :   (OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_FIRSTPRIVATE)->base.public_flag)
    1704                 :             : 
    1705                 :             : /* True on a FIRSTPRIVATE clause if only the reference and not what it refers
    1706                 :             :    to should be firstprivatized.  */
    1707                 :             : #define OMP_CLAUSE_FIRSTPRIVATE_NO_REFERENCE(NODE) \
    1708                 :             :   TREE_PRIVATE (OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_FIRSTPRIVATE))
    1709                 :             : 
    1710                 :             : /* True on a FIRSTPRIVATE clause with OMP_CLAUSE_FIRSTPRIVATE_IMPLICIT also
    1711                 :             :    set if target construct is the only one that accepts the clause.  */
    1712                 :             : #define OMP_CLAUSE_FIRSTPRIVATE_IMPLICIT_TARGET(NODE) \
    1713                 :             :   TREE_PROTECTED (OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_FIRSTPRIVATE))
    1714                 :             : 
    1715                 :             : /* True on a LASTPRIVATE clause if a FIRSTPRIVATE clause for the same
    1716                 :             :    decl is present in the chain.  */
    1717                 :             : #define OMP_CLAUSE_LASTPRIVATE_FIRSTPRIVATE(NODE) \
    1718                 :             :   (OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_LASTPRIVATE)->base.public_flag)
    1719                 :             : #define OMP_CLAUSE_LASTPRIVATE_STMT(NODE) \
    1720                 :             :   OMP_CLAUSE_OPERAND (OMP_CLAUSE_SUBCODE_CHECK (NODE,                   \
    1721                 :             :                                                 OMP_CLAUSE_LASTPRIVATE),\
    1722                 :             :                       1)
    1723                 :             : #define OMP_CLAUSE_LASTPRIVATE_GIMPLE_SEQ(NODE) \
    1724                 :             :   (OMP_CLAUSE_CHECK (NODE))->omp_clause.gimple_reduction_init
    1725                 :             : 
    1726                 :             : /* True if a LASTPRIVATE clause is for a C++ class IV on taskloop or
    1727                 :             :    loop construct (thus should be lastprivate on the outer taskloop and
    1728                 :             :    firstprivate on task for the taskloop construct and carefully handled
    1729                 :             :    for loop construct).  */
    1730                 :             : #define OMP_CLAUSE_LASTPRIVATE_LOOP_IV(NODE) \
    1731                 :             :   TREE_PROTECTED (OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_LASTPRIVATE))
    1732                 :             : 
    1733                 :             : /* True if a LASTPRIVATE clause has CONDITIONAL: modifier.  */
    1734                 :             : #define OMP_CLAUSE_LASTPRIVATE_CONDITIONAL(NODE) \
    1735                 :             :   TREE_PRIVATE (OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_LASTPRIVATE))
    1736                 :             : 
    1737                 :             : /* True on a SHARED clause if a FIRSTPRIVATE clause for the same
    1738                 :             :    decl is present in the chain (this can happen only for taskloop
    1739                 :             :    with FIRSTPRIVATE/LASTPRIVATE on it originally.  */
    1740                 :             : #define OMP_CLAUSE_SHARED_FIRSTPRIVATE(NODE) \
    1741                 :             :   (OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_SHARED)->base.public_flag)
    1742                 :             : 
    1743                 :             : /* True on a SHARED clause if a scalar is not modified in the body and
    1744                 :             :    thus could be optimized as firstprivate.  */
    1745                 :             : #define OMP_CLAUSE_SHARED_READONLY(NODE) \
    1746                 :             :   TREE_PRIVATE (OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_SHARED))
    1747                 :             : 
    1748                 :             : #define OMP_CLAUSE_IF_MODIFIER(NODE)    \
    1749                 :             :   (OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_IF)->omp_clause.subcode.if_modifier)
    1750                 :             : 
    1751                 :             : #define OMP_CLAUSE_FINAL_EXPR(NODE) \
    1752                 :             :   OMP_CLAUSE_OPERAND (OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_FINAL), 0)
    1753                 :             : #define OMP_CLAUSE_IF_EXPR(NODE) \
    1754                 :             :   OMP_CLAUSE_OPERAND (OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_IF), 0)
    1755                 :             : #define OMP_CLAUSE_SELF_EXPR(NODE) \
    1756                 :             :   OMP_CLAUSE_OPERAND (OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_SELF), 0)
    1757                 :             : #define OMP_CLAUSE_NUM_THREADS_EXPR(NODE) \
    1758                 :             :   OMP_CLAUSE_OPERAND (OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_NUM_THREADS),0)
    1759                 :             : #define OMP_CLAUSE_SCHEDULE_CHUNK_EXPR(NODE) \
    1760                 :             :   OMP_CLAUSE_OPERAND (OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_SCHEDULE), 0)
    1761                 :             : #define OMP_CLAUSE_NUM_TASKS_EXPR(NODE) \
    1762                 :             :   OMP_CLAUSE_OPERAND (OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_NUM_TASKS), 0)
    1763                 :             : #define OMP_CLAUSE_HINT_EXPR(NODE) \
    1764                 :             :   OMP_CLAUSE_OPERAND (OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_HINT), 0)
    1765                 :             : #define OMP_CLAUSE_FILTER_EXPR(NODE) \
    1766                 :             :   OMP_CLAUSE_OPERAND (OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_FILTER), 0)
    1767                 :             : #define OMP_CLAUSE_PARTIAL_EXPR(NODE) \
    1768                 :             :   OMP_CLAUSE_OPERAND (OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_PARTIAL), 0)
    1769                 :             : #define OMP_CLAUSE_SIZES_LIST(NODE) \
    1770                 :             :   OMP_CLAUSE_OPERAND (OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_SIZES), 0)
    1771                 :             : #define OMP_CLAUSE_NOVARIANTS_EXPR(NODE)                                       \
    1772                 :             :   OMP_CLAUSE_OPERAND (OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_NOVARIANTS), 0)
    1773                 :             : #define OMP_CLAUSE_NOCONTEXT_EXPR(NODE)                                        \
    1774                 :             :   OMP_CLAUSE_OPERAND (OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_NOCONTEXT), 0)
    1775                 :             : 
    1776                 :             : #define OMP_CLAUSE_GRAINSIZE_EXPR(NODE) \
    1777                 :             :   OMP_CLAUSE_OPERAND (OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_GRAINSIZE),0)
    1778                 :             : 
    1779                 :             : #define OMP_CLAUSE_PRIORITY_EXPR(NODE) \
    1780                 :             :   OMP_CLAUSE_OPERAND (OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_PRIORITY),0)
    1781                 :             : 
    1782                 :             : #define OMP_CLAUSE_GRAINSIZE_STRICT(NODE) \
    1783                 :             :   TREE_PRIVATE (OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_GRAINSIZE))
    1784                 :             : #define OMP_CLAUSE_NUM_TASKS_STRICT(NODE) \
    1785                 :             :   TREE_PRIVATE (OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_NUM_TASKS))
    1786                 :             : 
    1787                 :             : /* OpenACC clause expressions  */
    1788                 :             : #define OMP_CLAUSE_EXPR(NODE, CLAUSE) \
    1789                 :             :   OMP_CLAUSE_OPERAND (OMP_CLAUSE_SUBCODE_CHECK (NODE, CLAUSE), 0)
    1790                 :             : #define OMP_CLAUSE_GANG_EXPR(NODE) \
    1791                 :             :   OMP_CLAUSE_OPERAND ( \
    1792                 :             :     OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_GANG), 0)
    1793                 :             : #define OMP_CLAUSE_GANG_STATIC_EXPR(NODE) \
    1794                 :             :   OMP_CLAUSE_OPERAND ( \
    1795                 :             :     OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_GANG), 1)
    1796                 :             : #define OMP_CLAUSE_ASYNC_EXPR(NODE) \
    1797                 :             :   OMP_CLAUSE_OPERAND ( \
    1798                 :             :     OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_ASYNC), 0)
    1799                 :             : #define OMP_CLAUSE_WAIT_EXPR(NODE) \
    1800                 :             :   OMP_CLAUSE_OPERAND ( \
    1801                 :             :     OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_WAIT), 0)
    1802                 :             : #define OMP_CLAUSE_VECTOR_EXPR(NODE) \
    1803                 :             :   OMP_CLAUSE_OPERAND ( \
    1804                 :             :     OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_VECTOR), 0)
    1805                 :             : #define OMP_CLAUSE_WORKER_EXPR(NODE) \
    1806                 :             :   OMP_CLAUSE_OPERAND ( \
    1807                 :             :     OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_WORKER), 0)
    1808                 :             : #define OMP_CLAUSE_NUM_GANGS_EXPR(NODE) \
    1809                 :             :   OMP_CLAUSE_OPERAND ( \
    1810                 :             :     OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_NUM_GANGS), 0)
    1811                 :             : #define OMP_CLAUSE_NUM_WORKERS_EXPR(NODE) \
    1812                 :             :   OMP_CLAUSE_OPERAND ( \
    1813                 :             :     OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_NUM_WORKERS), 0)
    1814                 :             : #define OMP_CLAUSE_VECTOR_LENGTH_EXPR(NODE) \
    1815                 :             :   OMP_CLAUSE_OPERAND ( \
    1816                 :             :     OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_VECTOR_LENGTH), 0)
    1817                 :             : 
    1818                 :             : #define OMP_CLAUSE_DEPEND_KIND(NODE) \
    1819                 :             :   (OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_DEPEND)->omp_clause.subcode.depend_kind)
    1820                 :             : 
    1821                 :             : #define OMP_CLAUSE_DOACROSS_KIND(NODE) \
    1822                 :             :   (OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_DOACROSS)->omp_clause.subcode.doacross_kind)
    1823                 :             : 
    1824                 :             : #define OMP_CLAUSE_DOACROSS_SINK_NEGATIVE(NODE) \
    1825                 :             :   TREE_PUBLIC (TREE_LIST_CHECK (NODE))
    1826                 :             : 
    1827                 :             : /* True if DOACROSS clause is spelled as DEPEND.  */
    1828                 :             : #define OMP_CLAUSE_DOACROSS_DEPEND(NODE) \
    1829                 :             :   TREE_PROTECTED (OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_DOACROSS))
    1830                 :             : 
    1831                 :             : #define OMP_CLAUSE_MAP_KIND(NODE) \
    1832                 :             :   ((enum gomp_map_kind) OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_MAP)->omp_clause.subcode.map_kind)
    1833                 :             : #define OMP_CLAUSE_SET_MAP_KIND(NODE, MAP_KIND) \
    1834                 :             :   (OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_MAP)->omp_clause.subcode.map_kind \
    1835                 :             :    = (unsigned int) (MAP_KIND))
    1836                 :             : 
    1837                 :             : #define OMP_CLAUSE_MOTION_PRESENT(NODE) \
    1838                 :             :   (OMP_CLAUSE_RANGE_CHECK (NODE, OMP_CLAUSE_FROM, OMP_CLAUSE_TO)->base.deprecated_flag)
    1839                 :             : 
    1840                 :             : #define OMP_CLAUSE_INIT_TARGET(NODE) \
    1841                 :             :   (OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_INIT)->base.public_flag)
    1842                 :             : #define OMP_CLAUSE_INIT_TARGETSYNC(NODE) \
    1843                 :             :   (OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_INIT)->base.deprecated_flag)
    1844                 :             : #define OMP_CLAUSE_INIT_PREFER_TYPE(NODE)                               \
    1845                 :             :   OMP_CLAUSE_OPERAND (OMP_CLAUSE_RANGE_CHECK (OMP_CLAUSE_CHECK (NODE),  \
    1846                 :             :                                               OMP_CLAUSE_INIT,          \
    1847                 :             :                                               OMP_CLAUSE_INIT), 1)
    1848                 :             : 
    1849                 :             : /* Nonzero if this map clause is for array (rather than pointer) based array
    1850                 :             :    section with zero bias.  Both the non-decl OMP_CLAUSE_MAP and corresponding
    1851                 :             :    OMP_CLAUSE_MAP with GOMP_MAP_POINTER are marked with this flag.  */
    1852                 :             : #define OMP_CLAUSE_MAP_ZERO_BIAS_ARRAY_SECTION(NODE) \
    1853                 :             :   (OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_MAP)->base.public_flag)
    1854                 :             : /* Nonzero if this is a mapped array section, that might need special
    1855                 :             :    treatment if OMP_CLAUSE_SIZE is zero.  */
    1856                 :             : #define OMP_CLAUSE_MAP_MAYBE_ZERO_LENGTH_ARRAY_SECTION(NODE) \
    1857                 :             :   TREE_PROTECTED (OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_MAP))
    1858                 :             : /* Nonzero if this map clause is for an OpenACC compute construct's reduction
    1859                 :             :    variable or OpenMP map clause mentioned also in in_reduction clause on the
    1860                 :             :    same construct.  */
    1861                 :             : #define OMP_CLAUSE_MAP_IN_REDUCTION(NODE) \
    1862                 :             :   TREE_PRIVATE (OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_MAP))
    1863                 :             : /* Nonzero on map clauses added implicitly for reduction clauses on combined
    1864                 :             :    or composite constructs.  They shall be removed if there is an explicit
    1865                 :             :    map clause.  */
    1866                 :             : #define OMP_CLAUSE_MAP_IMPLICIT(NODE) \
    1867                 :             :   (OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_MAP)->base.default_def_flag)
    1868                 :             : /* Nonzero if this map clause is to be indicated to the runtime as 'implicit',
    1869                 :             :    due to being created through implicit data-mapping rules in the middle-end.
    1870                 :             :    NOTE: this is different than OMP_CLAUSE_MAP_IMPLICIT.  */
    1871                 :             : #define OMP_CLAUSE_MAP_RUNTIME_IMPLICIT_P(NODE) \
    1872                 :             :   (OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_MAP)->base.deprecated_flag)
    1873                 :             : /* Nonzero for an attach/detach node whose decl was explicitly mapped on the
    1874                 :             :    same directive.  */
    1875                 :             : #define OMP_CLAUSE_ATTACHMENT_MAPPING_ERASED(NODE) \
    1876                 :             :   TREE_STATIC (OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_MAP))
    1877                 :             : /* Nonzero if this is a release/delete node which refers to a (Fortran) array
    1878                 :             :    descriptor.  */
    1879                 :             : #define OMP_CLAUSE_RELEASE_DESCRIPTOR(NODE) \
    1880                 :             :   TREE_NOTHROW (OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_MAP))
    1881                 :             : 
    1882                 :             : /* Flag that 'OMP_CLAUSE_DECL (NODE)' is to be made addressable during OMP
    1883                 :             :    lowering.  */
    1884                 :             : #define OMP_CLAUSE_MAP_DECL_MAKE_ADDRESSABLE(NODE) \
    1885                 :             :   (OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_MAP)->base.addressable_flag)
    1886                 :             : 
    1887                 :             : /* Nonzero if OpenACC 'readonly' modifier set, used for 'copyin'.  */
    1888                 :             : #define OMP_CLAUSE_MAP_READONLY(NODE) \
    1889                 :             :   TREE_READONLY (OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_MAP))
    1890                 :             : 
    1891                 :             : /* Same as above, for use in OpenACC cache directives.  */
    1892                 :             : #define OMP_CLAUSE__CACHE__READONLY(NODE) \
    1893                 :             :   TREE_READONLY (OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE__CACHE_))
    1894                 :             : 
    1895                 :             : /* True on an OMP_CLAUSE_USE_DEVICE_PTR with an OpenACC 'if_present'
    1896                 :             :    clause.  */
    1897                 :             : #define OMP_CLAUSE_USE_DEVICE_PTR_IF_PRESENT(NODE) \
    1898                 :             :   (OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_USE_DEVICE_PTR)->base.public_flag)
    1899                 :             : 
    1900                 :             : #define OMP_CLAUSE_PROC_BIND_KIND(NODE) \
    1901                 :             :   (OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_PROC_BIND)->omp_clause.subcode.proc_bind_kind)
    1902                 :             : 
    1903                 :             : #define OMP_CLAUSE_DEVICE_TYPE_KIND(NODE) \
    1904                 :             :   (OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_DEVICE_TYPE)->omp_clause.subcode.device_type_kind)
    1905                 :             : 
    1906                 :             : #define OMP_CLAUSE_INDIRECT_EXPR(NODE) \
    1907                 :             :   OMP_CLAUSE_OPERAND (OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_INDIRECT), 0)
    1908                 :             : 
    1909                 :             : 
    1910                 :             : /* True if there is a device clause with a device-modifier 'ancestor'.  */
    1911                 :             : #define OMP_CLAUSE_DEVICE_ANCESTOR(NODE) \
    1912                 :             :   (OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_DEVICE)->base.public_flag)
    1913                 :             : 
    1914                 :             : #define OMP_CLAUSE_COLLAPSE_EXPR(NODE) \
    1915                 :             :   OMP_CLAUSE_OPERAND (OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_COLLAPSE), 0)
    1916                 :             : #define OMP_CLAUSE_COLLAPSE_ITERVAR(NODE) \
    1917                 :             :   OMP_CLAUSE_OPERAND (OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_COLLAPSE), 1)
    1918                 :             : #define OMP_CLAUSE_COLLAPSE_COUNT(NODE) \
    1919                 :             :   OMP_CLAUSE_OPERAND (OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_COLLAPSE), 2)
    1920                 :             : 
    1921                 :             : #define OMP_CLAUSE_ORDERED_EXPR(NODE) \
    1922                 :             :   OMP_CLAUSE_OPERAND (OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_ORDERED), 0)
    1923                 :             : 
    1924                 :             : /* True on an OMP_CLAUSE_ORDERED if stand-alone ordered construct is nested
    1925                 :             :    inside of work-sharing loop the clause is on.  */
    1926                 :             : #define OMP_CLAUSE_ORDERED_DOACROSS(NODE) \
    1927                 :             :   (OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_ORDERED)->base.public_flag)
    1928                 :             : 
    1929                 :             : /* True for unconstrained modifier on order(concurrent) clause.  */
    1930                 :             : #define OMP_CLAUSE_ORDER_UNCONSTRAINED(NODE) \
    1931                 :             :   (OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_ORDER)->base.public_flag)
    1932                 :             : /* True for reproducible modifier on order(concurrent) clause.  */
    1933                 :             : #define OMP_CLAUSE_ORDER_REPRODUCIBLE(NODE) \
    1934                 :             :   TREE_PROTECTED (OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_ORDER))
    1935                 :             : 
    1936                 :             : #define OMP_CLAUSE_REDUCTION_CODE(NODE) \
    1937                 :             :   (OMP_CLAUSE_RANGE_CHECK (NODE, OMP_CLAUSE_REDUCTION, \
    1938                 :             :      OMP_CLAUSE_IN_REDUCTION)->omp_clause.subcode.reduction_code)
    1939                 :             : #define OMP_CLAUSE_REDUCTION_INIT(NODE) \
    1940                 :             :   OMP_CLAUSE_OPERAND (OMP_CLAUSE_RANGE_CHECK (NODE, OMP_CLAUSE_REDUCTION, \
    1941                 :             :                                               OMP_CLAUSE_IN_REDUCTION), 1)
    1942                 :             : #define OMP_CLAUSE_REDUCTION_MERGE(NODE) \
    1943                 :             :   OMP_CLAUSE_OPERAND (OMP_CLAUSE_RANGE_CHECK (NODE, OMP_CLAUSE_REDUCTION, \
    1944                 :             :                                               OMP_CLAUSE_IN_REDUCTION), 2)
    1945                 :             : #define OMP_CLAUSE_REDUCTION_GIMPLE_INIT(NODE) \
    1946                 :             :   (OMP_CLAUSE_CHECK (NODE))->omp_clause.gimple_reduction_init
    1947                 :             : #define OMP_CLAUSE_REDUCTION_GIMPLE_MERGE(NODE) \
    1948                 :             :   (OMP_CLAUSE_CHECK (NODE))->omp_clause.gimple_reduction_merge
    1949                 :             : #define OMP_CLAUSE_REDUCTION_PLACEHOLDER(NODE) \
    1950                 :             :   OMP_CLAUSE_OPERAND (OMP_CLAUSE_RANGE_CHECK (NODE, OMP_CLAUSE_REDUCTION, \
    1951                 :             :                                               OMP_CLAUSE_IN_REDUCTION), 3)
    1952                 :             : #define OMP_CLAUSE_REDUCTION_DECL_PLACEHOLDER(NODE) \
    1953                 :             :   OMP_CLAUSE_OPERAND (OMP_CLAUSE_RANGE_CHECK (NODE, OMP_CLAUSE_REDUCTION, \
    1954                 :             :                                               OMP_CLAUSE_IN_REDUCTION), 4)
    1955                 :             : 
    1956                 :             : /* True if a REDUCTION clause may reference the original list item (omp_orig)
    1957                 :             :    in its OMP_CLAUSE_REDUCTION_{,GIMPLE_}INIT.  */
    1958                 :             : #define OMP_CLAUSE_REDUCTION_OMP_ORIG_REF(NODE) \
    1959                 :             :   (OMP_CLAUSE_RANGE_CHECK (NODE, OMP_CLAUSE_REDUCTION, \
    1960                 :             :                            OMP_CLAUSE_IN_REDUCTION)->base.public_flag)
    1961                 :             : 
    1962                 :             : /* True if a REDUCTION clause has task reduction-modifier.  */
    1963                 :             : #define OMP_CLAUSE_REDUCTION_TASK(NODE) \
    1964                 :             :   TREE_PROTECTED (OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_REDUCTION))
    1965                 :             : 
    1966                 :             : /* True if a REDUCTION clause has inscan reduction-modifier.  */
    1967                 :             : #define OMP_CLAUSE_REDUCTION_INSCAN(NODE) \
    1968                 :             :   TREE_PRIVATE (OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_REDUCTION))
    1969                 :             : 
    1970                 :             : /* True if a LINEAR clause doesn't need copy in.  True for iterator vars which
    1971                 :             :    are always initialized inside of the loop construct, false otherwise.  */
    1972                 :             : #define OMP_CLAUSE_LINEAR_NO_COPYIN(NODE) \
    1973                 :             :   (OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_LINEAR)->base.public_flag)
    1974                 :             : 
    1975                 :             : /* True if a LINEAR clause doesn't need copy out.  True for iterator vars which
    1976                 :             :    are declared inside of the simd construct.  */
    1977                 :             : #define OMP_CLAUSE_LINEAR_NO_COPYOUT(NODE) \
    1978                 :             :   TREE_PRIVATE (OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_LINEAR))
    1979                 :             : 
    1980                 :             : /* True if a LINEAR clause has a stride that is variable.  */
    1981                 :             : #define OMP_CLAUSE_LINEAR_VARIABLE_STRIDE(NODE) \
    1982                 :             :   TREE_PROTECTED (OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_LINEAR))
    1983                 :             : 
    1984                 :             : /* True for a LINEAR clause with old style modifier syntax
    1985                 :             :    linear(modifier(list)) or linear(modifier(list):step).  */
    1986                 :             : #define OMP_CLAUSE_LINEAR_OLD_LINEAR_MODIFIER(NODE) \
    1987                 :             :   (OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_LINEAR)->base.addressable_flag)
    1988                 :             : 
    1989                 :             : /* True if a LINEAR clause is for an array or allocatable variable that
    1990                 :             :    needs special handling by the frontend.  */
    1991                 :             : #define OMP_CLAUSE_LINEAR_ARRAY(NODE) \
    1992                 :             :   (OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_LINEAR)->base.deprecated_flag)
    1993                 :             : 
    1994                 :             : #define OMP_CLAUSE_LINEAR_STEP(NODE) \
    1995                 :             :   OMP_CLAUSE_OPERAND (OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_LINEAR), 1)
    1996                 :             : 
    1997                 :             : #define OMP_CLAUSE_LINEAR_STMT(NODE) \
    1998                 :             :   OMP_CLAUSE_OPERAND (OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_LINEAR), 2)
    1999                 :             : 
    2000                 :             : #define OMP_CLAUSE_LINEAR_GIMPLE_SEQ(NODE) \
    2001                 :             :   (OMP_CLAUSE_CHECK (NODE))->omp_clause.gimple_reduction_init
    2002                 :             : 
    2003                 :             : #define OMP_CLAUSE_LINEAR_KIND(NODE) \
    2004                 :             :   (OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_LINEAR)->omp_clause.subcode.linear_kind)
    2005                 :             : 
    2006                 :             : #define OMP_CLAUSE_ALIGNED_ALIGNMENT(NODE) \
    2007                 :             :   OMP_CLAUSE_OPERAND (OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_ALIGNED), 1)
    2008                 :             : 
    2009                 :             : #define OMP_CLAUSE_ALLOCATE_ALLOCATOR(NODE) \
    2010                 :             :   OMP_CLAUSE_OPERAND (OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_ALLOCATE), 1)
    2011                 :             : 
    2012                 :             : #define OMP_CLAUSE_ALLOCATE_ALIGN(NODE) \
    2013                 :             :   OMP_CLAUSE_OPERAND (OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_ALLOCATE), 2)
    2014                 :             : 
    2015                 :             : /* True if an ALLOCATE clause was present on a combined or composite
    2016                 :             :    construct and the code for splitting the clauses has already performed
    2017                 :             :    checking if the listed variable has explicit privatization on the
    2018                 :             :    construct.  */
    2019                 :             : #define OMP_CLAUSE_ALLOCATE_COMBINED(NODE) \
    2020                 :             :   (OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_ALLOCATE)->base.public_flag)
    2021                 :             : 
    2022                 :             : #define OMP_CLAUSE_NUM_TEAMS_UPPER_EXPR(NODE) \
    2023                 :             :   OMP_CLAUSE_OPERAND (OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_NUM_TEAMS), 0)
    2024                 :             : 
    2025                 :             : #define OMP_CLAUSE_NUM_TEAMS_LOWER_EXPR(NODE) \
    2026                 :             :   OMP_CLAUSE_OPERAND (OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_NUM_TEAMS), 1)
    2027                 :             : 
    2028                 :             : #define OMP_CLAUSE_THREAD_LIMIT_EXPR(NODE) \
    2029                 :             :   OMP_CLAUSE_OPERAND (OMP_CLAUSE_SUBCODE_CHECK (NODE, \
    2030                 :             :                                                 OMP_CLAUSE_THREAD_LIMIT), 0)
    2031                 :             : 
    2032                 :             : #define OMP_CLAUSE_DEVICE_ID(NODE) \
    2033                 :             :   OMP_CLAUSE_OPERAND (OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_DEVICE), 0)
    2034                 :             : 
    2035                 :             : #define OMP_CLAUSE_DIST_SCHEDULE_CHUNK_EXPR(NODE) \
    2036                 :             :   OMP_CLAUSE_OPERAND (OMP_CLAUSE_SUBCODE_CHECK (NODE, \
    2037                 :             :                                                 OMP_CLAUSE_DIST_SCHEDULE), 0)
    2038                 :             : 
    2039                 :             : #define OMP_CLAUSE_SAFELEN_EXPR(NODE) \
    2040                 :             :   OMP_CLAUSE_OPERAND (OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_SAFELEN), 0)
    2041                 :             : 
    2042                 :             : #define OMP_CLAUSE_SIMDLEN_EXPR(NODE) \
    2043                 :             :   OMP_CLAUSE_OPERAND (OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_SIMDLEN), 0)
    2044                 :             : 
    2045                 :             : #define OMP_CLAUSE__SIMDUID__DECL(NODE) \
    2046                 :             :   OMP_CLAUSE_OPERAND (OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE__SIMDUID_), 0)
    2047                 :             : 
    2048                 :             : #define OMP_CLAUSE_SCHEDULE_KIND(NODE) \
    2049                 :             :   (OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_SCHEDULE)->omp_clause.subcode.schedule_kind)
    2050                 :             : 
    2051                 :             : /* True if a SCHEDULE clause has the simd modifier on it.  */
    2052                 :             : #define OMP_CLAUSE_SCHEDULE_SIMD(NODE) \
    2053                 :             :   (OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_SCHEDULE)->base.public_flag)
    2054                 :             : 
    2055                 :             : #define OMP_CLAUSE_DEFAULT_KIND(NODE) \
    2056                 :             :   (OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_DEFAULT)->omp_clause.subcode.default_kind)
    2057                 :             : 
    2058                 :             : #define OMP_CLAUSE_DEFAULTMAP_KIND(NODE) \
    2059                 :             :   (OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_DEFAULTMAP)->omp_clause.subcode.defaultmap_kind)
    2060                 :             : #define OMP_CLAUSE_DEFAULTMAP_CATEGORY(NODE) \
    2061                 :             :   ((enum omp_clause_defaultmap_kind) \
    2062                 :             :    (OMP_CLAUSE_DEFAULTMAP_KIND (NODE) & OMP_CLAUSE_DEFAULTMAP_CATEGORY_MASK))
    2063                 :             : #define OMP_CLAUSE_DEFAULTMAP_BEHAVIOR(NODE) \
    2064                 :             :   ((enum omp_clause_defaultmap_kind) \
    2065                 :             :    (OMP_CLAUSE_DEFAULTMAP_KIND (NODE) & OMP_CLAUSE_DEFAULTMAP_MASK))
    2066                 :             : #define OMP_CLAUSE_DEFAULTMAP_SET_KIND(NODE, BEHAVIOR, CATEGORY) \
    2067                 :             :   (OMP_CLAUSE_DEFAULTMAP_KIND (NODE) \
    2068                 :             :    = (enum omp_clause_defaultmap_kind) (CATEGORY | BEHAVIOR))
    2069                 :             : 
    2070                 :             : #define OMP_CLAUSE_BIND_KIND(NODE) \
    2071                 :             :   (OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_BIND)->omp_clause.subcode.bind_kind)
    2072                 :             : 
    2073                 :             : /* True if ENTER clause is spelled as TO.  */
    2074                 :             : #define OMP_CLAUSE_ENTER_TO(NODE) \
    2075                 :             :   (OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_ENTER)->base.public_flag)
    2076                 :             : 
    2077                 :             : #define OMP_CLAUSE_TILE_LIST(NODE) \
    2078                 :             :   OMP_CLAUSE_OPERAND (OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_TILE), 0)
    2079                 :             : #define OMP_CLAUSE_TILE_ITERVAR(NODE) \
    2080                 :             :   OMP_CLAUSE_OPERAND (OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_TILE), 1)
    2081                 :             : #define OMP_CLAUSE_TILE_COUNT(NODE) \
    2082                 :             :   OMP_CLAUSE_OPERAND (OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE_TILE), 2)
    2083                 :             : 
    2084                 :             : /* _CONDTEMP_ holding temporary with iteration count.  */
    2085                 :             : #define OMP_CLAUSE__CONDTEMP__ITER(NODE) \
    2086                 :             :   (OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE__CONDTEMP_)->base.public_flag)
    2087                 :             : 
    2088                 :             : /* _SCANTEMP_ holding temporary with pointer to thread's local array;
    2089                 :             :    allocation.  */
    2090                 :             : #define OMP_CLAUSE__SCANTEMP__ALLOC(NODE) \
    2091                 :             :   (OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE__SCANTEMP_)->base.public_flag)
    2092                 :             : 
    2093                 :             : /* _SCANTEMP_ holding temporary with a control variable for deallocation;
    2094                 :             :    one boolean_type_node for test whether alloca was used, another one
    2095                 :             :    to pass to __builtin_stack_restore or free.  */
    2096                 :             : #define OMP_CLAUSE__SCANTEMP__CONTROL(NODE) \
    2097                 :             :   TREE_PRIVATE (OMP_CLAUSE_SUBCODE_CHECK (NODE, OMP_CLAUSE__SCANTEMP_))
    2098                 :             : 
    2099                 :             : /* SSA_NAME accessors.  */
    2100                 :             : 
    2101                 :             : /* Whether SSA_NAME NODE is a virtual operand.  This simply caches the
    2102                 :             :    information in the underlying SSA_NAME_VAR for efficiency.  */
    2103                 :             : #define SSA_NAME_IS_VIRTUAL_OPERAND(NODE) \
    2104                 :             :   SSA_NAME_CHECK (NODE)->base.public_flag
    2105                 :             : 
    2106                 :             : /* Returns the IDENTIFIER_NODE giving the SSA name a name or NULL_TREE
    2107                 :             :    if there is no name associated with it.  */
    2108                 :             : #define SSA_NAME_IDENTIFIER(NODE)                               \
    2109                 :             :   (SSA_NAME_CHECK (NODE)->ssa_name.var != NULL_TREE          \
    2110                 :             :    ? (TREE_CODE ((NODE)->ssa_name.var) == IDENTIFIER_NODE    \
    2111                 :             :       ? (NODE)->ssa_name.var                                 \
    2112                 :             :       : DECL_NAME ((NODE)->ssa_name.var))                    \
    2113                 :             :    : NULL_TREE)
    2114                 :             : 
    2115                 :             : /* Returns the variable being referenced.  This can be NULL_TREE for
    2116                 :             :    temporaries not associated with any user variable.
    2117                 :             :    Once released, this is the only field that can be relied upon.  */
    2118                 :             : #define SSA_NAME_VAR(NODE)                                      \
    2119                 :             :   (SSA_NAME_CHECK (NODE)->ssa_name.var == NULL_TREE          \
    2120                 :             :    || TREE_CODE ((NODE)->ssa_name.var) == IDENTIFIER_NODE    \
    2121                 :             :    ? NULL_TREE : (NODE)->ssa_name.var)
    2122                 :             : 
    2123                 :             : #define SET_SSA_NAME_VAR_OR_IDENTIFIER(NODE,VAR) \
    2124                 :             :   do \
    2125                 :             :     { \
    2126                 :             :       tree var_ = (VAR); \
    2127                 :             :       SSA_NAME_CHECK (NODE)->ssa_name.var = var_; \
    2128                 :             :       SSA_NAME_IS_VIRTUAL_OPERAND (NODE) \
    2129                 :             :         = (var_ \
    2130                 :             :            && TREE_CODE (var_) == VAR_DECL \
    2131                 :             :            && VAR_DECL_IS_VIRTUAL_OPERAND (var_)); \
    2132                 :             :     } \
    2133                 :             :   while (0)
    2134                 :             : 
    2135                 :             : /* Returns the statement which defines this SSA name.  */
    2136                 :             : #define SSA_NAME_DEF_STMT(NODE) SSA_NAME_CHECK (NODE)->ssa_name.def_stmt
    2137                 :             : 
    2138                 :             : /* Returns the SSA version number of this SSA name.  Note that in
    2139                 :             :    tree SSA, version numbers are not per variable and may be recycled.  */
    2140                 :             : #define SSA_NAME_VERSION(NODE)  SSA_NAME_CHECK (NODE)->base.u.version
    2141                 :             : 
    2142                 :             : /* Nonzero if this SSA name occurs in an abnormal PHI.  SSA_NAMES are
    2143                 :             :    never output, so we can safely use the ASM_WRITTEN_FLAG for this
    2144                 :             :    status bit.  */
    2145                 :             : #define SSA_NAME_OCCURS_IN_ABNORMAL_PHI(NODE) \
    2146                 :             :     SSA_NAME_CHECK (NODE)->base.asm_written_flag
    2147                 :             : 
    2148                 :             : /* Nonzero if this SSA_NAME expression is currently on the free list of
    2149                 :             :    SSA_NAMES.  Using NOTHROW_FLAG seems reasonably safe since throwing
    2150                 :             :    has no meaning for an SSA_NAME.  */
    2151                 :             : #define SSA_NAME_IN_FREE_LIST(NODE) \
    2152                 :             :     SSA_NAME_CHECK (NODE)->base.nothrow_flag
    2153                 :             : 
    2154                 :             : /* Nonzero if this SSA_NAME is the default definition for the
    2155                 :             :    underlying symbol.  A default SSA name is created for symbol S if
    2156                 :             :    the very first reference to S in the function is a read operation.
    2157                 :             :    Default definitions are always created by an empty statement and
    2158                 :             :    belong to no basic block.  */
    2159                 :             : #define SSA_NAME_IS_DEFAULT_DEF(NODE) \
    2160                 :             :     SSA_NAME_CHECK (NODE)->base.default_def_flag
    2161                 :             : 
    2162                 :             : /* Nonzero if this SSA_NAME is known to point to memory that may not
    2163                 :             :    be written to.  This is set for default defs of function parameters
    2164                 :             :    that have a corresponding r or R specification in the functions
    2165                 :             :    fn spec attribute.  This is used by alias analysis.  */
    2166                 :             : #define SSA_NAME_POINTS_TO_READONLY_MEMORY(NODE) \
    2167                 :             :     SSA_NAME_CHECK (NODE)->base.deprecated_flag
    2168                 :             : 
    2169                 :             : /* Attributes for SSA_NAMEs for pointer-type variables.  */
    2170                 :             : #define SSA_NAME_PTR_INFO(N) \
    2171                 :             :    SSA_NAME_CHECK (N)->ssa_name.info.ptr_info
    2172                 :             : 
    2173                 :             : /* Value range info attributes for SSA_NAMEs of non pointer-type variables.  */
    2174                 :             : #define SSA_NAME_RANGE_INFO(N) \
    2175                 :             :     SSA_NAME_CHECK (N)->ssa_name.info.range_info
    2176                 :             : 
    2177                 :             : /* Return the immediate_use information for an SSA_NAME. */
    2178                 :             : #define SSA_NAME_IMM_USE_NODE(NODE) SSA_NAME_CHECK (NODE)->ssa_name.imm_uses
    2179                 :             : 
    2180                 :             : #define OMP_CLAUSE_CODE(NODE)                                   \
    2181                 :             :         (OMP_CLAUSE_CHECK (NODE))->omp_clause.code
    2182                 :             : 
    2183                 :             : #define OMP_CLAUSE_SET_CODE(NODE, CODE)                         \
    2184                 :             :         ((OMP_CLAUSE_CHECK (NODE))->omp_clause.code = (CODE))
    2185                 :             : 
    2186                 :             : #define OMP_CLAUSE_OPERAND(NODE, I)                             \
    2187                 :             :         OMP_CLAUSE_ELT_CHECK (NODE, I)
    2188                 :             : 
    2189                 :             : /* In a BLOCK (scope) node:
    2190                 :             :    Variables declared in the scope NODE.  */
    2191                 :             : #define BLOCK_VARS(NODE) (BLOCK_CHECK (NODE)->block.vars)
    2192                 :             : #define BLOCK_NONLOCALIZED_VARS(NODE) \
    2193                 :             :   (BLOCK_CHECK (NODE)->block.nonlocalized_vars)
    2194                 :             : #define BLOCK_NUM_NONLOCALIZED_VARS(NODE) \
    2195                 :             :   vec_safe_length (BLOCK_NONLOCALIZED_VARS (NODE))
    2196                 :             : #define BLOCK_NONLOCALIZED_VAR(NODE,N) (*BLOCK_NONLOCALIZED_VARS (NODE))[N]
    2197                 :             : /* A chain of BLOCKs (scopes) nested within the scope NODE.  */
    2198                 :             : #define BLOCK_SUBBLOCKS(NODE) (BLOCK_CHECK (NODE)->block.subblocks)
    2199                 :             : /* The scope enclosing the scope NODE, or FUNCTION_DECL for the "outermost"
    2200                 :             :    function scope.  Inlined functions are chained by this so that given
    2201                 :             :    expression E and its TREE_BLOCK(E) B, BLOCK_SUPERCONTEXT(B) is the scope
    2202                 :             :    in which E has been made or into which E has been inlined.   */
    2203                 :             : #define BLOCK_SUPERCONTEXT(NODE) (BLOCK_CHECK (NODE)->block.supercontext)
    2204                 :             : /* Points to the next scope at the same level of nesting as scope NODE.  */
    2205                 :             : #define BLOCK_CHAIN(NODE) (BLOCK_CHECK (NODE)->block.chain)
    2206                 :             : /* A BLOCK, or FUNCTION_DECL of the function from which a block has been
    2207                 :             :    inlined.  In a scope immediately enclosing an inlined leaf expression,
    2208                 :             :    points to the outermost scope into which it has been inlined (thus
    2209                 :             :    bypassing all intermediate BLOCK_SUPERCONTEXTs). */
    2210                 :             : #define BLOCK_ABSTRACT_ORIGIN(NODE) (BLOCK_CHECK (NODE)->block.abstract_origin)
    2211                 :             : #define BLOCK_ORIGIN(NODE) \
    2212                 :             :   (BLOCK_ABSTRACT_ORIGIN(NODE) ? BLOCK_ABSTRACT_ORIGIN(NODE) : (NODE))
    2213                 :             : #define BLOCK_DIE(NODE) (BLOCK_CHECK (NODE)->block.die)
    2214                 :             : 
    2215                 :             : /* True if BLOCK has the same ranges as its BLOCK_SUPERCONTEXT.  */
    2216                 :             : #define BLOCK_SAME_RANGE(NODE) (BLOCK_CHECK (NODE)->base.u.bits.nameless_flag)
    2217                 :             : 
    2218                 :             : /* True if BLOCK appears in cold section.  */
    2219                 :             : #define BLOCK_IN_COLD_SECTION_P(NODE) \
    2220                 :             :   (BLOCK_CHECK (NODE)->base.u.bits.atomic_flag)
    2221                 :             : 
    2222                 :             : /* An index number for this block.  These values are not guaranteed to
    2223                 :             :    be unique across functions -- whether or not they are depends on
    2224                 :             :    the debugging output format in use.  */
    2225                 :             : #define BLOCK_NUMBER(NODE) (BLOCK_CHECK (NODE)->block.block_num)
    2226                 :             : 
    2227                 :             : /* If block reordering splits a lexical block into discontiguous
    2228                 :             :    address ranges, we'll make a copy of the original block.
    2229                 :             : 
    2230                 :             :    Note that this is logically distinct from BLOCK_ABSTRACT_ORIGIN.
    2231                 :             :    In that case, we have one source block that has been replicated
    2232                 :             :    (through inlining or unrolling) into many logical blocks, and that
    2233                 :             :    these logical blocks have different physical variables in them.
    2234                 :             : 
    2235                 :             :    In this case, we have one logical block split into several
    2236                 :             :    non-contiguous address ranges.  Most debug formats can't actually
    2237                 :             :    represent this idea directly, so we fake it by creating multiple
    2238                 :             :    logical blocks with the same variables in them.  However, for those
    2239                 :             :    that do support non-contiguous regions, these allow the original
    2240                 :             :    logical block to be reconstructed, along with the set of address
    2241                 :             :    ranges.
    2242                 :             : 
    2243                 :             :    One of the logical block fragments is arbitrarily chosen to be
    2244                 :             :    the ORIGIN.  The other fragments will point to the origin via
    2245                 :             :    BLOCK_FRAGMENT_ORIGIN; the origin itself will have this pointer
    2246                 :             :    be null.  The list of fragments will be chained through
    2247                 :             :    BLOCK_FRAGMENT_CHAIN from the origin.  */
    2248                 :             : 
    2249                 :             : #define BLOCK_FRAGMENT_ORIGIN(NODE) (BLOCK_CHECK (NODE)->block.fragment_origin)
    2250                 :             : #define BLOCK_FRAGMENT_CHAIN(NODE) (BLOCK_CHECK (NODE)->block.fragment_chain)
    2251                 :             : 
    2252                 :             : /* For an inlined function, this gives the location where it was called
    2253                 :             :    from.  This is only set in the top level block, which corresponds to the
    2254                 :             :    inlined function scope.  This is used in the debug output routines.  */
    2255                 :             : 
    2256                 :             : #define BLOCK_SOURCE_LOCATION(NODE) (BLOCK_CHECK (NODE)->block.locus)
    2257                 :             : 
    2258                 :             : /* This gives the location of the end of the block, useful to attach
    2259                 :             :    code implicitly generated for outgoing paths.  */
    2260                 :             : 
    2261                 :             : #define BLOCK_SOURCE_END_LOCATION(NODE) (BLOCK_CHECK (NODE)->block.end_locus)
    2262                 :             : 
    2263                 :             : /* Define fields and accessors for nodes representing data types.  */
    2264                 :             : 
    2265                 :             : /* See tree.def for documentation of the use of these fields.
    2266                 :             :    Look at the documentation of the various ..._TYPE tree codes.
    2267                 :             : 
    2268                 :             :    Note that the type.values, type.minval, and type.maxval fields are
    2269                 :             :    overloaded and used for different macros in different kinds of types.
    2270                 :             :    Each macro must check to ensure the tree node is of the proper kind of
    2271                 :             :    type.  Note also that some of the front-ends also overload these fields,
    2272                 :             :    so they must be checked as well.  */
    2273                 :             : 
    2274                 :             : #define TYPE_UID(NODE) (TYPE_CHECK (NODE)->type_common.uid)
    2275                 :             : /* Type size in bits as a tree expression.  Need not be constant and may
    2276                 :             :    be greater than TYPE_SIZE for a C++ FIELD_DECL representing a base
    2277                 :             :    class subobject with its own virtual base classes (which are laid out
    2278                 :             :    separately).  */
    2279                 :             : #define TYPE_SIZE(NODE) (TYPE_CHECK (NODE)->type_common.size)
    2280                 :             : /* Likewise, type size in bytes.  */
    2281                 :             : #define TYPE_SIZE_UNIT(NODE) (TYPE_CHECK (NODE)->type_common.size_unit)
    2282                 :             : #define TYPE_POINTER_TO(NODE) (TYPE_CHECK (NODE)->type_common.pointer_to)
    2283                 :             : #define TYPE_REFERENCE_TO(NODE) (TYPE_CHECK (NODE)->type_common.reference_to)
    2284                 :             : #define TYPE_PRECISION(NODE) \
    2285                 :             :   (TREE_NOT_CHECK (TYPE_CHECK (NODE), VECTOR_TYPE)->type_common.precision)
    2286                 :             : #define TYPE_PRECISION_RAW(NODE) (TYPE_CHECK (NODE)->type_common.precision)
    2287                 :             : #define TYPE_NAME(NODE) (TYPE_CHECK (NODE)->type_common.name)
    2288                 :             : #define TYPE_NEXT_VARIANT(NODE) (TYPE_CHECK (NODE)->type_common.next_variant)
    2289                 :             : #define TYPE_MAIN_VARIANT(NODE) (TYPE_CHECK (NODE)->type_common.main_variant)
    2290                 :             : #define TYPE_CONTEXT(NODE) (TYPE_CHECK (NODE)->type_common.context)
    2291                 :             : 
    2292                 :             : #define TYPE_MODE_RAW(NODE) (TYPE_CHECK (NODE)->type_common.mode)
    2293                 :             : #define TYPE_MODE(NODE) \
    2294                 :             :   (VECTOR_TYPE_P (TYPE_CHECK (NODE)) \
    2295                 :             :    ? vector_type_mode (NODE) : (NODE)->type_common.mode)
    2296                 :             : #define SCALAR_TYPE_MODE(NODE) \
    2297                 :             :   (as_a <scalar_mode> (TYPE_CHECK (NODE)->type_common.mode))
    2298                 :             : #define SCALAR_INT_TYPE_MODE(NODE) \
    2299                 :             :   (as_a <scalar_int_mode> (TYPE_CHECK (NODE)->type_common.mode))
    2300                 :             : #define SCALAR_FLOAT_TYPE_MODE(NODE) \
    2301                 :             :   (as_a <scalar_float_mode> (TYPE_CHECK (NODE)->type_common.mode))
    2302                 :             : #define SET_TYPE_MODE(NODE, MODE) \
    2303                 :             :   (TYPE_CHECK (NODE)->type_common.mode = (MODE))
    2304                 :             : 
    2305                 :             : extern unsigned int element_precision (const_tree);
    2306                 :             : extern machine_mode element_mode (const_tree);
    2307                 :             : extern machine_mode vector_type_mode (const_tree);
    2308                 :             : extern unsigned int vector_element_bits (const_tree);
    2309                 :             : extern tree vector_element_bits_tree (const_tree);
    2310                 :             : 
    2311                 :             : /* The "canonical" type for this type node, which is used by frontends to
    2312                 :             :    compare the type for equality with another type.  If two types are
    2313                 :             :    equal (based on the semantics of the language), then they will have
    2314                 :             :    equivalent TYPE_CANONICAL entries.
    2315                 :             : 
    2316                 :             :    As a special case, if TYPE_CANONICAL is NULL_TREE, and thus
    2317                 :             :    TYPE_STRUCTURAL_EQUALITY_P is true, then it cannot
    2318                 :             :    be used for comparison against other types.  Instead, the type is
    2319                 :             :    said to require structural equality checks, described in
    2320                 :             :    TYPE_STRUCTURAL_EQUALITY_P.
    2321                 :             : 
    2322                 :             :    For unqualified aggregate and function types the middle-end relies on
    2323                 :             :    TYPE_CANONICAL to tell whether two variables can be assigned
    2324                 :             :    to each other without a conversion.  The middle-end also makes sure
    2325                 :             :    to assign the same alias-sets to the type partition with equal
    2326                 :             :    TYPE_CANONICAL of their unqualified variants.  */
    2327                 :             : #define TYPE_CANONICAL(NODE) (TYPE_CHECK (NODE)->type_common.canonical)
    2328                 :             : /* Indicates that the type node requires structural equality
    2329                 :             :    checks.  The compiler will need to look at the composition of the
    2330                 :             :    type to determine whether it is equal to another type, rather than
    2331                 :             :    just comparing canonical type pointers.  For instance, we would need
    2332                 :             :    to look at the return and parameter types of a FUNCTION_TYPE
    2333                 :             :    node.  */
    2334                 :             : #define TYPE_STRUCTURAL_EQUALITY_P(NODE) (TYPE_CANONICAL (NODE) == NULL_TREE)
    2335                 :             : /* Sets the TYPE_CANONICAL field to NULL_TREE, indicating that the
    2336                 :             :    type node requires structural equality.  */
    2337                 :             : #define SET_TYPE_STRUCTURAL_EQUALITY(NODE) (TYPE_CANONICAL (NODE) = NULL_TREE)
    2338                 :             : 
    2339                 :             : #define TYPE_IBIT(NODE) (GET_MODE_IBIT (TYPE_MODE (NODE)))
    2340                 :             : #define TYPE_FBIT(NODE) (GET_MODE_FBIT (TYPE_MODE (NODE)))
    2341                 :             : 
    2342                 :             : /* The (language-specific) typed-based alias set for this type.
    2343                 :             :    Objects whose TYPE_ALIAS_SETs are different cannot alias each
    2344                 :             :    other.  If the TYPE_ALIAS_SET is -1, no alias set has yet been
    2345                 :             :    assigned to this type.  If the TYPE_ALIAS_SET is 0, objects of this
    2346                 :             :    type can alias objects of any type.  */
    2347                 :             : #define TYPE_ALIAS_SET(NODE) (TYPE_CHECK (NODE)->type_common.alias_set)
    2348                 :             : 
    2349                 :             : /* Nonzero iff the typed-based alias set for this type has been
    2350                 :             :    calculated.  */
    2351                 :             : #define TYPE_ALIAS_SET_KNOWN_P(NODE) \
    2352                 :             :   (TYPE_CHECK (NODE)->type_common.alias_set != -1)
    2353                 :             : 
    2354                 :             : /* A TREE_LIST of IDENTIFIER nodes of the attributes that apply
    2355                 :             :    to this type.  */
    2356                 :             : #define TYPE_ATTRIBUTES(NODE) (TYPE_CHECK (NODE)->type_common.attributes)
    2357                 :             : 
    2358                 :             : /* Raw access to the alignment field.  */
    2359                 :             : #define TYPE_ALIGN_RAW(NODE)                    \
    2360                 :             :   (TYPE_CHECK (NODE)->type_common.align)
    2361                 :             : 
    2362                 :             : /* The alignment necessary for objects of this type.
    2363                 :             :    The value is an int, measured in bits and must be a power of two.
    2364                 :             :    We support also an "alignment" of zero.  */
    2365                 :             : #define TYPE_ALIGN(NODE)                                        \
    2366                 :             :   (TYPE_ALIGN_RAW (NODE)                                        \
    2367                 :             :    ? ((unsigned)1) << (TYPE_ALIGN_RAW(NODE) - 1) : 0)
    2368                 :             : 
    2369                 :             : /* Specify that TYPE_ALIGN(NODE) is X.  */
    2370                 :             : #define SET_TYPE_ALIGN(NODE, X) \
    2371                 :             :     (TYPE_CHECK (NODE)->type_common.align = ffs_hwi (X))
    2372                 :             : 
    2373                 :             : /* 1 if the alignment for this type was requested by "aligned" attribute,
    2374                 :             :    0 if it is the default for this type.  */
    2375                 :             : #define TYPE_USER_ALIGN(NODE) (TYPE_CHECK (NODE)->base.u.bits.user_align)
    2376                 :             : 
    2377                 :             : /* The alignment for NODE, in bytes.  */
    2378                 :             : #define TYPE_ALIGN_UNIT(NODE) (TYPE_ALIGN (NODE) / BITS_PER_UNIT)
    2379                 :             : 
    2380                 :             : /* The minimum alignment necessary for objects of this type without
    2381                 :             :    warning.  The value is an int, measured in bits.  */
    2382                 :             : #define TYPE_WARN_IF_NOT_ALIGN_RAW(NODE) \
    2383                 :             :     (TYPE_CHECK (NODE)->type_common.warn_if_not_align)
    2384                 :             : #define TYPE_WARN_IF_NOT_ALIGN(NODE) \
    2385                 :             :     (TYPE_WARN_IF_NOT_ALIGN_RAW (NODE) \
    2386                 :             :      ? ((unsigned)1) << (TYPE_WARN_IF_NOT_ALIGN_RAW (NODE) - 1) : 0)
    2387                 :             : 
    2388                 :             : /* Specify that TYPE_WARN_IF_NOT_ALIGN(NODE) is X.  */
    2389                 :             : #define SET_TYPE_WARN_IF_NOT_ALIGN(NODE, X) \
    2390                 :             :     (TYPE_WARN_IF_NOT_ALIGN_RAW (NODE) = ffs_hwi (X))
    2391                 :             : 
    2392                 :             : /* If your language allows you to declare types, and you want debug info
    2393                 :             :    for them, then you need to generate corresponding TYPE_DECL nodes.
    2394                 :             :    These "stub" TYPE_DECL nodes have no name, and simply point at the
    2395                 :             :    type node.  You then set the TYPE_STUB_DECL field of the type node
    2396                 :             :    to point back at the TYPE_DECL node.  This allows the debug routines
    2397                 :             :    to know that the two nodes represent the same type, so that we only
    2398                 :             :    get one debug info record for them.  */
    2399                 :             : #define TYPE_STUB_DECL(NODE) (TREE_CHAIN (TYPE_CHECK (NODE)))
    2400                 :             : 
    2401                 :             : /* In a RECORD_TYPE, UNION_TYPE, QUAL_UNION_TYPE or ARRAY_TYPE, it means
    2402                 :             :    the type has BLKmode only because it lacks the alignment required for
    2403                 :             :    its size.  */
    2404                 :             : #define TYPE_NO_FORCE_BLK(NODE) \
    2405                 :             :   (TYPE_CHECK (NODE)->type_common.no_force_blk_flag)
    2406                 :             : 
    2407                 :             : /* Nonzero in a type considered volatile as a whole.  */
    2408                 :             : #define TYPE_VOLATILE(NODE) (TYPE_CHECK (NODE)->base.volatile_flag)
    2409                 :             : 
    2410                 :             : /* Nonzero in a type considered atomic as a whole.  */
    2411                 :             : #define TYPE_ATOMIC(NODE) (TYPE_CHECK (NODE)->base.u.bits.atomic_flag)
    2412                 :             : 
    2413                 :             : /* Means this type is const-qualified.  */
    2414                 :             : #define TYPE_READONLY(NODE) (TYPE_CHECK (NODE)->base.readonly_flag)
    2415                 :             : 
    2416                 :             : /* If nonzero, this type is `restrict'-qualified, in the C sense of
    2417                 :             :    the term.  */
    2418                 :             : #define TYPE_RESTRICT(NODE) (TYPE_CHECK (NODE)->type_common.restrict_flag)
    2419                 :             : 
    2420                 :             : /* If nonzero, type's name shouldn't be emitted into debug info.  */
    2421                 :             : #define TYPE_NAMELESS(NODE) (TYPE_CHECK (NODE)->base.u.bits.nameless_flag)
    2422                 :             : 
    2423                 :             : /* The address space the type is in.  */
    2424                 :             : #define TYPE_ADDR_SPACE(NODE) (TYPE_CHECK (NODE)->base.u.bits.address_space)
    2425                 :             : 
    2426                 :             : /* Encode/decode the named memory support as part of the qualifier.  If more
    2427                 :             :    than 8 qualifiers are added, these macros need to be adjusted.  */
    2428                 :             : #define ENCODE_QUAL_ADDR_SPACE(NUM) ((NUM & 0xFF) << 8)
    2429                 :             : #define DECODE_QUAL_ADDR_SPACE(X) (((X) >> 8) & 0xFF)
    2430                 :             : 
    2431                 :             : /* Return all qualifiers except for the address space qualifiers.  */
    2432                 :             : #define CLEAR_QUAL_ADDR_SPACE(X) ((X) & ~0xFF00)
    2433                 :             : 
    2434                 :             : /* Only keep the address space out of the qualifiers and discard the other
    2435                 :             :    qualifiers.  */
    2436                 :             : #define KEEP_QUAL_ADDR_SPACE(X) ((X) & 0xFF00)
    2437                 :             : 
    2438                 :             : /* The set of type qualifiers for this type.  */
    2439                 :             : #define TYPE_QUALS(NODE)                                        \
    2440                 :             :   ((int) ((TYPE_READONLY (NODE) * TYPE_QUAL_CONST)              \
    2441                 :             :           | (TYPE_VOLATILE (NODE) * TYPE_QUAL_VOLATILE)         \
    2442                 :             :           | (TYPE_ATOMIC (NODE) * TYPE_QUAL_ATOMIC)             \
    2443                 :             :           | (TYPE_RESTRICT (NODE) * TYPE_QUAL_RESTRICT)         \
    2444                 :             :           | (ENCODE_QUAL_ADDR_SPACE (TYPE_ADDR_SPACE (NODE)))))
    2445                 :             : 
    2446                 :             : /* The same as TYPE_QUALS without the address space qualifications.  */
    2447                 :             : #define TYPE_QUALS_NO_ADDR_SPACE(NODE)                          \
    2448                 :             :   ((int) ((TYPE_READONLY (NODE) * TYPE_QUAL_CONST)              \
    2449                 :             :           | (TYPE_VOLATILE (NODE) * TYPE_QUAL_VOLATILE)         \
    2450                 :             :           | (TYPE_ATOMIC (NODE) * TYPE_QUAL_ATOMIC)             \
    2451                 :             :           | (TYPE_RESTRICT (NODE) * TYPE_QUAL_RESTRICT)))
    2452                 :             : 
    2453                 :             : /* The same as TYPE_QUALS without the address space and atomic
    2454                 :             :    qualifications.  */
    2455                 :             : #define TYPE_QUALS_NO_ADDR_SPACE_NO_ATOMIC(NODE)                \
    2456                 :             :   ((int) ((TYPE_READONLY (NODE) * TYPE_QUAL_CONST)              \
    2457                 :             :           | (TYPE_VOLATILE (NODE) * TYPE_QUAL_VOLATILE)         \
    2458                 :             :           | (TYPE_RESTRICT (NODE) * TYPE_QUAL_RESTRICT)))
    2459                 :             : 
    2460                 :             : /* These flags are available for each language front end to use internally.  */
    2461                 :             : #define TYPE_LANG_FLAG_0(NODE) (TYPE_CHECK (NODE)->type_common.lang_flag_0)
    2462                 :             : #define TYPE_LANG_FLAG_1(NODE) (TYPE_CHECK (NODE)->type_common.lang_flag_1)
    2463                 :             : #define TYPE_LANG_FLAG_2(NODE) (TYPE_CHECK (NODE)->type_common.lang_flag_2)
    2464                 :             : #define TYPE_LANG_FLAG_3(NODE) (TYPE_CHECK (NODE)->type_common.lang_flag_3)
    2465                 :             : #define TYPE_LANG_FLAG_4(NODE) (TYPE_CHECK (NODE)->type_common.lang_flag_4)
    2466                 :             : #define TYPE_LANG_FLAG_5(NODE) (TYPE_CHECK (NODE)->type_common.lang_flag_5)
    2467                 :             : #define TYPE_LANG_FLAG_6(NODE) (TYPE_CHECK (NODE)->type_common.lang_flag_6)
    2468                 :             : #define TYPE_LANG_FLAG_7(NODE) (TYPE_CHECK (NODE)->type_common.lang_flag_7)
    2469                 :             : 
    2470                 :             : /* Used to keep track of visited nodes in tree traversals.  This is set to
    2471                 :             :    0 by copy_node and make_node.  */
    2472                 :             : #define TREE_VISITED(NODE) ((NODE)->base.visited)
    2473                 :             : 
    2474                 :             : /* If set in an ARRAY_TYPE, indicates a string type (for languages
    2475                 :             :    that distinguish string from array of char).
    2476                 :             :    If set in a INTEGER_TYPE, indicates a character type.  */
    2477                 :             : #define TYPE_STRING_FLAG(NODE) \
    2478                 :             :         (ARRAY_OR_INTEGER_TYPE_CHECK (NODE)->type_common.string_flag)
    2479                 :             : 
    2480                 :             : /* If set for RECORD_TYPE or UNION_TYPE it indicates that the type conforms
    2481                 :             :    to the C++ one definition rule.  This is used for LTO canonical type
    2482                 :             :    computation.  */
    2483                 :             : #define TYPE_CXX_ODR_P(NODE) \
    2484                 :             :         (RECORD_OR_UNION_CHECK (NODE)->type_common.string_flag)
    2485                 :             : 
    2486                 :             : /* Nonzero in a VECTOR_TYPE if the frontends should not emit warnings
    2487                 :             :    about missing conversions to other vector types of the same size.  */
    2488                 :             : #define TYPE_VECTOR_OPAQUE(NODE) \
    2489                 :             :   (VECTOR_TYPE_CHECK (NODE)->base.default_def_flag)
    2490                 :             : 
    2491                 :             : /* Indicates that objects of this type must be initialized by calling a
    2492                 :             :    function when they are created.  */
    2493                 :             : #define TYPE_NEEDS_CONSTRUCTING(NODE) \
    2494                 :             :   (TYPE_CHECK (NODE)->type_common.needs_constructing_flag)
    2495                 :             : 
    2496                 :             : /* Indicates that a UNION_TYPE object should be passed the same way that
    2497                 :             :    the first union alternative would be passed, or that a RECORD_TYPE
    2498                 :             :    object should be passed the same way that the first (and only) member
    2499                 :             :    would be passed.  */
    2500                 :             : #define TYPE_TRANSPARENT_AGGR(NODE) \
    2501                 :             :   (RECORD_OR_UNION_CHECK (NODE)->type_common.transparent_aggr_flag)
    2502                 :             : 
    2503                 :             : /* For an ARRAY_TYPE, indicates that it is not permitted to take the
    2504                 :             :    address of a component of the type.  This is the counterpart of
    2505                 :             :    DECL_NONADDRESSABLE_P for arrays, see the definition of this flag.  */
    2506                 :             : #define TYPE_NONALIASED_COMPONENT(NODE) \
    2507                 :             :   (ARRAY_TYPE_CHECK (NODE)->type_common.transparent_aggr_flag)
    2508                 :             : 
    2509                 :             : /* For an ARRAY_TYPE, a RECORD_TYPE, a UNION_TYPE or a QUAL_UNION_TYPE
    2510                 :             :    whether the array is typeless storage or the type contains a member
    2511                 :             :    with this flag set.  Such types are exempt from type-based alias
    2512                 :             :    analysis.  For ARRAY_TYPEs with AGGREGATE_TYPE_P element types
    2513                 :             :    the flag should be inherited from the element type, can change
    2514                 :             :    when type is finalized and because of that should not be used in
    2515                 :             :    type hashing.  For ARRAY_TYPEs with non-AGGREGATE_TYPE_P element types
    2516                 :             :    the flag should not be changed after the array is created and should
    2517                 :             :    be used in type hashing.  */
    2518                 :             : #define TYPE_TYPELESS_STORAGE(NODE) \
    2519                 :             :   (TREE_CHECK4 (NODE, RECORD_TYPE, UNION_TYPE, QUAL_UNION_TYPE, \
    2520                 :             :                 ARRAY_TYPE)->type_common.typeless_storage)
    2521                 :             : 
    2522                 :             : /* Indicated that objects of this type should be laid out in as
    2523                 :             :    compact a way as possible.  */
    2524                 :             : #define TYPE_PACKED(NODE) (TYPE_CHECK (NODE)->base.u.bits.packed_flag)
    2525                 :             : 
    2526                 :             : /* Used by type_contains_placeholder_p to avoid recomputation.
    2527                 :             :    Values are: 0 (unknown), 1 (false), 2 (true).  Never access
    2528                 :             :    this field directly.  */
    2529                 :             : #define TYPE_CONTAINS_PLACEHOLDER_INTERNAL(NODE) \
    2530                 :             :   (TYPE_CHECK (NODE)->type_common.contains_placeholder_bits)
    2531                 :             : 
    2532                 :             : /* Nonzero if RECORD_TYPE represents a final derivation of class.  */
    2533                 :             : #define TYPE_FINAL_P(NODE) \
    2534                 :             :   (RECORD_OR_UNION_CHECK (NODE)->base.default_def_flag)
    2535                 :             : 
    2536                 :             : /* The debug output functions use the symtab union field to store
    2537                 :             :    information specific to the debugging format.  The different debug
    2538                 :             :    output hooks store different types in the union field.  These three
    2539                 :             :    macros are used to access different fields in the union.  The debug
    2540                 :             :    hooks are responsible for consistently using only a specific
    2541                 :             :    macro.  */
    2542                 :             : 
    2543                 :             : /* Symtab field as an integer.  Used by stabs generator in dbxout.cc to
    2544                 :             :    hold the type's number in the generated stabs.  */
    2545                 :             : #define TYPE_SYMTAB_ADDRESS(NODE) \
    2546                 :             :   (TYPE_CHECK (NODE)->type_common.symtab.address)
    2547                 :             : 
    2548                 :             : /* Symtab field as a pointer to a DWARF DIE.  Used by DWARF generator
    2549                 :             :    in dwarf2out.cc to point to the DIE generated for the type.  */
    2550                 :             : #define TYPE_SYMTAB_DIE(NODE) \
    2551                 :             :   (TYPE_CHECK (NODE)->type_common.symtab.die)
    2552                 :             : 
    2553                 :             : /* The garbage collector needs to know the interpretation of the
    2554                 :             :    symtab field.  These constants represent the different types in the
    2555                 :             :    union.  */
    2556                 :             : 
    2557                 :             : #define TYPE_SYMTAB_IS_ADDRESS (0)
    2558                 :             : #define TYPE_SYMTAB_IS_DIE (1)
    2559                 :             : 
    2560                 :             : #define TYPE_LANG_SPECIFIC(NODE) \
    2561                 :             :   (TYPE_CHECK (NODE)->type_with_lang_specific.lang_specific)
    2562                 :             : 
    2563                 :             : #define TYPE_VALUES(NODE) (ENUMERAL_TYPE_CHECK (NODE)->type_non_common.values)
    2564                 :             : #define TYPE_DOMAIN(NODE) (ARRAY_TYPE_CHECK (NODE)->type_non_common.values)
    2565                 :             : #define TYPE_FIELDS(NODE)                               \
    2566                 :             :   (RECORD_OR_UNION_CHECK (NODE)->type_non_common.values)
    2567                 :             : #define TYPE_CACHED_VALUES(NODE) (TYPE_CHECK (NODE)->type_non_common.values)
    2568                 :             : #define TYPE_ARG_TYPES(NODE)                            \
    2569                 :             :   (FUNC_OR_METHOD_CHECK (NODE)->type_non_common.values)
    2570                 :             : #define TYPE_VALUES_RAW(NODE) (TYPE_CHECK (NODE)->type_non_common.values)
    2571                 :             : 
    2572                 :             : #define TYPE_MIN_VALUE(NODE)                            \
    2573                 :             :   (NUMERICAL_TYPE_CHECK (NODE)->type_non_common.minval)
    2574                 :             : #define TYPE_NEXT_PTR_TO(NODE)                          \
    2575                 :             :   (POINTER_TYPE_CHECK (NODE)->type_non_common.minval)
    2576                 :             : #define TYPE_NEXT_REF_TO(NODE)                          \
    2577                 :             :   (REFERENCE_TYPE_CHECK (NODE)->type_non_common.minval)
    2578                 :             : #define TYPE_VFIELD(NODE)                               \
    2579                 :             :   (RECORD_OR_UNION_CHECK (NODE)->type_non_common.minval)
    2580                 :             : #define TYPE_MIN_VALUE_RAW(NODE) (TYPE_CHECK (NODE)->type_non_common.minval)
    2581                 :             : 
    2582                 :             : #define TYPE_MAX_VALUE(NODE) \
    2583                 :             :   (NUMERICAL_TYPE_CHECK (NODE)->type_non_common.maxval)
    2584                 :             : #define TYPE_METHOD_BASETYPE(NODE)                      \
    2585                 :             :   (FUNC_OR_METHOD_CHECK (NODE)->type_non_common.maxval)
    2586                 :             : #define TYPE_OFFSET_BASETYPE(NODE)                      \
    2587                 :             :   (OFFSET_TYPE_CHECK (NODE)->type_non_common.maxval)
    2588                 :             : /* If non-NULL, this is an upper bound of the size (in bytes) of an
    2589                 :             :    object of the given ARRAY_TYPE_NON_COMMON.  This allows temporaries to be
    2590                 :             :    allocated.  */
    2591                 :             : #define TYPE_ARRAY_MAX_SIZE(ARRAY_TYPE) \
    2592                 :             :   (ARRAY_TYPE_CHECK (ARRAY_TYPE)->type_non_common.maxval)
    2593                 :             : #define TYPE_MAX_VALUE_RAW(NODE) (TYPE_CHECK (NODE)->type_non_common.maxval)
    2594                 :             : /* For record and union types, information about this type, as a base type
    2595                 :             :    for itself.  */
    2596                 :             : #define TYPE_BINFO(NODE) (RECORD_OR_UNION_CHECK (NODE)->type_non_common.maxval)
    2597                 :             : 
    2598                 :             : /* For types, used in a language-dependent way.  */
    2599                 :             : #define TYPE_LANG_SLOT_1(NODE) \
    2600                 :             :   (TYPE_CHECK (NODE)->type_non_common.lang_1)
    2601                 :             : 
    2602                 :             : /* Define accessor macros for information about type inheritance
    2603                 :             :    and basetypes.
    2604                 :             : 
    2605                 :             :    A "basetype" means a particular usage of a data type for inheritance
    2606                 :             :    in another type.  Each such basetype usage has its own "binfo"
    2607                 :             :    object to describe it.  The binfo object is a TREE_VEC node.
    2608                 :             : 
    2609                 :             :    Inheritance is represented by the binfo nodes allocated for a
    2610                 :             :    given type.  For example, given types C and D, such that D is
    2611                 :             :    inherited by C, 3 binfo nodes will be allocated: one for describing
    2612                 :             :    the binfo properties of C, similarly one for D, and one for
    2613                 :             :    describing the binfo properties of D as a base type for C.
    2614                 :             :    Thus, given a pointer to class C, one can get a pointer to the binfo
    2615                 :             :    of D acting as a basetype for C by looking at C's binfo's basetypes.  */
    2616                 :             : 
    2617                 :             : /* BINFO specific flags.  */
    2618                 :             : 
    2619                 :             : /* Nonzero means that the derivation chain is via a `virtual' declaration.  */
    2620                 :             : #define BINFO_VIRTUAL_P(NODE) (TREE_BINFO_CHECK (NODE)->base.static_flag)
    2621                 :             : 
    2622                 :             : /* Flags for language dependent use.  */
    2623                 :             : #define BINFO_FLAG_0(NODE) TREE_LANG_FLAG_0 (TREE_BINFO_CHECK (NODE))
    2624                 :             : #define BINFO_FLAG_1(NODE) TREE_LANG_FLAG_1 (TREE_BINFO_CHECK (NODE))
    2625                 :             : #define BINFO_FLAG_2(NODE) TREE_LANG_FLAG_2 (TREE_BINFO_CHECK (NODE))
    2626                 :             : #define BINFO_FLAG_3(NODE) TREE_LANG_FLAG_3 (TREE_BINFO_CHECK (NODE))
    2627                 :             : #define BINFO_FLAG_4(NODE) TREE_LANG_FLAG_4 (TREE_BINFO_CHECK (NODE))
    2628                 :             : #define BINFO_FLAG_5(NODE) TREE_LANG_FLAG_5 (TREE_BINFO_CHECK (NODE))
    2629                 :             : #define BINFO_FLAG_6(NODE) TREE_LANG_FLAG_6 (TREE_BINFO_CHECK (NODE))
    2630                 :             : 
    2631                 :             : /* The actual data type node being inherited in this basetype.  */
    2632                 :             : #define BINFO_TYPE(NODE) TREE_TYPE (TREE_BINFO_CHECK (NODE))
    2633                 :             : 
    2634                 :             : /* The offset where this basetype appears in its containing type.
    2635                 :             :    BINFO_OFFSET slot holds the offset (in bytes)
    2636                 :             :    from the base of the complete object to the base of the part of the
    2637                 :             :    object that is allocated on behalf of this `type'.
    2638                 :             :    This is always 0 except when there is multiple inheritance.  */
    2639                 :             : 
    2640                 :             : #define BINFO_OFFSET(NODE) (TREE_BINFO_CHECK (NODE)->binfo.offset)
    2641                 :             : #define BINFO_OFFSET_ZEROP(NODE) (integer_zerop (BINFO_OFFSET (NODE)))
    2642                 :             : 
    2643                 :             : /* The virtual function table belonging to this basetype.  Virtual
    2644                 :             :    function tables provide a mechanism for run-time method dispatching.
    2645                 :             :    The entries of a virtual function table are language-dependent.  */
    2646                 :             : 
    2647                 :             : #define BINFO_VTABLE(NODE) (TREE_BINFO_CHECK (NODE)->binfo.vtable)
    2648                 :             : 
    2649                 :             : /* The virtual functions in the virtual function table.  This is
    2650                 :             :    a TREE_LIST that is used as an initial approximation for building
    2651                 :             :    a virtual function table for this basetype.  */
    2652                 :             : #define BINFO_VIRTUALS(NODE) (TREE_BINFO_CHECK (NODE)->binfo.virtuals)
    2653                 :             : 
    2654                 :             : /* A vector of binfos for the direct basetypes inherited by this
    2655                 :             :    basetype.
    2656                 :             : 
    2657                 :             :    If this basetype describes type D as inherited in C, and if the
    2658                 :             :    basetypes of D are E and F, then this vector contains binfos for
    2659                 :             :    inheritance of E and F by C.  */
    2660                 :             : #define BINFO_BASE_BINFOS(NODE) (&TREE_BINFO_CHECK (NODE)->binfo.base_binfos)
    2661                 :             : 
    2662                 :             : /* The number of basetypes for NODE.  */
    2663                 :             : #define BINFO_N_BASE_BINFOS(NODE) (BINFO_BASE_BINFOS (NODE)->length ())
    2664                 :             : 
    2665                 :             : /* Accessor macro to get to the Nth base binfo of this binfo.  */
    2666                 :             : #define BINFO_BASE_BINFO(NODE,N) \
    2667                 :             :  ((*BINFO_BASE_BINFOS (NODE))[(N)])
    2668                 :             : #define BINFO_BASE_ITERATE(NODE,N,B) \
    2669                 :             :  (BINFO_BASE_BINFOS (NODE)->iterate ((N), &(B)))
    2670                 :             : #define BINFO_BASE_APPEND(NODE,T) \
    2671                 :             :  (BINFO_BASE_BINFOS (NODE)->quick_push ((T)))
    2672                 :             : 
    2673                 :             : /* For a BINFO record describing a virtual base class, i.e., one where
    2674                 :             :    TREE_VIA_VIRTUAL is set, this field assists in locating the virtual
    2675                 :             :    base.  The actual contents are language-dependent.  In the C++
    2676                 :             :    front-end this field is an INTEGER_CST giving an offset into the
    2677                 :             :    vtable where the offset to the virtual base can be found.  */
    2678                 :             : #define BINFO_VPTR_FIELD(NODE) (TREE_BINFO_CHECK (NODE)->binfo.vptr_field)
    2679                 :             : 
    2680                 :             : /* Indicates the accesses this binfo has to its bases. The values are
    2681                 :             :    access_public_node, access_protected_node or access_private_node.
    2682                 :             :    If this array is not present, public access is implied.  */
    2683                 :             : #define BINFO_BASE_ACCESSES(NODE) \
    2684                 :             :   (TREE_BINFO_CHECK (NODE)->binfo.base_accesses)
    2685                 :             : 
    2686                 :             : #define BINFO_BASE_ACCESS(NODE,N) \
    2687                 :             :   (*BINFO_BASE_ACCESSES (NODE))[(N)]
    2688                 :             : #define BINFO_BASE_ACCESS_APPEND(NODE,T) \
    2689                 :             :   BINFO_BASE_ACCESSES (NODE)->quick_push ((T))
    2690                 :             : 
    2691                 :             : /* The index in the VTT where this subobject's sub-VTT can be found.
    2692                 :             :    NULL_TREE if there is no sub-VTT.  */
    2693                 :             : #define BINFO_SUBVTT_INDEX(NODE) (TREE_BINFO_CHECK (NODE)->binfo.vtt_subvtt)
    2694                 :             : 
    2695                 :             : /* The index in the VTT where the vptr for this subobject can be
    2696                 :             :    found.  NULL_TREE if there is no secondary vptr in the VTT.  */
    2697                 :             : #define BINFO_VPTR_INDEX(NODE) (TREE_BINFO_CHECK (NODE)->binfo.vtt_vptr)
    2698                 :             : 
    2699                 :             : /* The BINFO_INHERITANCE_CHAIN points at the binfo for the base
    2700                 :             :    inheriting this base for non-virtual bases. For virtual bases it
    2701                 :             :    points either to the binfo for which this is a primary binfo, or to
    2702                 :             :    the binfo of the most derived type.  */
    2703                 :             : #define BINFO_INHERITANCE_CHAIN(NODE) \
    2704                 :             :         (TREE_BINFO_CHECK (NODE)->binfo.inheritance)
    2705                 :             : 
    2706                 :             : 
    2707                 :             : /* Define fields and accessors for nodes representing declared names.  */
    2708                 :             : 
    2709                 :             : /* Nonzero if DECL represents an SSA name or a variable that can possibly
    2710                 :             :    have an associated SSA name.  */
    2711                 :             : #define SSA_VAR_P(DECL)                                                 \
    2712                 :             :         (TREE_CODE (DECL) == VAR_DECL                                   \
    2713                 :             :          || TREE_CODE (DECL) == PARM_DECL                               \
    2714                 :             :          || TREE_CODE (DECL) == RESULT_DECL                             \
    2715                 :             :          || TREE_CODE (DECL) == SSA_NAME)
    2716                 :             : 
    2717                 :             : 
    2718                 :             : #define DECL_CHAIN(NODE) (TREE_CHAIN (DECL_MINIMAL_CHECK (NODE)))
    2719                 :             : 
    2720                 :             : /* This is the name of the object as written by the user.
    2721                 :             :    It is an IDENTIFIER_NODE.  */
    2722                 :             : #define DECL_NAME(NODE) (DECL_MINIMAL_CHECK (NODE)->decl_minimal.name)
    2723                 :             : 
    2724                 :             : /* The IDENTIFIER_NODE associated with the TYPE_NAME field.  */
    2725                 :             : #define TYPE_IDENTIFIER(NODE) \
    2726                 :             :   (TYPE_NAME (NODE) && DECL_P (TYPE_NAME (NODE)) \
    2727                 :             :    ? DECL_NAME (TYPE_NAME (NODE)) : TYPE_NAME (NODE))
    2728                 :             : 
    2729                 :             : /* Every ..._DECL node gets a unique number.  */
    2730                 :             : #define DECL_UID(NODE) (DECL_MINIMAL_CHECK (NODE)->decl_minimal.uid)
    2731                 :             : 
    2732                 :             : /* DEBUG_EXPR_DECLs get negative UID numbers, to catch erroneous
    2733                 :             :    uses.  */
    2734                 :             : #define DEBUG_TEMP_UID(NODE) (-DECL_UID (TREE_CHECK ((NODE), DEBUG_EXPR_DECL)))
    2735                 :             : 
    2736                 :             : /* Every ..._DECL node gets a unique number that stays the same even
    2737                 :             :    when the decl is copied by the inliner once it is set.  */
    2738                 :             : #define DECL_PT_UID(NODE) \
    2739                 :             :   (DECL_COMMON_CHECK (NODE)->decl_common.pt_uid == -1u \
    2740                 :             :    ? (NODE)->decl_minimal.uid : (NODE)->decl_common.pt_uid)
    2741                 :             : /* Initialize the ..._DECL node pt-uid to the decls uid.  */
    2742                 :             : #define SET_DECL_PT_UID(NODE, UID) \
    2743                 :             :   (DECL_COMMON_CHECK (NODE)->decl_common.pt_uid = (UID))
    2744                 :             : /* Whether the ..._DECL node pt-uid has been initialized and thus needs to
    2745                 :             :    be preserved when copyin the decl.  */
    2746                 :             : #define DECL_PT_UID_SET_P(NODE) \
    2747                 :             :   (DECL_COMMON_CHECK (NODE)->decl_common.pt_uid != -1u)
    2748                 :             : 
    2749                 :             : /* These two fields describe where in the source code the declaration
    2750                 :             :    was.  If the declaration appears in several places (as for a C
    2751                 :             :    function that is declared first and then defined later), this
    2752                 :             :    information should refer to the definition.  */
    2753                 :             : #define DECL_SOURCE_LOCATION(NODE) \
    2754                 :             :   (DECL_MINIMAL_CHECK (NODE)->decl_minimal.locus)
    2755                 :             : #define DECL_SOURCE_FILE(NODE) LOCATION_FILE (DECL_SOURCE_LOCATION (NODE))
    2756                 :             : #define DECL_SOURCE_LINE(NODE) LOCATION_LINE (DECL_SOURCE_LOCATION (NODE))
    2757                 :             : #define DECL_SOURCE_COLUMN(NODE) LOCATION_COLUMN (DECL_SOURCE_LOCATION (NODE))
    2758                 :             : /* This decl was created by a front-end or back-end rather than by
    2759                 :             :    user code, and has not been explicitly declared by the user -- when
    2760                 :             :    that happens the source location is updated to the user's
    2761                 :             :    source.  This includes decls with no location (!).  */
    2762                 :             : #define DECL_IS_UNDECLARED_BUILTIN(DECL) \
    2763                 :             :   (DECL_SOURCE_LOCATION (DECL) <= BUILTINS_LOCATION)
    2764                 :             : 
    2765                 :             : /*  For FIELD_DECLs, this is the RECORD_TYPE, UNION_TYPE, or
    2766                 :             :     QUAL_UNION_TYPE node that the field is a member of.  For VAR_DECL,
    2767                 :             :     PARM_DECL, FUNCTION_DECL, LABEL_DECL, RESULT_DECL, and CONST_DECL
    2768                 :             :     nodes, this points to either the FUNCTION_DECL for the containing
    2769                 :             :     function, the RECORD_TYPE or UNION_TYPE for the containing type, or
    2770                 :             :     NULL_TREE or a TRANSLATION_UNIT_DECL if the given decl has "file
    2771                 :             :     scope".  In particular, for VAR_DECLs which are virtual table pointers
    2772                 :             :     (they have DECL_VIRTUAL set), we use DECL_CONTEXT to determine the type
    2773                 :             :     they belong to.  */
    2774                 :             : #define DECL_CONTEXT(NODE) (DECL_MINIMAL_CHECK (NODE)->decl_minimal.context)
    2775                 :             : #define DECL_FIELD_CONTEXT(NODE) \
    2776                 :             :   (FIELD_DECL_CHECK (NODE)->decl_minimal.context)
    2777                 :             : 
    2778                 :             : /* If nonzero, decl's name shouldn't be emitted into debug info.  */
    2779                 :             : #define DECL_NAMELESS(NODE) (DECL_MINIMAL_CHECK (NODE)->base.u.bits.nameless_flag)
    2780                 :             : 
    2781                 :             : /* For any sort of a ..._DECL node, this points to the original (abstract)
    2782                 :             :    decl node which this decl is an inlined/cloned instance of, or else it
    2783                 :             :    is NULL indicating that this decl is not an instance of some other decl.
    2784                 :             : 
    2785                 :             :    The C front-end also uses this in a nested declaration of an inline
    2786                 :             :    function, to point back to the definition.  */
    2787                 :             : #define DECL_ABSTRACT_ORIGIN(NODE) \
    2788                 :             :   (DECL_COMMON_CHECK (NODE)->decl_common.abstract_origin)
    2789                 :             : 
    2790                 :             : /* Like DECL_ABSTRACT_ORIGIN, but returns NODE if there's no abstract
    2791                 :             :    origin.  This is useful when setting the DECL_ABSTRACT_ORIGIN.  */
    2792                 :             : #define DECL_ORIGIN(NODE) \
    2793                 :             :   (DECL_ABSTRACT_ORIGIN (NODE) ? DECL_ABSTRACT_ORIGIN (NODE) : (NODE))
    2794                 :             : 
    2795                 :             : /* Nonzero for any sort of ..._DECL node means this decl node represents an
    2796                 :             :    inline instance of some original (abstract) decl from an inline function;
    2797                 :             :    suppress any warnings about shadowing some other variable.  FUNCTION_DECL
    2798                 :             :    nodes can also have their abstract origin set to themselves.  */
    2799                 :             : #define DECL_FROM_INLINE(NODE) \
    2800                 :             :   (DECL_ABSTRACT_ORIGIN (NODE) != NULL_TREE \
    2801                 :             :    && DECL_ABSTRACT_ORIGIN (NODE) != (NODE))
    2802                 :             : 
    2803                 :             : /* In a DECL this is the field where attributes are stored.  */
    2804                 :             : #define DECL_ATTRIBUTES(NODE) \
    2805                 :             :   (DECL_COMMON_CHECK (NODE)->decl_common.attributes)
    2806                 :             : 
    2807                 :             : /* For a FUNCTION_DECL, holds the tree of BINDINGs.
    2808                 :             :    For a TRANSLATION_UNIT_DECL, holds the namespace's BLOCK.
    2809                 :             :    For a VAR_DECL, holds the initial value.
    2810                 :             :    For a PARM_DECL, used for DECL_ARG_TYPE--default
    2811                 :             :    values for parameters are encoded in the type of the function,
    2812                 :             :    not in the PARM_DECL slot.
    2813                 :             :    For a FIELD_DECL, this is used for enumeration values and the C
    2814                 :             :    frontend uses it for temporarily storing bitwidth of bitfields.
    2815                 :             : 
    2816                 :             :    ??? Need to figure out some way to check this isn't a PARM_DECL.  */
    2817                 :             : #define DECL_INITIAL(NODE) (DECL_COMMON_CHECK (NODE)->decl_common.initial)
    2818                 :             : 
    2819                 :             : /* Holds the size of the datum, in bits, as a tree expression.
    2820                 :             :    Need not be constant and may be null.  May be less than TYPE_SIZE
    2821                 :             :    for a C++ FIELD_DECL representing a base class subobject with its
    2822                 :             :    own virtual base classes (which are laid out separately).  */
    2823                 :             : #define DECL_SIZE(NODE) (DECL_COMMON_CHECK (NODE)->decl_common.size)
    2824                 :             : /* Likewise for the size in bytes.  */
    2825                 :             : #define DECL_SIZE_UNIT(NODE) (DECL_COMMON_CHECK (NODE)->decl_common.size_unit)
    2826                 :             : #define DECL_ALIGN_RAW(NODE) (DECL_COMMON_CHECK (NODE)->decl_common.align)
    2827                 :             : /* Returns the alignment required for the datum, in bits.  It must
    2828                 :             :    be a power of two, but an "alignment" of zero is supported
    2829                 :             :    (e.g. as "uninitialized" sentinel).  */
    2830                 :             : #define DECL_ALIGN(NODE)                                        \
    2831                 :             :   (DECL_ALIGN_RAW (NODE)                                        \
    2832                 :             :    ? ((unsigned)1) << (DECL_ALIGN_RAW (NODE) - 1) : 0)
    2833                 :             : /* Specify that DECL_ALIGN(NODE) is X.  */
    2834                 :             : #define SET_DECL_ALIGN(NODE, X) \
    2835                 :             :   (DECL_ALIGN_RAW (NODE) = ffs_hwi (X))
    2836                 :             : 
    2837                 :             : /* The minimum alignment necessary for the datum, in bits, without
    2838                 :             :    warning.  */
    2839                 :             : #define DECL_WARN_IF_NOT_ALIGN_RAW(NODE)                        \
    2840                 :             :   (DECL_COMMON_CHECK (NODE)->decl_common.warn_if_not_align)
    2841                 :             : #define DECL_WARN_IF_NOT_ALIGN(NODE)                                    \
    2842                 :             :   (DECL_WARN_IF_NOT_ALIGN_RAW (NODE)                                    \
    2843                 :             :    ? ((unsigned)1) << (DECL_WARN_IF_NOT_ALIGN_RAW (NODE) - 1) : 0)
    2844                 :             : 
    2845                 :             : /* Specify that DECL_WARN_IF_NOT_ALIGN(NODE) is X.  */
    2846                 :             : #define SET_DECL_WARN_IF_NOT_ALIGN(NODE, X)             \
    2847                 :             :   (DECL_WARN_IF_NOT_ALIGN_RAW (NODE) = ffs_hwi (X))
    2848                 :             : 
    2849                 :             : /* The alignment of NODE, in bytes.  */
    2850                 :             : #define DECL_ALIGN_UNIT(NODE) (DECL_ALIGN (NODE) / BITS_PER_UNIT)
    2851                 :             : /* Set if the alignment of this DECL has been set by the user, for
    2852                 :             :    example with an 'aligned' attribute.  */
    2853                 :             : #define DECL_USER_ALIGN(NODE) \
    2854                 :             :   (DECL_COMMON_CHECK (NODE)->base.u.bits.user_align)
    2855                 :             : /* Holds the machine mode corresponding to the declaration of a variable or
    2856                 :             :    field.  Always equal to TYPE_MODE (TREE_TYPE (decl)) except for a
    2857                 :             :    FIELD_DECL.  */
    2858                 :             : #define DECL_MODE(NODE) (DECL_COMMON_CHECK (NODE)->decl_common.mode)
    2859                 :             : #define SET_DECL_MODE(NODE, MODE) \
    2860                 :             :   (DECL_COMMON_CHECK (NODE)->decl_common.mode = (MODE))
    2861                 :             : 
    2862                 :             : /* For FUNCTION_DECL, if it is built-in, this identifies which built-in
    2863                 :             :    operation it is.  This is only intended for low-level accesses;
    2864                 :             :    normally DECL_FUNCTION_CODE, DECL_FE_FUNCTION_CODE or DECL_MD_FUNCTION
    2865                 :             :    should be used instead.  */
    2866                 :             : #define DECL_UNCHECKED_FUNCTION_CODE(NODE) \
    2867                 :             :   (FUNCTION_DECL_CHECK (NODE)->function_decl.function_code)
    2868                 :             : 
    2869                 :             : /* Test if FCODE is a function code for an alloca operation.  */
    2870                 :             : #define ALLOCA_FUNCTION_CODE_P(FCODE)                           \
    2871                 :             :   ((FCODE) == BUILT_IN_ALLOCA                                   \
    2872                 :             :    || (FCODE) == BUILT_IN_ALLOCA_WITH_ALIGN                     \
    2873                 :             :    || (FCODE) == BUILT_IN_ALLOCA_WITH_ALIGN_AND_MAX)
    2874                 :             : 
    2875                 :             : /* Generate case for an alloca operation.  */
    2876                 :             : #define CASE_BUILT_IN_ALLOCA                    \
    2877                 :             :   case BUILT_IN_ALLOCA:                         \
    2878                 :             :   case BUILT_IN_ALLOCA_WITH_ALIGN:              \
    2879                 :             :   case BUILT_IN_ALLOCA_WITH_ALIGN_AND_MAX
    2880                 :             : 
    2881                 :             : #define DECL_FUNCTION_PERSONALITY(NODE) \
    2882                 :             :   (FUNCTION_DECL_CHECK (NODE)->function_decl.personality)
    2883                 :             : 
    2884                 :             : /* Nonzero for a given ..._DECL node means that the name of this node should
    2885                 :             :    be ignored for symbolic debug purposes.  For a TYPE_DECL, this means that
    2886                 :             :    the associated type should be ignored.  For a FUNCTION_DECL, the body of
    2887                 :             :    the function should also be ignored.  */
    2888                 :             : #define DECL_IGNORED_P(NODE) \
    2889                 :             :   (DECL_COMMON_CHECK (NODE)->decl_common.ignored_flag)
    2890                 :             : 
    2891                 :             : /* Nonzero for a given ..._DECL node means that this node represents an
    2892                 :             :    "abstract instance" of the given declaration (e.g. in the original
    2893                 :             :    declaration of an inline function).  When generating symbolic debugging
    2894                 :             :    information, we mustn't try to generate any address information for nodes
    2895                 :             :    marked as "abstract instances" because we don't actually generate
    2896                 :             :    any code or allocate any data space for such instances.  */
    2897                 :             : #define DECL_ABSTRACT_P(NODE) \
    2898                 :             :   (DECL_COMMON_CHECK (NODE)->decl_common.abstract_flag)
    2899                 :             : 
    2900                 :             : /* Language-specific decl information.  */
    2901                 :             : #define DECL_LANG_SPECIFIC(NODE) \
    2902                 :             :   (DECL_COMMON_CHECK (NODE)->decl_common.lang_specific)
    2903                 :             : 
    2904                 :             : /* In a VAR_DECL or FUNCTION_DECL, nonzero means external reference:
    2905                 :             :    do not allocate storage, and refer to a definition elsewhere.  Note that
    2906                 :             :    this does not necessarily imply the entity represented by NODE
    2907                 :             :    has no program source-level definition in this translation unit.  For
    2908                 :             :    example, for a FUNCTION_DECL, DECL_SAVED_TREE may be non-NULL and
    2909                 :             :    DECL_EXTERNAL may be true simultaneously; that can be the case for
    2910                 :             :    a C99 "extern inline" function.  */
    2911                 :             : #define DECL_EXTERNAL(NODE) (DECL_COMMON_CHECK (NODE)->decl_common.decl_flag_1)
    2912                 :             : 
    2913                 :             : /* Nonzero in a ..._DECL means this variable is ref'd from a nested function.
    2914                 :             :    For VAR_DECL nodes, PARM_DECL nodes, and FUNCTION_DECL nodes.
    2915                 :             : 
    2916                 :             :    For LABEL_DECL nodes, nonzero if nonlocal gotos to the label are permitted.
    2917                 :             : 
    2918                 :             :    Also set in some languages for variables, etc., outside the normal
    2919                 :             :    lexical scope, such as class instance variables.  */
    2920                 :             : #define DECL_NONLOCAL(NODE) \
    2921                 :             :   (DECL_COMMON_CHECK (NODE)->decl_common.nonlocal_flag)
    2922                 :             : 
    2923                 :             : /* Used in VAR_DECLs to indicate that the variable is a vtable.
    2924                 :             :    Used in FIELD_DECLs for vtable pointers.
    2925                 :             :    Used in FUNCTION_DECLs to indicate that the function is virtual.  */
    2926                 :             : #define DECL_VIRTUAL_P(NODE) \
    2927                 :             :   (DECL_COMMON_CHECK (NODE)->decl_common.virtual_flag)
    2928                 :             : 
    2929                 :             : /* Used to indicate that this DECL represents a compiler-generated entity.  */
    2930                 :             : #define DECL_ARTIFICIAL(NODE) \
    2931                 :             :   (DECL_COMMON_CHECK (NODE)->decl_common.artificial_flag)
    2932                 :             : 
    2933                 :             : /* Additional flags for language-specific uses.  */
    2934                 :             : #define DECL_LANG_FLAG_0(NODE) \
    2935                 :             :   (DECL_COMMON_CHECK (NODE)->decl_common.lang_flag_0)
    2936                 :             : #define DECL_LANG_FLAG_1(NODE) \
    2937                 :             :   (DECL_COMMON_CHECK (NODE)->decl_common.lang_flag_1)
    2938                 :             : #define DECL_LANG_FLAG_2(NODE) \
    2939                 :             :   (DECL_COMMON_CHECK (NODE)->decl_common.lang_flag_2)
    2940                 :             : #define DECL_LANG_FLAG_3(NODE) \
    2941                 :             :   (DECL_COMMON_CHECK (NODE)->decl_common.lang_flag_3)
    2942                 :             : #define DECL_LANG_FLAG_4(NODE) \
    2943                 :             :   (DECL_COMMON_CHECK (NODE)->decl_common.lang_flag_4)
    2944                 :             : #define DECL_LANG_FLAG_5(NODE) \
    2945                 :             :   (DECL_COMMON_CHECK (NODE)->decl_common.lang_flag_5)
    2946                 :             : #define DECL_LANG_FLAG_6(NODE) \
    2947                 :             :   (DECL_COMMON_CHECK (NODE)->decl_common.lang_flag_6)
    2948                 :             : #define DECL_LANG_FLAG_7(NODE) \
    2949                 :             :   (DECL_COMMON_CHECK (NODE)->decl_common.lang_flag_7)
    2950                 :             : #define DECL_LANG_FLAG_8(NODE) \
    2951                 :             :   (DECL_COMMON_CHECK (NODE)->decl_common.lang_flag_8)
    2952                 :             : 
    2953                 :             : /* Nonzero for a scope which is equal to file scope.  */
    2954                 :             : #define SCOPE_FILE_SCOPE_P(EXP) \
    2955                 :             :   (! (EXP) || TREE_CODE (EXP) == TRANSLATION_UNIT_DECL)
    2956                 :             : /* Nonzero for a decl which is at file scope.  */
    2957                 :             : #define DECL_FILE_SCOPE_P(EXP) SCOPE_FILE_SCOPE_P (DECL_CONTEXT (EXP))
    2958                 :             : /* Nonzero for a type which is at file scope.  */
    2959                 :             : #define TYPE_FILE_SCOPE_P(EXP) SCOPE_FILE_SCOPE_P (TYPE_CONTEXT (EXP))
    2960                 :             : 
    2961                 :             : /* Nonzero for a decl that is decorated using attribute used.
    2962                 :             :    This indicates to compiler tools that this decl needs to be preserved.  */
    2963                 :             : #define DECL_PRESERVE_P(DECL) \
    2964                 :             :   DECL_COMMON_CHECK (DECL)->decl_common.preserve_flag
    2965                 :             : 
    2966                 :             : /* Nonzero for a decl that is decorated with the "noinit" attribute.
    2967                 :             :    decls with this attribute are placed into the ".noinit" section, so they are
    2968                 :             :    not initialized by the target's startup code.  */
    2969                 :             : #define DECL_NOINIT_P(DECL)     \
    2970                 :             :   (DECL_P (DECL)                \
    2971                 :             :    && (lookup_attribute ("noinit", DECL_ATTRIBUTES (DECL)) != NULL_TREE))
    2972                 :             : 
    2973                 :             : /* Nonzero for a decl that is decorated with the "persistent" attribute.
    2974                 :             :    decls with this attribute are placed into the ".persistent" section, so they
    2975                 :             :    are not initialized by the target's startup code.  */
    2976                 :             : #define DECL_PERSISTENT_P(DECL) \
    2977                 :             :   (DECL_P (DECL)                \
    2978                 :             :    && (lookup_attribute ("persistent", DECL_ATTRIBUTES (DECL)) != NULL_TREE))
    2979                 :             : 
    2980                 :             : /* For function local variables of COMPLEX and VECTOR types,
    2981                 :             :    indicates that the variable is not aliased, and that all
    2982                 :             :    modifications to the variable have been adjusted so that
    2983                 :             :    they are killing assignments.  Thus the variable may now
    2984                 :             :    be treated as a GIMPLE register, and use real instead of
    2985                 :             :    virtual ops in SSA form.  */
    2986                 :             : #define DECL_NOT_GIMPLE_REG_P(DECL) \
    2987                 :             :   DECL_COMMON_CHECK (DECL)->decl_common.not_gimple_reg_flag
    2988                 :             : 
    2989                 :             : extern tree decl_value_expr_lookup (tree);
    2990                 :             : extern void decl_value_expr_insert (tree, tree);
    2991                 :             : 
    2992                 :             : /* In a VAR_DECL or PARM_DECL, the location at which the value may be found,
    2993                 :             :    if transformations have made this more complicated than evaluating the
    2994                 :             :    decl itself.  */
    2995                 :             : #define DECL_HAS_VALUE_EXPR_P(NODE) \
    2996                 :             :   (TREE_CHECK3 (NODE, VAR_DECL, PARM_DECL, RESULT_DECL) \
    2997                 :             :    ->decl_common.decl_flag_2)
    2998                 :             : #define DECL_VALUE_EXPR(NODE) \
    2999                 :             :   (decl_value_expr_lookup (DECL_WRTL_CHECK (NODE)))
    3000                 :             : #define SET_DECL_VALUE_EXPR(NODE, VAL) \
    3001                 :             :   (decl_value_expr_insert (DECL_WRTL_CHECK (NODE), VAL))
    3002                 :             : 
    3003                 :             : /* Holds the RTL expression for the value of a variable or function.
    3004                 :             :    This value can be evaluated lazily for functions, variables with
    3005                 :             :    static storage duration, and labels.  */
    3006                 :             : #define DECL_RTL(NODE)                                  \
    3007                 :             :   (DECL_WRTL_CHECK (NODE)->decl_with_rtl.rtl         \
    3008                 :             :    ? (NODE)->decl_with_rtl.rtl                                       \
    3009                 :             :    : (make_decl_rtl (NODE), (NODE)->decl_with_rtl.rtl))
    3010                 :             : 
    3011                 :             : /* Set the DECL_RTL for NODE to RTL.  */
    3012                 :             : #define SET_DECL_RTL(NODE, RTL) set_decl_rtl (NODE, RTL)
    3013                 :             : 
    3014                 :             : /* Returns nonzero if NODE is a tree node that can contain RTL.  */
    3015                 :             : #define HAS_RTL_P(NODE) (CODE_CONTAINS_STRUCT (TREE_CODE (NODE), TS_DECL_WRTL))
    3016                 :             : 
    3017                 :             : /* Returns nonzero if the DECL_RTL for NODE has already been set.  */
    3018                 :             : #define DECL_RTL_SET_P(NODE) \
    3019                 :             :   (HAS_RTL_P (NODE) && DECL_WRTL_CHECK (NODE)->decl_with_rtl.rtl != NULL)
    3020                 :             : 
    3021                 :             : /* Copy the RTL from SRC_DECL to DST_DECL.  If the RTL was not set for
    3022                 :             :    SRC_DECL, it will not be set for DST_DECL; this is a lazy copy.  */
    3023                 :             : #define COPY_DECL_RTL(SRC_DECL, DST_DECL) \
    3024                 :             :   (DECL_WRTL_CHECK (DST_DECL)->decl_with_rtl.rtl \
    3025                 :             :    = DECL_WRTL_CHECK (SRC_DECL)->decl_with_rtl.rtl)
    3026                 :             : 
    3027                 :             : /* The DECL_RTL for NODE, if it is set, or NULL, if it is not set.  */
    3028                 :             : #define DECL_RTL_IF_SET(NODE) (DECL_RTL_SET_P (NODE) ? DECL_RTL (NODE) : NULL)
    3029                 :             : 
    3030                 :             : #if (GCC_VERSION >= 2007)
    3031                 :             : #define DECL_RTL_KNOWN_SET(decl) __extension__                          \
    3032                 :             : ({  tree const __d = (decl);                                            \
    3033                 :             :     gcc_checking_assert (DECL_RTL_SET_P (__d));                         \
    3034                 :             :     /* Dereference it so the compiler knows it can't be NULL even       \
    3035                 :             :        without assertion checking.  */                                  \
    3036                 :             :     &*DECL_RTL_IF_SET (__d); })
    3037                 :             : #else
    3038                 :             : #define DECL_RTL_KNOWN_SET(decl) (&*DECL_RTL_IF_SET (decl))
    3039                 :             : #endif
    3040                 :             : 
    3041                 :             : /* In VAR_DECL and PARM_DECL nodes, nonzero means declared `register'.  */
    3042                 :             : #define DECL_REGISTER(NODE) (DECL_WRTL_CHECK (NODE)->decl_common.decl_flag_0)
    3043                 :             : 
    3044                 :             : /* In a FIELD_DECL, this is the field position, counting in bytes, of the
    3045                 :             :    DECL_OFFSET_ALIGN-bit-sized word containing the bit closest to the beginning
    3046                 :             :    of the structure.  */
    3047                 :             : #define DECL_FIELD_OFFSET(NODE) (FIELD_DECL_CHECK (NODE)->field_decl.offset)
    3048                 :             : 
    3049                 :             : /* In a FIELD_DECL, this is the offset, in bits, of the first bit of the
    3050                 :             :    field from DECL_FIELD_OFFSET.  This field may be nonzero even for fields
    3051                 :             :    that are not bit fields (since DECL_OFFSET_ALIGN may be larger than the
    3052                 :             :    natural alignment of the field's type).  */
    3053                 :             : #define DECL_FIELD_BIT_OFFSET(NODE) \
    3054                 :             :   (FIELD_DECL_CHECK (NODE)->field_decl.bit_offset)
    3055                 :             : 
    3056                 :             : /* In a FIELD_DECL, this indicates whether the field was a bit-field and
    3057                 :             :    if so, the type that was originally specified for it.
    3058                 :             :    TREE_TYPE may have been modified (in finish_struct).  */
    3059                 :             : #define DECL_BIT_FIELD_TYPE(NODE) \
    3060                 :             :   (FIELD_DECL_CHECK (NODE)->field_decl.bit_field_type)
    3061                 :             : 
    3062                 :             : /* In a FIELD_DECL of a RECORD_TYPE, this is a pointer to the storage
    3063                 :             :    representative FIELD_DECL.  */
    3064                 :             : #define DECL_BIT_FIELD_REPRESENTATIVE(NODE) \
    3065                 :             :   (FIELD_DECL_CHECK (NODE)->field_decl.qualifier)
    3066                 :             : 
    3067                 :             : /* For a FIELD_DECL in a QUAL_UNION_TYPE, records the expression, which
    3068                 :             :    if nonzero, indicates that the field occupies the type.  */
    3069                 :             : #define DECL_QUALIFIER(NODE) (FIELD_DECL_CHECK (NODE)->field_decl.qualifier)
    3070                 :             : 
    3071                 :             : /* For FIELD_DECLs, off_align holds the number of low-order bits of
    3072                 :             :    DECL_FIELD_OFFSET which are known to be always zero.
    3073                 :             :    DECL_OFFSET_ALIGN thus returns the alignment that DECL_FIELD_OFFSET
    3074                 :             :    has.  */
    3075                 :             : #define DECL_OFFSET_ALIGN(NODE) \
    3076                 :             :   (HOST_WIDE_INT_1U << FIELD_DECL_CHECK (NODE)->decl_common.off_align)
    3077                 :             : 
    3078                 :             : /* Specify that DECL_OFFSET_ALIGN(NODE) is X.  */
    3079                 :             : #define SET_DECL_OFFSET_ALIGN(NODE, X) \
    3080                 :             :   (FIELD_DECL_CHECK (NODE)->decl_common.off_align = ffs_hwi (X) - 1)
    3081                 :             : 
    3082                 :             : /* For FIELD_DECLS, DECL_FCONTEXT is the *first* baseclass in
    3083                 :             :    which this FIELD_DECL is defined.  This information is needed when
    3084                 :             :    writing debugging information about vfield and vbase decls for C++.  */
    3085                 :             : #define DECL_FCONTEXT(NODE) (FIELD_DECL_CHECK (NODE)->field_decl.fcontext)
    3086                 :             : 
    3087                 :             : /* In a FIELD_DECL, indicates this field should be bit-packed.  */
    3088                 :             : #define DECL_PACKED(NODE) (FIELD_DECL_CHECK (NODE)->base.u.bits.packed_flag)
    3089                 :             : 
    3090                 :             : /* Nonzero in a FIELD_DECL means it is a bit field, and must be accessed
    3091                 :             :    specially.  */
    3092                 :             : #define DECL_BIT_FIELD(NODE) (FIELD_DECL_CHECK (NODE)->decl_common.decl_flag_1)
    3093                 :             : 
    3094                 :             : /* In a FIELD_DECL, indicates this field should be ignored for ABI decisions
    3095                 :             :    like passing/returning containing struct by value.
    3096                 :             :    Set for C++17 empty base artificial FIELD_DECLs as well as
    3097                 :             :    empty [[no_unique_address]] non-static data members.  */
    3098                 :             : #define DECL_FIELD_ABI_IGNORED(NODE) \
    3099                 :             :   (!DECL_BIT_FIELD (NODE) && (NODE)->decl_common.decl_flag_0)
    3100                 :             : #define SET_DECL_FIELD_ABI_IGNORED(NODE, VAL) \
    3101                 :             :   do {                                                                  \
    3102                 :             :     gcc_checking_assert (!DECL_BIT_FIELD (NODE));                       \
    3103                 :             :     FIELD_DECL_CHECK (NODE)->decl_common.decl_flag_0 = (VAL);                \
    3104                 :             :   } while (0)
    3105                 :             : 
    3106                 :             : /* In a FIELD_DECL, indicates C++ zero-width bitfield that used to be
    3107                 :             :    removed from the IL since PR42217 until PR101539 and by that changed
    3108                 :             :    the ABI on several targets.  This flag is provided so that the backends
    3109                 :             :    can decide on the ABI with zero-width bitfields and emit -Wpsabi
    3110                 :             :    warnings.  */
    3111                 :             : #define DECL_FIELD_CXX_ZERO_WIDTH_BIT_FIELD(NODE) \
    3112                 :             :   (DECL_BIT_FIELD (NODE) && (NODE)->decl_common.decl_flag_0)
    3113                 :             : #define SET_DECL_FIELD_CXX_ZERO_WIDTH_BIT_FIELD(NODE, VAL) \
    3114                 :             :   do {                                                                  \
    3115                 :             :     gcc_checking_assert (DECL_BIT_FIELD (NODE));                        \
    3116                 :             :     FIELD_DECL_CHECK (NODE)->decl_common.decl_flag_0 = (VAL);                \
    3117                 :             :   } while (0)
    3118                 :             : 
    3119                 :             : /* Used in a FIELD_DECL to indicate that we cannot form the address of
    3120                 :             :    this component.  This makes it possible for Type-Based Alias Analysis
    3121                 :             :    to disambiguate accesses to this field with indirect accesses using
    3122                 :             :    the field's type:
    3123                 :             : 
    3124                 :             :      struct S { int i; } s;
    3125                 :             :      int *p;
    3126                 :             : 
    3127                 :             :    If the flag is set on 'i', TBAA computes that s.i and *p never conflict.
    3128                 :             : 
    3129                 :             :    From the implementation's viewpoint, the alias set of the type of the
    3130                 :             :    field 'i' (int) will not be recorded as a subset of that of the type of
    3131                 :             :    's' (struct S) in record_component_aliases.  The counterpart is that
    3132                 :             :    accesses to s.i must not be given the alias set of the type of 'i'
    3133                 :             :    (int) but instead directly that of the type of 's' (struct S).  */
    3134                 :             : #define DECL_NONADDRESSABLE_P(NODE) \
    3135                 :             :   (FIELD_DECL_CHECK (NODE)->decl_common.decl_flag_2)
    3136                 :             : 
    3137                 :             : /* Used in a FIELD_DECL to indicate that this field is padding.  */
    3138                 :             : #define DECL_PADDING_P(NODE) \
    3139                 :             :   (FIELD_DECL_CHECK (NODE)->decl_common.decl_flag_3)
    3140                 :             : 
    3141                 :             : /* Used in a FIELD_DECL to indicate whether this field is not a flexible
    3142                 :             :    array member. This is only valid for the last array type field of a
    3143                 :             :    structure.  */
    3144                 :             : #define DECL_NOT_FLEXARRAY(NODE) \
    3145                 :             :   (FIELD_DECL_CHECK (NODE)->decl_common.decl_not_flexarray)
    3146                 :             : 
    3147                 :             : /* A numeric unique identifier for a LABEL_DECL.  The UID allocation is
    3148                 :             :    dense, unique within any one function, and may be used to index arrays.
    3149                 :             :    If the value is -1, then no UID has been assigned.  */
    3150                 :             : #define LABEL_DECL_UID(NODE) \
    3151                 :             :   (LABEL_DECL_CHECK (NODE)->label_decl.label_decl_uid)
    3152                 :             : 
    3153                 :             : /* In a LABEL_DECL, the EH region number for which the label is the
    3154                 :             :    post_landing_pad.  */
    3155                 :             : #define EH_LANDING_PAD_NR(NODE) \
    3156                 :             :   (LABEL_DECL_CHECK (NODE)->label_decl.eh_landing_pad_nr)
    3157                 :             : 
    3158                 :             : /* For a PARM_DECL, records the data type used to pass the argument,
    3159                 :             :    which may be different from the type seen in the program.  */
    3160                 :             : #define DECL_ARG_TYPE(NODE) (PARM_DECL_CHECK (NODE)->decl_common.initial)
    3161                 :             : 
    3162                 :             : /* For PARM_DECL, holds an RTL for the stack slot or register
    3163                 :             :    where the data was actually passed.  */
    3164                 :             : #define DECL_INCOMING_RTL(NODE) \
    3165                 :             :   (PARM_DECL_CHECK (NODE)->parm_decl.incoming_rtl)
    3166                 :             : 
    3167                 :             : /* Nonzero for a given ..._DECL node means that no warnings should be
    3168                 :             :    generated just because this node is unused.  */
    3169                 :             : #define DECL_IN_SYSTEM_HEADER(NODE) \
    3170                 :             :   (in_system_header_at (DECL_SOURCE_LOCATION (NODE)))
    3171                 :             : 
    3172                 :             : /* Used to indicate that the linkage status of this DECL is not yet known,
    3173                 :             :    so it should not be output now.  */
    3174                 :             : #define DECL_DEFER_OUTPUT(NODE) \
    3175                 :             :   (DECL_WITH_VIS_CHECK (NODE)->decl_with_vis.defer_output)
    3176                 :             : 
    3177                 :             : /* In a VAR_DECL that's static,
    3178                 :             :    nonzero if the space is in the text section.  */
    3179                 :             : #define DECL_IN_TEXT_SECTION(NODE) \
    3180                 :             :   (VAR_DECL_CHECK (NODE)->decl_with_vis.in_text_section)
    3181                 :             : 
    3182                 :             : /* In a VAR_DECL that's static,
    3183                 :             :    nonzero if it belongs to the global constant pool.  */
    3184                 :             : #define DECL_IN_CONSTANT_POOL(NODE) \
    3185                 :             :   (VAR_DECL_CHECK (NODE)->decl_with_vis.in_constant_pool)
    3186                 :             : 
    3187                 :             : /* Nonzero for a given ..._DECL node means that this node should be
    3188                 :             :    put in .common, if possible.  If a DECL_INITIAL is given, and it
    3189                 :             :    is not error_mark_node, then the decl cannot be put in .common.  */
    3190                 :             : #define DECL_COMMON(NODE) \
    3191                 :             :   (DECL_WITH_VIS_CHECK (NODE)->decl_with_vis.common_flag)
    3192                 :             : 
    3193                 :             : /* In a VAR_DECL, nonzero if the decl is a register variable with
    3194                 :             :    an explicit asm specification.  */
    3195                 :             : #define DECL_HARD_REGISTER(NODE)  \
    3196                 :             :   (VAR_DECL_CHECK (NODE)->decl_with_vis.hard_register)
    3197                 :             : 
    3198                 :             :   /* Used to indicate that this DECL has weak linkage.  */
    3199                 :             : #define DECL_WEAK(NODE) (DECL_WITH_VIS_CHECK (NODE)->decl_with_vis.weak_flag)
    3200                 :             : 
    3201                 :             : /* Used to indicate that the DECL is a dllimport.  */
    3202                 :             : #define DECL_DLLIMPORT_P(NODE) \
    3203                 :             :   (DECL_WITH_VIS_CHECK (NODE)->decl_with_vis.dllimport_flag)
    3204                 :             : 
    3205                 :             : /* Used in a DECL to indicate that, even if it TREE_PUBLIC, it need
    3206                 :             :    not be put out unless it is needed in this translation unit.
    3207                 :             :    Entities like this are shared across translation units (like weak
    3208                 :             :    entities), but are guaranteed to be generated by any translation
    3209                 :             :    unit that needs them, and therefore need not be put out anywhere
    3210                 :             :    where they are not needed.  DECL_COMDAT is just a hint to the
    3211                 :             :    back-end; it is up to front-ends which set this flag to ensure
    3212                 :             :    that there will never be any harm, other than bloat, in putting out
    3213                 :             :    something which is DECL_COMDAT.  */
    3214                 :             : #define DECL_COMDAT(NODE) \
    3215                 :             :   (DECL_WITH_VIS_CHECK (NODE)->decl_with_vis.comdat_flag)
    3216                 :             : 
    3217                 :             : #define DECL_COMDAT_GROUP(NODE) \
    3218                 :             :   decl_comdat_group (NODE)
    3219                 :             : 
    3220                 :             : /* Used in TREE_PUBLIC decls to indicate that copies of this DECL in
    3221                 :             :    multiple translation units should be merged.  */
    3222                 :             : #define DECL_ONE_ONLY(NODE) (DECL_COMDAT_GROUP (NODE) != NULL_TREE \
    3223                 :             :                              && (TREE_PUBLIC (NODE) || DECL_EXTERNAL (NODE)))
    3224                 :             : 
    3225                 :             : /* The name of the object as the assembler will see it (but before any
    3226                 :             :    translations made by ASM_OUTPUT_LABELREF).  Often this is the same
    3227                 :             :    as DECL_NAME.  It is an IDENTIFIER_NODE.
    3228                 :             : 
    3229                 :             :    ASSEMBLER_NAME of TYPE_DECLS may store global name of type used for
    3230                 :             :    One Definition Rule based type merging at LTO.  It is computed only for
    3231                 :             :    LTO compilation and C++.  */
    3232                 :             : #define DECL_ASSEMBLER_NAME(NODE) decl_assembler_name (NODE)
    3233                 :             : 
    3234                 :             : /* Raw accessor for DECL_ASSEMBLE_NAME.  */
    3235                 :             : #define DECL_ASSEMBLER_NAME_RAW(NODE) \
    3236                 :             :   (DECL_WITH_VIS_CHECK (NODE)->decl_with_vis.assembler_name)
    3237                 :             : 
    3238                 :             : /* Return true if NODE is a NODE that can contain a DECL_ASSEMBLER_NAME.
    3239                 :             :    This is true of all DECL nodes except FIELD_DECL.  */
    3240                 :             : #define HAS_DECL_ASSEMBLER_NAME_P(NODE) \
    3241                 :             :   (CODE_CONTAINS_STRUCT (TREE_CODE (NODE), TS_DECL_WITH_VIS))
    3242                 :             : 
    3243                 :             : /* Returns nonzero if the DECL_ASSEMBLER_NAME for NODE has been set.  If zero,
    3244                 :             :    the NODE might still have a DECL_ASSEMBLER_NAME -- it just hasn't been set
    3245                 :             :    yet.  */
    3246                 :             : #define DECL_ASSEMBLER_NAME_SET_P(NODE) \
    3247                 :             :   (DECL_ASSEMBLER_NAME_RAW (NODE) != NULL_TREE)
    3248                 :             : 
    3249                 :             : /* Set the DECL_ASSEMBLER_NAME for NODE to NAME.  */
    3250                 :             : #define SET_DECL_ASSEMBLER_NAME(NODE, NAME) \
    3251                 :             :   overwrite_decl_assembler_name (NODE, NAME)
    3252                 :             : 
    3253                 :             : /* Copy the DECL_ASSEMBLER_NAME from SRC_DECL to DST_DECL.  Note that
    3254                 :             :    if SRC_DECL's DECL_ASSEMBLER_NAME has not yet been set, using this
    3255                 :             :    macro will not cause the DECL_ASSEMBLER_NAME to be set, but will
    3256                 :             :    clear DECL_ASSEMBLER_NAME of DST_DECL, if it was already set.  In
    3257                 :             :    other words, the semantics of using this macro, are different than
    3258                 :             :    saying:
    3259                 :             : 
    3260                 :             :      SET_DECL_ASSEMBLER_NAME(DST_DECL, DECL_ASSEMBLER_NAME (SRC_DECL))
    3261                 :             : 
    3262                 :             :    which will try to set the DECL_ASSEMBLER_NAME for SRC_DECL.  */
    3263                 :             : 
    3264                 :             : #define COPY_DECL_ASSEMBLER_NAME(SRC_DECL, DST_DECL)                    \
    3265                 :             :   SET_DECL_ASSEMBLER_NAME (DST_DECL, DECL_ASSEMBLER_NAME_RAW (SRC_DECL))
    3266                 :             : 
    3267                 :             : /* Records the section name in a section attribute.  Used to pass
    3268                 :             :    the name from decl_attributes to make_function_rtl and make_decl_rtl.  */
    3269                 :             : #define DECL_SECTION_NAME(NODE) decl_section_name (NODE)
    3270                 :             : 
    3271                 :             : /* Nonzero in a decl means that the gimplifier has seen (or placed)
    3272                 :             :    this variable in a BIND_EXPR.  */
    3273                 :             : #define DECL_SEEN_IN_BIND_EXPR_P(NODE) \
    3274                 :             :   (DECL_WITH_VIS_CHECK (NODE)->decl_with_vis.seen_in_bind_expr)
    3275                 :             : 
    3276                 :             : /* Value of the decls's visibility attribute */
    3277                 :             : #define DECL_VISIBILITY(NODE) \
    3278                 :             :   (DECL_WITH_VIS_CHECK (NODE)->decl_with_vis.visibility)
    3279                 :             : 
    3280                 :             : /* Nonzero means that the decl (or an enclosing scope) had its
    3281                 :             :    visibility specified rather than being inferred.  */
    3282                 :             : #define DECL_VISIBILITY_SPECIFIED(NODE) \
    3283                 :             :   (DECL_WITH_VIS_CHECK (NODE)->decl_with_vis.visibility_specified)
    3284                 :             : 
    3285                 :             : /* In a VAR_DECL, the model to use if the data should be allocated from
    3286                 :             :    thread-local storage.  */
    3287                 :             : #define DECL_TLS_MODEL(NODE) decl_tls_model (NODE)
    3288                 :             : 
    3289                 :             : /* In a VAR_DECL, nonzero if the data should be allocated from
    3290                 :             :    thread-local storage.  */
    3291                 :             : #define DECL_THREAD_LOCAL_P(NODE) \
    3292                 :             :   ((TREE_STATIC (NODE) || DECL_EXTERNAL (NODE)) && decl_tls_model (NODE) >= TLS_MODEL_REAL)
    3293                 :             : 
    3294                 :             : /* In a non-local VAR_DECL with static storage duration, true if the
    3295                 :             :    variable has an initialization priority.  If false, the variable
    3296                 :             :    will be initialized at the DEFAULT_INIT_PRIORITY.  */
    3297                 :             : #define DECL_HAS_INIT_PRIORITY_P(NODE) \
    3298                 :             :   (VAR_DECL_CHECK (NODE)->decl_with_vis.init_priority_p)
    3299                 :             : 
    3300                 :             : extern tree decl_debug_expr_lookup (tree);
    3301                 :             : extern void decl_debug_expr_insert (tree, tree);
    3302                 :             : 
    3303                 :             : /* For VAR_DECL, this is set to an expression that it was split from.  */
    3304                 :             : #define DECL_HAS_DEBUG_EXPR_P(NODE) \
    3305                 :             :   (VAR_DECL_CHECK (NODE)->decl_common.debug_expr_is_from)
    3306                 :             : #define DECL_DEBUG_EXPR(NODE) \
    3307                 :             :   (decl_debug_expr_lookup (VAR_DECL_CHECK (NODE)))
    3308                 :             : 
    3309                 :             : #define SET_DECL_DEBUG_EXPR(NODE, VAL) \
    3310                 :             :   (decl_debug_expr_insert (VAR_DECL_CHECK (NODE), VAL))
    3311                 :             : 
    3312                 :             : extern priority_type decl_init_priority_lookup (tree);
    3313                 :             : extern priority_type decl_fini_priority_lookup (tree);
    3314                 :             : extern void decl_init_priority_insert (tree, priority_type);
    3315                 :             : extern void decl_fini_priority_insert (tree, priority_type);
    3316                 :             : 
    3317                 :             : /* For a VAR_DECL or FUNCTION_DECL the initialization priority of
    3318                 :             :    NODE.  */
    3319                 :             : #define DECL_INIT_PRIORITY(NODE) \
    3320                 :             :   (decl_init_priority_lookup (NODE))
    3321                 :             : /* Set the initialization priority for NODE to VAL.  */
    3322                 :             : #define SET_DECL_INIT_PRIORITY(NODE, VAL) \
    3323                 :             :   (decl_init_priority_insert (NODE, VAL))
    3324                 :             : 
    3325                 :             : /* For a FUNCTION_DECL the finalization priority of NODE.  */
    3326                 :             : #define DECL_FINI_PRIORITY(NODE) \
    3327                 :             :   (decl_fini_priority_lookup (NODE))
    3328                 :             : /* Set the finalization priority for NODE to VAL.  */
    3329                 :             : #define SET_DECL_FINI_PRIORITY(NODE, VAL) \
    3330                 :             :   (decl_fini_priority_insert (NODE, VAL))
    3331                 :             : 
    3332                 :             : /* The initialization priority for entities for which no explicit
    3333                 :             :    initialization priority has been specified.  */
    3334                 :             : #define DEFAULT_INIT_PRIORITY 65535
    3335                 :             : 
    3336                 :             : /* The maximum allowed initialization priority.  */
    3337                 :             : #define MAX_INIT_PRIORITY 65535
    3338                 :             : 
    3339                 :             : /* The largest priority value reserved for use by system runtime
    3340                 :             :    libraries.  */
    3341                 :             : #define MAX_RESERVED_INIT_PRIORITY 100
    3342                 :             : 
    3343                 :             : /* In a VAR_DECL, nonzero if this is a global variable for VOPs.  */
    3344                 :             : #define VAR_DECL_IS_VIRTUAL_OPERAND(NODE) \
    3345                 :             :   (VAR_DECL_CHECK (NODE)->base.u.bits.saturating_flag)
    3346                 :             : 
    3347                 :             : /* In a VAR_DECL, nonzero if this is a non-local frame structure.  */
    3348                 :             : #define DECL_NONLOCAL_FRAME(NODE)  \
    3349                 :             :   (VAR_DECL_CHECK (NODE)->base.default_def_flag)
    3350                 :             : 
    3351                 :             : /* In a VAR_DECL, nonzero if this variable is not aliased by any pointer.  */
    3352                 :             : #define DECL_NONALIASED(NODE) \
    3353                 :             :   (VAR_DECL_CHECK (NODE)->base.nothrow_flag)
    3354                 :             : 
    3355                 :             : /* In a VAR_DECL, nonzero if this variable is not required to have a distinct
    3356                 :             :    address from other variables with the same constant value.  In other words,
    3357                 :             :    consider -fmerge-all-constants to be on for this VAR_DECL.  */
    3358                 :             : #define DECL_MERGEABLE(NODE) \
    3359                 :             :   (VAR_DECL_CHECK (NODE)->decl_common.decl_flag_3)
    3360                 :             : 
    3361                 :             : /* This field is used to reference anything in decl.result and is meant only
    3362                 :             :    for use by the garbage collector.  */
    3363                 :             : #define DECL_RESULT_FLD(NODE) \
    3364                 :             :   (DECL_NON_COMMON_CHECK (NODE)->decl_non_common.result)
    3365                 :             : 
    3366                 :             : /* The DECL_VINDEX is used for FUNCTION_DECLS in two different ways.
    3367                 :             :    Before the struct containing the FUNCTION_DECL is laid out,
    3368                 :             :    DECL_VINDEX may point to a FUNCTION_DECL in a base class which
    3369                 :             :    is the FUNCTION_DECL which this FUNCTION_DECL will replace as a virtual
    3370                 :             :    function.  When the class is laid out, this pointer is changed
    3371                 :             :    to an INTEGER_CST node which is suitable for use as an index
    3372                 :             :    into the virtual function table. */
    3373                 :             : #define DECL_VINDEX(NODE) \
    3374                 :             :   (FUNCTION_DECL_CHECK (NODE)->function_decl.vindex)
    3375                 :             : 
    3376                 :             : /* In FUNCTION_DECL, holds the decl for the return value.  */
    3377                 :             : #define DECL_RESULT(NODE) (FUNCTION_DECL_CHECK (NODE)->decl_non_common.result)
    3378                 :             : 
    3379                 :             : /* In a FUNCTION_DECL, nonzero if the function cannot be inlined.  */
    3380                 :             : #define DECL_UNINLINABLE(NODE) \
    3381                 :             :   (FUNCTION_DECL_CHECK (NODE)->function_decl.uninlinable)
    3382                 :             : 
    3383                 :             : /* In a FUNCTION_DECL, the saved representation of the body of the
    3384                 :             :    entire function.  */
    3385                 :             : #define DECL_SAVED_TREE(NODE) \
    3386                 :             :   (FUNCTION_DECL_CHECK (NODE)->function_decl.saved_tree)
    3387                 :             : 
    3388                 :             : /* Nonzero in a FUNCTION_DECL means this function should be treated
    3389                 :             :    as if it were a malloc, meaning it returns a pointer that is
    3390                 :             :    not an alias.  */
    3391                 :             : #define DECL_IS_MALLOC(NODE) \
    3392                 :             :   (FUNCTION_DECL_CHECK (NODE)->function_decl.malloc_flag)
    3393                 :             : 
    3394                 :             : /* Macro for direct set and get of function_decl.decl_type.  */
    3395                 :             : #define FUNCTION_DECL_DECL_TYPE(NODE) \
    3396                 :             :   (NODE->function_decl.decl_type)
    3397                 :             : 
    3398                 :             : /* Set decl_type of a DECL.  Set it to T when SET is true, or reset
    3399                 :             :    it to NONE.  */
    3400                 :             : 
    3401                 :             : inline void
    3402                 :     2429831 : set_function_decl_type (tree decl, function_decl_type t, bool set)
    3403                 :             : {
    3404                 :     2429831 :   if (set)
    3405                 :             :     {
    3406                 :     1915737 :       gcc_assert (FUNCTION_DECL_DECL_TYPE (decl) == NONE
    3407                 :             :                   || FUNCTION_DECL_DECL_TYPE (decl) == t);
    3408                 :     1915737 :       FUNCTION_DECL_DECL_TYPE (decl) = t;
    3409                 :             :     }
    3410                 :      514094 :   else if (FUNCTION_DECL_DECL_TYPE (decl) == t)
    3411                 :          67 :     FUNCTION_DECL_DECL_TYPE (decl) = NONE;
    3412                 :     2429831 : }
    3413                 :             : 
    3414                 :             : /* Nonzero in a FUNCTION_DECL means this function is a replaceable
    3415                 :             :    function (like replaceable operators new or delete).  */
    3416                 :             : #define DECL_IS_REPLACEABLE_OPERATOR(NODE)\
    3417                 :             :    (FUNCTION_DECL_CHECK (NODE)->function_decl.replaceable_operator)
    3418                 :             : 
    3419                 :             : /* Nonzero in a FUNCTION_DECL means this function should be treated as
    3420                 :             :    C++ operator new, meaning that it returns a pointer for which we
    3421                 :             :    should not use type based aliasing.  */
    3422                 :             : #define DECL_IS_OPERATOR_NEW_P(NODE) \
    3423                 :             :   (FUNCTION_DECL_DECL_TYPE (FUNCTION_DECL_CHECK (NODE)) == OPERATOR_NEW)
    3424                 :             : 
    3425                 :             : #define DECL_IS_REPLACEABLE_OPERATOR_NEW_P(NODE) \
    3426                 :             :   (DECL_IS_OPERATOR_NEW_P (NODE) && DECL_IS_REPLACEABLE_OPERATOR (NODE))
    3427                 :             : 
    3428                 :             : #define DECL_SET_IS_OPERATOR_NEW(NODE, VAL) \
    3429                 :             :   set_function_decl_type (FUNCTION_DECL_CHECK (NODE), OPERATOR_NEW, VAL)
    3430                 :             : 
    3431                 :             : /* Nonzero in a FUNCTION_DECL means this function should be treated as
    3432                 :             :    C++ operator delete.  */
    3433                 :             : #define DECL_IS_OPERATOR_DELETE_P(NODE) \
    3434                 :             :   (FUNCTION_DECL_DECL_TYPE (FUNCTION_DECL_CHECK (NODE)) == OPERATOR_DELETE)
    3435                 :             : 
    3436                 :             : #define DECL_SET_IS_OPERATOR_DELETE(NODE, VAL) \
    3437                 :             :   set_function_decl_type (FUNCTION_DECL_CHECK (NODE), OPERATOR_DELETE, VAL)
    3438                 :             : 
    3439                 :             : /* Nonzero in a FUNCTION_DECL means this function may return more
    3440                 :             :    than once.  */
    3441                 :             : #define DECL_IS_RETURNS_TWICE(NODE) \
    3442                 :             :   (FUNCTION_DECL_CHECK (NODE)->function_decl.returns_twice_flag)
    3443                 :             : 
    3444                 :             : /* Nonzero in a FUNCTION_DECL means this function should be treated
    3445                 :             :    as "pure" function (like const function, but may read global memory).
    3446                 :             :    Note that being pure or const for a function is orthogonal to being
    3447                 :             :    nothrow, i.e. it is valid to have DECL_PURE_P set and TREE_NOTHROW
    3448                 :             :    cleared.  */
    3449                 :             : #define DECL_PURE_P(NODE) (FUNCTION_DECL_CHECK (NODE)->function_decl.pure_flag)
    3450                 :             : 
    3451                 :             : /* Nonzero only if one of TREE_READONLY or DECL_PURE_P is nonzero AND
    3452                 :             :    the const or pure function may not terminate.  When this is nonzero
    3453                 :             :    for a const or pure function, it can be dealt with by cse passes
    3454                 :             :    but cannot be removed by dce passes since you are not allowed to
    3455                 :             :    change an infinite looping program into one that terminates without
    3456                 :             :    error.  */
    3457                 :             : #define DECL_LOOPING_CONST_OR_PURE_P(NODE) \
    3458                 :             :   (FUNCTION_DECL_CHECK (NODE)->function_decl.looping_const_or_pure_flag)
    3459                 :             : 
    3460                 :             : /* Nonzero in a FUNCTION_DECL means this function should be treated
    3461                 :             :    as "novops" function (function that does not read global memory,
    3462                 :             :    but may have arbitrary side effects).  */
    3463                 :             : #define DECL_IS_NOVOPS(NODE) \
    3464                 :             :   (FUNCTION_DECL_CHECK (NODE)->function_decl.novops_flag)
    3465                 :             : 
    3466                 :             : /* Used in FUNCTION_DECLs to indicate that they should be run automatically
    3467                 :             :    at the beginning or end of execution.  */
    3468                 :             : #define DECL_STATIC_CONSTRUCTOR(NODE) \
    3469                 :             :   (FUNCTION_DECL_CHECK (NODE)->function_decl.static_ctor_flag)
    3470                 :             : 
    3471                 :             : #define DECL_STATIC_DESTRUCTOR(NODE) \
    3472                 :             : (FUNCTION_DECL_CHECK (NODE)->function_decl.static_dtor_flag)
    3473                 :             : 
    3474                 :             : /* Used in FUNCTION_DECLs to indicate that function entry and exit should
    3475                 :             :    be instrumented with calls to support routines.  */
    3476                 :             : #define DECL_NO_INSTRUMENT_FUNCTION_ENTRY_EXIT(NODE) \
    3477                 :             :   (FUNCTION_DECL_CHECK (NODE)->function_decl.no_instrument_function_entry_exit)
    3478                 :             : 
    3479                 :             : /* Used in FUNCTION_DECLs to indicate that limit-stack-* should be
    3480                 :             :    disabled in this function.  */
    3481                 :             : #define DECL_NO_LIMIT_STACK(NODE) \
    3482                 :             :   (FUNCTION_DECL_CHECK (NODE)->function_decl.no_limit_stack)
    3483                 :             : 
    3484                 :             : /* In a FUNCTION_DECL indicates that a static chain is needed.  */
    3485                 :             : #define DECL_STATIC_CHAIN(NODE) \
    3486                 :             :   (FUNCTION_DECL_CHECK (NODE)->decl_with_vis.regdecl_flag)
    3487                 :             : 
    3488                 :             : /* Nonzero for a decl that cgraph has decided should be inlined into
    3489                 :             :    at least one call site.  It is not meaningful to look at this
    3490                 :             :    directly; always use cgraph_function_possibly_inlined_p.  */
    3491                 :             : #define DECL_POSSIBLY_INLINED(DECL) \
    3492                 :             :   FUNCTION_DECL_CHECK (DECL)->function_decl.possibly_inlined
    3493                 :             : 
    3494                 :             : /* Nonzero in a FUNCTION_DECL means that this function was declared inline,
    3495                 :             :    such as via the `inline' keyword in C/C++.  This flag controls the linkage
    3496                 :             :    semantics of 'inline'  */
    3497                 :             : #define DECL_DECLARED_INLINE_P(NODE) \
    3498                 :             :   (FUNCTION_DECL_CHECK (NODE)->function_decl.declared_inline_flag)
    3499                 :             : 
    3500                 :             : /* Nonzero in a FUNCTION_DECL means this function should not get
    3501                 :             :    -Winline warnings.  */
    3502                 :             : #define DECL_NO_INLINE_WARNING_P(NODE) \
    3503                 :             :   (FUNCTION_DECL_CHECK (NODE)->function_decl.no_inline_warning_flag)
    3504                 :             : 
    3505                 :             : /* Nonzero if a FUNCTION_CODE is a TM load/store.  */
    3506                 :             : #define BUILTIN_TM_LOAD_STORE_P(FN) \
    3507                 :             :   ((FN) >= BUILT_IN_TM_STORE_1 && (FN) <= BUILT_IN_TM_LOAD_RFW_LDOUBLE)
    3508                 :             : 
    3509                 :             : /* Nonzero if a FUNCTION_CODE is a TM load.  */
    3510                 :             : #define BUILTIN_TM_LOAD_P(FN) \
    3511                 :             :   ((FN) >= BUILT_IN_TM_LOAD_1 && (FN) <= BUILT_IN_TM_LOAD_RFW_LDOUBLE)
    3512                 :             : 
    3513                 :             : /* Nonzero if a FUNCTION_CODE is a TM store.  */
    3514                 :             : #define BUILTIN_TM_STORE_P(FN) \
    3515                 :             :   ((FN) >= BUILT_IN_TM_STORE_1 && (FN) <= BUILT_IN_TM_STORE_WAW_LDOUBLE)
    3516                 :             : 
    3517                 :             : #define CASE_BUILT_IN_TM_LOAD(FN)       \
    3518                 :             :   case BUILT_IN_TM_LOAD_##FN:           \
    3519                 :             :   case BUILT_IN_TM_LOAD_RAR_##FN:       \
    3520                 :             :   case BUILT_IN_TM_LOAD_RAW_##FN:       \
    3521                 :             :   case BUILT_IN_TM_LOAD_RFW_##FN
    3522                 :             : 
    3523                 :             : #define CASE_BUILT_IN_TM_STORE(FN)      \
    3524                 :             :   case BUILT_IN_TM_STORE_##FN:          \
    3525                 :             :   case BUILT_IN_TM_STORE_WAR_##FN:      \
    3526                 :             :   case BUILT_IN_TM_STORE_WAW_##FN
    3527                 :             : 
    3528                 :             : /* Nonzero in a FUNCTION_DECL that should be always inlined by the inliner
    3529                 :             :    disregarding size and cost heuristics.  This is equivalent to using
    3530                 :             :    the always_inline attribute without the required diagnostics if the
    3531                 :             :    function cannot be inlined.  */
    3532                 :             : #define DECL_DISREGARD_INLINE_LIMITS(NODE) \
    3533                 :             :   (FUNCTION_DECL_CHECK (NODE)->function_decl.disregard_inline_limits)
    3534                 :             : 
    3535                 :             : extern vec<tree, va_gc> **decl_debug_args_lookup (tree);
    3536                 :             : extern vec<tree, va_gc> **decl_debug_args_insert (tree);
    3537                 :             : 
    3538                 :             : /* Nonzero if a FUNCTION_DECL has DEBUG arguments attached to it.  */
    3539                 :             : #define DECL_HAS_DEBUG_ARGS_P(NODE) \
    3540                 :             :   (FUNCTION_DECL_CHECK (NODE)->function_decl.has_debug_args_flag)
    3541                 :             : 
    3542                 :             : /* For FUNCTION_DECL, this holds a pointer to a structure ("struct function")
    3543                 :             :    that describes the status of this function.  */
    3544                 :             : #define DECL_STRUCT_FUNCTION(NODE) \
    3545                 :             :   (FUNCTION_DECL_CHECK (NODE)->function_decl.f)
    3546                 :             : 
    3547                 :             : /* For a builtin function, identify which part of the compiler defined it.  */
    3548                 :             : #define DECL_BUILT_IN_CLASS(NODE) \
    3549                 :             :    ((built_in_class) FUNCTION_DECL_CHECK (NODE)->function_decl.built_in_class)
    3550                 :             : 
    3551                 :             : /* In FUNCTION_DECL, a chain of ..._DECL nodes.  */
    3552                 :             : #define DECL_ARGUMENTS(NODE) \
    3553                 :             :    (FUNCTION_DECL_CHECK (NODE)->function_decl.arguments)
    3554                 :             : 
    3555                 :             : /* In FUNCTION_DECL, the function specific target options to use when compiling
    3556                 :             :    this function.  */
    3557                 :             : #define DECL_FUNCTION_SPECIFIC_TARGET(NODE) \
    3558                 :             :    (FUNCTION_DECL_CHECK (NODE)->function_decl.function_specific_target)
    3559                 :             : 
    3560                 :             : /* In FUNCTION_DECL, the function specific optimization options to use when
    3561                 :             :    compiling this function.  */
    3562                 :             : #define DECL_FUNCTION_SPECIFIC_OPTIMIZATION(NODE) \
    3563                 :             :    (FUNCTION_DECL_CHECK (NODE)->function_decl.function_specific_optimization)
    3564                 :             : 
    3565                 :             : /* In FUNCTION_DECL, this is set if this function has other versions generated
    3566                 :             :    to support different architecture feature sets, e.g. using "target" or
    3567                 :             :    "target_version" attributes.  */
    3568                 :             : #define DECL_FUNCTION_VERSIONED(NODE)\
    3569                 :             :    (FUNCTION_DECL_CHECK (NODE)->function_decl.versioned_function)
    3570                 :             : 
    3571                 :             : /* In FUNCTION_DECL, this is set if this function is a C++ constructor.
    3572                 :             :    Devirtualization machinery uses this knowledge for determing type of the
    3573                 :             :    object constructed.  Also we assume that constructor address is not
    3574                 :             :    important.  */
    3575                 :             : #define DECL_CXX_CONSTRUCTOR_P(NODE)\
    3576                 :             :    (FUNCTION_DECL_CHECK (NODE)->decl_with_vis.cxx_constructor)
    3577                 :             : 
    3578                 :             : /* In FUNCTION_DECL, this is set if this function is a C++ destructor.
    3579                 :             :    Devirtualization machinery uses this to track types in destruction.  */
    3580                 :             : #define DECL_CXX_DESTRUCTOR_P(NODE)\
    3581                 :             :    (FUNCTION_DECL_CHECK (NODE)->decl_with_vis.cxx_destructor)
    3582                 :             : 
    3583                 :             : /* In FUNCTION_DECL, this is set if this function is a lambda function.  */
    3584                 :             : #define DECL_LAMBDA_FUNCTION_P(NODE) \
    3585                 :             :   (FUNCTION_DECL_DECL_TYPE (FUNCTION_DECL_CHECK (NODE)) == LAMBDA_FUNCTION)
    3586                 :             : 
    3587                 :             : #define DECL_SET_LAMBDA_FUNCTION(NODE, VAL) \
    3588                 :             :   set_function_decl_type (FUNCTION_DECL_CHECK (NODE), LAMBDA_FUNCTION, VAL)
    3589                 :             : 
    3590                 :             : /* In FUNCTION_DECL that represent an virtual method this is set when
    3591                 :             :    the method is final.  */
    3592                 :             : #define DECL_FINAL_P(NODE)\
    3593                 :             :    (FUNCTION_DECL_CHECK (NODE)->decl_with_vis.final)
    3594                 :             : 
    3595                 :             : /* The source language of the translation-unit.  */
    3596                 :             : #define TRANSLATION_UNIT_LANGUAGE(NODE) \
    3597                 :             :   (TRANSLATION_UNIT_DECL_CHECK (NODE)->translation_unit_decl.language)
    3598                 :             : 
    3599                 :             : /* TRANSLATION_UNIT_DECL inherits from DECL_MINIMAL.  */
    3600                 :             : 
    3601                 :             : /* For a TYPE_DECL, holds the "original" type.  (TREE_TYPE has the copy.) */
    3602                 :             : #define DECL_ORIGINAL_TYPE(NODE) \
    3603                 :             :   (TYPE_DECL_CHECK (NODE)->decl_non_common.result)
    3604                 :             : 
    3605                 :             : /* In a TYPE_DECL nonzero means the detail info about this type is not dumped
    3606                 :             :    into stabs.  Instead it will generate cross reference ('x') of names.
    3607                 :             :    This uses the same flag as DECL_EXTERNAL.  */
    3608                 :             : #define TYPE_DECL_SUPPRESS_DEBUG(NODE) \
    3609                 :             :   (TYPE_DECL_CHECK (NODE)->decl_common.decl_flag_1)
    3610                 :             : 
    3611                 :             : /* Getter of the imported declaration associated to the
    3612                 :             :    IMPORTED_DECL node.  */
    3613                 :             : #define IMPORTED_DECL_ASSOCIATED_DECL(NODE) \
    3614                 :             : (DECL_INITIAL (IMPORTED_DECL_CHECK (NODE)))
    3615                 :             : 
    3616                 :             : /* Getter of the symbol declaration associated with the
    3617                 :             :    NAMELIST_DECL node.  */
    3618                 :             : #define NAMELIST_DECL_ASSOCIATED_DECL(NODE) \
    3619                 :             :   (DECL_INITIAL (NODE))
    3620                 :             : 
    3621                 :             : /* A STATEMENT_LIST chains statements together in GENERIC and GIMPLE.
    3622                 :             :    To reduce overhead, the nodes containing the statements are not trees.
    3623                 :             :    This avoids the overhead of tree_common on all linked list elements.
    3624                 :             : 
    3625                 :             :    Use the interface in tree-iterator.h to access this node.  */
    3626                 :             : 
    3627                 :             : #define STATEMENT_LIST_HEAD(NODE) \
    3628                 :             :   (STATEMENT_LIST_CHECK (NODE)->stmt_list.head)
    3629                 :             : #define STATEMENT_LIST_TAIL(NODE) \
    3630                 :             :   (STATEMENT_LIST_CHECK (NODE)->stmt_list.tail)
    3631                 :             : 
    3632                 :             : #define TREE_OPTIMIZATION(NODE) \
    3633                 :             :   (OPTIMIZATION_NODE_CHECK (NODE)->optimization.opts)
    3634                 :             : 
    3635                 :             : #define TREE_OPTIMIZATION_OPTABS(NODE) \
    3636                 :             :   (OPTIMIZATION_NODE_CHECK (NODE)->optimization.optabs)
    3637                 :             : 
    3638                 :             : #define TREE_OPTIMIZATION_BASE_OPTABS(NODE) \
    3639                 :             :   (OPTIMIZATION_NODE_CHECK (NODE)->optimization.base_optabs)
    3640                 :             : 
    3641                 :             : /* Return a tree node that encapsulates the optimization options in OPTS
    3642                 :             :    and OPTS_SET.  */
    3643                 :             : extern tree build_optimization_node (struct gcc_options *opts,
    3644                 :             :                                      struct gcc_options *opts_set);
    3645                 :             : 
    3646                 :             : #define TREE_TARGET_OPTION(NODE) \
    3647                 :             :   (TARGET_OPTION_NODE_CHECK (NODE)->target_option.opts)
    3648                 :             : 
    3649                 :             : #define TREE_TARGET_GLOBALS(NODE) \
    3650                 :             :   (TARGET_OPTION_NODE_CHECK (NODE)->target_option.globals)
    3651                 :             : 
    3652                 :             : /* Return a tree node that encapsulates the target options in OPTS and
    3653                 :             :    OPTS_SET.  */
    3654                 :             : extern tree build_target_option_node (struct gcc_options *opts,
    3655                 :             :                                       struct gcc_options *opts_set);
    3656                 :             : 
    3657                 :             : extern void prepare_target_option_nodes_for_pch (void);
    3658                 :             : 
    3659                 :             : #if defined ENABLE_TREE_CHECKING && (GCC_VERSION >= 2007)
    3660                 :             : 
    3661                 :             : inline tree
    3662                 : >72595*10^7 : tree_check (tree __t, const char *__f, int __l, const char *__g, tree_code __c)
    3663                 :             : {
    3664                 : >69477*10^7 :   if (TREE_CODE (__t) != __c)
    3665                 :           0 :     tree_check_failed (__t, __f, __l, __g, __c, 0);
    3666                 : >64038*10^7 :   return __t;
    3667                 :             : }
    3668                 :             : 
    3669                 :             : inline tree
    3670                 : 88451856692 : tree_not_check (tree __t, const char *__f, int __l, const char *__g,
    3671                 :             :                 enum tree_code __c)
    3672                 :             : {
    3673                 : 51892125223 :   if (TREE_CODE (__t) == __c)
    3674                 :           0 :     tree_not_check_failed (__t, __f, __l, __g, __c, 0);
    3675                 : 51825656507 :   return __t;
    3676                 :             : }
    3677                 :             : 
    3678                 :             : inline tree
    3679                 : 32585280551 : tree_check2 (tree __t, const char *__f, int __l, const char *__g,
    3680                 :             :              enum tree_code __c1, enum tree_code __c2)
    3681                 :             : {
    3682                 : 32585280551 :   if (TREE_CODE (__t) != __c1
    3683                 : 14807718629 :       && TREE_CODE (__t) != __c2)
    3684                 :           0 :     tree_check_failed (__t, __f, __l, __g, __c1, __c2, 0);
    3685                 : 32585280551 :   return __t;
    3686                 :             : }
    3687                 :             : 
    3688                 :             : inline tree
    3689                 : >14631*10^7 : tree_not_check2 (tree __t, const char *__f, int __l, const char *__g,
    3690                 :             :                  enum tree_code __c1, enum tree_code __c2)
    3691                 :             : {
    3692                 : >14631*10^7 :   if (TREE_CODE (__t) == __c1
    3693                 : >14631*10^7 :       || TREE_CODE (__t) == __c2)
    3694                 :           0 :     tree_not_check_failed (__t, __f, __l, __g, __c1, __c2, 0);
    3695                 : >14631*10^7 :   return __t;
    3696                 :             : }
    3697                 :             : 
    3698                 :             : inline tree
    3699                 : 49672204061 : tree_check3 (tree __t, const char *__f, int __l, const char *__g,
    3700                 :             :              enum tree_code __c1, enum tree_code __c2, enum tree_code __c3)
    3701                 :             : {
    3702                 : 49672204061 :   if (TREE_CODE (__t) != __c1
    3703                 :  1615544730 :       && TREE_CODE (__t) != __c2
    3704                 :   426332767 :       && TREE_CODE (__t) != __c3)
    3705                 :           0 :     tree_check_failed (__t, __f, __l, __g, __c1, __c2, __c3, 0);
    3706                 : 49672204061 :   return __t;
    3707                 :             : }
    3708                 :             : 
    3709                 :             : inline tree
    3710                 :             : tree_not_check3 (tree __t, const char *__f, int __l, const char *__g,
    3711                 :             :                  enum tree_code __c1, enum tree_code __c2, enum tree_code __c3)
    3712                 :             : {
    3713                 :             :   if (TREE_CODE (__t) == __c1
    3714                 :             :       || TREE_CODE (__t) == __c2
    3715                 :             :       || TREE_CODE (__t) == __c3)
    3716                 :             :     tree_not_check_failed (__t, __f, __l, __g, __c1, __c2, __c3, 0);
    3717                 :             :   return __t;
    3718                 :             : }
    3719                 :             : 
    3720                 :             : inline tree
    3721                 : 10439933396 : tree_check4 (tree __t, const char *__f, int __l, const char *__g,
    3722                 :             :              enum tree_code __c1, enum tree_code __c2, enum tree_code __c3,
    3723                 :             :              enum tree_code __c4)
    3724                 :             : {
    3725                 : 10439933396 :   if (TREE_CODE (__t) != __c1
    3726                 :  8581157013 :       && TREE_CODE (__t) != __c2
    3727                 :  8546175606 :       && TREE_CODE (__t) != __c3
    3728                 :  8537389176 :       && TREE_CODE (__t) != __c4)
    3729                 :           0 :     tree_check_failed (__t, __f, __l, __g, __c1, __c2, __c3, __c4, 0);
    3730                 : 10439933396 :   return __t;
    3731                 :             : }
    3732                 :             : 
    3733                 :             : inline tree
    3734                 :   656859238 : tree_not_check4 (tree __t, const char *__f, int __l, const char *__g,
    3735                 :             :                  enum tree_code __c1, enum tree_code __c2, enum tree_code __c3,
    3736                 :             :                  enum tree_code __c4)
    3737                 :             : {
    3738                 :   656859238 :   if (TREE_CODE (__t) == __c1
    3739                 :   656859238 :       || TREE_CODE (__t) == __c2
    3740                 :   656859238 :       || TREE_CODE (__t) == __c3
    3741                 :   656859238 :       || TREE_CODE (__t) == __c4)
    3742                 :           0 :     tree_not_check_failed (__t, __f, __l, __g, __c1, __c2, __c3, __c4, 0);
    3743                 :   656859238 :   return __t;
    3744                 :             : }
    3745                 :             : 
    3746                 :             : inline tree
    3747                 :  1121354255 : tree_check5 (tree __t, const char *__f, int __l, const char *__g,
    3748                 :             :              enum tree_code __c1, enum tree_code __c2, enum tree_code __c3,
    3749                 :             :              enum tree_code __c4, enum tree_code __c5)
    3750                 :             : {
    3751                 :  1121354255 :   if (TREE_CODE (__t) != __c1
    3752                 :  1083079100 :       && TREE_CODE (__t) != __c2
    3753                 :   458263718 :       && TREE_CODE (__t) != __c3
    3754                 :   372796397 :       && TREE_CODE (__t) != __c4
    3755                 :      579999 :       && TREE_CODE (__t) != __c5)
    3756                 :           0 :     tree_check_failed (__t, __f, __l, __g, __c1, __c2, __c3, __c4, __c5, 0);
    3757                 :  1121354255 :   return __t;
    3758                 :             : }
    3759                 :             : 
    3760                 :             : inline tree
    3761                 :             : tree_not_check5 (tree __t, const char *__f, int __l, const char *__g,
    3762                 :             :                  enum tree_code __c1, enum tree_code __c2, enum tree_code __c3,
    3763                 :             :                  enum tree_code __c4, enum tree_code __c5)
    3764                 :             : {
    3765                 :             :   if (TREE_CODE (__t) == __c1
    3766                 :             :       || TREE_CODE (__t) == __c2
    3767                 :             :       || TREE_CODE (__t) == __c3
    3768                 :             :       || TREE_CODE (__t) == __c4
    3769                 :             :       || TREE_CODE (__t) == __c5)
    3770                 :             :     tree_not_check_failed (__t, __f, __l, __g, __c1, __c2, __c3, __c4, __c5, 0);
    3771                 :             :   return __t;
    3772                 :             : }
    3773                 :             : 
    3774                 :             : inline tree
    3775                 :  6560823094 : tree_check6 (tree __t, const char *__f, int __l, const char *__g,
    3776                 :             :              enum tree_code __c1, enum tree_code __c2, enum tree_code __c3,
    3777                 :             :              enum tree_code __c4, enum tree_code __c5, enum tree_code __c6)
    3778                 :             : {
    3779                 :  6560823094 :   if (TREE_CODE (__t) != __c1
    3780                 :   297614754 :       && TREE_CODE (__t) != __c2
    3781                 :   220018926 :       && TREE_CODE (__t) != __c3
    3782                 :   115141812 :       && TREE_CODE (__t) != __c4
    3783                 :    16221306 :       && TREE_CODE (__t) != __c5
    3784                 :    16221306 :       && TREE_CODE (__t) != __c6)
    3785                 :           0 :     tree_check_failed (__t, __f, __l, __g, __c1, __c2, __c3, __c4, __c5, __c6,
    3786                 :             :                        0);
    3787                 :  6560823094 :   return __t;
    3788                 :             : }
    3789                 :             : 
    3790                 :             : inline tree
    3791                 :             : tree_not_check6 (tree __t, const char *__f, int __l, const char *__g,
    3792                 :             :                  enum tree_code __c1, enum tree_code __c2, enum tree_code __c3,
    3793                 :             :                  enum tree_code __c4, enum tree_code __c5, enum tree_code __c6)
    3794                 :             : {
    3795                 :             :   if (TREE_CODE (__t) == __c1
    3796                 :             :       || TREE_CODE (__t) == __c2
    3797                 :             :       || TREE_CODE (__t) == __c3
    3798                 :             :       || TREE_CODE (__t) == __c4
    3799                 :             :       || TREE_CODE (__t) == __c5
    3800                 :             :       || TREE_CODE (__t) == __c6)
    3801                 :             :     tree_not_check_failed (__t, __f, __l, __g, __c1, __c2, __c3, __c4, __c5,
    3802                 :             :                            __c6, 0);
    3803                 :             :   return __t;
    3804                 :             : }
    3805                 :             : 
    3806                 :             : inline tree
    3807                 : >13961*10^8 : contains_struct_check (tree __t, const enum tree_node_structure_enum __s,
    3808                 :             :                        const char *__f, int __l, const char *__g)
    3809                 :             : {
    3810                 : >13961*10^8 :   if (tree_contains_struct[TREE_CODE (__t)][__s] != 1)
    3811                 :           0 :       tree_contains_struct_check_failed (__t, __s, __f, __l, __g);
    3812                 : >13961*10^8 :   return __t;
    3813                 :             : }
    3814                 :             : 
    3815                 :             : inline tree
    3816                 : >67182*10^7 : tree_class_check (tree __t, const enum tree_code_class __class,
    3817                 :             :                   const char *__f, int __l, const char *__g)
    3818                 :             : {
    3819                 : >67182*10^7 :   if (TREE_CODE_CLASS (TREE_CODE (__t)) != __class)
    3820                 :           0 :     tree_class_check_failed (__t, __class, __f, __l, __g);
    3821                 : >67182*10^7 :   return __t;
    3822                 :             : }
    3823                 :             : 
    3824                 :             : inline tree
    3825                 :     4422536 : tree_range_check (tree __t,
    3826                 :             :                   enum tree_code __code1, enum tree_code __code2,
    3827                 :             :                   const char *__f, int __l, const char *__g)
    3828                 :             : {
    3829                 :     4422536 :   if (TREE_CODE (__t) < __code1 || TREE_CODE (__t) > __code2)
    3830                 :           0 :     tree_range_check_failed (__t, __f, __l, __g, __code1, __code2);
    3831                 :     4422536 :   return __t;
    3832                 :             : }
    3833                 :             : 
    3834                 :             : inline tree
    3835                 :     6256713 : omp_clause_subcode_check (tree __t, enum omp_clause_code __code,
    3836                 :             :                           const char *__f, int __l, const char *__g)
    3837                 :             : {
    3838                 :     6256713 :   if (TREE_CODE (__t) != OMP_CLAUSE)
    3839                 :           0 :     tree_check_failed (__t, __f, __l, __g, OMP_CLAUSE, 0);
    3840                 :     6256713 :   if (__t->omp_clause.code != __code)
    3841                 :           0 :     omp_clause_check_failed (__t, __f, __l, __g, __code);
    3842                 :     6256713 :   return __t;
    3843                 :             : }
    3844                 :             : 
    3845                 :             : inline tree
    3846                 :     4161003 : omp_clause_range_check (tree __t,
    3847                 :             :                         enum omp_clause_code __code1,
    3848                 :             :                         enum omp_clause_code __code2,
    3849                 :             :                         const char *__f, int __l, const char *__g)
    3850                 :             : {
    3851                 :     4161003 :   if (TREE_CODE (__t) != OMP_CLAUSE)
    3852                 :           0 :     tree_check_failed (__t, __f, __l, __g, OMP_CLAUSE, 0);
    3853                 :     4161003 :   if ((int) __t->omp_clause.code < (int) __code1
    3854                 :     4161003 :       || (int) __t->omp_clause.code > (int) __code2)
    3855                 :           0 :     omp_clause_range_check_failed (__t, __f, __l, __g, __code1, __code2);
    3856                 :     4161003 :   return __t;
    3857                 :             : }
    3858                 :             : 
    3859                 :             : /* These checks have to be special cased.  */
    3860                 :             : 
    3861                 :             : inline tree
    3862                 : >15277*10^7 : expr_check (tree __t, const char *__f, int __l, const char *__g)
    3863                 :             : {
    3864                 : >15277*10^7 :   char const __c = TREE_CODE_CLASS (TREE_CODE (__t));
    3865                 : >15277*10^7 :   if (!IS_EXPR_CODE_CLASS (__c))
    3866                 :           0 :     tree_class_check_failed (__t, tcc_expression, __f, __l, __g);
    3867                 : >15277*10^7 :   return __t;
    3868                 :             : }
    3869                 :             : 
    3870                 :             : /* These checks have to be special cased.  */
    3871                 :             : 
    3872                 :             : inline tree
    3873                 : 46288278543 : non_type_check (tree __t, const char *__f, int __l, const char *__g)
    3874                 :             : {
    3875                 : 46288278543 :   if (TYPE_P (__t))
    3876                 :           0 :     tree_not_class_check_failed (__t, tcc_type, __f, __l, __g);
    3877                 : 46288278543 :   return __t;
    3878                 :             : }
    3879                 :             : 
    3880                 :             : inline const HOST_WIDE_INT *
    3881                 : 45278457911 : tree_int_cst_elt_check (const_tree __t, int __i,
    3882                 :             :                         const char *__f, int __l, const char *__g)
    3883                 :             : {
    3884                 : 45278457911 :   if (TREE_CODE (__t) != INTEGER_CST)
    3885                 :           0 :     tree_check_failed (__t, __f, __l, __g, INTEGER_CST, 0);
    3886                 : 45278457911 :   if (__i < 0 || __i >= __t->base.u.int_length.extended)
    3887                 :           0 :     tree_int_cst_elt_check_failed (__i, __t->base.u.int_length.extended,
    3888                 :             :                                    __f, __l, __g);
    3889                 : 45278457911 :   return &CONST_CAST_TREE (__t)->int_cst.val[__i];
    3890                 :             : }
    3891                 :             : 
    3892                 :             : inline HOST_WIDE_INT *
    3893                 : 23678251975 : tree_int_cst_elt_check (tree __t, int __i,
    3894                 :             :                         const char *__f, int __l, const char *__g)
    3895                 :             : {
    3896                 : 23678251975 :   if (TREE_CODE (__t) != INTEGER_CST)
    3897                 :           0 :     tree_check_failed (__t, __f, __l, __g, INTEGER_CST, 0);
    3898                 : 23678251975 :   if (__i < 0 || __i >= __t->base.u.int_length.extended)
    3899                 :           0 :     tree_int_cst_elt_check_failed (__i, __t->base.u.int_length.extended,
    3900                 :             :                                    __f, __l, __g);
    3901                 : 23678251975 :   return &CONST_CAST_TREE (__t)->int_cst.val[__i];
    3902                 :             : }
    3903                 :             : 
    3904                 :             : /* Workaround -Wstrict-overflow false positive during profiledbootstrap.  */
    3905                 :             : 
    3906                 :             : # if GCC_VERSION >= 4006
    3907                 :             : #pragma GCC diagnostic push
    3908                 :             : #pragma GCC diagnostic ignored "-Wstrict-overflow"
    3909                 :             : #endif
    3910                 :             : 
    3911                 :             : inline tree *
    3912                 : 75562435907 : tree_vec_elt_check (tree __t, int __i,
    3913                 :             :                     const char *__f, int __l, const char *__g)
    3914                 :             : {
    3915                 : 75562435907 :   if (TREE_CODE (__t) != TREE_VEC)
    3916                 :           0 :     tree_check_failed (__t, __f, __l, __g, TREE_VEC, 0);
    3917                 : 75562435907 :   if (__i < 0 || __i >= __t->base.u.length)
    3918                 :           0 :     tree_vec_elt_check_failed (__i, __t->base.u.length, __f, __l, __g);
    3919                 : 75562435907 :   return &CONST_CAST_TREE (__t)->vec.a[__i];
    3920                 :             : }
    3921                 :             : 
    3922                 :             : # if GCC_VERSION >= 4006
    3923                 :             : #pragma GCC diagnostic pop
    3924                 :             : #endif
    3925                 :             : 
    3926                 :             : inline tree *
    3927                 :     7100852 : omp_clause_elt_check (tree __t, int __i,
    3928                 :             :                       const char *__f, int __l, const char *__g)
    3929                 :             : {
    3930                 :     7100852 :   if (TREE_CODE (__t) != OMP_CLAUSE)
    3931                 :           0 :     tree_check_failed (__t, __f, __l, __g, OMP_CLAUSE, 0);
    3932                 :     7100852 :   if (__i < 0 || __i >= omp_clause_num_ops [__t->omp_clause.code])
    3933                 :           0 :     omp_clause_operand_check_failed (__i, __t, __f, __l, __g);
    3934                 :     7100852 :   return &__t->omp_clause.ops[__i];
    3935                 :             : }
    3936                 :             : 
    3937                 :             : /* These checks have to be special cased.  */
    3938                 :             : 
    3939                 :             : inline tree
    3940                 :  2790362124 : any_integral_type_check (tree __t, const char *__f, int __l, const char *__g)
    3941                 :             : {
    3942                 :  2790362124 :   if (!ANY_INTEGRAL_TYPE_P (__t))
    3943                 :           0 :     tree_check_failed (__t, __f, __l, __g, BOOLEAN_TYPE, ENUMERAL_TYPE,
    3944                 :             :                        INTEGER_TYPE, BITINT_TYPE, 0);
    3945                 :  2790362124 :   return __t;
    3946                 :             : }
    3947                 :             : 
    3948                 :             : inline const_tree
    3949                 : >11308*10^7 : tree_check (const_tree __t, const char *__f, int __l, const char *__g,
    3950                 :             :             tree_code __c)
    3951                 :             : {
    3952                 : 67947241338 :   if (TREE_CODE (__t) != __c)
    3953                 :           0 :     tree_check_failed (__t, __f, __l, __g, __c, 0);
    3954                 : 77220314004 :   return __t;
    3955                 :             : }
    3956                 :             : 
    3957                 :             : inline const_tree
    3958                 : 15622207224 : tree_not_check (const_tree __t, const char *__f, int __l, const char *__g,
    3959                 :             :                 enum tree_code __c)
    3960                 :             : {
    3961                 : 13239035287 :   if (TREE_CODE (__t) == __c)
    3962                 :           0 :     tree_not_check_failed (__t, __f, __l, __g, __c, 0);
    3963                 :  6906244541 :   return __t;
    3964                 :             : }
    3965                 :             : 
    3966                 :             : inline const_tree
    3967                 : 12723714878 : tree_check2 (const_tree __t, const char *__f, int __l, const char *__g,
    3968                 :             :              enum tree_code __c1, enum tree_code __c2)
    3969                 :             : {
    3970                 : 12723714878 :   if (TREE_CODE (__t) != __c1
    3971                 :  7000216592 :       && TREE_CODE (__t) != __c2)
    3972                 :           0 :     tree_check_failed (__t, __f, __l, __g, __c1, __c2, 0);
    3973                 : 12723714878 :   return __t;
    3974                 :             : }
    3975                 :             : 
    3976                 :             : inline const_tree
    3977                 :  2339183828 : tree_not_check2 (const_tree __t, const char *__f, int __l, const char *__g,
    3978                 :             :                  enum tree_code __c1, enum tree_code __c2)
    3979                 :             : {
    3980                 :  2339183828 :   if (TREE_CODE (__t) == __c1
    3981                 :  2339183828 :       || TREE_CODE (__t) == __c2)
    3982                 :           0 :     tree_not_check_failed (__t, __f, __l, __g, __c1, __c2, 0);
    3983                 :  2339183828 :   return __t;
    3984                 :             : }
    3985                 :             : 
    3986                 :             : inline const_tree
    3987                 :  6894121801 : tree_check3 (const_tree __t, const char *__f, int __l, const char *__g,
    3988                 :             :              enum tree_code __c1, enum tree_code __c2, enum tree_code __c3)
    3989                 :             : {
    3990                 :  6894121801 :   if (TREE_CODE (__t) != __c1
    3991                 :   298106451 :       && TREE_CODE (__t) != __c2
    3992                 :   124334303 :       && TREE_CODE (__t) != __c3)
    3993                 :           0 :     tree_check_failed (__t, __f, __l, __g, __c1, __c2, __c3, 0);
    3994                 :  6894121801 :   return __t;
    3995                 :             : }
    3996                 :             : 
    3997                 :             : inline const_tree
    3998                 :             : tree_not_check3 (const_tree __t, const char *__f, int __l, const char *__g,
    3999                 :             :                  enum tree_code __c1, enum tree_code __c2, enum tree_code __c3)
    4000                 :             : {
    4001                 :             :   if (TREE_CODE (__t) == __c1
    4002                 :             :       || TREE_CODE (__t) == __c2
    4003                 :             :       || TREE_CODE (__t) == __c3)
    4004                 :             :     tree_not_check_failed (__t, __f, __l, __g, __c1, __c2, __c3, 0);
    4005                 :             :   return __t;
    4006                 :             : }
    4007                 :             : 
    4008                 :             : inline const_tree
    4009                 :   258215156 : tree_check4 (const_tree __t, const char *__f, int __l, const char *__g,
    4010                 :             :              enum tree_code __c1, enum tree_code __c2, enum tree_code __c3,
    4011                 :             :              enum tree_code __c4)
    4012                 :             : {
    4013                 :   258215156 :   if (TREE_CODE (__t) != __c1
    4014                 :    20649031 :       && TREE_CODE (__t) != __c2
    4015                 :     2276434 :       && TREE_CODE (__t) != __c3
    4016                 :     2276434 :       && TREE_CODE (__t) != __c4)
    4017                 :           0 :     tree_check_failed (__t, __f, __l, __g, __c1, __c2, __c3, __c4, 0);
    4018                 :   258215156 :   return __t;
    4019                 :             : }
    4020                 :             : 
    4021                 :             : inline const_tree
    4022                 :    83309961 : tree_not_check4 (const_tree __t, const char *__f, int __l, const char *__g,
    4023                 :             :                  enum tree_code __c1, enum tree_code __c2, enum tree_code __c3,
    4024                 :             :                  enum tree_code __c4)
    4025                 :             : {
    4026                 :    83309961 :   if (TREE_CODE (__t) == __c1
    4027                 :    83309961 :       || TREE_CODE (__t) == __c2
    4028                 :    83309961 :       || TREE_CODE (__t) == __c3
    4029                 :    83309961 :       || TREE_CODE (__t) == __c4)
    4030                 :           0 :     tree_not_check_failed (__t, __f, __l, __g, __c1, __c2, __c3, __c4, 0);
    4031                 :    83309961 :   return __t;
    4032                 :             : }
    4033                 :             : 
    4034                 :             : inline const_tree
    4035                 :             : tree_check5 (const_tree __t, const char *__f, int __l, const char *__g,
    4036                 :             :              enum tree_code __c1, enum tree_code __c2, enum tree_code __c3,
    4037                 :             :              enum tree_code __c4, enum tree_code __c5)
    4038                 :             : {
    4039                 :             :   if (TREE_CODE (__t) != __c1
    4040                 :             :       && TREE_CODE (__t) != __c2
    4041                 :             :       && TREE_CODE (__t) != __c3
    4042                 :             :       && TREE_CODE (__t) != __c4
    4043                 :             :       && TREE_CODE (__t) != __c5)
    4044                 :             :     tree_check_failed (__t, __f, __l, __g, __c1, __c2, __c3, __c4, __c5, 0);
    4045                 :             :   return __t;
    4046                 :             : }
    4047                 :             : 
    4048                 :             : inline const_tree
    4049                 :             : tree_not_check5 (const_tree __t, const char *__f, int __l, const char *__g,
    4050                 :             :                  enum tree_code __c1, enum tree_code __c2, enum tree_code __c3,
    4051                 :             :                  enum tree_code __c4, enum tree_code __c5)
    4052                 :             : {
    4053                 :             :   if (TREE_CODE (__t) == __c1
    4054                 :             :       || TREE_CODE (__t) == __c2
    4055                 :             :       || TREE_CODE (__t) == __c3
    4056                 :             :       || TREE_CODE (__t) == __c4
    4057                 :             :       || TREE_CODE (__t) == __c5)
    4058                 :             :     tree_not_check_failed (__t, __f, __l, __g, __c1, __c2, __c3, __c4, __c5, 0);
    4059                 :             :   return __t;
    4060                 :             : }
    4061                 :             : 
    4062                 :             : inline const_tree
    4063                 :   459344290 : tree_check6 (const_tree __t, const char *__f, int __l, const char *__g,
    4064                 :             :              enum tree_code __c1, enum tree_code __c2, enum tree_code __c3,
    4065                 :             :              enum tree_code __c4, enum tree_code __c5, enum tree_code __c6)
    4066                 :             : {
    4067                 :   459344290 :   if (TREE_CODE (__t) != __c1
    4068                 :    36089024 :       && TREE_CODE (__t) != __c2
    4069                 :    31191416 :       && TREE_CODE (__t) != __c3
    4070                 :     1819858 :       && TREE_CODE (__t) != __c4
    4071                 :       48860 :       && TREE_CODE (__t) != __c5
    4072                 :       48860 :       && TREE_CODE (__t) != __c6)
    4073                 :           0 :     tree_check_failed (__t, __f, __l, __g, __c1, __c2, __c3, __c4, __c5, __c6,
    4074                 :             :                        0);
    4075                 :   459344290 :   return __t;
    4076                 :             : }
    4077                 :             : 
    4078                 :             : inline const_tree
    4079                 :             : tree_not_check6 (const_tree __t, const char *__f, int __l, const char *__g,
    4080                 :             :                  enum tree_code __c1, enum tree_code __c2, enum tree_code __c3,
    4081                 :             :                  enum tree_code __c4, enum tree_code __c5, enum tree_code __c6)
    4082                 :             : {
    4083                 :             :   if (TREE_CODE (__t) == __c1
    4084                 :             :       || TREE_CODE (__t) == __c2
    4085                 :             :       || TREE_CODE (__t) == __c3
    4086                 :             :       || TREE_CODE (__t) == __c4
    4087                 :             :       || TREE_CODE (__t) == __c5
    4088                 :             :       || TREE_CODE (__t) == __c6)
    4089                 :             :     tree_not_check_failed (__t, __f, __l, __g, __c1, __c2, __c3, __c4, __c5,
    4090                 :             :                            __c6, 0);
    4091                 :             :   return __t;
    4092                 :             : }
    4093                 :             : 
    4094                 :             : inline const_tree
    4095                 : >20998*10^7 : contains_struct_check (const_tree __t, const enum tree_node_structure_enum __s,
    4096                 :             :                        const char *__f, int __l, const char *__g)
    4097                 :             : {
    4098                 : >20998*10^7 :   if (tree_contains_struct[TREE_CODE (__t)][__s] != 1)
    4099                 :           0 :       tree_contains_struct_check_failed (__t, __s, __f, __l, __g);
    4100                 : >20998*10^7 :   return __t;
    4101                 :             : }
    4102                 :             : 
    4103                 :             : inline const_tree
    4104                 : >20156*10^7 : tree_class_check (const_tree __t, const enum tree_code_class __class,
    4105                 :             :                   const char *__f, int __l, const char *__g)
    4106                 :             : {
    4107                 : >20156*10^7 :   if (TREE_CODE_CLASS (TREE_CODE (__t)) != __class)
    4108                 :           0 :     tree_class_check_failed (__t, __class, __f, __l, __g);
    4109                 : >20156*10^7 :   return __t;
    4110                 :             : }
    4111                 :             : 
    4112                 :             : inline const_tree
    4113                 :             : tree_range_check (const_tree __t,
    4114                 :             :                   enum tree_code __code1, enum tree_code __code2,
    4115                 :             :                   const char *__f, int __l, const char *__g)
    4116                 :             : {
    4117                 :             :   if (TREE_CODE (__t) < __code1 || TREE_CODE (__t) > __code2)
    4118                 :             :     tree_range_check_failed (__t, __f, __l, __g, __code1, __code2);
    4119                 :             :   return __t;
    4120                 :             : }
    4121                 :             : 
    4122                 :             : inline const_tree
    4123                 :             : omp_clause_subcode_check (const_tree __t, enum omp_clause_code __code,
    4124                 :             :                           const char *__f, int __l, const char *__g)
    4125                 :             : {
    4126                 :             :   if (TREE_CODE (__t) != OMP_CLAUSE)
    4127                 :             :     tree_check_failed (__t, __f, __l, __g, OMP_CLAUSE, 0);
    4128                 :             :   if (__t->omp_clause.code != __code)
    4129                 :             :     omp_clause_check_failed (__t, __f, __l, __g, __code);
    4130                 :             :   return __t;
    4131                 :             : }
    4132                 :             : 
    4133                 :             : inline const_tree
    4134                 :             : omp_clause_range_check (const_tree __t,
    4135                 :             :                         enum omp_clause_code __code1,
    4136                 :             :                         enum omp_clause_code __code2,
    4137                 :             :                         const char *__f, int __l, const char *__g)
    4138                 :             : {
    4139                 :             :   if (TREE_CODE (__t) != OMP_CLAUSE)
    4140                 :             :     tree_check_failed (__t, __f, __l, __g, OMP_CLAUSE, 0);
    4141                 :             :   if ((int) __t->omp_clause.code < (int) __code1
    4142                 :             :       || (int) __t->omp_clause.code > (int) __code2)
    4143                 :             :     omp_clause_range_check_failed (__t, __f, __l, __g, __code1, __code2);
    4144                 :             :   return __t;
    4145                 :             : }
    4146                 :             : 
    4147                 :             : inline const_tree
    4148                 : 26936185732 : expr_check (const_tree __t, const char *__f, int __l, const char *__g)
    4149                 :             : {
    4150                 : 26936185732 :   char const __c = TREE_CODE_CLASS (TREE_CODE (__t));
    4151                 : 26936185732 :   if (!IS_EXPR_CODE_CLASS (__c))
    4152                 :           0 :     tree_class_check_failed (__t, tcc_expression, __f, __l, __g);
    4153                 : 26936185732 :   return __t;
    4154                 :             : }
    4155                 :             : 
    4156                 :             : inline const_tree
    4157                 :  8852419274 : non_type_check (const_tree __t, const char *__f, int __l, const char *__g)
    4158                 :             : {
    4159                 :  8852419274 :   if (TYPE_P (__t))
    4160                 :           0 :     tree_not_class_check_failed (__t, tcc_type, __f, __l, __g);
    4161                 :  8852419274 :   return __t;
    4162                 :             : }
    4163                 :             : 
    4164                 :             : # if GCC_VERSION >= 4006
    4165                 :             : #pragma GCC diagnostic push
    4166                 :             : #pragma GCC diagnostic ignored "-Wstrict-overflow"
    4167                 :             : #endif
    4168                 :             : 
    4169                 :             : inline const_tree *
    4170                 :  3603883127 : tree_vec_elt_check (const_tree __t, int __i,
    4171                 :             :                     const char *__f, int __l, const char *__g)
    4172                 :             : {
    4173                 :  3603883127 :   if (TREE_CODE (__t) != TREE_VEC)
    4174                 :           0 :     tree_check_failed (__t, __f, __l, __g, TREE_VEC, 0);
    4175                 :  3603883127 :   if (__i < 0 || __i >= __t->base.u.length)
    4176                 :           0 :     tree_vec_elt_check_failed (__i, __t->base.u.length, __f, __l, __g);
    4177                 :  3603883127 :   return CONST_CAST (const_tree *, &__t->vec.a[__i]);
    4178                 :             :   //return &__t->vec.a[__i];
    4179                 :             : }
    4180                 :             : 
    4181                 :             : # if GCC_VERSION >= 4006
    4182                 :             : #pragma GCC diagnostic pop
    4183                 :             : #endif
    4184                 :             : 
    4185                 :             : inline const_tree *
    4186                 :             : omp_clause_elt_check (const_tree __t, int __i,
    4187                 :             :                       const char *__f, int __l, const char *__g)
    4188                 :             : {
    4189                 :             :   if (TREE_CODE (__t) != OMP_CLAUSE)
    4190                 :             :     tree_check_failed (__t, __f, __l, __g, OMP_CLAUSE, 0);
    4191                 :             :   if (__i < 0 || __i >= omp_clause_num_ops [__t->omp_clause.code])
    4192                 :             :     omp_clause_operand_check_failed (__i, __t, __f, __l, __g);
    4193                 :             :   return CONST_CAST (const_tree *, &__t->omp_clause.ops[__i]);
    4194                 :             : }
    4195                 :             : 
    4196                 :             : inline const_tree
    4197                 :     3167031 : any_integral_type_check (const_tree __t, const char *__f, int __l,
    4198                 :             :                          const char *__g)
    4199                 :             : {
    4200                 :     3167031 :   if (!ANY_INTEGRAL_TYPE_P (__t))
    4201                 :           0 :     tree_check_failed (__t, __f, __l, __g, BOOLEAN_TYPE, ENUMERAL_TYPE,
    4202                 :             :                        INTEGER_TYPE, BITINT_TYPE, 0);
    4203                 :     3167031 :   return __t;
    4204                 :             : }
    4205                 :             : 
    4206                 :             : #endif
    4207                 :             : 
    4208                 :             : /* Compute the number of operands in an expression node NODE.  For
    4209                 :             :    tcc_vl_exp nodes like CALL_EXPRs, this is stored in the node itself,
    4210                 :             :    otherwise it is looked up from the node's code.  */
    4211                 :             : inline int
    4212                 : >19710*10^7 : tree_operand_length (const_tree node)
    4213                 :             : {
    4214                 : >19710*10^7 :   if (VL_EXP_CLASS_P (node))
    4215                 :  9482079121 :     return VL_EXP_OPERAND_LENGTH (node);
    4216                 :             :   else
    4217                 : >18762*10^7 :     return TREE_CODE_LENGTH (TREE_CODE (node));
    4218                 :             : }
    4219                 :             : 
    4220                 :             : #if defined ENABLE_TREE_CHECKING && (GCC_VERSION >= 2007)
    4221                 :             : 
    4222                 :             : /* Special checks for TREE_OPERANDs.  */
    4223                 :             : inline tree *
    4224                 : >14264*10^7 : tree_operand_check (tree __t, int __i,
    4225                 :             :                     const char *__f, int __l, const char *__g)
    4226                 :             : {
    4227                 : >14264*10^7 :   const_tree __u = EXPR_CHECK (__t);
    4228                 : >14264*10^7 :   if (__i < 0 || __i >= TREE_OPERAND_LENGTH (__u))
    4229                 :           0 :     tree_operand_check_failed (__i, __u, __f, __l, __g);
    4230                 : >14264*10^7 :   return &CONST_CAST_TREE (__u)->exp.operands[__i];
    4231                 :             : }
    4232                 :             : 
    4233                 :             : inline tree *
    4234                 :   197322233 : tree_operand_check_code (tree __t, enum tree_code __code, int __i,
    4235                 :             :                          const char *__f, int __l, const char *__g)
    4236                 :             : {
    4237                 :   197322233 :   if (TREE_CODE (__t) != __code)
    4238                 :           0 :     tree_check_failed (__t, __f, __l, __g, __code, 0);
    4239                 :   197322233 :   if (__i < 0 || __i >= TREE_OPERAND_LENGTH (__t))
    4240                 :           0 :     tree_operand_check_failed (__i, __t, __f, __l, __g);
    4241                 :   197322233 :   return &__t->exp.operands[__i];
    4242                 :             : }
    4243                 :             : 
    4244                 :             : inline const_tree *
    4245                 : 26936185727 : tree_operand_check (const_tree __t, int __i,
    4246                 :             :                     const char *__f, int __l, const char *__g)
    4247                 :             : {
    4248                 : 26936185727 :   const_tree __u = EXPR_CHECK (__t);
    4249                 : 26936185727 :   if (__i < 0 || __i >= TREE_OPERAND_LENGTH (__u))
    4250                 :           0 :     tree_operand_check_failed (__i, __u, __f, __l, __g);
    4251                 : 26936185727 :   return CONST_CAST (const_tree *, &__u->exp.operands[__i]);
    4252                 :             : }
    4253                 :             : 
    4254                 :             : inline const_tree *
    4255                 :          72 : tree_operand_check_code (const_tree __t, enum tree_code __code, int __i,
    4256                 :             :                          const char *__f, int __l, const char *__g)
    4257                 :             : {
    4258                 :          72 :   if (TREE_CODE (__t) != __code)
    4259                 :           0 :     tree_check_failed (__t, __f, __l, __g, __code, 0);
    4260                 :          72 :   if (__i < 0 || __i >= TREE_OPERAND_LENGTH (__t))
    4261                 :           0 :     tree_operand_check_failed (__i, __t, __f, __l, __g);
    4262                 :          72 :   return CONST_CAST (const_tree *, &__t->exp.operands[__i]);
    4263                 :             : }
    4264                 :             : 
    4265                 :             : #endif
    4266                 :             : 
    4267                 :             : /* True iff an identifier matches a C string.  */
    4268                 :             : 
    4269                 :             : inline bool
    4270                 :  2842460016 : id_equal (const_tree id, const char *str)
    4271                 :             : {
    4272                 :  2842460016 :   return !strcmp (IDENTIFIER_POINTER (id), str);
    4273                 :             : }
    4274                 :             : 
    4275                 :             : inline bool
    4276                 :         316 : id_equal (const char *str, const_tree id)
    4277                 :             : {
    4278                 :         316 :   return id_equal (id, str);
    4279                 :             : }
    4280                 :             : 
    4281                 :             : /* Return the number of elements in the VECTOR_TYPE given by NODE.  */
    4282                 :             : 
    4283                 :             : inline poly_uint64
    4284                 :   490157744 : TYPE_VECTOR_SUBPARTS (const_tree node)
    4285                 :             : {
    4286                 :   490157744 :   STATIC_ASSERT (NUM_POLY_INT_COEFFS <= 2);
    4287                 :   490157744 :   unsigned int precision = VECTOR_TYPE_CHECK (node)->type_common.precision;
    4288                 :   490157744 :   if (NUM_POLY_INT_COEFFS == 2)
    4289                 :             :     {
    4290                 :             :       /* See the corresponding code in SET_TYPE_VECTOR_SUBPARTS for a
    4291                 :             :          description of the encoding.  */
    4292                 :             :       poly_uint64 res = 0;
    4293                 :             :       res.coeffs[0] = HOST_WIDE_INT_1U << (precision & 0xff);
    4294                 :             :       if (precision & 0x100)
    4295                 :             :         res.coeffs[1] = HOST_WIDE_INT_1U << (precision & 0xff);
    4296                 :             :       return res;
    4297                 :             :     }
    4298                 :             :   else
    4299                 :   490157744 :     return HOST_WIDE_INT_1U << precision;
    4300                 :             : }
    4301                 :             : 
    4302                 :             : /* Set the number of elements in VECTOR_TYPE NODE to SUBPARTS, which must
    4303                 :             :    satisfy valid_vector_subparts_p.  */
    4304                 :             : 
    4305                 :             : inline void
    4306                 :    64691203 : SET_TYPE_VECTOR_SUBPARTS (tree node, poly_uint64 subparts)
    4307                 :             : {
    4308                 :    64691203 :   STATIC_ASSERT (NUM_POLY_INT_COEFFS <= 2);
    4309                 :    64691203 :   unsigned HOST_WIDE_INT coeff0 = subparts.coeffs[0];
    4310                 :    64691203 :   int index = exact_log2 (coeff0);
    4311                 :           0 :   gcc_assert (index >= 0);
    4312                 :    64691203 :   if (NUM_POLY_INT_COEFFS == 2)
    4313                 :             :     {
    4314                 :             :       /* We have two coefficients that are each in the range 1 << [0, 63],
    4315                 :             :          so supporting all combinations would require 6 bits per coefficient
    4316                 :             :          and 12 bits in total.  Since the precision field is only 10 bits
    4317                 :             :          in size, we need to be more restrictive than that.
    4318                 :             : 
    4319                 :             :          At present, coeff[1] is always either 0 (meaning that the number
    4320                 :             :          of units is constant) or equal to coeff[0] (meaning that the number
    4321                 :             :          of units is N + X * N for some target-dependent zero-based runtime
    4322                 :             :          parameter X).  We can therefore encode coeff[1] in a single bit.
    4323                 :             : 
    4324                 :             :          The most compact encoding would be to use mask 0x3f for coeff[0]
    4325                 :             :          and 0x40 for coeff[1], leaving 0x380 unused.  It's possible to
    4326                 :             :          get slightly more efficient code on some hosts if we instead
    4327                 :             :          treat the shift amount as an independent byte, so here we use
    4328                 :             :          0xff for coeff[0] and 0x100 for coeff[1].  */
    4329                 :             :       unsigned HOST_WIDE_INT coeff1 = subparts.coeffs[1];
    4330                 :             :       gcc_assert (coeff1 == 0 || coeff1 == coeff0);
    4331                 :             :       VECTOR_TYPE_CHECK (node)->type_common.precision
    4332                 :             :         = index + (coeff1 != 0 ? 0x100 : 0);
    4333                 :             :     }
    4334                 :             :   else
    4335                 :    64691203 :     VECTOR_TYPE_CHECK (node)->type_common.precision = index;
    4336                 :    64691203 : }
    4337                 :             : 
    4338                 :             : /* Return true if we can construct vector types with the given number
    4339                 :             :    of subparts.  */
    4340                 :             : 
    4341                 :             : inline bool
    4342                 :       20859 : valid_vector_subparts_p (poly_uint64 subparts)
    4343                 :             : {
    4344                 :       20859 :   unsigned HOST_WIDE_INT coeff0 = subparts.coeffs[0];
    4345                 :     9022166 :   if (!pow2p_hwi (coeff0))
    4346                 :             :     return false;
    4347                 :             :   if (NUM_POLY_INT_COEFFS == 2)
    4348                 :             :     {
    4349                 :             :       unsigned HOST_WIDE_INT coeff1 = subparts.coeffs[1];
    4350                 :             :       if (coeff1 != 0 && coeff1 != coeff0)
    4351                 :             :         return false;
    4352                 :             :     }
    4353                 :             :   return true;
    4354                 :             : }
    4355                 :             : 
    4356                 :             : /* Return the built-in function that DECL represents, given that it is known
    4357                 :             :    to be a FUNCTION_DECL with built-in class BUILT_IN_NORMAL.  */
    4358                 :             : inline built_in_function
    4359                 :  2371694531 : DECL_FUNCTION_CODE (const_tree decl)
    4360                 :             : {
    4361                 :  2371694531 :   const tree_function_decl &fndecl = FUNCTION_DECL_CHECK (decl)->function_decl;
    4362                 :  2371694531 :   gcc_checking_assert (fndecl.built_in_class == BUILT_IN_NORMAL);
    4363                 :  2371694531 :   return (built_in_function) fndecl.function_code;
    4364                 :             : }
    4365                 :             : 
    4366                 :             : /* Return the target-specific built-in function that DECL represents,
    4367                 :             :    given that it is known to be a FUNCTION_DECL with built-in class
    4368                 :             :    BUILT_IN_MD.  */
    4369                 :             : inline int
    4370                 :    70285161 : DECL_MD_FUNCTION_CODE (const_tree decl)
    4371                 :             : {
    4372                 :    70285161 :   const tree_function_decl &fndecl = FUNCTION_DECL_CHECK (decl)->function_decl;
    4373                 :    70285161 :   gcc_checking_assert (fndecl.built_in_class == BUILT_IN_MD);
    4374                 :    70285161 :   return fndecl.function_code;
    4375                 :             : }
    4376                 :             : 
    4377                 :             : /* Return the frontend-specific built-in function that DECL represents,
    4378                 :             :    given that it is known to be a FUNCTION_DECL with built-in class
    4379                 :             :    BUILT_IN_FRONTEND.  */
    4380                 :             : inline int
    4381                 :      187581 : DECL_FE_FUNCTION_CODE (const_tree decl)
    4382                 :             : {
    4383                 :      187581 :   const tree_function_decl &fndecl = FUNCTION_DECL_CHECK (decl)->function_decl;
    4384                 :      187581 :   gcc_checking_assert (fndecl.built_in_class == BUILT_IN_FRONTEND);
    4385                 :      187581 :   return fndecl.function_code;
    4386                 :             : }
    4387                 :             : 
    4388                 :             : /* Record that FUNCTION_DECL DECL represents built-in function FCODE of
    4389                 :             :    class FCLASS.  */
    4390                 :             : inline void
    4391                 :   799085021 : set_decl_built_in_function (tree decl, built_in_class fclass,
    4392                 :             :                             unsigned int fcode)
    4393                 :             : {
    4394                 :   799085021 :   tree_function_decl &fndecl = FUNCTION_DECL_CHECK (decl)->function_decl;
    4395                 :   799085021 :   fndecl.built_in_class = fclass;
    4396                 :   799085021 :   fndecl.function_code = fcode;
    4397                 :   799085021 : }
    4398                 :             : 
    4399                 :             : /* Record that FUNCTION_DECL NEWDECL represents the same built-in function
    4400                 :             :    as OLDDECL (or none, if OLDDECL doesn't represent a built-in function).  */
    4401                 :             : inline void
    4402                 :     6985140 : copy_decl_built_in_function (tree newdecl, const_tree olddecl)
    4403                 :             : {
    4404                 :     6985140 :   tree_function_decl &newfndecl = FUNCTION_DECL_CHECK (newdecl)->function_decl;
    4405                 :     6985140 :   const tree_function_decl &oldfndecl
    4406                 :     6985140 :     = FUNCTION_DECL_CHECK (olddecl)->function_decl;
    4407                 :     6985140 :   newfndecl.built_in_class = oldfndecl.built_in_class;
    4408                 :     6985140 :   newfndecl.function_code = oldfndecl.function_code;
    4409                 :     6985140 : }
    4410                 :             : 
    4411                 :             : /* In NON_LVALUE_EXPR and VIEW_CONVERT_EXPR, set when this node is merely a
    4412                 :             :    wrapper added to express a location_t on behalf of the node's child
    4413                 :             :    (e.g. by maybe_wrap_with_location).  */
    4414                 :             : 
    4415                 :             : #define EXPR_LOCATION_WRAPPER_P(NODE) \
    4416                 :             :   (TREE_CHECK2(NODE, NON_LVALUE_EXPR, VIEW_CONVERT_EXPR)->base.public_flag)
    4417                 :             : 
    4418                 :             : /* Test if EXP is merely a wrapper node, added to express a location_t
    4419                 :             :    on behalf of the node's child (e.g. by maybe_wrap_with_location).  */
    4420                 :             : 
    4421                 :             : inline bool
    4422                 : 62208092025 : location_wrapper_p (const_tree exp)
    4423                 :             : {
    4424                 :             :   /* A wrapper node has code NON_LVALUE_EXPR or VIEW_CONVERT_EXPR, and
    4425                 :             :      the flag EXPR_LOCATION_WRAPPER_P is set.
    4426                 :             :      It normally has the same type as its operand, but it can have a
    4427                 :             :      different one if the type of the operand has changed (e.g. when
    4428                 :             :      merging duplicate decls).
    4429                 :             : 
    4430                 :             :      NON_LVALUE_EXPR is used for wrapping constants, apart from STRING_CST.
    4431                 :             :      VIEW_CONVERT_EXPR is used for wrapping non-constants and STRING_CST.  */
    4432                 : 62208092025 :   if ((TREE_CODE (exp) == NON_LVALUE_EXPR
    4433                 : 61470901207 :        || TREE_CODE (exp) == VIEW_CONVERT_EXPR)
    4434                 : 65224751839 :       && EXPR_LOCATION_WRAPPER_P (exp))
    4435                 :  3566786447 :     return true;
    4436                 :             :   return false;
    4437                 :             : }
    4438                 :             : 
    4439                 :             : /* Implementation of STRIP_ANY_LOCATION_WRAPPER.  */
    4440                 :             : 
    4441                 :             : inline tree
    4442                 : 39861892568 : tree_strip_any_location_wrapper (tree exp)
    4443                 :             : {
    4444                 : 39861892568 :   if (location_wrapper_p (exp))
    4445                 :  1985913737 :     return TREE_OPERAND (exp, 0);
    4446                 :             :   else
    4447                 :             :     return exp;
    4448                 :             : }
    4449                 :             : 
    4450                 :             : #define error_mark_node                 global_trees[TI_ERROR_MARK]
    4451                 :             : 
    4452                 :             : #define intQI_type_node                 global_trees[TI_INTQI_TYPE]
    4453                 :             : #define intHI_type_node                 global_trees[TI_INTHI_TYPE]
    4454                 :             : #define intSI_type_node                 global_trees[TI_INTSI_TYPE]
    4455                 :             : #define intDI_type_node                 global_trees[TI_INTDI_TYPE]
    4456                 :             : #define intTI_type_node                 global_trees[TI_INTTI_TYPE]
    4457                 :             : 
    4458                 :             : #define unsigned_intQI_type_node        global_trees[TI_UINTQI_TYPE]
    4459                 :             : #define unsigned_intHI_type_node        global_trees[TI_UINTHI_TYPE]
    4460                 :             : #define unsigned_intSI_type_node        global_trees[TI_UINTSI_TYPE]
    4461                 :             : #define unsigned_intDI_type_node        global_trees[TI_UINTDI_TYPE]
    4462                 :             : #define unsigned_intTI_type_node        global_trees[TI_UINTTI_TYPE]
    4463                 :             : 
    4464                 :             : #define atomicQI_type_node      global_trees[TI_ATOMICQI_TYPE]
    4465                 :             : #define atomicHI_type_node      global_trees[TI_ATOMICHI_TYPE]
    4466                 :             : #define atomicSI_type_node      global_trees[TI_ATOMICSI_TYPE]
    4467                 :             : #define atomicDI_type_node      global_trees[TI_ATOMICDI_TYPE]
    4468                 :             : #define atomicTI_type_node      global_trees[TI_ATOMICTI_TYPE]
    4469                 :             : 
    4470                 :             : #define uint16_type_node                global_trees[TI_UINT16_TYPE]
    4471                 :             : #define uint32_type_node                global_trees[TI_UINT32_TYPE]
    4472                 :             : #define uint64_type_node                global_trees[TI_UINT64_TYPE]
    4473                 :             : #define uint128_type_node               global_trees[TI_UINT128_TYPE]
    4474                 :             : 
    4475                 :             : #define void_node                       global_trees[TI_VOID]
    4476                 :             : 
    4477                 :             : #define integer_zero_node               global_trees[TI_INTEGER_ZERO]
    4478                 :             : #define integer_one_node                global_trees[TI_INTEGER_ONE]
    4479                 :             : #define integer_minus_one_node          global_trees[TI_INTEGER_MINUS_ONE]
    4480                 :             : #define size_zero_node                  global_trees[TI_SIZE_ZERO]
    4481                 :             : #define size_one_node                   global_trees[TI_SIZE_ONE]
    4482                 :             : #define bitsize_zero_node               global_trees[TI_BITSIZE_ZERO]
    4483                 :             : #define bitsize_one_node                global_trees[TI_BITSIZE_ONE]
    4484                 :             : #define bitsize_unit_node               global_trees[TI_BITSIZE_UNIT]
    4485                 :             : 
    4486                 :             : /* Base access nodes.  */
    4487                 :             : #define access_public_node              global_trees[TI_PUBLIC]
    4488                 :             : #define access_protected_node           global_trees[TI_PROTECTED]
    4489                 :             : #define access_private_node             global_trees[TI_PRIVATE]
    4490                 :             : 
    4491                 :             : #define null_pointer_node               global_trees[TI_NULL_POINTER]
    4492                 :             : 
    4493                 :             : #define float_type_node                 global_trees[TI_FLOAT_TYPE]
    4494                 :             : #define double_type_node                global_trees[TI_DOUBLE_TYPE]
    4495                 :             : #define long_double_type_node           global_trees[TI_LONG_DOUBLE_TYPE]
    4496                 :             : #define bfloat16_type_node              global_trees[TI_BFLOAT16_TYPE]
    4497                 :             : 
    4498                 :             : /* Nodes for particular _FloatN and _FloatNx types in sequence.  */
    4499                 :             : #define FLOATN_TYPE_NODE(IDX)           global_trees[TI_FLOATN_TYPE_FIRST + (IDX)]
    4500                 :             : #define FLOATN_NX_TYPE_NODE(IDX)        global_trees[TI_FLOATN_NX_TYPE_FIRST + (IDX)]
    4501                 :             : #define FLOATNX_TYPE_NODE(IDX)          global_trees[TI_FLOATNX_TYPE_FIRST + (IDX)]
    4502                 :             : 
    4503                 :             : /* Names for individual types (code should normally iterate over all
    4504                 :             :    such types; these are only for back-end use, or in contexts such as
    4505                 :             :    *.def where iteration is not possible).  */
    4506                 :             : #define float16_type_node               global_trees[TI_FLOAT16_TYPE]
    4507                 :             : #define float32_type_node               global_trees[TI_FLOAT32_TYPE]
    4508                 :             : #define float64_type_node               global_trees[TI_FLOAT64_TYPE]
    4509                 :             : #define float128_type_node              global_trees[TI_FLOAT128_TYPE]
    4510                 :             : #define float32x_type_node              global_trees[TI_FLOAT32X_TYPE]
    4511                 :             : #define float64x_type_node              global_trees[TI_FLOAT64X_TYPE]
    4512                 :             : #define float128x_type_node             global_trees[TI_FLOAT128X_TYPE]
    4513                 :             : 
    4514                 :             : /* Type used by certain backends for __float128, which in C++ should be
    4515                 :             :    distinct type from _Float128 for backwards compatibility reasons.  */
    4516                 :             : #define float128t_type_node             global_trees[TI_FLOAT128T_TYPE]
    4517                 :             : 
    4518                 :             : #define float_ptr_type_node             global_trees[TI_FLOAT_PTR_TYPE]
    4519                 :             : #define double_ptr_type_node            global_trees[TI_DOUBLE_PTR_TYPE]
    4520                 :             : #define long_double_ptr_type_node       global_trees[TI_LONG_DOUBLE_PTR_TYPE]
    4521                 :             : #define integer_ptr_type_node           global_trees[TI_INTEGER_PTR_TYPE]
    4522                 :             : 
    4523                 :             : #define complex_integer_type_node       global_trees[TI_COMPLEX_INTEGER_TYPE]
    4524                 :             : #define complex_float_type_node         global_trees[TI_COMPLEX_FLOAT_TYPE]
    4525                 :             : #define complex_double_type_node        global_trees[TI_COMPLEX_DOUBLE_TYPE]
    4526                 :             : #define complex_long_double_type_node   global_trees[TI_COMPLEX_LONG_DOUBLE_TYPE]
    4527                 :             : 
    4528                 :             : #define COMPLEX_FLOATN_NX_TYPE_NODE(IDX)        global_trees[TI_COMPLEX_FLOATN_NX_TYPE_FIRST + (IDX)]
    4529                 :             : 
    4530                 :             : #define void_type_node                  global_trees[TI_VOID_TYPE]
    4531                 :             : /* The C type `void *'.  */
    4532                 :             : #define ptr_type_node                   global_trees[TI_PTR_TYPE]
    4533                 :             : /* The C type `const void *'.  */
    4534                 :             : #define const_ptr_type_node             global_trees[TI_CONST_PTR_TYPE]
    4535                 :             : /* The C type `size_t'.  */
    4536                 :             : #define size_type_node                  global_trees[TI_SIZE_TYPE]
    4537                 :             : #define pid_type_node                   global_trees[TI_PID_TYPE]
    4538                 :             : #define ptrdiff_type_node               global_trees[TI_PTRDIFF_TYPE]
    4539                 :             : #define va_list_type_node               global_trees[TI_VA_LIST_TYPE]
    4540                 :             : #define va_list_gpr_counter_field       global_trees[TI_VA_LIST_GPR_COUNTER_FIELD]
    4541                 :             : #define va_list_fpr_counter_field       global_trees[TI_VA_LIST_FPR_COUNTER_FIELD]
    4542                 :             : /* The C type `FILE *'.  */
    4543                 :             : #define fileptr_type_node               global_trees[TI_FILEPTR_TYPE]
    4544                 :             : /* The C type `const struct tm *'.  */
    4545                 :             : #define const_tm_ptr_type_node          global_trees[TI_CONST_TM_PTR_TYPE]
    4546                 :             : /* The C type `fenv_t *'.  */
    4547                 :             : #define fenv_t_ptr_type_node            global_trees[TI_FENV_T_PTR_TYPE]
    4548                 :             : #define const_fenv_t_ptr_type_node      global_trees[TI_CONST_FENV_T_PTR_TYPE]
    4549                 :             : /* The C type `fexcept_t *'.  */
    4550                 :             : #define fexcept_t_ptr_type_node         global_trees[TI_FEXCEPT_T_PTR_TYPE]
    4551                 :             : #define const_fexcept_t_ptr_type_node   global_trees[TI_CONST_FEXCEPT_T_PTR_TYPE]
    4552                 :             : #define pointer_sized_int_node          global_trees[TI_POINTER_SIZED_TYPE]
    4553                 :             : 
    4554                 :             : #define boolean_type_node               global_trees[TI_BOOLEAN_TYPE]
    4555                 :             : #define boolean_false_node              global_trees[TI_BOOLEAN_FALSE]
    4556                 :             : #define boolean_true_node               global_trees[TI_BOOLEAN_TRUE]
    4557                 :             : 
    4558                 :             : /* The decimal floating point types. */
    4559                 :             : #define dfloat32_type_node              global_trees[TI_DFLOAT32_TYPE]
    4560                 :             : #define dfloat64_type_node              global_trees[TI_DFLOAT64_TYPE]
    4561                 :             : #define dfloat128_type_node             global_trees[TI_DFLOAT128_TYPE]
    4562                 :             : #define dfloat64x_type_node             global_trees[TI_DFLOAT64X_TYPE]
    4563                 :             : 
    4564                 :             : /* The fixed-point types.  */
    4565                 :             : #define sat_short_fract_type_node       global_trees[TI_SAT_SFRACT_TYPE]
    4566                 :             : #define sat_fract_type_node             global_trees[TI_SAT_FRACT_TYPE]
    4567                 :             : #define sat_long_fract_type_node        global_trees[TI_SAT_LFRACT_TYPE]
    4568                 :             : #define sat_long_long_fract_type_node   global_trees[TI_SAT_LLFRACT_TYPE]
    4569                 :             : #define sat_unsigned_short_fract_type_node \
    4570                 :             :                                         global_trees[TI_SAT_USFRACT_TYPE]
    4571                 :             : #define sat_unsigned_fract_type_node    global_trees[TI_SAT_UFRACT_TYPE]
    4572                 :             : #define sat_unsigned_long_fract_type_node \
    4573                 :             :                                         global_trees[TI_SAT_ULFRACT_TYPE]
    4574                 :             : #define sat_unsigned_long_long_fract_type_node \
    4575                 :             :                                         global_trees[TI_SAT_ULLFRACT_TYPE]
    4576                 :             : #define short_fract_type_node           global_trees[TI_SFRACT_TYPE]
    4577                 :             : #define fract_type_node                 global_trees[TI_FRACT_TYPE]
    4578                 :             : #define long_fract_type_node            global_trees[TI_LFRACT_TYPE]
    4579                 :             : #define long_long_fract_type_node       global_trees[TI_LLFRACT_TYPE]
    4580                 :             : #define unsigned_short_fract_type_node  global_trees[TI_USFRACT_TYPE]
    4581                 :             : #define unsigned_fract_type_node        global_trees[TI_UFRACT_TYPE]
    4582                 :             : #define unsigned_long_fract_type_node   global_trees[TI_ULFRACT_TYPE]
    4583                 :             : #define unsigned_long_long_fract_type_node \
    4584                 :             :                                         global_trees[TI_ULLFRACT_TYPE]
    4585                 :             : #define sat_short_accum_type_node       global_trees[TI_SAT_SACCUM_TYPE]
    4586                 :             : #define sat_accum_type_node             global_trees[TI_SAT_ACCUM_TYPE]
    4587                 :             : #define sat_long_accum_type_node        global_trees[TI_SAT_LACCUM_TYPE]
    4588                 :             : #define sat_long_long_accum_type_node   global_trees[TI_SAT_LLACCUM_TYPE]
    4589                 :             : #define sat_unsigned_short_accum_type_node \
    4590                 :             :                                         global_trees[TI_SAT_USACCUM_TYPE]
    4591                 :             : #define sat_unsigned_accum_type_node    global_trees[TI_SAT_UACCUM_TYPE]
    4592                 :             : #define sat_unsigned_long_accum_type_node \
    4593                 :             :                                         global_trees[TI_SAT_ULACCUM_TYPE]
    4594                 :             : #define sat_unsigned_long_long_accum_type_node \
    4595                 :             :                                         global_trees[TI_SAT_ULLACCUM_TYPE]
    4596                 :             : #define short_accum_type_node           global_trees[TI_SACCUM_TYPE]
    4597                 :             : #define accum_type_node                 global_trees[TI_ACCUM_TYPE]
    4598                 :             : #define long_accum_type_node            global_trees[TI_LACCUM_TYPE]
    4599                 :             : #define long_long_accum_type_node       global_trees[TI_LLACCUM_TYPE]
    4600                 :             : #define unsigned_short_accum_type_node  global_trees[TI_USACCUM_TYPE]
    4601                 :             : #define unsigned_accum_type_node        global_trees[TI_UACCUM_TYPE]
    4602                 :             : #define unsigned_long_accum_type_node   global_trees[TI_ULACCUM_TYPE]
    4603                 :             : #define unsigned_long_long_accum_type_node \
    4604                 :             :                                         global_trees[TI_ULLACCUM_TYPE]
    4605                 :             : #define qq_type_node                    global_trees[TI_QQ_TYPE]
    4606                 :             : #define hq_type_node                    global_trees[TI_HQ_TYPE]
    4607                 :             : #define sq_type_node                    global_trees[TI_SQ_TYPE]
    4608                 :             : #define dq_type_node                    global_trees[TI_DQ_TYPE]
    4609                 :             : #define tq_type_node                    global_trees[TI_TQ_TYPE]
    4610                 :             : #define uqq_type_node                   global_trees[TI_UQQ_TYPE]
    4611                 :             : #define uhq_type_node                   global_trees[TI_UHQ_TYPE]
    4612                 :             : #define usq_type_node                   global_trees[TI_USQ_TYPE]
    4613                 :             : #define udq_type_node                   global_trees[TI_UDQ_TYPE]
    4614                 :             : #define utq_type_node                   global_trees[TI_UTQ_TYPE]
    4615                 :             : #define sat_qq_type_node                global_trees[TI_SAT_QQ_TYPE]
    4616                 :             : #define sat_hq_type_node                global_trees[TI_SAT_HQ_TYPE]
    4617                 :             : #define sat_sq_type_node                global_trees[TI_SAT_SQ_TYPE]
    4618                 :             : #define sat_dq_type_node                global_trees[TI_SAT_DQ_TYPE]
    4619                 :             : #define sat_tq_type_node                global_trees[TI_SAT_TQ_TYPE]
    4620                 :             : #define sat_uqq_type_node               global_trees[TI_SAT_UQQ_TYPE]
    4621                 :             : #define sat_uhq_type_node               global_trees[TI_SAT_UHQ_TYPE]
    4622                 :             : #define sat_usq_type_node               global_trees[TI_SAT_USQ_TYPE]
    4623                 :             : #define sat_udq_type_node               global_trees[TI_SAT_UDQ_TYPE]
    4624                 :             : #define sat_utq_type_node               global_trees[TI_SAT_UTQ_TYPE]
    4625                 :             : #define ha_type_node                    global_trees[TI_HA_TYPE]
    4626                 :             : #define sa_type_node                    global_trees[TI_SA_TYPE]
    4627                 :             : #define da_type_node                    global_trees[TI_DA_TYPE]
    4628                 :             : #define ta_type_node                    global_trees[TI_TA_TYPE]
    4629                 :             : #define uha_type_node                   global_trees[TI_UHA_TYPE]
    4630                 :             : #define usa_type_node                   global_trees[TI_USA_TYPE]
    4631                 :             : #define uda_type_node                   global_trees[TI_UDA_TYPE]
    4632                 :             : #define uta_type_node                   global_trees[TI_UTA_TYPE]
    4633                 :             : #define sat_ha_type_node                global_trees[TI_SAT_HA_TYPE]
    4634                 :             : #define sat_sa_type_node                global_trees[TI_SAT_SA_TYPE]
    4635                 :             : #define sat_da_type_node                global_trees[TI_SAT_DA_TYPE]
    4636                 :             : #define sat_ta_type_node                global_trees[TI_SAT_TA_TYPE]
    4637                 :             : #define sat_uha_type_node               global_trees[TI_SAT_UHA_TYPE]
    4638                 :             : #define sat_usa_type_node               global_trees[TI_SAT_USA_TYPE]
    4639                 :             : #define sat_uda_type_node               global_trees[TI_SAT_UDA_TYPE]
    4640                 :             : #define sat_uta_type_node               global_trees[TI_SAT_UTA_TYPE]
    4641                 :             : 
    4642                 :             : /* The node that should be placed at the end of a parameter list to
    4643                 :             :    indicate that the function does not take a variable number of
    4644                 :             :    arguments.  The TREE_VALUE will be void_type_node and there will be
    4645                 :             :    no TREE_CHAIN.  Language-independent code should not assume
    4646                 :             :    anything else about this node.  */
    4647                 :             : #define void_list_node                  global_trees[TI_VOID_LIST_NODE]
    4648                 :             : 
    4649                 :             : #define main_identifier_node            global_trees[TI_MAIN_IDENTIFIER]
    4650                 :             : #define MAIN_NAME_P(NODE) \
    4651                 :             :   (IDENTIFIER_NODE_CHECK (NODE) == main_identifier_node)
    4652                 :             : 
    4653                 :             : /* Optimization options (OPTIMIZATION_NODE) to use for default and current
    4654                 :             :    functions.  */
    4655                 :             : #define optimization_default_node       global_trees[TI_OPTIMIZATION_DEFAULT]
    4656                 :             : #define optimization_current_node       global_trees[TI_OPTIMIZATION_CURRENT]
    4657                 :             : 
    4658                 :             : /* Default/current target options (TARGET_OPTION_NODE).  */
    4659                 :             : #define target_option_default_node      global_trees[TI_TARGET_OPTION_DEFAULT]
    4660                 :             : #define target_option_current_node      global_trees[TI_TARGET_OPTION_CURRENT]
    4661                 :             : 
    4662                 :             : /* Default tree list option(), optimize() pragmas to be linked into the
    4663                 :             :    attribute list.  */
    4664                 :             : #define current_target_pragma           global_trees[TI_CURRENT_TARGET_PRAGMA]
    4665                 :             : #define current_optimize_pragma         global_trees[TI_CURRENT_OPTIMIZE_PRAGMA]
    4666                 :             : 
    4667                 :             : /* SCEV analyzer global shared trees.  */
    4668                 :             : #define chrec_not_analyzed_yet          NULL_TREE
    4669                 :             : #define chrec_dont_know                 global_trees[TI_CHREC_DONT_KNOW]
    4670                 :             : #define chrec_known                     global_trees[TI_CHREC_KNOWN]
    4671                 :             : 
    4672                 :             : #define char_type_node                  integer_types[itk_char]
    4673                 :             : #define signed_char_type_node           integer_types[itk_signed_char]
    4674                 :             : #define unsigned_char_type_node         integer_types[itk_unsigned_char]
    4675                 :             : #define short_integer_type_node         integer_types[itk_short]
    4676                 :             : #define short_unsigned_type_node        integer_types[itk_unsigned_short]
    4677                 :             : #define integer_type_node               integer_types[itk_int]
    4678                 :             : #define unsigned_type_node              integer_types[itk_unsigned_int]
    4679                 :             : #define long_integer_type_node          integer_types[itk_long]
    4680                 :             : #define long_unsigned_type_node         integer_types[itk_unsigned_long]
    4681                 :             : #define long_long_integer_type_node     integer_types[itk_long_long]
    4682                 :             : #define long_long_unsigned_type_node    integer_types[itk_unsigned_long_long]
    4683                 :             : 
    4684                 :             : /* True if T is an erroneous expression.  */
    4685                 :             : 
    4686                 :             : inline bool
    4687                 : 20170071548 : error_operand_p (const_tree t)
    4688                 :             : {
    4689                 : 20170071548 :   return (t == error_mark_node
    4690                 : 20170071548 :           || (t && TREE_TYPE (t) == error_mark_node));
    4691                 :             : }
    4692                 :             : 
    4693                 :             : /* Return the number of elements encoded directly in a VECTOR_CST.  */
    4694                 :             : 
    4695                 :             : inline unsigned int
    4696                 :    27292747 : vector_cst_encoded_nelts (const_tree t)
    4697                 :             : {
    4698                 :    27292747 :   return VECTOR_CST_NPATTERNS (t) * VECTOR_CST_NELTS_PER_PATTERN (t);
    4699                 :             : }
    4700                 :             : 
    4701                 :             : extern tree decl_assembler_name (tree);
    4702                 :             : extern void overwrite_decl_assembler_name (tree decl, tree name);
    4703                 :             : extern tree decl_comdat_group (const_tree);
    4704                 :             : extern tree decl_comdat_group_id (const_tree);
    4705                 :             : extern const char *decl_section_name (const_tree);
    4706                 :             : extern void set_decl_section_name (tree, const char *);
    4707                 :             : extern void set_decl_section_name (tree, const_tree);
    4708                 :             : extern enum tls_model decl_tls_model (const_tree);
    4709                 :             : extern void set_decl_tls_model (tree, enum tls_model);
    4710                 :             : 
    4711                 :             : /* Compute the number of bytes occupied by 'node'.  This routine only
    4712                 :             :    looks at TREE_CODE and, if the code is TREE_VEC, TREE_VEC_LENGTH.  */
    4713                 :             : 
    4714                 :             : extern size_t tree_size (const_tree);
    4715                 :             : 
    4716                 :             : /* Compute the number of bytes occupied by a tree with code CODE.
    4717                 :             :    This function cannot be used for TREE_VEC or INTEGER_CST nodes,
    4718                 :             :    which are of variable length.  */
    4719                 :             : extern size_t tree_code_size (enum tree_code);
    4720                 :             : 
    4721                 :             : /* Allocate and return a new UID from the DECL_UID namespace.  */
    4722                 :             : extern int allocate_decl_uid (void);
    4723                 :             : 
    4724                 :             : /* Lowest level primitive for allocating a node.
    4725                 :             :    The TREE_CODE is the only argument.  Contents are initialized
    4726                 :             :    to zero except for a few of the common fields.  */
    4727                 :             : 
    4728                 :             : extern tree make_node (enum tree_code CXX_MEM_STAT_INFO);
    4729                 :             : 
    4730                 :             : /* Free tree node.  */
    4731                 :             : 
    4732                 :             : extern void free_node (tree);
    4733                 :             : 
    4734                 :             : /* Make a copy of a node, with all the same contents.  */
    4735                 :             : 
    4736                 :             : extern tree copy_node (tree CXX_MEM_STAT_INFO);
    4737                 :             : 
    4738                 :             : /* Make a copy of a chain of TREE_LIST nodes.  */
    4739                 :             : 
    4740                 :             : extern tree copy_list (tree);
    4741                 :             : 
    4742                 :             : /* Make a CASE_LABEL_EXPR.  */
    4743                 :             : 
    4744                 :             : extern tree build_case_label (tree, tree, tree);
    4745                 :             : 
    4746                 :             : /* Make a BINFO.  */
    4747                 :             : extern tree make_tree_binfo (unsigned CXX_MEM_STAT_INFO);
    4748                 :             : 
    4749                 :             : /* Make an INTEGER_CST.  */
    4750                 :             : 
    4751                 :             : extern tree make_int_cst (int, int CXX_MEM_STAT_INFO);
    4752                 :             : 
    4753                 :             : /* Make a TREE_VEC.  */
    4754                 :             : 
    4755                 :             : extern tree make_tree_vec (int CXX_MEM_STAT_INFO);
    4756                 :             : 
    4757                 :             : /* Grow a TREE_VEC.  */
    4758                 :             : 
    4759                 :             : extern tree grow_tree_vec (tree v, int CXX_MEM_STAT_INFO);
    4760                 :             : 
    4761                 :             : /* Treat a TREE_VEC as a range of trees, e.g.
    4762                 :             :    for (tree e : tree_vec_range (v)) { ... }  */
    4763                 :             : 
    4764                 :             : class tree_vec_range
    4765                 :             : {
    4766                 :             :   tree v;
    4767                 :             : public:
    4768                 :  3942225221 :   tree_vec_range(tree v) : v(v) { }
    4769                 :  3942225221 :   tree *begin() { return TREE_VEC_BEGIN (v); }
    4770                 :  3942225221 :   tree *end() { return TREE_VEC_END (v); }
    4771                 :             : };
    4772                 :             : 
    4773                 :             : /* Construct various types of nodes.  */
    4774                 :             : 
    4775                 :             : extern tree build_nt (enum tree_code, ...);
    4776                 :             : extern tree build_nt_call_vec (tree, vec<tree, va_gc> *);
    4777                 :             : 
    4778                 :             : extern tree build0 (enum tree_code, tree CXX_MEM_STAT_INFO);
    4779                 :             : extern tree build1 (enum tree_code, tree, tree CXX_MEM_STAT_INFO);
    4780                 :             : extern tree build2 (enum tree_code, tree, tree, tree CXX_MEM_STAT_INFO);
    4781                 :             : extern tree build3 (enum tree_code, tree, tree, tree, tree CXX_MEM_STAT_INFO);
    4782                 :             : extern tree build4 (enum tree_code, tree, tree, tree, tree,
    4783                 :             :                     tree CXX_MEM_STAT_INFO);
    4784                 :             : extern tree build5 (enum tree_code, tree, tree, tree, tree, tree,
    4785                 :             :                     tree CXX_MEM_STAT_INFO);
    4786                 :             : 
    4787                 :             : /* _loc versions of build[1-5].  */
    4788                 :             : 
    4789                 :             : inline tree
    4790                 :  1939193585 : build1_loc (location_t loc, enum tree_code code, tree type,
    4791                 :             :             tree arg1 CXX_MEM_STAT_INFO)
    4792                 :             : {
    4793                 :  1939193585 :   tree t = build1 (code, type, arg1 PASS_MEM_STAT);
    4794                 :  1939193585 :   if (CAN_HAVE_LOCATION_P (t))
    4795                 :  1939193585 :     SET_EXPR_LOCATION (t, loc);
    4796                 :  1939193585 :   return t;
    4797                 :             : }
    4798                 :             : 
    4799                 :             : inline tree
    4800                 :   493988554 : build2_loc (location_t loc, enum tree_code code, tree type, tree arg0,
    4801                 :             :             tree arg1 CXX_MEM_STAT_INFO)
    4802                 :             : {
    4803                 :   493988554 :   tree t = build2 (code, type, arg0, arg1 PASS_MEM_STAT);
    4804                 :   493988554 :   if (CAN_HAVE_LOCATION_P (t))
    4805                 :   493988554 :     SET_EXPR_LOCATION (t, loc);
    4806                 :   493988554 :   return t;
    4807                 :             : }
    4808                 :             : 
    4809                 :             : inline tree
    4810                 :   126468439 : build3_loc (location_t loc, enum tree_code code, tree type, tree arg0,
    4811                 :             :             tree arg1, tree arg2 CXX_MEM_STAT_INFO)
    4812                 :             : {
    4813                 :   126468439 :   tree t = build3 (code, type, arg0, arg1, arg2 PASS_MEM_STAT);
    4814                 :   126468439 :   if (CAN_HAVE_LOCATION_P (t))
    4815                 :   126468439 :     SET_EXPR_LOCATION (t, loc);
    4816                 :   126468439 :   return t;
    4817                 :             : }
    4818                 :             : 
    4819                 :             : inline tree
    4820                 :     5163579 : build4_loc (location_t loc, enum tree_code code, tree type, tree arg0,
    4821                 :             :             tree arg1, tree arg2, tree arg3 CXX_MEM_STAT_INFO)
    4822                 :             : {
    4823                 :     5163579 :   tree t = build4 (code, type, arg0, arg1, arg2, arg3 PASS_MEM_STAT);
    4824                 :     5163579 :   if (CAN_HAVE_LOCATION_P (t))
    4825                 :     5163579 :     SET_EXPR_LOCATION (t, loc);
    4826                 :     5163579 :   return t;
    4827                 :             : }
    4828                 :             : 
    4829                 :             : inline tree
    4830                 :        6172 : build5_loc (location_t loc, enum tree_code code, tree type, tree arg0,
    4831                 :             :             tree arg1, tree arg2, tree arg3, tree arg4 CXX_MEM_STAT_INFO)
    4832                 :             : {
    4833                 :        6172 :   tree t = build5 (code, type, arg0, arg1, arg2, arg3,
    4834                 :             :                         arg4 PASS_MEM_STAT);
    4835                 :        6172 :   if (CAN_HAVE_LOCATION_P (t))
    4836                 :        6172 :     SET_EXPR_LOCATION (t, loc);
    4837                 :        6172 :   return t;
    4838                 :             : }
    4839                 :             : 
    4840                 :             : /* Constructs double_int from tree CST.  */
    4841                 :             : 
    4842                 :             : extern tree double_int_to_tree (tree, double_int);
    4843                 :             : 
    4844                 :             : extern tree wide_int_to_tree (tree type, const poly_wide_int_ref &cst);
    4845                 :             : extern tree force_fit_type (tree, const poly_wide_int_ref &, int, bool);
    4846                 :             : 
    4847                 :             : /* Create an INT_CST node with a CST value zero extended.  */
    4848                 :             : 
    4849                 :             : /* static inline */
    4850                 :             : extern tree build_int_cst (tree, poly_int64);
    4851                 :             : extern tree build_int_cstu (tree type, poly_uint64);
    4852                 :             : extern tree build_int_cst_type (tree, poly_int64);
    4853                 :             : extern tree make_vector (unsigned, unsigned CXX_MEM_STAT_INFO);
    4854                 :             : extern tree build_vector_from_ctor (tree, const vec<constructor_elt, va_gc> *);
    4855                 :             : extern tree build_vector_from_val (tree, tree);
    4856                 :             : extern tree build_uniform_cst (tree, tree);
    4857                 :             : extern tree build_vec_series (tree, tree, tree);
    4858                 :             : extern tree build_index_vector (tree, poly_uint64, poly_uint64);
    4859                 :             : extern tree build_vector_a_then_b (tree, unsigned int, tree, tree);
    4860                 :             : extern void recompute_constructor_flags (tree);
    4861                 :             : extern void verify_constructor_flags (tree);
    4862                 :             : extern tree build_constructor (tree, vec<constructor_elt, va_gc> * CXX_MEM_STAT_INFO);
    4863                 :             : extern tree build_constructor_single (tree, tree, tree);
    4864                 :             : extern tree build_constructor_from_list (tree, tree);
    4865                 :             : extern tree build_constructor_from_vec (tree, const vec<tree, va_gc> *);
    4866                 :             : extern tree build_constructor_va (tree, int, ...);
    4867                 :             : extern tree build_clobber (tree, enum clobber_kind = CLOBBER_UNDEF);
    4868                 :             : extern tree build_real_from_int_cst (tree, const_tree);
    4869                 :             : extern tree build_real_from_wide (tree, const wide_int_ref &, signop);
    4870                 :             : extern tree build_complex (tree, tree, tree);
    4871                 :             : extern tree build_complex_inf (tree, bool);
    4872                 :             : extern tree build_each_one_cst (tree);
    4873                 :             : extern tree build_one_cst (tree);
    4874                 :             : extern tree build_minus_one_cst (tree);
    4875                 :             : extern tree build_all_ones_cst (tree);
    4876                 :             : extern tree build_zero_cst (tree);
    4877                 :             : extern tree build_replicated_int_cst (tree, unsigned, HOST_WIDE_INT);
    4878                 :             : extern tree sign_mask_for (tree);
    4879                 :             : extern tree build_string (unsigned, const char * = NULL);
    4880                 :             : extern tree build_poly_int_cst (tree, const poly_wide_int_ref &);
    4881                 :             : extern tree build_tree_list (tree, tree CXX_MEM_STAT_INFO);
    4882                 :             : extern tree build_tree_list_vec (const vec<tree, va_gc> * CXX_MEM_STAT_INFO);
    4883                 :             : extern tree build_decl (location_t, enum tree_code,
    4884                 :             :                         tree, tree CXX_MEM_STAT_INFO);
    4885                 :             : extern tree build_debug_expr_decl (tree type);
    4886                 :             : extern tree build_fn_decl (const char *, tree);
    4887                 :             : extern tree build_translation_unit_decl (tree);
    4888                 :             : extern tree build_block (tree, tree, tree, tree);
    4889                 :             : extern tree build_empty_stmt (location_t);
    4890                 :             : extern tree build_omp_clause (location_t, enum omp_clause_code);
    4891                 :             : 
    4892                 :             : extern tree build_vl_exp (enum tree_code, int CXX_MEM_STAT_INFO);
    4893                 :             : 
    4894                 :             : extern tree build_call_nary (tree, tree, int, ...);
    4895                 :             : extern tree build_call_valist (tree, tree, int, va_list);
    4896                 :             : #define build_call_array(T1,T2,N,T3)\
    4897                 :             :    build_call_array_loc (UNKNOWN_LOCATION, T1, T2, N, T3)
    4898                 :             : extern tree build_call_array_loc (location_t, tree, tree, int, const tree *);
    4899                 :             : extern tree build_call_vec (tree, tree, const vec<tree, va_gc> *);
    4900                 :             : extern tree build_call_expr_loc_array (location_t, tree, int, tree *);
    4901                 :             : extern tree build_call_expr_loc_vec (location_t, tree, vec<tree, va_gc> *);
    4902                 :             : extern tree build_call_expr_loc (location_t, tree, int, ...);
    4903                 :             : extern tree build_call_expr (tree, int, ...);
    4904                 :             : extern tree build_call_expr_internal_loc (location_t, enum internal_fn,
    4905                 :             :                                           tree, int, ...);
    4906                 :             : extern tree build_call_expr_internal_loc_array (location_t, enum internal_fn,
    4907                 :             :                                                 tree, int, const tree *);
    4908                 :             : extern tree maybe_build_call_expr_loc (location_t, combined_fn, tree,
    4909                 :             :                                        int, ...);
    4910                 :             : extern tree build_alloca_call_expr (tree, unsigned int, HOST_WIDE_INT);
    4911                 :             : extern tree build_string_literal (unsigned, const char * = NULL,
    4912                 :             :                                   tree = char_type_node,
    4913                 :             :                                   unsigned HOST_WIDE_INT = HOST_WIDE_INT_M1U);
    4914                 :        9012 : inline tree build_string_literal (const char *p)
    4915                 :        9012 : { return build_string_literal (strlen (p) + 1, p); }
    4916                 :         591 : inline tree build_string_literal (tree t)
    4917                 :             : {
    4918                 :         591 :   return build_string_literal (IDENTIFIER_LENGTH (t) + 1,
    4919                 :         591 :                                IDENTIFIER_POINTER (t));
    4920                 :             : }
    4921                 :             : 
    4922                 :             : /* Construct various nodes representing data types.  */
    4923                 :             : 
    4924                 :             : extern tree signed_or_unsigned_type_for (int, tree);
    4925                 :             : extern tree signed_type_for (tree);
    4926                 :             : extern tree unsigned_type_for (tree);
    4927                 :             : extern bool is_truth_type_for (tree, tree);
    4928                 :             : extern bool tree_zero_one_valued_p (tree);
    4929                 :             : extern tree truth_type_for (tree);
    4930                 :             : extern tree build_pointer_type_for_mode (tree, machine_mode, bool);
    4931                 :             : extern tree build_pointer_type (tree);
    4932                 :             : extern tree build_reference_type_for_mode (tree, machine_mode, bool);
    4933                 :             : extern tree build_reference_type (tree);
    4934                 :             : extern tree build_vector_type_for_mode (tree, machine_mode);
    4935                 :             : extern tree build_vector_type (tree, poly_int64);
    4936                 :             : extern tree build_truth_vector_type_for_mode (poly_uint64, machine_mode);
    4937                 :             : extern tree build_opaque_vector_type (tree, poly_int64);
    4938                 :             : extern tree build_index_type (tree);
    4939                 :             : extern tree build_array_type_1 (tree, tree, bool, bool, bool);
    4940                 :             : extern tree build_array_type (tree, tree, bool = false);
    4941                 :             : extern tree build_nonshared_array_type (tree, tree);
    4942                 :             : extern tree build_array_type_nelts (tree, poly_uint64);
    4943                 :             : extern tree build_function_type (tree, tree, bool = false);
    4944                 :             : extern tree build_function_type_list (tree, ...);
    4945                 :             : extern tree build_varargs_function_type_list (tree, ...);
    4946                 :             : extern tree build_function_type_array (tree, int, tree *);
    4947                 :             : extern tree build_varargs_function_type_array (tree, int, tree *);
    4948                 :             : #define build_function_type_vec(RET, V) \
    4949                 :             :   build_function_type_array (RET, vec_safe_length (V), vec_safe_address (V))
    4950                 :             : #define build_varargs_function_type_vec(RET, V) \
    4951                 :             :   build_varargs_function_type_array (RET, vec_safe_length (V), \
    4952                 :             :                                      vec_safe_address (V))
    4953                 :             : extern tree build_method_type_directly (tree, tree, tree);
    4954                 :             : extern tree build_method_type (tree, tree);
    4955                 :             : extern tree build_offset_type (tree, tree);
    4956                 :             : extern tree build_complex_type (tree, bool named = false);
    4957                 :             : extern tree array_type_nelts_minus_one (const_tree);
    4958                 :             : extern tree array_type_nelts_top (tree);
    4959                 :             : 
    4960                 :             : extern tree value_member (tree, tree);
    4961                 :             : extern tree purpose_member (const_tree, tree);
    4962                 :             : extern bool vec_member (const_tree, vec<tree, va_gc> *);
    4963                 :             : extern tree chain_index (int, tree);
    4964                 :             : 
    4965                 :             : /* Arguments may be null.  */
    4966                 :             : extern bool tree_int_cst_equal (const_tree, const_tree);
    4967                 :             : 
    4968                 :             : /* The following predicates are safe to call with a null argument.  */
    4969                 :             : extern bool tree_fits_shwi_p (const_tree) ATTRIBUTE_PURE;
    4970                 :             : extern bool tree_fits_poly_int64_p (const_tree) ATTRIBUTE_PURE;
    4971                 :             : extern bool tree_fits_uhwi_p (const_tree) ATTRIBUTE_PURE;
    4972                 :             : extern bool tree_fits_poly_uint64_p (const_tree) ATTRIBUTE_PURE;
    4973                 :             : 
    4974                 :             : extern HOST_WIDE_INT tree_to_shwi (const_tree)
    4975                 :             :   ATTRIBUTE_NONNULL (1) ATTRIBUTE_PURE;
    4976                 :             : extern poly_int64 tree_to_poly_int64 (const_tree)
    4977                 :             :   ATTRIBUTE_NONNULL (1) ATTRIBUTE_PURE;
    4978                 :             : extern unsigned HOST_WIDE_INT tree_to_uhwi (const_tree)
    4979                 :             :   ATTRIBUTE_NONNULL (1) ATTRIBUTE_PURE;
    4980                 :             : extern poly_uint64 tree_to_poly_uint64 (const_tree)
    4981                 :             :   ATTRIBUTE_NONNULL (1) ATTRIBUTE_PURE;
    4982                 :             : #if !defined ENABLE_TREE_CHECKING && (GCC_VERSION >= 4003)
    4983                 :             : extern inline __attribute__ ((__gnu_inline__)) HOST_WIDE_INT
    4984                 :             : tree_to_shwi (const_tree t)
    4985                 :             : {
    4986                 :             :   gcc_assert (tree_fits_shwi_p (t));
    4987                 :             :   return TREE_INT_CST_LOW (t);
    4988                 :             : }
    4989                 :             : 
    4990                 :             : extern inline __attribute__ ((__gnu_inline__)) unsigned HOST_WIDE_INT
    4991                 :             : tree_to_uhwi (const_tree t)
    4992                 :             : {
    4993                 :             :   gcc_assert (tree_fits_uhwi_p (t));
    4994                 :             :   return TREE_INT_CST_LOW (t);
    4995                 :             : }
    4996                 :             : #if NUM_POLY_INT_COEFFS == 1
    4997                 :             : extern inline __attribute__ ((__gnu_inline__)) poly_int64
    4998                 :             : tree_to_poly_int64 (const_tree t)
    4999                 :             : {
    5000                 :             :   gcc_assert (tree_fits_poly_int64_p (t));
    5001                 :             :   return TREE_INT_CST_LOW (t);
    5002                 :             : }
    5003                 :             : 
    5004                 :             : extern inline __attribute__ ((__gnu_inline__)) poly_uint64
    5005                 :             : tree_to_poly_uint64 (const_tree t)
    5006                 :             : {
    5007                 :             :   gcc_assert (tree_fits_poly_uint64_p (t));
    5008                 :             :   return TREE_INT_CST_LOW (t);
    5009                 :             : }
    5010                 :             : #endif
    5011                 :             : #endif
    5012                 :             : extern int tree_int_cst_sgn (const_tree);
    5013                 :             : extern int tree_int_cst_sign_bit (const_tree);
    5014                 :             : extern unsigned int tree_int_cst_min_precision (tree, signop);
    5015                 :             : extern tree excess_precision_type (tree);
    5016                 :             : 
    5017                 :             : /* Recursively examines the array elements of TYPE, until a non-array
    5018                 :             :    element type is found.  */
    5019                 :             : 
    5020                 :             : inline tree
    5021                 : 43683561402 : strip_array_types (tree type)
    5022                 :             : {
    5023                 : 43747216575 :   while (TREE_CODE (type) == ARRAY_TYPE)
    5024                 :    63655173 :     type = TREE_TYPE (type);
    5025                 :             : 
    5026                 : 43683561402 :   return type;
    5027                 :             : }
    5028                 :             : 
    5029                 :             : /* Desription of the reason why the argument of valid_constant_size_p
    5030                 :             :    is not a valid size.  */
    5031                 :             : enum cst_size_error {
    5032                 :             :   cst_size_ok,
    5033                 :             :   cst_size_not_constant,
    5034                 :             :   cst_size_negative,
    5035                 :             :   cst_size_too_big,
    5036                 :             :   cst_size_overflow
    5037                 :             : };
    5038                 :             : 
    5039                 :             : extern bool valid_constant_size_p (const_tree, cst_size_error * = NULL);
    5040                 :             : extern tree max_object_size ();
    5041                 :             : 
    5042                 :             : /* Return true if T holds a value that can be represented as a poly_int64
    5043                 :             :    without loss of precision.  Store the value in *VALUE if so.  */
    5044                 :             : 
    5045                 :             : inline bool
    5046                 :   418666045 : poly_int_tree_p (const_tree t, poly_int64 *value)
    5047                 :             : {
    5048                 :   418666045 :   if (tree_fits_poly_int64_p (t))
    5049                 :             :     {
    5050                 :   380894824 :       *value = tree_to_poly_int64 (t);
    5051                 :   380894824 :       return true;
    5052                 :             :     }
    5053                 :             :   return false;
    5054                 :             : }
    5055                 :             : 
    5056                 :             : /* Return true if T holds a value that can be represented as a poly_uint64
    5057                 :             :    without loss of precision.  Store the value in *VALUE if so.  */
    5058                 :             : 
    5059                 :             : inline bool
    5060                 :   329813386 : poly_int_tree_p (const_tree t, poly_uint64 *value)
    5061                 :             : {
    5062                 :   329813386 :   if (tree_fits_poly_uint64_p (t))
    5063                 :             :     {
    5064                 :   328486253 :       *value = tree_to_poly_uint64 (t);
    5065                 :   328486253 :       return true;
    5066                 :             :     }
    5067                 :             :   return false;
    5068                 :             : }
    5069                 :             : 
    5070                 :             : /* From expmed.cc.  Since rtl.h is included after tree.h, we can't
    5071                 :             :    put the prototype here.  Rtl.h does declare the prototype if
    5072                 :             :    tree.h had been included.  */
    5073                 :             : 
    5074                 :             : extern tree make_tree (tree, rtx);
    5075                 :             : 
    5076                 :             : /* Returns true iff CAND and BASE have equivalent language-specific
    5077                 :             :    qualifiers.  */
    5078                 :             : 
    5079                 :             : extern bool check_lang_type (const_tree cand, const_tree base);
    5080                 :             : 
    5081                 :             : /* Returns true iff unqualified CAND and BASE are equivalent.  */
    5082                 :             : 
    5083                 :             : extern bool check_base_type (const_tree cand, const_tree base);
    5084                 :             : 
    5085                 :             : /* Check whether CAND is suitable to be returned from get_qualified_type
    5086                 :             :    (BASE, TYPE_QUALS).  */
    5087                 :             : 
    5088                 :             : extern bool check_qualified_type (const_tree, const_tree, int);
    5089                 :             : 
    5090                 :             : /* Return a version of the TYPE, qualified as indicated by the
    5091                 :             :    TYPE_QUALS, if one exists.  If no qualified version exists yet,
    5092                 :             :    return NULL_TREE.  */
    5093                 :             : 
    5094                 :             : extern tree get_qualified_type (tree, int);
    5095                 :             : 
    5096                 :             : /* Like get_qualified_type, but creates the type if it does not
    5097                 :             :    exist.  This function never returns NULL_TREE.  */
    5098                 :             : 
    5099                 :             : extern tree build_qualified_type (tree, int CXX_MEM_STAT_INFO);
    5100                 :             : 
    5101                 :             : /* Create a variant of type T with alignment ALIGN.  */
    5102                 :             : 
    5103                 :             : extern tree build_aligned_type (tree, unsigned int);
    5104                 :             : 
    5105                 :             : /* Like build_qualified_type, but only deals with the `const' and
    5106                 :             :    `volatile' qualifiers.  This interface is retained for backwards
    5107                 :             :    compatibility with the various front-ends; new code should use
    5108                 :             :    build_qualified_type instead.  */
    5109                 :             : 
    5110                 :             : #define build_type_variant(TYPE, CONST_P, VOLATILE_P)                   \
    5111                 :             :   build_qualified_type ((TYPE),                                         \
    5112                 :             :                         ((CONST_P) ? TYPE_QUAL_CONST : 0)               \
    5113                 :             :                         | ((VOLATILE_P) ? TYPE_QUAL_VOLATILE : 0))
    5114                 :             : 
    5115                 :             : /* Make a copy of a type node.  */
    5116                 :             : 
    5117                 :             : extern tree build_distinct_type_copy (tree CXX_MEM_STAT_INFO);
    5118                 :             : extern tree build_variant_type_copy (tree CXX_MEM_STAT_INFO);
    5119                 :             : 
    5120                 :             : /* Given a hashcode and a ..._TYPE node (for which the hashcode was made),
    5121                 :             :    return a canonicalized ..._TYPE node, so that duplicates are not made.
    5122                 :             :    How the hash code is computed is up to the caller, as long as any two
    5123                 :             :    callers that could hash identical-looking type nodes agree.  */
    5124                 :             : 
    5125                 :             : extern hashval_t type_hash_canon_hash (tree);
    5126                 :             : extern tree type_hash_canon (unsigned int, tree);
    5127                 :             : 
    5128                 :             : extern tree convert (tree, tree);
    5129                 :             : extern tree size_in_bytes_loc (location_t, const_tree);
    5130                 :             : inline tree
    5131                 :    18279616 : size_in_bytes (const_tree t)
    5132                 :             : {
    5133                 :    18279616 :   return size_in_bytes_loc (input_location, t);
    5134                 :             : }
    5135                 :             : 
    5136                 :             : extern HOST_WIDE_INT int_size_in_bytes (const_tree);
    5137                 :             : extern HOST_WIDE_INT max_int_size_in_bytes (const_tree);
    5138                 :             : extern tree bit_position (const_tree);
    5139                 :             : extern tree byte_position (const_tree);
    5140                 :             : extern HOST_WIDE_INT int_byte_position (const_tree);
    5141                 :             : 
    5142                 :             : /* Type for sizes of data-type.  */
    5143                 :             : 
    5144                 :             : #define sizetype sizetype_tab[(int) stk_sizetype]
    5145                 :             : #define bitsizetype sizetype_tab[(int) stk_bitsizetype]
    5146                 :             : #define ssizetype sizetype_tab[(int) stk_ssizetype]
    5147                 :             : #define sbitsizetype sizetype_tab[(int) stk_sbitsizetype]
    5148                 :             : #define size_int(L) size_int_kind (L, stk_sizetype)
    5149                 :             : #define ssize_int(L) size_int_kind (L, stk_ssizetype)
    5150                 :             : #define bitsize_int(L) size_int_kind (L, stk_bitsizetype)
    5151                 :             : #define sbitsize_int(L) size_int_kind (L, stk_sbitsizetype)
    5152                 :             : 
    5153                 :             : /* Log2 of BITS_PER_UNIT.  */
    5154                 :             : 
    5155                 :             : #if BITS_PER_UNIT == 8
    5156                 :             : #define LOG2_BITS_PER_UNIT 3
    5157                 :             : #elif BITS_PER_UNIT == 16
    5158                 :             : #define LOG2_BITS_PER_UNIT 4
    5159                 :             : #else
    5160                 :             : #error Unknown BITS_PER_UNIT
    5161                 :             : #endif
    5162                 :             : 
    5163                 :             : /* Concatenate two lists (chains of TREE_LIST nodes) X and Y
    5164                 :             :    by making the last node in X point to Y.
    5165                 :             :    Returns X, except if X is 0 returns Y.  */
    5166                 :             : 
    5167                 :             : extern tree chainon (tree, tree);
    5168                 :             : 
    5169                 :             : /* Make a new TREE_LIST node from specified PURPOSE, VALUE and CHAIN.  */
    5170                 :             : 
    5171                 :             : extern tree tree_cons (tree, tree, tree CXX_MEM_STAT_INFO);
    5172                 :             : 
    5173                 :             : /* Return the last tree node in a chain.  */
    5174                 :             : 
    5175                 :             : extern tree tree_last (tree);
    5176                 :             : 
    5177                 :             : /* Reverse the order of elements in a chain, and return the new head.  */
    5178                 :             : 
    5179                 :             : extern tree nreverse (tree);
    5180                 :             : 
    5181                 :             : /* Returns the length of a chain of nodes
    5182                 :             :    (number of chain pointers to follow before reaching a null pointer).  */
    5183                 :             : 
    5184                 :             : extern int list_length (const_tree);
    5185                 :             : 
    5186                 :             : /* Returns the first/last FIELD_DECL in a RECORD_TYPE.  */
    5187                 :             : 
    5188                 :             : extern tree first_field (const_tree) ATTRIBUTE_NONNULL (1);
    5189                 :             : extern tree last_field (const_tree) ATTRIBUTE_NONNULL (1);
    5190                 :             : 
    5191                 :             : /* Given an initializer INIT, return TRUE if INIT is zero or some
    5192                 :             :    aggregate of zeros.  Otherwise return FALSE.  If NONZERO is not
    5193                 :             :    null, set *NONZERO if and only if INIT is known not to be all
    5194                 :             :    zeros.  The combination of return value of false and *NONZERO
    5195                 :             :    false implies that INIT may but need not be all zeros.  Other
    5196                 :             :    combinations indicate definitive answers.  */
    5197                 :             : 
    5198                 :             : extern bool initializer_zerop (const_tree, bool * = NULL);
    5199                 :             : extern bool initializer_each_zero_or_onep (const_tree);
    5200                 :             : 
    5201                 :             : extern tree vector_cst_elt (const_tree, unsigned int);
    5202                 :             : 
    5203                 :             : /* Given a vector VEC, return its first element if all elements are
    5204                 :             :    the same.  Otherwise return NULL_TREE.  */
    5205                 :             : 
    5206                 :             : extern tree uniform_vector_p (const_tree);
    5207                 :             : 
    5208                 :             : /* If the argument is INTEGER_CST, return it.  If the argument is vector
    5209                 :             :    with all elements the same INTEGER_CST, return that INTEGER_CST.  Otherwise
    5210                 :             :    return NULL_TREE.  */
    5211                 :             : 
    5212                 :             : extern tree uniform_integer_cst_p (tree);
    5213                 :             : 
    5214                 :             : extern int single_nonzero_element (const_tree);
    5215                 :             : 
    5216                 :             : /* Given a CONSTRUCTOR CTOR, return the element values as a vector.  */
    5217                 :             : 
    5218                 :             : extern vec<tree, va_gc> *ctor_to_vec (tree);
    5219                 :             : 
    5220                 :             : /* zerop (tree x) is nonzero if X is a constant of value 0.  */
    5221                 :             : 
    5222                 :             : extern bool zerop (const_tree);
    5223                 :             : 
    5224                 :             : /* integer_zerop (tree x) is nonzero if X is an integer constant of value 0.  */
    5225                 :             : 
    5226                 :             : extern bool integer_zerop (const_tree);
    5227                 :             : 
    5228                 :             : /* integer_onep (tree x) is nonzero if X is an integer constant of value 1.  */
    5229                 :             : 
    5230                 :             : extern bool integer_onep (const_tree);
    5231                 :             : 
    5232                 :             : /* integer_onep (tree x) is nonzero if X is an integer constant of value 1, or
    5233                 :             :    a vector or complex where each part is 1.  */
    5234                 :             : 
    5235                 :             : extern bool integer_each_onep (const_tree);
    5236                 :             : 
    5237                 :             : /* integer_all_onesp (tree x) is nonzero if X is an integer constant
    5238                 :             :    all of whose significant bits are 1.  */
    5239                 :             : 
    5240                 :             : extern bool integer_all_onesp (const_tree);
    5241                 :             : 
    5242                 :             : /* integer_minus_onep (tree x) is nonzero if X is an integer constant of
    5243                 :             :    value -1.  */
    5244                 :             : 
    5245                 :             : extern bool integer_minus_onep (const_tree);
    5246                 :             : 
    5247                 :             : /* integer_pow2p (tree x) is nonzero is X is an integer constant with
    5248                 :             :    exactly one bit 1.  */
    5249                 :             : 
    5250                 :             : extern bool integer_pow2p (const_tree);
    5251                 :             : 
    5252                 :             : /* Checks to see if T is a constant or a constant vector and if each element E
    5253                 :             :    adheres to ~E + 1 == pow2 then return ~E otherwise NULL_TREE.  */
    5254                 :             : 
    5255                 :             : extern tree bitmask_inv_cst_vector_p (tree);
    5256                 :             : 
    5257                 :             : /* integer_nonzerop (tree x) is nonzero if X is an integer constant
    5258                 :             :    with a nonzero value.  */
    5259                 :             : 
    5260                 :             : extern bool integer_nonzerop (const_tree);
    5261                 :             : 
    5262                 :             : /* integer_truep (tree x) is nonzero if X is an integer constant of value 1 or
    5263                 :             :    a vector where each element is an integer constant of value -1.  */
    5264                 :             : 
    5265                 :             : extern bool integer_truep (const_tree);
    5266                 :             : 
    5267                 :             : extern bool cst_and_fits_in_hwi (const_tree);
    5268                 :             : extern tree num_ending_zeros (const_tree);
    5269                 :             : 
    5270                 :             : /* fixed_zerop (tree x) is nonzero if X is a fixed-point constant of
    5271                 :             :    value 0.  */
    5272                 :             : 
    5273                 :             : extern bool fixed_zerop (const_tree);
    5274                 :             : 
    5275                 :             : /* staticp (tree x) is nonzero if X is a reference to data allocated
    5276                 :             :    at a fixed address in memory.  Returns the outermost data.  */
    5277                 :             : 
    5278                 :             : extern tree staticp (tree);
    5279                 :             : 
    5280                 :             : /* save_expr (EXP) returns an expression equivalent to EXP
    5281                 :             :    but it can be used multiple times within context CTX
    5282                 :             :    and only evaluate EXP once.  */
    5283                 :             : 
    5284                 :             : extern tree save_expr (tree);
    5285                 :             : 
    5286                 :             : /* Return true if T is function-invariant.  */
    5287                 :             : 
    5288                 :             : extern bool tree_invariant_p (tree);
    5289                 :             : 
    5290                 :             : /* Look inside EXPR into any simple arithmetic operations.  Return the
    5291                 :             :    outermost non-arithmetic or non-invariant node.  */
    5292                 :             : 
    5293                 :             : extern tree skip_simple_arithmetic (tree);
    5294                 :             : 
    5295                 :             : /* Look inside EXPR into simple arithmetic operations involving constants.
    5296                 :             :    Return the outermost non-arithmetic or non-constant node.  */
    5297                 :             : 
    5298                 :             : extern tree skip_simple_constant_arithmetic (tree);
    5299                 :             : 
    5300                 :             : /* Return which tree structure is used by T.  */
    5301                 :             : 
    5302                 :             : enum tree_node_structure_enum tree_node_structure (const_tree);
    5303                 :             : 
    5304                 :             : /* Return true if EXP contains a PLACEHOLDER_EXPR, i.e. if it represents a
    5305                 :             :    size or offset that depends on a field within a record.  */
    5306                 :             : 
    5307                 :             : extern bool contains_placeholder_p (const_tree);
    5308                 :             : 
    5309                 :             : /* This macro calls the above function but short-circuits the common
    5310                 :             :    case of a constant to save time.  Also check for null.  */
    5311                 :             : 
    5312                 :             : #define CONTAINS_PLACEHOLDER_P(EXP) \
    5313                 :             :   ((EXP) != 0 && ! TREE_CONSTANT (EXP) && contains_placeholder_p (EXP))
    5314                 :             : 
    5315                 :             : /* Return true if any part of the structure of TYPE involves a PLACEHOLDER_EXPR
    5316                 :             :    directly.  This includes size, bounds, qualifiers (for QUAL_UNION_TYPE) and
    5317                 :             :    field positions.  */
    5318                 :             : 
    5319                 :             : extern bool type_contains_placeholder_p (tree);
    5320                 :             : 
    5321                 :             : /* Given a tree EXP, find all occurrences of references to fields
    5322                 :             :    in a PLACEHOLDER_EXPR and place them in vector REFS without
    5323                 :             :    duplicates.  Also record VAR_DECLs and CONST_DECLs.  Note that
    5324                 :             :    we assume here that EXP contains only arithmetic expressions
    5325                 :             :    or CALL_EXPRs with PLACEHOLDER_EXPRs occurring only in their
    5326                 :             :    argument list.  */
    5327                 :             : 
    5328                 :             : extern void find_placeholder_in_expr (tree, vec<tree> *);
    5329                 :             : 
    5330                 :             : /* This macro calls the above function but short-circuits the common
    5331                 :             :    case of a constant to save time and also checks for NULL.  */
    5332                 :             : 
    5333                 :             : #define FIND_PLACEHOLDER_IN_EXPR(EXP, V) \
    5334                 :             : do {                                     \
    5335                 :             :   if((EXP) && !TREE_CONSTANT (EXP))      \
    5336                 :             :     find_placeholder_in_expr (EXP, V);   \
    5337                 :             : } while (0)
    5338                 :             : 
    5339                 :             : /* Given a tree EXP, a FIELD_DECL F, and a replacement value R,
    5340                 :             :    return a tree with all occurrences of references to F in a
    5341                 :             :    PLACEHOLDER_EXPR replaced by R.  Also handle VAR_DECLs and
    5342                 :             :    CONST_DECLs.  Note that we assume here that EXP contains only
    5343                 :             :    arithmetic expressions or CALL_EXPRs with PLACEHOLDER_EXPRs
    5344                 :             :    occurring only in their argument list.  */
    5345                 :             : 
    5346                 :             : extern tree substitute_in_expr (tree, tree, tree);
    5347                 :             : 
    5348                 :             : /* This macro calls the above function but short-circuits the common
    5349                 :             :    case of a constant to save time and also checks for NULL.  */
    5350                 :             : 
    5351                 :             : #define SUBSTITUTE_IN_EXPR(EXP, F, R) \
    5352                 :             :   ((EXP) == 0 || TREE_CONSTANT (EXP) ? (EXP) : substitute_in_expr (EXP, F, R))
    5353                 :             : 
    5354                 :             : /* Similar, but look for a PLACEHOLDER_EXPR in EXP and find a replacement
    5355                 :             :    for it within OBJ, a tree that is an object or a chain of references.  */
    5356                 :             : 
    5357                 :             : extern tree substitute_placeholder_in_expr (tree, tree);
    5358                 :             : 
    5359                 :             : /* This macro calls the above function but short-circuits the common
    5360                 :             :    case of a constant to save time and also checks for NULL.  */
    5361                 :             : 
    5362                 :             : #define SUBSTITUTE_PLACEHOLDER_IN_EXPR(EXP, OBJ) \
    5363                 :             :   ((EXP) == 0 || TREE_CONSTANT (EXP) ? (EXP)    \
    5364                 :             :    : substitute_placeholder_in_expr (EXP, OBJ))
    5365                 :             : 
    5366                 :             : 
    5367                 :             : /* stabilize_reference (EXP) returns a reference equivalent to EXP
    5368                 :             :    but it can be used multiple times
    5369                 :             :    and only evaluate the subexpressions once.  */
    5370                 :             : 
    5371                 :             : extern tree stabilize_reference (tree);
    5372                 :             : 
    5373                 :             : /* Return EXP, stripped of any conversions to wider types
    5374                 :             :    in such a way that the result of converting to type FOR_TYPE
    5375                 :             :    is the same as if EXP were converted to FOR_TYPE.
    5376                 :             :    If FOR_TYPE is 0, it signifies EXP's type.  */
    5377                 :             : 
    5378                 :             : extern tree get_unwidened (tree, tree);
    5379                 :             : 
    5380                 :             : /* Return OP or a simpler expression for a narrower value
    5381                 :             :    which can be sign-extended or zero-extended to give back OP.
    5382                 :             :    Store in *UNSIGNEDP_PTR either 1 if the value should be zero-extended
    5383                 :             :    or 0 if the value should be sign-extended.  */
    5384                 :             : 
    5385                 :             : extern tree get_narrower (tree, int *);
    5386                 :             : 
    5387                 :             : /* Return true if T is an expression that get_inner_reference handles.  */
    5388                 :             : 
    5389                 :             : inline bool
    5390                 : 33230955041 : handled_component_p (const_tree t)
    5391                 :             : {
    5392                 : 32773246719 :   switch (TREE_CODE (t))
    5393                 :             :     {
    5394                 :             :     case COMPONENT_REF:
    5395                 :             :     case BIT_FIELD_REF:
    5396                 :             :     case ARRAY_REF:
    5397                 :             :     case ARRAY_RANGE_REF:
    5398                 :             :     case REALPART_EXPR:
    5399                 :             :     case IMAGPART_EXPR:
    5400                 :             :     case VIEW_CONVERT_EXPR:
    5401                 :             :       return true;
    5402                 :             : 
    5403                 : 16453530162 :     default:
    5404                 : 16453526986 :       return false;
    5405                 :             :     }
    5406                 :             : }
    5407                 :             : 
    5408                 :             : /* Return true T is a component with reverse storage order.  */
    5409                 :             : 
    5410                 :             : inline bool
    5411                 :  3015278208 : reverse_storage_order_for_component_p (tree t)
    5412                 :             : {
    5413                 :             :   /* The storage order only applies to scalar components.  */
    5414                 :  5894192951 :   if (AGGREGATE_TYPE_P (TREE_TYPE (t))
    5415                 :  2314190291 :       || POINTER_TYPE_P (TREE_TYPE (t))
    5416                 :  4567597892 :       || VECTOR_TYPE_P (TREE_TYPE (t)))
    5417                 :             :     return false;
    5418                 :             : 
    5419                 :  1456409158 :   if (TREE_CODE (t) == REALPART_EXPR || TREE_CODE (t) == IMAGPART_EXPR)
    5420                 :    11086799 :     t = TREE_OPERAND (t, 0);
    5421                 :             : 
    5422                 :  1456409158 :   switch (TREE_CODE (t))
    5423                 :             :     {
    5424                 :  1098931281 :     case ARRAY_REF:
    5425                 :  1098931281 :     case COMPONENT_REF:
    5426                 :             :       /* ??? Fortran can take COMPONENT_REF of a VOID_TYPE.  */
    5427                 :             :       /* ??? UBSan can take COMPONENT_REF of a REFERENCE_TYPE.  */
    5428                 :  1999905999 :       return AGGREGATE_TYPE_P (TREE_TYPE (TREE_OPERAND (t, 0)))
    5429                 :  1999896819 :              && TYPE_REVERSE_STORAGE_ORDER (TREE_TYPE (TREE_OPERAND (t, 0)));
    5430                 :             : 
    5431                 :   190463816 :     case BIT_FIELD_REF:
    5432                 :   190463816 :     case MEM_REF:
    5433                 :   190463816 :       return REF_REVERSE_STORAGE_ORDER (t);
    5434                 :             : 
    5435                 :             :     case ARRAY_RANGE_REF:
    5436                 :             :     case VIEW_CONVERT_EXPR:
    5437                 :             :     default:
    5438                 :             :       return false;
    5439                 :             :     }
    5440                 :             : }
    5441                 :             : 
    5442                 :             : /* Return true if T is a storage order barrier, i.e. a VIEW_CONVERT_EXPR
    5443                 :             :    that can modify the storage order of objects.  Note that, even if the
    5444                 :             :    TYPE_REVERSE_STORAGE_ORDER flag is set on both the inner type and the
    5445                 :             :    outer type, a VIEW_CONVERT_EXPR can modify the storage order because
    5446                 :             :    it can change the partition of the aggregate object into scalars.  */
    5447                 :             : 
    5448                 :             : inline bool
    5449                 :    69084568 : storage_order_barrier_p (const_tree t)
    5450                 :             : {
    5451                 :    69084568 :   if (TREE_CODE (t) != VIEW_CONVERT_EXPR)
    5452                 :             :     return false;
    5453                 :             : 
    5454                 :     3548124 :   if (AGGREGATE_TYPE_P (TREE_TYPE (t))
    5455                 :     3493284 :       && TYPE_REVERSE_STORAGE_ORDER (TREE_TYPE (t)))
    5456                 :             :     return true;
    5457                 :             : 
    5458                 :     1935897 :   tree op = TREE_OPERAND (t, 0);
    5459                 :             : 
    5460                 :     3851506 :   if (AGGREGATE_TYPE_P (TREE_TYPE (op))
    5461                 :     3493017 :       && TYPE_REVERSE_STORAGE_ORDER (TREE_TYPE (op)))
    5462                 :           0 :     return true;
    5463                 :             : 
    5464                 :             :   return false;
    5465                 :             : }
    5466                 :             : 
    5467                 :             : /* Given a DECL or TYPE, return the scope in which it was declared, or
    5468                 :             :    NUL_TREE if there is no containing scope.  */
    5469                 :             : 
    5470                 :             : extern tree get_containing_scope (const_tree);
    5471                 :             : 
    5472                 :             : /* Returns the ultimate TRANSLATION_UNIT_DECL context of DECL or NULL.  */
    5473                 :             : 
    5474                 :             : extern const_tree get_ultimate_context (const_tree);
    5475                 :             : 
    5476                 :             : /* Return the FUNCTION_DECL which provides this _DECL with its context,
    5477                 :             :    or zero if none.  */
    5478                 :             : extern tree decl_function_context (const_tree);
    5479                 :             : 
    5480                 :             : /* Return the RECORD_TYPE, UNION_TYPE, or QUAL_UNION_TYPE which provides
    5481                 :             :    this _DECL with its context, or zero if none.  */
    5482                 :             : extern tree decl_type_context (const_tree);
    5483                 :             : 
    5484                 :             : /* Return true if EXPR is the real constant zero.  */
    5485                 :             : extern bool real_zerop (const_tree);
    5486                 :             : 
    5487                 :             : /* Initialize the iterator I with arguments from function FNDECL  */
    5488                 :             : 
    5489                 :             : inline void
    5490                 :  1208964131 : function_args_iter_init (function_args_iterator *i, const_tree fntype)
    5491                 :             : {
    5492                 :  1208964131 :   i->next = TYPE_ARG_TYPES (fntype);
    5493                 :  1208964131 : }
    5494                 :             : 
    5495                 :             : /* Return a pointer that holds the next argument if there are more arguments to
    5496                 :             :    handle, otherwise return NULL.  */
    5497                 :             : 
    5498                 :             : inline tree *
    5499                 :             : function_args_iter_cond_ptr (function_args_iterator *i)
    5500                 :             : {
    5501                 :             :   return (i->next) ? &TREE_VALUE (i->next) : NULL;
    5502                 :             : }
    5503                 :             : 
    5504                 :             : /* Return the next argument if there are more arguments to handle, otherwise
    5505                 :             :    return NULL.  */
    5506                 :             : 
    5507                 :             : inline tree
    5508                 :  1907896720 : function_args_iter_cond (function_args_iterator *i)
    5509                 :             : {
    5510                 :  1907896720 :   return (i->next) ? TREE_VALUE (i->next) : NULL_TREE;
    5511                 :             : }
    5512                 :             : 
    5513                 :             : /* Advance to the next argument.  */
    5514                 :             : inline void
    5515                 :   702337179 : function_args_iter_next (function_args_iterator *i)
    5516                 :             : {
    5517                 :   702337179 :   gcc_assert (i->next != NULL_TREE);
    5518                 :   702337179 :   i->next = TREE_CHAIN (i->next);
    5519                 :   702337179 : }
    5520                 :             : 
    5521                 :             : /* Returns true if a BLOCK has a source location.
    5522                 :             :    BLOCK_SOURCE_LOCATION is set only to inlined function entry points,
    5523                 :             :    so the function returns true for all but the innermost and outermost
    5524                 :             :    blocks into which an expression has been inlined.  */
    5525                 :             : 
    5526                 :             : inline bool
    5527                 :    40833609 : inlined_function_outer_scope_p (const_tree block)
    5528                 :             : {
    5529                 :    40833609 :  return LOCATION_LOCUS (BLOCK_SOURCE_LOCATION (block)) != UNKNOWN_LOCATION;
    5530                 :             : }
    5531                 :             : 
    5532                 :             : /* Loop over all function arguments of FNTYPE.  In each iteration, PTR is set
    5533                 :             :    to point to the next tree element.  ITER is an instance of
    5534                 :             :    function_args_iterator used to iterate the arguments.  */
    5535                 :             : #define FOREACH_FUNCTION_ARGS_PTR(FNTYPE, PTR, ITER)                    \
    5536                 :             :   for (function_args_iter_init (&(ITER), (FNTYPE));                 \
    5537                 :             :        (PTR = function_args_iter_cond_ptr (&(ITER))) != NULL;               \
    5538                 :             :        function_args_iter_next (&(ITER)))
    5539                 :             : 
    5540                 :             : /* Loop over all function arguments of FNTYPE.  In each iteration, TREE is set
    5541                 :             :    to the next tree element.  ITER is an instance of function_args_iterator
    5542                 :             :    used to iterate the arguments.  */
    5543                 :             : #define FOREACH_FUNCTION_ARGS(FNTYPE, TREE, ITER)                       \
    5544                 :             :   for (function_args_iter_init (&(ITER), (FNTYPE));                 \
    5545                 :             :        (TREE = function_args_iter_cond (&(ITER))) != NULL_TREE;             \
    5546                 :             :        function_args_iter_next (&(ITER)))
    5547                 :             : 
    5548                 :             : /* In tree.cc */
    5549                 :             : extern unsigned crc32_unsigned_n (unsigned, unsigned, unsigned);
    5550                 :             : extern unsigned crc32_string (unsigned, const char *);
    5551                 :             : inline unsigned
    5552                 :      748961 : crc32_unsigned (unsigned chksum, unsigned value)
    5553                 :             : {
    5554                 :      745651 :   return crc32_unsigned_n (chksum, value, 4);
    5555                 :             : }
    5556                 :             : inline unsigned
    5557                 :    14499378 : crc32_byte (unsigned chksum, char byte)
    5558                 :             : {
    5559                 :    14499378 :   return crc32_unsigned_n (chksum, byte, 1);
    5560                 :             : }
    5561                 :             : extern void clean_symbol_name (char *);
    5562                 :             : extern tree get_file_function_name (const char *);
    5563                 :             : extern tree get_callee_fndecl (const_tree);
    5564                 :             : extern combined_fn get_call_combined_fn (const_tree);
    5565                 :             : extern int type_num_arguments (const_tree);
    5566                 :             : extern tree type_argument_type (const_tree, unsigned) ATTRIBUTE_NONNULL (1);
    5567                 :             : extern bool associative_tree_code (enum tree_code);
    5568                 :             : extern bool commutative_tree_code (enum tree_code);
    5569                 :             : extern bool commutative_ternary_tree_code (enum tree_code);
    5570                 :             : extern bool operation_can_overflow (enum tree_code);
    5571                 :             : extern bool operation_no_trapping_overflow (tree, enum tree_code);
    5572                 :             : extern tree upper_bound_in_type (tree, tree);
    5573                 :             : extern tree lower_bound_in_type (tree, tree);
    5574                 :             : extern bool operand_equal_for_phi_arg_p (const_tree, const_tree);
    5575                 :             : extern tree create_artificial_label (location_t);
    5576                 :             : extern const char *get_name (tree);
    5577                 :             : extern bool stdarg_p (const_tree);
    5578                 :             : extern bool prototype_p (const_tree);
    5579                 :             : extern bool auto_var_p (const_tree);
    5580                 :             : extern bool auto_var_in_fn_p (const_tree, const_tree);
    5581                 :             : extern tree build_low_bits_mask (tree, unsigned);
    5582                 :             : extern bool tree_nop_conversion_p (const_tree, const_tree);
    5583                 :             : extern tree tree_strip_nop_conversions (tree);
    5584                 :             : extern tree tree_strip_sign_nop_conversions (tree);
    5585                 :             : extern const_tree strip_invariant_refs (const_tree);
    5586                 :             : extern tree strip_zero_offset_components (tree);
    5587                 :             : extern tree lhd_gcc_personality (void);
    5588                 :             : extern void assign_assembler_name_if_needed (tree);
    5589                 :             : extern bool warn_deprecated_use (tree, tree);
    5590                 :             : extern void error_unavailable_use (tree, tree);
    5591                 :             : extern tree cache_integer_cst (tree, bool might_duplicate = false);
    5592                 :             : extern const char *combined_fn_name (combined_fn);
    5593                 :             : 
    5594                 :             : /* Returns true if X is a typedef decl.  */
    5595                 :             : 
    5596                 :             : inline bool
    5597                 : 21861021366 : is_typedef_decl (const_tree x)
    5598                 :             : {
    5599                 : 18904419470 :   return (x && TREE_CODE (x) == TYPE_DECL
    5600                 : 20317938607 :           && DECL_ORIGINAL_TYPE (x) != NULL_TREE);
    5601                 :             : }
    5602                 :             : 
    5603                 :             : /* Returns true iff TYPE is a type variant created for a typedef. */
    5604                 :             : 
    5605                 :             : inline bool
    5606                 : 16210246041 : typedef_variant_p (const_tree type)
    5607                 :             : {
    5608                 : 16210246041 :   return is_typedef_decl (TYPE_NAME (type));
    5609                 :             : }
    5610                 :             : 
    5611                 :             : /* Compare and hash for any structure which begins with a canonical
    5612                 :             :    pointer.  Assumes all pointers are interchangeable, which is sort
    5613                 :             :    of already assumed by gcc elsewhere IIRC.  */
    5614                 :             : 
    5615                 :             : inline int
    5616                 :             : struct_ptr_eq (const void *a, const void *b)
    5617                 :             : {
    5618                 :             :   const void * const * x = (const void * const *) a;
    5619                 :             :   const void * const * y = (const void * const *) b;
    5620                 :             :   return *x == *y;
    5621                 :             : }
    5622                 :             : 
    5623                 :             : inline hashval_t
    5624                 :             : struct_ptr_hash (const void *a)
    5625                 :             : {
    5626                 :             :   const void * const * x = (const void * const *) a;
    5627                 :             :   return (intptr_t)*x >> 4;
    5628                 :             : }
    5629                 :             : 
    5630                 :             : /* Return true if CODE can be treated as a truncating division.
    5631                 :             : 
    5632                 :             :    EXACT_DIV_EXPR can be treated as a truncating division in which the
    5633                 :             :    remainder is known to be zero.  However, if trunc_div_p gates the
    5634                 :             :    generation of new IL, the conservative choice for that new IL is
    5635                 :             :    TRUNC_DIV_EXPR rather than CODE.  Using CODE (EXACT_DIV_EXPR) would
    5636                 :             :    only be correct if the transformation preserves exactness.  */
    5637                 :             : inline bool
    5638                 :      647487 : trunc_or_exact_div_p (tree_code code)
    5639                 :             : {
    5640                 :      647487 :   return code == TRUNC_DIV_EXPR || code == EXACT_DIV_EXPR;
    5641                 :             : }
    5642                 :             : 
    5643                 :             : /* Return nonzero if CODE is a tree code that represents a truth value.  */
    5644                 :             : inline bool
    5645                 :   173368851 : truth_value_p (enum tree_code code)
    5646                 :             : {
    5647                 :   173368851 :   return (TREE_CODE_CLASS (code) == tcc_comparison
    5648                 :   161584028 :           || code == TRUTH_AND_EXPR || code == TRUTH_ANDIF_EXPR
    5649                 :   161436705 :           || code == TRUTH_OR_EXPR || code == TRUTH_ORIF_EXPR
    5650                 :   334693152 :           || code == TRUTH_XOR_EXPR || code == TRUTH_NOT_EXPR);
    5651                 :             : }
    5652                 :             : 
    5653                 :             : /* Return whether TYPE is a type suitable for an offset for
    5654                 :             :    a POINTER_PLUS_EXPR.  */
    5655                 :             : inline bool
    5656                 :   187705680 : ptrofftype_p (tree type)
    5657                 :             : {
    5658                 :   187705680 :   return (INTEGRAL_TYPE_P (type)
    5659                 :   186119027 :           && TYPE_PRECISION (type) == TYPE_PRECISION (sizetype)
    5660                 :   373796001 :           && TYPE_UNSIGNED (type) == TYPE_UNSIGNED (sizetype));
    5661                 :             : }
    5662                 :             : 
    5663                 :             : /* Return true if the argument is a complete type or an array
    5664                 :             :    of unknown bound (whose type is incomplete but) whose elements
    5665                 :             :    have complete type.  */
    5666                 :             : inline bool
    5667                 :     8101082 : complete_or_array_type_p (const_tree type)
    5668                 :             : {
    5669                 :     8101082 :   return COMPLETE_TYPE_P (type)
    5670                 :     8101082 :          || (TREE_CODE (type) == ARRAY_TYPE
    5671                 :      129547 :              && COMPLETE_TYPE_P (TREE_TYPE (type)));
    5672                 :             : }
    5673                 :             : 
    5674                 :             : /* Return true if the value of T could be represented as a poly_widest_int.  */
    5675                 :             : 
    5676                 :             : inline bool
    5677                 : 17239807887 : poly_int_tree_p (const_tree t)
    5678                 :             : {
    5679                 : 12557397670 :   return (TREE_CODE (t) == INTEGER_CST || POLY_INT_CST_P (t));
    5680                 :             : }
    5681                 :             : 
    5682                 :             : /* Return the bit size of BIT_FIELD_REF T, in cases where it is known
    5683                 :             :    to be a poly_uint64.  (This is always true at the gimple level.)  */
    5684                 :             : 
    5685                 :             : inline poly_uint64
    5686                 :      167472 : bit_field_size (const_tree t)
    5687                 :             : {
    5688                 :      167472 :   return tree_to_poly_uint64 (TREE_OPERAND (t, 1));
    5689                 :             : }
    5690                 :             : 
    5691                 :             : /* Return the starting bit offset of BIT_FIELD_REF T, in cases where it is
    5692                 :             :    known to be a poly_uint64.  (This is always true at the gimple level.)  */
    5693                 :             : 
    5694                 :             : inline poly_uint64
    5695                 :      765322 : bit_field_offset (const_tree t)
    5696                 :             : {
    5697                 :      765322 :   return tree_to_poly_uint64 (TREE_OPERAND (t, 2));
    5698                 :             : }
    5699                 :             : 
    5700                 :             : extern tree strip_float_extensions (tree);
    5701                 :             : extern bool really_constant_p (const_tree);
    5702                 :             : extern bool ptrdiff_tree_p (const_tree, poly_int64 *);
    5703                 :             : extern bool decl_address_invariant_p (const_tree);
    5704                 :             : extern bool decl_address_ip_invariant_p (const_tree);
    5705                 :             : extern bool int_fits_type_p (const_tree, const_tree)
    5706                 :             :   ATTRIBUTE_NONNULL (1) ATTRIBUTE_NONNULL (2) ATTRIBUTE_PURE;
    5707                 :             : #ifndef GENERATOR_FILE
    5708                 :             : extern void get_type_static_bounds (const_tree, mpz_t, mpz_t);
    5709                 :             : #endif
    5710                 :             : extern bool variably_modified_type_p (tree, tree);
    5711                 :             : extern int tree_log2 (const_tree);
    5712                 :             : extern int tree_floor_log2 (const_tree);
    5713                 :             : extern unsigned int tree_ctz (const_tree);
    5714                 :             : extern int simple_cst_equal (const_tree, const_tree);
    5715                 :             : 
    5716                 :             : namespace inchash
    5717                 :             : {
    5718                 :             : 
    5719                 :             : extern void add_expr (const_tree, hash &, unsigned int = 0);
    5720                 :             : 
    5721                 :             : }
    5722                 :             : 
    5723                 :             : /* Compat version until all callers are converted. Return hash for
    5724                 :             :    TREE with SEED.  */
    5725                 :   563205844 : inline hashval_t iterative_hash_expr(const_tree tree, hashval_t seed)
    5726                 :             : {
    5727                 :   557709612 :   inchash::hash hstate (seed);
    5728                 :   557709612 :   inchash::add_expr (tree, hstate);
    5729                 :   557511741 :   return hstate.end ();
    5730                 :             : }
    5731                 :             : 
    5732                 :             : extern int compare_tree_int (const_tree, unsigned HOST_WIDE_INT);
    5733                 :             : extern bool type_list_equal (const_tree, const_tree);
    5734                 :             : extern bool chain_member (const_tree, const_tree);
    5735                 :             : extern void dump_tree_statistics (void);
    5736                 :             : extern void recompute_tree_invariant_for_addr_expr (tree);
    5737                 :             : extern bool needs_to_live_in_memory (const_tree);
    5738                 :             : extern tree reconstruct_complex_type (tree, tree);
    5739                 :             : extern bool real_onep (const_tree);
    5740                 :             : extern bool real_minus_onep (const_tree);
    5741                 :             : extern bool real_maybe_zerop (const_tree);
    5742                 :             : extern void init_ttree (void);
    5743                 :             : extern void build_common_tree_nodes (bool);
    5744                 :             : extern void build_common_builtin_nodes (void);
    5745                 :             : extern void tree_cc_finalize (void);
    5746                 :             : extern tree build_nonstandard_integer_type (unsigned HOST_WIDE_INT, int);
    5747                 :             : extern tree build_nonstandard_boolean_type (unsigned HOST_WIDE_INT);
    5748                 :             : extern tree build_bitint_type (unsigned HOST_WIDE_INT, int);
    5749                 :             : extern tree build_range_type (tree, tree, tree);
    5750                 :             : extern tree build_nonshared_range_type (tree, tree, tree);
    5751                 :             : extern bool subrange_type_for_debug_p (const_tree, tree *, tree *);
    5752                 :             : extern HOST_WIDE_INT int_cst_value (const_tree);
    5753                 :             : extern tree tree_block (tree);
    5754                 :             : extern void tree_set_block (tree, tree);
    5755                 :             : extern location_t *block_nonartificial_location (tree);
    5756                 :             : extern location_t tree_nonartificial_location (tree);
    5757                 :             : extern location_t tree_inlined_location (tree, bool = true);
    5758                 :             : extern tree block_ultimate_origin (const_tree);
    5759                 :             : extern tree get_binfo_at_offset (tree, poly_int64, tree);
    5760                 :             : extern bool virtual_method_call_p (const_tree, bool = false);
    5761                 :             : extern tree obj_type_ref_class (const_tree ref, bool = false);
    5762                 :             : extern bool types_same_for_odr (const_tree type1, const_tree type2);
    5763                 :             : extern bool contains_bitfld_component_ref_p (const_tree);
    5764                 :             : extern bool block_may_fallthru (const_tree);
    5765                 :             : extern void using_eh_for_cleanups (void);
    5766                 :             : extern bool using_eh_for_cleanups_p (void);
    5767                 :             : extern const char *get_tree_code_name (enum tree_code);
    5768                 :             : extern void set_call_expr_flags (tree, int);
    5769                 :             : extern tree walk_tree_1 (tree*, walk_tree_fn, void*, hash_set<tree>*,
    5770                 :             :                          walk_tree_lh);
    5771                 :             : extern tree walk_tree_without_duplicates_1 (tree*, walk_tree_fn, void*,
    5772                 :             :                                             walk_tree_lh);
    5773                 :             : #define walk_tree(a,b,c,d) \
    5774                 :             :         walk_tree_1 (a, b, c, d, NULL)
    5775                 :             : #define walk_tree_without_duplicates(a,b,c) \
    5776                 :             :         walk_tree_without_duplicates_1 (a, b, c, NULL)
    5777                 :             : 
    5778                 :             : extern tree drop_tree_overflow (tree);
    5779                 :             : 
    5780                 :             : /* Given a memory reference expression T, return its base address.
    5781                 :             :    The base address of a memory reference expression is the main
    5782                 :             :    object being referenced.  */
    5783                 :             : extern tree get_base_address (tree t);
    5784                 :             : 
    5785                 :             : /* Return a tree of sizetype representing the size, in bytes, of the element
    5786                 :             :    of EXP, an ARRAY_REF or an ARRAY_RANGE_REF.  */
    5787                 :             : extern tree array_ref_element_size (tree);
    5788                 :             : 
    5789                 :             : /* Return a typenode for the "standard" C type with a given name.  */
    5790                 :             : extern tree get_typenode_from_name (const char *);
    5791                 :             : 
    5792                 :             : /* Return a tree representing the upper bound of the array mentioned in
    5793                 :             :    EXP, an ARRAY_REF or an ARRAY_RANGE_REF.  */
    5794                 :             : extern tree array_ref_up_bound (tree);
    5795                 :             : 
    5796                 :             : /* Return a tree representing the lower bound of the array mentioned in
    5797                 :             :    EXP, an ARRAY_REF or an ARRAY_RANGE_REF.  */
    5798                 :             : extern tree array_ref_low_bound (tree);
    5799                 :             : 
    5800                 :             : /* Returns true if REF is an array reference, a component reference,
    5801                 :             :    or a memory reference to an array whose actual size might be larger
    5802                 :             :    than its upper bound implies.  */
    5803                 :             : extern bool array_ref_flexible_size_p (tree, bool * = NULL);
    5804                 :             : 
    5805                 :             : /* Return a tree representing the offset, in bytes, of the field referenced
    5806                 :             :    by EXP.  This does not include any offset in DECL_FIELD_BIT_OFFSET.  */
    5807                 :             : extern tree component_ref_field_offset (tree);
    5808                 :             : 
    5809                 :             : /* Describes a "special" array member for a COMPONENT_REF.  */
    5810                 :             : enum struct special_array_member
    5811                 :             :   {
    5812                 :             :     none,       /* Not a special array member.  */
    5813                 :             :     int_0,      /* Interior array member with zero elements.  */
    5814                 :             :     trail_0,    /* Trailing array member with zero elements.  */
    5815                 :             :     trail_1,    /* Trailing array member with one element.  */
    5816                 :             :     trail_n,    /* Trailing array member with two or more elements.  */
    5817                 :             :     int_n       /* Interior array member with one or more elements.  */
    5818                 :             :   };
    5819                 :             : 
    5820                 :             : /* Determines the special array member type for a COMPONENT_REF.  */
    5821                 :             : extern special_array_member component_ref_sam_type (tree);
    5822                 :             : 
    5823                 :             : /* Return the size of the member referenced by the COMPONENT_REF, using
    5824                 :             :    its initializer expression if necessary in order to determine the size
    5825                 :             :    of an initialized flexible array member.  The size might be zero for
    5826                 :             :    an object with an uninitialized flexible array member or null if it
    5827                 :             :    cannot be determined.  */
    5828                 :             : extern tree component_ref_size (tree, special_array_member * = NULL);
    5829                 :             : 
    5830                 :             : /* Return true if the given node is a call to a .ACCESS_WITH_SIZE
    5831                 :             :    function.  */
    5832                 :             : extern bool is_access_with_size_p (const_tree);
    5833                 :             : 
    5834                 :             : /* Get the corresponding reference from the call to a .ACCESS_WITH_SIZE,
    5835                 :             :  * i.e. the first argument of this call.  Return NULL_TREE otherwise.  */
    5836                 :             : extern tree get_ref_from_access_with_size (tree);
    5837                 :             : 
    5838                 :             : extern int tree_map_base_eq (const void *, const void *);
    5839                 :             : extern unsigned int tree_map_base_hash (const void *);
    5840                 :             : extern bool tree_map_base_marked_p (const void *);
    5841                 :             : extern void DEBUG_FUNCTION verify_type (const_tree t);
    5842                 :             : extern bool gimple_canonical_types_compatible_p (const_tree, const_tree,
    5843                 :             :                                                  bool trust_type_canonical = true);
    5844                 :             : extern bool type_with_interoperable_signedness (const_tree);
    5845                 :             : extern bitmap get_nonnull_args (const_tree);
    5846                 :             : extern int get_range_pos_neg (tree);
    5847                 :             : 
    5848                 :             : /* Return true for a valid pair of new and delete operators.  */
    5849                 :             : extern bool valid_new_delete_pair_p (tree, tree, bool * = NULL);
    5850                 :             : 
    5851                 :             : /* Return simplified tree code of type that is used for canonical type
    5852                 :             :    merging.  */
    5853                 :             : inline enum tree_code
    5854                 :   487579053 : tree_code_for_canonical_type_merging (enum tree_code code)
    5855                 :             : {
    5856                 :             :   /* By C standard, each enumerated type shall be compatible with char,
    5857                 :             :      a signed integer, or an unsigned integer.  The choice of type is
    5858                 :             :      implementation defined (in our case it depends on -fshort-enum).
    5859                 :             : 
    5860                 :             :      For this reason we make no distinction between ENUMERAL_TYPE and INTEGER
    5861                 :             :      type and compare only by their signedness and precision.  */
    5862                 :   484799816 :   if (code == ENUMERAL_TYPE)
    5863                 :             :     return INTEGER_TYPE;
    5864                 :             :   /* To allow inter-operability between languages having references and
    5865                 :             :      C, we consider reference types and pointers alike.  Note that this is
    5866                 :             :      not strictly necessary for C-Fortran 2008 interoperability because
    5867                 :             :      Fortran define C_PTR type that needs to be compatible with C pointers
    5868                 :             :      and we handle this one as ptr_type_node.  */
    5869                 :   482117259 :   if (code == REFERENCE_TYPE)
    5870                 :    32491736 :     return POINTER_TYPE;
    5871                 :             :   return code;
    5872                 :             : }
    5873                 :             : 
    5874                 :             : /* Return ture if get_alias_set care about TYPE_CANONICAL of given type.
    5875                 :             :    We don't define the types for pointers, arrays and vectors.  The reason is
    5876                 :             :    that pointers are handled specially: ptr_type_node accesses conflict with
    5877                 :             :    accesses to all other pointers.  This is done by alias.cc.
    5878                 :             :    Because alias sets of arrays and vectors are the same as types of their
    5879                 :             :    elements, we can't compute canonical type either.  Otherwise we could go
    5880                 :             :    form void *[10] to int *[10] (because they are equivalent for canonical type
    5881                 :             :    machinery) and get wrong TBAA.  */
    5882                 :             : 
    5883                 :             : inline bool
    5884                 :   278925906 : canonical_type_used_p (const_tree t)
    5885                 :             : {
    5886                 :   283150050 :   return !(POINTER_TYPE_P (t)
    5887                 :     4373683 :            || TREE_CODE (t) == ARRAY_TYPE
    5888                 :             :            || TREE_CODE (t) == VECTOR_TYPE);
    5889                 :             : }
    5890                 :             : 
    5891                 :             : /* Kinds of access to pass-by-reference arguments to functions.  */
    5892                 :             : enum access_mode
    5893                 :             : {
    5894                 :             :   access_none = 0,
    5895                 :             :   access_read_only = 1,
    5896                 :             :   access_write_only = 2,
    5897                 :             :   access_read_write = access_read_only | access_write_only,
    5898                 :             :   access_deferred = 4
    5899                 :             : };
    5900                 :             : 
    5901                 :             : #define tree_map_eq tree_map_base_eq
    5902                 :             : extern unsigned int tree_map_hash (const void *);
    5903                 :             : #define tree_map_marked_p tree_map_base_marked_p
    5904                 :             : 
    5905                 :             : #define tree_decl_map_eq tree_map_base_eq
    5906                 :             : extern unsigned int tree_decl_map_hash (const void *);
    5907                 :             : #define tree_decl_map_marked_p tree_map_base_marked_p
    5908                 :             : 
    5909                 :             : struct tree_decl_map_cache_hasher : ggc_cache_ptr_hash<tree_decl_map>
    5910                 :             : {
    5911                 :  1000866888 :   static hashval_t hash (tree_decl_map *m) { return tree_decl_map_hash (m); }
    5912                 :             :   static bool
    5913                 :  1509148575 :   equal (tree_decl_map *a, tree_decl_map *b)
    5914                 :             :   {
    5915                 :  1509148575 :     return tree_decl_map_eq (a, b);
    5916                 :             :   }
    5917                 :             : 
    5918                 :             :   static int
    5919                 :    10134073 :   keep_cache_entry (tree_decl_map *&m)
    5920                 :             :   {
    5921                 :    10134073 :     return ggc_marked_p (m->base.from);
    5922                 :             :   }
    5923                 :             : };
    5924                 :             : 
    5925                 :             : #define tree_int_map_eq tree_map_base_eq
    5926                 :             : #define tree_int_map_hash tree_map_base_hash
    5927                 :             : #define tree_int_map_marked_p tree_map_base_marked_p
    5928                 :             : 
    5929                 :             : #define tree_vec_map_eq tree_map_base_eq
    5930                 :             : #define tree_vec_map_hash tree_decl_map_hash
    5931                 :             : #define tree_vec_map_marked_p tree_map_base_marked_p
    5932                 :             : 
    5933                 :             : struct tree_vec_map_cache_hasher : ggc_cache_ptr_hash<tree_vec_map>
    5934                 :             : {
    5935                 :     5101542 :   static hashval_t hash (tree_vec_map *m) { return DECL_UID (m->base.from); }
    5936                 :             : 
    5937                 :             :   static bool
    5938                 :     6055520 :   equal (tree_vec_map *a, tree_vec_map *b)
    5939                 :             :   {
    5940                 :     6055520 :     return a->base.from == b->base.from;
    5941                 :             :   }
    5942                 :             : 
    5943                 :             :   static int
    5944                 :      990458 :   keep_cache_entry (tree_vec_map *&m)
    5945                 :             :   {
    5946                 :      990458 :     return ggc_marked_p (m->base.from);
    5947                 :             :   }
    5948                 :             : };
    5949                 :             : 
    5950                 :             : /* Hasher for tree decls.  Pointer equality is enough here, but the DECL_UID
    5951                 :             :    is a better hash than the pointer value and gives a predictable traversal
    5952                 :             :    order.  Additionally it can be used across PCH save/restore.  */
    5953                 :             : struct tree_decl_hash : ggc_ptr_hash <tree_node>
    5954                 :             : {
    5955                 :             :   static inline hashval_t hash (tree);
    5956                 :             : };
    5957                 :             : 
    5958                 :             : inline hashval_t
    5959                 :  1793060678 : tree_decl_hash::hash (tree t)
    5960                 :             : {
    5961                 :  1793060678 :   return DECL_UID (t);
    5962                 :             : }
    5963                 :             : 
    5964                 :             : /* Similarly for types.  Uses TYPE_UID as hash function.  */
    5965                 :             : struct tree_type_hash : ggc_ptr_hash <tree_node>
    5966                 :             : {
    5967                 :             :   static inline hashval_t hash (tree);
    5968                 :             : };
    5969                 :             : 
    5970                 :             : inline hashval_t
    5971                 :      955663 : tree_type_hash::hash (tree t)
    5972                 :             : {
    5973                 :      955663 :   return TYPE_UID (t);
    5974                 :             : }
    5975                 :             : 
    5976                 :             : /* Hash for SSA_NAMEs in the same function.  Pointer equality is enough
    5977                 :             :    here, but the SSA_NAME_VERSION is a better hash than the pointer
    5978                 :             :    value and gives a predictable traversal order.  */
    5979                 :             : struct tree_ssa_name_hash : ggc_ptr_hash <tree_node>
    5980                 :             : {
    5981                 :             :   static inline hashval_t hash (tree);
    5982                 :             : };
    5983                 :             : 
    5984                 :             : inline hashval_t
    5985                 :    88134947 : tree_ssa_name_hash::hash (tree t)
    5986                 :             : {
    5987                 :    88134947 :   return SSA_NAME_VERSION (t);
    5988                 :             : }
    5989                 :             : 
    5990                 :             : /* Hasher for general trees, based on their TREE_HASH.  */
    5991                 :             : struct tree_hash : ggc_ptr_hash <tree_node>
    5992                 :             : {
    5993                 :             :   static hashval_t hash (tree);
    5994                 :             : };
    5995                 :             : 
    5996                 :             : inline hashval_t
    5997                 :       58842 : tree_hash::hash (tree t)
    5998                 :             : {
    5999                 :       58842 :   return TREE_HASH (t);
    6000                 :             : }
    6001                 :             : 
    6002                 :             : /* A hash_map of two trees for use with GTY((cache)).  Garbage collection for
    6003                 :             :    such a map will not mark keys, and will mark values if the key is already
    6004                 :             :    marked.  */
    6005                 :             : struct tree_cache_traits
    6006                 :             :   : simple_cache_map_traits<default_hash_traits<tree>, tree> { };
    6007                 :             : typedef hash_map<tree,tree,tree_cache_traits> tree_cache_map;
    6008                 :             : 
    6009                 :             : /* Similarly, but use DECL_UID as hash function rather than pointer hashing.
    6010                 :             :    This is for hash_maps from decls to trees that need to work across PCH.  */
    6011                 :             : struct decl_tree_cache_traits
    6012                 :             :   : simple_cache_map_traits<tree_decl_hash, tree> { };
    6013                 :             : typedef hash_map<tree,tree,decl_tree_cache_traits> decl_tree_cache_map;
    6014                 :             : 
    6015                 :             : /* Similarly, but use TYPE_UID as hash function rather than pointer hashing.
    6016                 :             :    This is for hash_maps from types to trees that need to work across PCH.  */
    6017                 :             : struct type_tree_cache_traits
    6018                 :             :   : simple_cache_map_traits<tree_type_hash, tree> { };
    6019                 :             : typedef hash_map<tree,tree,type_tree_cache_traits> type_tree_cache_map;
    6020                 :             : 
    6021                 :             : /* Similarly to decl_tree_cache_map, but without caching.  */
    6022                 :             : struct decl_tree_traits
    6023                 :             :   : simple_hashmap_traits<tree_decl_hash, tree> { };
    6024                 :             : typedef hash_map<tree,tree,decl_tree_traits> decl_tree_map;
    6025                 :             : 
    6026                 :             : /* Initialize the abstract argument list iterator object ITER with the
    6027                 :             :    arguments from CALL_EXPR node EXP.  */
    6028                 :             : inline void
    6029                 :   127356322 : init_call_expr_arg_iterator (tree exp, call_expr_arg_iterator *iter)
    6030                 :             : {
    6031                 :   127356322 :   iter->t = exp;
    6032                 :   127356322 :   iter->n = call_expr_nargs (exp);
    6033                 :   127356322 :   iter->i = 0;
    6034                 :   127356322 : }
    6035                 :             : 
    6036                 :             : inline void
    6037                 :     1757099 : init_const_call_expr_arg_iterator (const_tree exp, const_call_expr_arg_iterator *iter)
    6038                 :             : {
    6039                 :     1757099 :   iter->t = exp;
    6040                 :     1757099 :   iter->n = call_expr_nargs (exp);
    6041                 :     1757099 :   iter->i = 0;
    6042                 :     1757099 : }
    6043                 :             : 
    6044                 :             : /* Return the next argument from abstract argument list iterator object ITER,
    6045                 :             :    and advance its state.  Return NULL_TREE if there are no more arguments.  */
    6046                 :             : inline tree
    6047                 :   189552481 : next_call_expr_arg (call_expr_arg_iterator *iter)
    6048                 :             : {
    6049                 :   189552481 :   tree result;
    6050                 :   189552481 :   if (iter->i >= iter->n)
    6051                 :             :     return NULL_TREE;
    6052                 :    87327976 :   result = CALL_EXPR_ARG (iter->t, iter->i);
    6053                 :    87327976 :   iter->i++;
    6054                 :    87327976 :   return result;
    6055                 :             : }
    6056                 :             : 
    6057                 :             : inline const_tree
    6058                 :     3136229 : next_const_call_expr_arg (const_call_expr_arg_iterator *iter)
    6059                 :             : {
    6060                 :     3136229 :   const_tree result;
    6061                 :     3136229 :   if (iter->i >= iter->n)
    6062                 :             :     return NULL_TREE;
    6063                 :     2693310 :   result = CALL_EXPR_ARG (iter->t, iter->i);
    6064                 :     2693310 :   iter->i++;
    6065                 :     2693310 :   return result;
    6066                 :             : }
    6067                 :             : 
    6068                 :             : /* Initialize the abstract argument list iterator object ITER, then advance
    6069                 :             :    past and return the first argument.  Useful in for expressions, e.g.
    6070                 :             :      for (arg = first_call_expr_arg (exp, &iter); arg;
    6071                 :             :           arg = next_call_expr_arg (&iter))   */
    6072                 :             : inline tree
    6073                 :   102224732 : first_call_expr_arg (tree exp, call_expr_arg_iterator *iter)
    6074                 :             : {
    6075                 :   102224732 :   init_call_expr_arg_iterator (exp, iter);
    6076                 :   102224732 :   return next_call_expr_arg (iter);
    6077                 :             : }
    6078                 :             : 
    6079                 :             : inline const_tree
    6080                 :      660220 : first_const_call_expr_arg (const_tree exp, const_call_expr_arg_iterator *iter)
    6081                 :             : {
    6082                 :      660220 :   init_const_call_expr_arg_iterator (exp, iter);
    6083                 :      660220 :   return next_const_call_expr_arg (iter);
    6084                 :             : }
    6085                 :             : 
    6086                 :             : /* Test whether there are more arguments in abstract argument list iterator
    6087                 :             :    ITER, without changing its state.  */
    6088                 :             : inline bool
    6089                 :    13364232 : more_call_expr_args_p (const call_expr_arg_iterator *iter)
    6090                 :             : {
    6091                 :    13364232 :   return (iter->i < iter->n);
    6092                 :             : }
    6093                 :             : 
    6094                 :             : /* Iterate through each argument ARG of CALL_EXPR CALL, using variable ITER
    6095                 :             :    (of type call_expr_arg_iterator) to hold the iteration state.  */
    6096                 :             : #define FOR_EACH_CALL_EXPR_ARG(arg, iter, call)                 \
    6097                 :             :   for ((arg) = first_call_expr_arg ((call), &(iter)); (arg);        \
    6098                 :             :        (arg) = next_call_expr_arg (&(iter)))
    6099                 :             : 
    6100                 :             : #define FOR_EACH_CONST_CALL_EXPR_ARG(arg, iter, call)                   \
    6101                 :             :   for ((arg) = first_const_call_expr_arg ((call), &(iter)); (arg);  \
    6102                 :             :        (arg) = next_const_call_expr_arg (&(iter)))
    6103                 :             : 
    6104                 :             : /* Return true if tree node T is a language-specific node.  */
    6105                 :             : inline bool
    6106                 :   212668239 : is_lang_specific (const_tree t)
    6107                 :             : {
    6108                 :   212668239 :   return TREE_CODE (t) == LANG_TYPE || TREE_CODE (t) >= NUM_TREE_CODES;
    6109                 :             : }
    6110                 :             : 
    6111                 :             : /* Valid builtin number.  */
    6112                 :             : #define BUILTIN_VALID_P(FNCODE) \
    6113                 :             :   (IN_RANGE ((int)FNCODE, ((int)BUILT_IN_NONE) + 1, ((int) END_BUILTINS) - 1))
    6114                 :             : 
    6115                 :             : /* Obtain a pointer to the identifier string holding the asm name for
    6116                 :             :    BUILTIN, a BUILT_IN code.  This is handy if the target
    6117                 :             :    mangles/overrides the function name that implements the
    6118                 :             :    builtin.  */
    6119                 :             : #define BUILTIN_ASM_NAME_PTR(BUILTIN) \
    6120                 :             :   (IDENTIFIER_POINTER (DECL_ASSEMBLER_NAME (builtin_decl_explicit (BUILTIN))))
    6121                 :             : 
    6122                 :             : /* Return the tree node for an explicit standard builtin function or NULL.  */
    6123                 :             : inline tree
    6124                 :   303131069 : builtin_decl_explicit (enum built_in_function fncode)
    6125                 :             : {
    6126                 :   287577820 :   gcc_checking_assert (BUILTIN_VALID_P (fncode));
    6127                 :             : 
    6128                 :   290855260 :   return builtin_info[(size_t)fncode].decl;
    6129                 :             : }
    6130                 :             : 
    6131                 :             : /* Return the tree node for an implicit builtin function or NULL.  */
    6132                 :             : inline tree
    6133                 :      807285 : builtin_decl_implicit (enum built_in_function fncode)
    6134                 :             : {
    6135                 :      807138 :   size_t uns_fncode = (size_t)fncode;
    6136                 :      320813 :   gcc_checking_assert (BUILTIN_VALID_P (fncode));
    6137                 :             : 
    6138                 :      807285 :   if (!builtin_info[uns_fncode].implicit_p)
    6139                 :             :     return NULL_TREE;
    6140                 :             : 
    6141                 :      805856 :   return builtin_info[uns_fncode].decl;
    6142                 :             : }
    6143                 :             : 
    6144                 :             : /* For BUILTIN_UNREACHABLE, use one of these or
    6145                 :             :    gimple_build_builtin_unreachable instead of one of the above.  */
    6146                 :             : extern tree builtin_decl_unreachable ();
    6147                 :             : extern tree build_builtin_unreachable (location_t);
    6148                 :             : 
    6149                 :             : /* Set explicit builtin function nodes and whether it is an implicit
    6150                 :             :    function.  */
    6151                 :             : 
    6152                 :             : inline void
    6153                 :   336038295 : set_builtin_decl (enum built_in_function fncode, tree decl, bool implicit_p)
    6154                 :             : {
    6155                 :   336038295 :   size_t ufncode = (size_t)fncode;
    6156                 :             : 
    6157                 :   336038295 :   gcc_checking_assert (BUILTIN_VALID_P (fncode)
    6158                 :             :                        && (decl != NULL_TREE || !implicit_p));
    6159                 :             : 
    6160                 :   336038295 :   builtin_info[ufncode].decl = decl;
    6161                 :   336038295 :   builtin_info[ufncode].implicit_p = implicit_p;
    6162                 :   336038295 :   builtin_info[ufncode].declared_p = false;
    6163                 :   336038295 : }
    6164                 :             : 
    6165                 :             : /* Set the implicit flag for a builtin function.  */
    6166                 :             : 
    6167                 :             : inline void
    6168                 :     1244774 : set_builtin_decl_implicit_p (enum built_in_function fncode, bool implicit_p)
    6169                 :             : {
    6170                 :     1244774 :   size_t uns_fncode = (size_t)fncode;
    6171                 :             : 
    6172                 :     1244774 :   gcc_checking_assert (BUILTIN_VALID_P (fncode)
    6173                 :             :                        && builtin_info[uns_fncode].decl != NULL_TREE);
    6174                 :             : 
    6175                 :     1244774 :   builtin_info[uns_fncode].implicit_p = implicit_p;
    6176                 :     1244774 : }
    6177                 :             : 
    6178                 :             : /* Set the declared flag for a builtin function.  */
    6179                 :             : 
    6180                 :             : inline void
    6181                 :     6970653 : set_builtin_decl_declared_p (enum built_in_function fncode, bool declared_p)
    6182                 :             : {
    6183                 :     6970653 :   size_t uns_fncode = (size_t)fncode;
    6184                 :             : 
    6185                 :     6970653 :   gcc_checking_assert (BUILTIN_VALID_P (fncode)
    6186                 :             :                        && builtin_info[uns_fncode].decl != NULL_TREE);
    6187                 :             : 
    6188                 :     6970653 :   builtin_info[uns_fncode].declared_p = declared_p;
    6189                 :     6970653 : }
    6190                 :             : 
    6191                 :             : /* Return whether the standard builtin function can be used as an explicit
    6192                 :             :    function.  */
    6193                 :             : 
    6194                 :             : inline bool
    6195                 :    20099231 : builtin_decl_explicit_p (enum built_in_function fncode)
    6196                 :             : {
    6197                 :    20099231 :   gcc_checking_assert (BUILTIN_VALID_P (fncode));
    6198                 :    17785577 :   return (builtin_info[(size_t)fncode].decl != NULL_TREE);
    6199                 :             : }
    6200                 :             : 
    6201                 :             : /* Return whether the standard builtin function can be used implicitly.  */
    6202                 :             : 
    6203                 :             : inline bool
    6204                 :      162593 : builtin_decl_implicit_p (enum built_in_function fncode)
    6205                 :             : {
    6206                 :      162593 :   size_t uns_fncode = (size_t)fncode;
    6207                 :             : 
    6208                 :      162593 :   gcc_checking_assert (BUILTIN_VALID_P (fncode));
    6209                 :      162593 :   return (builtin_info[uns_fncode].decl != NULL_TREE
    6210                 :      162587 :           && builtin_info[uns_fncode].implicit_p);
    6211                 :             : }
    6212                 :             : 
    6213                 :             : /* Return whether the standard builtin function was declared.  */
    6214                 :             : 
    6215                 :             : inline bool
    6216                 :     3718888 : builtin_decl_declared_p (enum built_in_function fncode)
    6217                 :             : {
    6218                 :     3718888 :   size_t uns_fncode = (size_t)fncode;
    6219                 :             : 
    6220                 :     3718888 :   gcc_checking_assert (BUILTIN_VALID_P (fncode));
    6221                 :     3718888 :   return (builtin_info[uns_fncode].decl != NULL_TREE
    6222                 :     3718888 :           && builtin_info[uns_fncode].declared_p);
    6223                 :             : }
    6224                 :             : 
    6225                 :             : /* Determine if the function identified by FNDECL is one that
    6226                 :             :    makes sense to match by name, for those places where we detect
    6227                 :             :    "magic" functions by name.
    6228                 :             : 
    6229                 :             :    Return true if FNDECL has a name and is an extern fndecl at file scope.
    6230                 :             :    FNDECL must be a non-NULL decl.
    6231                 :             : 
    6232                 :             :    Avoid using this, as it's generally better to use attributes rather
    6233                 :             :    than to check for functions by name.  */
    6234                 :             : 
    6235                 :             : inline bool
    6236                 :  4167036274 : maybe_special_function_p (const_tree fndecl)
    6237                 :             : {
    6238                 :  4167036274 :   tree name_decl = DECL_NAME (fndecl);
    6239                 :  4167036274 :   if (name_decl
    6240                 :             :       /* Exclude functions not at the file scope, or not `extern',
    6241                 :             :          since they are not the magic functions we would otherwise
    6242                 :             :          think they are.  */
    6243                 :  4167036274 :       && (DECL_CONTEXT (fndecl) == NULL_TREE
    6244                 :  2553307857 :           || TREE_CODE (DECL_CONTEXT (fndecl)) == TRANSLATION_UNIT_DECL)
    6245                 :  7248344642 :       && TREE_PUBLIC (fndecl))
    6246                 :  2931267410 :     return true;
    6247                 :             :   return false;
    6248                 :             : }
    6249                 :             : 
    6250                 :             : /* Return true if T (assumed to be a DECL) is a global variable.
    6251                 :             :    A variable is considered global if its storage is not automatic.  */
    6252                 :             : 
    6253                 :             : inline bool
    6254                 :  2373715551 : is_global_var (const_tree t)
    6255                 :             : {
    6256                 :  2373715551 :   return (TREE_STATIC (t) || DECL_EXTERNAL (t));
    6257                 :             : }
    6258                 :             : 
    6259                 :             : /* Return true if VAR may be aliased.  A variable is considered as
    6260                 :             :    maybe aliased if it has its address taken by the local TU
    6261                 :             :    or possibly by another TU and might be modified through a pointer.  */
    6262                 :             : 
    6263                 :             : inline bool
    6264                 :   657612926 : may_be_aliased (const_tree var)
    6265                 :             : {
    6266                 :   657612926 :   return (TREE_CODE (var) != CONST_DECL
    6267                 :   657074799 :           && (TREE_PUBLIC (var)
    6268                 :   633391876 :               || DECL_EXTERNAL (var)
    6269                 :   633391876 :               || TREE_ADDRESSABLE (var))
    6270                 :   875507090 :           && !((TREE_STATIC (var) || TREE_PUBLIC (var) || DECL_EXTERNAL (var))
    6271                 :    32223972 :                && (TREE_READONLY (var)
    6272                 :    27306189 :                    || (TREE_CODE (var) == VAR_DECL
    6273                 :    26485932 :                        && DECL_NONALIASED (var)))));
    6274                 :             : }
    6275                 :             : 
    6276                 :             : /* Return pointer to optimization flags of FNDECL.  */
    6277                 :             : inline struct cl_optimization *
    6278                 :  2817018511 : opts_for_fn (const_tree fndecl)
    6279                 :             : {
    6280                 :  2817018511 :   tree fn_opts = DECL_FUNCTION_SPECIFIC_OPTIMIZATION (fndecl);
    6281                 :  2817018511 :   if (fn_opts == NULL_TREE)
    6282                 :  2534343650 :     fn_opts = optimization_default_node;
    6283                 :  2817018511 :   return TREE_OPTIMIZATION (fn_opts);
    6284                 :             : }
    6285                 :             : 
    6286                 :             : /* Return pointer to target flags of FNDECL.  */
    6287                 :             : inline cl_target_option *
    6288                 :     2794254 : target_opts_for_fn (const_tree fndecl)
    6289                 :             : {
    6290                 :     2794254 :   tree fn_opts = DECL_FUNCTION_SPECIFIC_TARGET (fndecl);
    6291                 :     2794254 :   if (fn_opts == NULL_TREE)
    6292                 :     1655293 :     fn_opts = target_option_default_node;
    6293                 :     4449547 :   return fn_opts == NULL_TREE ? NULL : TREE_TARGET_OPTION (fn_opts);
    6294                 :             : }
    6295                 :             : 
    6296                 :             : /* opt flag for function FNDECL, e.g. opts_for_fn (fndecl, optimize) is
    6297                 :             :    the optimization level of function fndecl.  */
    6298                 :             : #define opt_for_fn(fndecl, opt) (opts_for_fn (fndecl)->x_##opt)
    6299                 :             : 
    6300                 :             : /* For anonymous aggregate types, we need some sort of name to
    6301                 :             :    hold on to.  In practice, this should not appear, but it should
    6302                 :             :    not be harmful if it does.  Identifiers returned will be
    6303                 :             :    IDENTIFIER_ANON_P.  */
    6304                 :             : extern tree make_anon_name ();
    6305                 :             : 
    6306                 :             : /* The tree and const_tree overload templates.   */
    6307                 :             : namespace wi
    6308                 :             : {
    6309                 :             :   class unextended_tree
    6310                 :             :   {
    6311                 :             :   private:
    6312                 :             :     const_tree m_t;
    6313                 :             : 
    6314                 :             :   public:
    6315                 :             :     unextended_tree () {}
    6316                 :   930892215 :     unextended_tree (const_tree t) : m_t (t) {}
    6317                 :             : 
    6318                 :             :     unsigned int get_precision () const;
    6319                 :             :     const HOST_WIDE_INT *get_val () const;
    6320                 :             :     unsigned int get_len () const;
    6321                 :             :     const_tree get_tree () const { return m_t; }
    6322                 :             :   };
    6323                 :             : 
    6324                 :             :   template <>
    6325                 :             :   struct int_traits <unextended_tree>
    6326                 :             :   {
    6327                 :             :     static const enum precision_type precision_type = VAR_PRECISION;
    6328                 :             :     static const bool host_dependent_precision = false;
    6329                 :             :     static const bool is_sign_extended = false;
    6330                 :             :     static const bool needs_write_val_arg = false;
    6331                 :             :   };
    6332                 :             : 
    6333                 :             :   template <int N>
    6334                 :             :   class extended_tree
    6335                 :             :   {
    6336                 :             :   private:
    6337                 :             :     const_tree m_t;
    6338                 :             : 
    6339                 :             :   public:
    6340                 :             :     extended_tree () {}
    6341                 :             :     extended_tree (const_tree);
    6342                 :             : 
    6343                 :             :     unsigned int get_precision () const;
    6344                 :             :     const HOST_WIDE_INT *get_val () const;
    6345                 :             :     unsigned int get_len () const;
    6346                 :             :     const_tree get_tree () const { return m_t; }
    6347                 :             :   };
    6348                 :             : 
    6349                 :             :   template <int N>
    6350                 :             :   struct int_traits <extended_tree <N> >
    6351                 :             :   {
    6352                 :             :     static const enum precision_type precision_type
    6353                 :             :       = N == ADDR_MAX_PRECISION ? INL_CONST_PRECISION : CONST_PRECISION;
    6354                 :             :     static const bool host_dependent_precision = false;
    6355                 :             :     static const bool is_sign_extended = true;
    6356                 :             :     static const bool needs_write_val_arg = false;
    6357                 :             :     static const unsigned int precision = N;
    6358                 :             :   };
    6359                 :             : 
    6360                 :             :   typedef extended_tree <WIDEST_INT_MAX_PRECISION> widest_extended_tree;
    6361                 :             :   typedef extended_tree <ADDR_MAX_PRECISION> offset_extended_tree;
    6362                 :             : 
    6363                 :             :   typedef const generic_wide_int <widest_extended_tree> tree_to_widest_ref;
    6364                 :             :   typedef const generic_wide_int <offset_extended_tree> tree_to_offset_ref;
    6365                 :             :   typedef const generic_wide_int<wide_int_ref_storage<false, false> >
    6366                 :             :     tree_to_wide_ref;
    6367                 :             : 
    6368                 :             :   tree_to_widest_ref to_widest (const_tree);
    6369                 :             :   tree_to_offset_ref to_offset (const_tree);
    6370                 :             :   tree_to_wide_ref to_wide (const_tree);
    6371                 :             :   wide_int to_wide (const_tree, unsigned int);
    6372                 :             : 
    6373                 :             :   typedef const poly_int <NUM_POLY_INT_COEFFS,
    6374                 :             :                           generic_wide_int <widest_extended_tree> >
    6375                 :             :     tree_to_poly_widest_ref;
    6376                 :             :   typedef const poly_int <NUM_POLY_INT_COEFFS,
    6377                 :             :                           generic_wide_int <offset_extended_tree> >
    6378                 :             :     tree_to_poly_offset_ref;
    6379                 :             :   typedef const poly_int <NUM_POLY_INT_COEFFS,
    6380                 :             :                           generic_wide_int <unextended_tree> >
    6381                 :             :     tree_to_poly_wide_ref;
    6382                 :             : 
    6383                 :             :   tree_to_poly_widest_ref to_poly_widest (const_tree);
    6384                 :             :   tree_to_poly_offset_ref to_poly_offset (const_tree);
    6385                 :             :   tree_to_poly_wide_ref to_poly_wide (const_tree);
    6386                 :             : 
    6387                 :             :   template <int N>
    6388                 :             :   struct ints_for <generic_wide_int <extended_tree <N> >, INL_CONST_PRECISION>
    6389                 :             :   {
    6390                 :             :     typedef generic_wide_int <extended_tree <N> > extended;
    6391                 :             :     static extended zero (const extended &);
    6392                 :             :   };
    6393                 :             : 
    6394                 :             :   template <int N>
    6395                 :             :   struct ints_for <generic_wide_int <extended_tree <N> >, CONST_PRECISION>
    6396                 :             :   {
    6397                 :             :     typedef generic_wide_int <extended_tree <N> > extended;
    6398                 :             :     static extended zero (const extended &);
    6399                 :             :   };
    6400                 :             : 
    6401                 :             :   template <>
    6402                 :             :   struct ints_for <generic_wide_int <unextended_tree>, VAR_PRECISION>
    6403                 :             :   {
    6404                 :             :     typedef generic_wide_int <unextended_tree> unextended;
    6405                 :             :     static unextended zero (const unextended &);
    6406                 :             :   };
    6407                 :             : }
    6408                 :             : 
    6409                 :             : /* Used to convert a tree to a widest2_int like this:
    6410                 :             :    widest2_int foo = widest2_int_cst (some_tree).  */
    6411                 :             : typedef generic_wide_int <wi::extended_tree <WIDEST_INT_MAX_PRECISION * 2> >
    6412                 :             :   widest2_int_cst;
    6413                 :             : 
    6414                 :             : /* Refer to INTEGER_CST T as though it were a widest_int.
    6415                 :             : 
    6416                 :             :    This function gives T's actual numerical value, influenced by the
    6417                 :             :    signedness of its type.  For example, a signed byte with just the
    6418                 :             :    top bit set would be -128 while an unsigned byte with the same
    6419                 :             :    bit pattern would be 128.
    6420                 :             : 
    6421                 :             :    This is the right choice when operating on groups of INTEGER_CSTs
    6422                 :             :    that might have different signedness or precision.  It is also the
    6423                 :             :    right choice in code that specifically needs an approximation of
    6424                 :             :    infinite-precision arithmetic instead of normal modulo arithmetic.
    6425                 :             : 
    6426                 :             :    The approximation of infinite precision is good enough for realistic
    6427                 :             :    numbers of additions and subtractions of INTEGER_CSTs (where
    6428                 :             :    "realistic" includes any number less than 1 << 31) but it cannot
    6429                 :             :    represent the result of multiplying the two largest supported
    6430                 :             :    INTEGER_CSTs.  The overflow-checking form of wi::mul provides a way
    6431                 :             :    of multiplying two arbitrary INTEGER_CSTs and checking that the
    6432                 :             :    result is representable as a widest_int.
    6433                 :             : 
    6434                 :             :    Note that any overflow checking done on these values is relative to
    6435                 :             :    the range of widest_int rather than the range of a TREE_TYPE.
    6436                 :             : 
    6437                 :             :    Calling this function should have no overhead in release builds,
    6438                 :             :    so it is OK to call it several times for the same tree.  If it is
    6439                 :             :    useful for readability reasons to reduce the number of calls,
    6440                 :             :    it is more efficient to use:
    6441                 :             : 
    6442                 :             :      wi::tree_to_widest_ref wt = wi::to_widest (t);
    6443                 :             : 
    6444                 :             :    instead of:
    6445                 :             : 
    6446                 :             :      widest_int wt = wi::to_widest (t).  */
    6447                 :             : 
    6448                 :             : inline wi::tree_to_widest_ref
    6449                 :  3554236771 : wi::to_widest (const_tree t)
    6450                 :             : {
    6451                 : 10212951720 :   return t;
    6452                 :             : }
    6453                 :             : 
    6454                 :             : /* Refer to INTEGER_CST T as though it were an offset_int.
    6455                 :             : 
    6456                 :             :    This function is an optimisation of wi::to_widest for cases
    6457                 :             :    in which T is known to be a bit or byte count in the range
    6458                 :             :    (-(2 ^ (N + BITS_PER_UNIT)), 2 ^ (N + BITS_PER_UNIT)), where N is
    6459                 :             :    the target's address size in bits.
    6460                 :             : 
    6461                 :             :    This is the right choice when operating on bit or byte counts as
    6462                 :             :    untyped numbers rather than M-bit values.  The wi::to_widest comments
    6463                 :             :    about addition, subtraction and multiplication apply here: sequences
    6464                 :             :    of 1 << 31 additions and subtractions do not induce overflow, but
    6465                 :             :    multiplying the largest sizes might.  Again,
    6466                 :             : 
    6467                 :             :      wi::tree_to_offset_ref wt = wi::to_offset (t);
    6468                 :             : 
    6469                 :             :    is more efficient than:
    6470                 :             : 
    6471                 :             :      offset_int wt = wi::to_offset (t).  */
    6472                 :             : 
    6473                 :             : inline wi::tree_to_offset_ref
    6474                 :  3507223119 : wi::to_offset (const_tree t)
    6475                 :             : {
    6476                 :  3348152169 :   return t;
    6477                 :             : }
    6478                 :             : 
    6479                 :             : /* Refer to INTEGER_CST T as though it were a wide_int.
    6480                 :             : 
    6481                 :             :    In contrast to the approximation of infinite-precision numbers given
    6482                 :             :    by wi::to_widest and wi::to_offset, this function treats T as a
    6483                 :             :    signless collection of N bits, where N is the precision of T's type.
    6484                 :             :    As with machine registers, signedness is determined by the operation
    6485                 :             :    rather than the operands; for example, there is a distinction between
    6486                 :             :    signed and unsigned division.
    6487                 :             : 
    6488                 :             :    This is the right choice when operating on values with the same type
    6489                 :             :    using normal modulo arithmetic.  The overflow-checking forms of things
    6490                 :             :    like wi::add check whether the result can be represented in T's type.
    6491                 :             : 
    6492                 :             :    Calling this function should have no overhead in release builds,
    6493                 :             :    so it is OK to call it several times for the same tree.  If it is
    6494                 :             :    useful for readability reasons to reduce the number of calls,
    6495                 :             :    it is more efficient to use:
    6496                 :             : 
    6497                 :             :      wi::tree_to_wide_ref wt = wi::to_wide (t);
    6498                 :             : 
    6499                 :             :    instead of:
    6500                 :             : 
    6501                 :             :      wide_int wt = wi::to_wide (t).  */
    6502                 :             : 
    6503                 :             : inline wi::tree_to_wide_ref
    6504                 : 12748725819 : wi::to_wide (const_tree t)
    6505                 :             : {
    6506                 : 25497451638 :   return wi::storage_ref (&TREE_INT_CST_ELT (t, 0), TREE_INT_CST_NUNITS (t),
    6507                 : 12748725819 :                           TYPE_PRECISION (TREE_TYPE (t)));
    6508                 :             : }
    6509                 :             : 
    6510                 :             : /* Convert INTEGER_CST T to a wide_int of precision PREC, extending or
    6511                 :             :    truncating as necessary.  When extending, use sign extension if T's
    6512                 :             :    type is signed and zero extension if T's type is unsigned.  */
    6513                 :             : 
    6514                 :             : inline wide_int
    6515                 :  1308674778 : wi::to_wide (const_tree t, unsigned int prec)
    6516                 :             : {
    6517                 :  1308674778 :   return wide_int::from (wi::to_wide (t), prec, TYPE_SIGN (TREE_TYPE (t)));
    6518                 :             : }
    6519                 :             : 
    6520                 :             : template <int N>
    6521                 : 22905171712 : inline wi::extended_tree <N>::extended_tree (const_tree t)
    6522                 : 22905171712 :   : m_t (t)
    6523                 :             : {
    6524                 : 22905171712 :   gcc_checking_assert (TYPE_PRECISION (TREE_TYPE (t)) <= N);
    6525                 : 22905171712 : }
    6526                 :             : 
    6527                 :             : template <int N>
    6528                 :             : inline unsigned int
    6529                 :             : wi::extended_tree <N>::get_precision () const
    6530                 :             : {
    6531                 :             :   return N;
    6532                 :             : }
    6533                 :             : 
    6534                 :             : template <int N>
    6535                 :             : inline const HOST_WIDE_INT *
    6536                 : 22991850635 : wi::extended_tree <N>::get_val () const
    6537                 :             : {
    6538                 : 22991850635 :   return &TREE_INT_CST_ELT (m_t, 0);
    6539                 :             : }
    6540                 :             : 
    6541                 :             : template <int N>
    6542                 :             : inline unsigned int
    6543                 : 22979668480 : wi::extended_tree <N>::get_len () const
    6544                 :             : {
    6545                 :             :   if (N == ADDR_MAX_PRECISION)
    6546                 :             :     {
    6547                 :             :       /* to_offset can only be applied to trees that are offset_int-sized
    6548                 :             :          or smaller.  EXT_LEN is correct if it fits, otherwise the constant
    6549                 :             :          must be exactly the precision of offset_int and so LEN is correct.  */
    6550                 : 10056751977 :       unsigned int ext_len = TREE_INT_CST_EXT_NUNITS (m_t);
    6551                 : 10056751977 :       if (ext_len <= OFFSET_INT_ELTS)
    6552                 :             :         return ext_len;
    6553                 :         395 :       return TREE_INT_CST_NUNITS (m_t);
    6554                 :             :     }
    6555                 :             :   else if (N >= WIDEST_INT_MAX_PRECISION)
    6556                 : 12922916503 :     return TREE_INT_CST_EXT_NUNITS (m_t);
    6557                 :             :   else
    6558                 :             :     /* This class is designed to be used for specific output precisions
    6559                 :             :        and needs to be as fast as possible, so there is no fallback for
    6560                 :             :        other casees.  */
    6561                 :             :     gcc_unreachable ();
    6562                 :             : }
    6563                 :             : 
    6564                 :             : inline unsigned int
    6565                 :  1923418905 : wi::unextended_tree::get_precision () const
    6566                 :             : {
    6567                 :  1923418905 :   return TYPE_PRECISION (TREE_TYPE (m_t));
    6568                 :             : }
    6569                 :             : 
    6570                 :             : inline const HOST_WIDE_INT *
    6571                 :   965324403 : wi::unextended_tree::get_val () const
    6572                 :             : {
    6573                 :   965324403 :   return &TREE_INT_CST_ELT (m_t, 0);
    6574                 :             : }
    6575                 :             : 
    6576                 :             : inline unsigned int
    6577                 :   958551924 : wi::unextended_tree::get_len () const
    6578                 :             : {
    6579                 :   958551924 :   return TREE_INT_CST_NUNITS (m_t);
    6580                 :             : }
    6581                 :             : 
    6582                 :             : /* Return the value of a POLY_INT_CST in its native precision.  */
    6583                 :             : 
    6584                 :             : inline wi::tree_to_poly_wide_ref
    6585                 :           0 : poly_int_cst_value (const_tree x)
    6586                 :             : {
    6587                 :           0 :   poly_int <NUM_POLY_INT_COEFFS, generic_wide_int <wi::unextended_tree> > res;
    6588                 :           0 :   for (unsigned int i = 0; i < NUM_POLY_INT_COEFFS; ++i)
    6589                 :           0 :     res.coeffs[i] = POLY_INT_CST_COEFF (x, i);
    6590                 :           0 :   return res;
    6591                 :             : }
    6592                 :             : 
    6593                 :             : /* Access INTEGER_CST or POLY_INT_CST tree T as if it were a
    6594                 :             :    poly_widest_int.  See wi::to_widest for more details.  */
    6595                 :             : 
    6596                 :             : inline wi::tree_to_poly_widest_ref
    6597                 :    88202926 : wi::to_poly_widest (const_tree t)
    6598                 :             : {
    6599                 :    68897980 :   if (POLY_INT_CST_P (t))
    6600                 :             :     {
    6601                 :             :       poly_int <NUM_POLY_INT_COEFFS,
    6602                 :             :                 generic_wide_int <widest_extended_tree> > res;
    6603                 :             :       for (unsigned int i = 0; i < NUM_POLY_INT_COEFFS; ++i)
    6604                 :             :         res.coeffs[i] = POLY_INT_CST_COEFF (t, i);
    6605                 :             :       return res;
    6606                 :             :     }
    6607                 :    68897891 :   return t;
    6608                 :             : }
    6609                 :             : 
    6610                 :             : /* Access INTEGER_CST or POLY_INT_CST tree T as if it were a
    6611                 :             :    poly_offset_int.  See wi::to_offset for more details.  */
    6612                 :             : 
    6613                 :             : inline wi::tree_to_poly_offset_ref
    6614                 :  6525572322 : wi::to_poly_offset (const_tree t)
    6615                 :             : {
    6616                 :  1333828522 :   if (POLY_INT_CST_P (t))
    6617                 :             :     {
    6618                 :             :       poly_int <NUM_POLY_INT_COEFFS,
    6619                 :             :                 generic_wide_int <offset_extended_tree> > res;
    6620                 :             :       for (unsigned int i = 0; i < NUM_POLY_INT_COEFFS; ++i)
    6621                 :             :         res.coeffs[i] = POLY_INT_CST_COEFF (t, i);
    6622                 :             :       return res;
    6623                 :             :     }
    6624                 :  5830887687 :   return t;
    6625                 :             : }
    6626                 :             : 
    6627                 :             : /* Access INTEGER_CST or POLY_INT_CST tree T as if it were a
    6628                 :             :    poly_wide_int.  See wi::to_wide for more details.  */
    6629                 :             : 
    6630                 :             : inline wi::tree_to_poly_wide_ref
    6631                 :   930892215 : wi::to_poly_wide (const_tree t)
    6632                 :             : {
    6633                 :   930892215 :   if (POLY_INT_CST_P (t))
    6634                 :             :     return poly_int_cst_value (t);
    6635                 :   930892215 :   return t;
    6636                 :             : }
    6637                 :             : 
    6638                 :             : template <int N>
    6639                 :             : inline generic_wide_int <wi::extended_tree <N> >
    6640                 :             : wi::ints_for <generic_wide_int <wi::extended_tree <N> >,
    6641                 :             :               wi::INL_CONST_PRECISION>::zero (const extended &x)
    6642                 :             : {
    6643                 :             :   return build_zero_cst (TREE_TYPE (x.get_tree ()));
    6644                 :             : }
    6645                 :             : 
    6646                 :             : template <int N>
    6647                 :             : inline generic_wide_int <wi::extended_tree <N> >
    6648                 :             : wi::ints_for <generic_wide_int <wi::extended_tree <N> >,
    6649                 :             :               wi::CONST_PRECISION>::zero (const extended &x)
    6650                 :             : {
    6651                 :             :   return build_zero_cst (TREE_TYPE (x.get_tree ()));
    6652                 :             : }
    6653                 :             : 
    6654                 :             : inline generic_wide_int <wi::unextended_tree>
    6655                 :             : wi::ints_for <generic_wide_int <wi::unextended_tree>,
    6656                 :             :               wi::VAR_PRECISION>::zero (const unextended &x)
    6657                 :             : {
    6658                 :             :   return build_zero_cst (TREE_TYPE (x.get_tree ()));
    6659                 :             : }
    6660                 :             : 
    6661                 :             : namespace wi
    6662                 :             : {
    6663                 :             :   template <typename T>
    6664                 :             :   bool fits_to_boolean_p (const T &x, const_tree);
    6665                 :             : 
    6666                 :             :   template <typename T>
    6667                 :             :   bool fits_to_tree_p (const T &x, const_tree);
    6668                 :             : 
    6669                 :             :   wide_int min_value (const_tree);
    6670                 :             :   wide_int max_value (const_tree);
    6671                 :             : #ifndef GENERATOR_FILE
    6672                 :             :   wide_int from_mpz (const_tree, mpz_t, bool);
    6673                 :             : #endif
    6674                 :             : }
    6675                 :             : 
    6676                 :             : template <typename T>
    6677                 :             : bool
    6678                 :     4470900 : wi::fits_to_boolean_p (const T &x, const_tree type)
    6679                 :             : {
    6680                 :             :   typedef typename poly_int_traits<T>::int_type int_type;
    6681                 :     4470900 :   return (known_eq (x, int_type (0))
    6682                 :     4479022 :           || known_eq (x, int_type (TYPE_UNSIGNED (type) ? 1 : -1)));
    6683                 :             : }
    6684                 :             : 
    6685                 :             : template <typename T>
    6686                 :             : bool
    6687                 :  2390831969 : wi::fits_to_tree_p (const T &x, const_tree type)
    6688                 :             : {
    6689                 :             :   /* Non-standard boolean types can have arbitrary precision but various
    6690                 :             :      transformations assume that they can only take values 0 and +/-1.  */
    6691                 :  2390831969 :   if (TREE_CODE (type) == BOOLEAN_TYPE)
    6692                 :     3485593 :     return fits_to_boolean_p (x, type);
    6693                 :             : 
    6694                 :  2387346376 :   if (TYPE_UNSIGNED (type))
    6695                 :  2129034759 :     return known_eq (x, zext (x, TYPE_PRECISION (type)));
    6696                 :             :   else
    6697                 :   258311617 :     return known_eq (x, sext (x, TYPE_PRECISION (type)));
    6698                 :             : }
    6699                 :             : 
    6700                 :             : /* Produce the smallest number that is represented in TYPE.  The precision
    6701                 :             :    and sign are taken from TYPE.  */
    6702                 :             : inline wide_int
    6703                 :    74087707 : wi::min_value (const_tree type)
    6704                 :             : {
    6705                 :    74087707 :   return min_value (TYPE_PRECISION (type), TYPE_SIGN (type));
    6706                 :             : }
    6707                 :             : 
    6708                 :             : /* Produce the largest number that is represented in TYPE.  The precision
    6709                 :             :    and sign are taken from TYPE.  */
    6710                 :             : inline wide_int
    6711                 :    74794829 : wi::max_value (const_tree type)
    6712                 :             : {
    6713                 :    74794829 :   return max_value (TYPE_PRECISION (type), TYPE_SIGN (type));
    6714                 :             : }
    6715                 :             : 
    6716                 :             : /* Return true if INTEGER_CST T1 is less than INTEGER_CST T2,
    6717                 :             :    extending both according to their respective TYPE_SIGNs.  */
    6718                 :             : 
    6719                 :             : inline bool
    6720                 :  1294865364 : tree_int_cst_lt (const_tree t1, const_tree t2)
    6721                 :             : {
    6722                 :  1294865364 :   return wi::to_widest (t1) < wi::to_widest (t2);
    6723                 :             : }
    6724                 :             : 
    6725                 :             : /* Return true if INTEGER_CST T1 is less than or equal to INTEGER_CST T2,
    6726                 :             :    extending both according to their respective TYPE_SIGNs.  */
    6727                 :             : 
    6728                 :             : inline bool
    6729                 :     1727665 : tree_int_cst_le (const_tree t1, const_tree t2)
    6730                 :             : {
    6731                 :     1727665 :   return wi::to_widest (t1) <= wi::to_widest (t2);
    6732                 :             : }
    6733                 :             : 
    6734                 :             : /* Returns -1 if T1 < T2, 0 if T1 == T2, and 1 if T1 > T2.  T1 and T2
    6735                 :             :    are both INTEGER_CSTs and their values are extended according to their
    6736                 :             :    respective TYPE_SIGNs.  */
    6737                 :             : 
    6738                 :             : inline int
    6739                 :   179828957 : tree_int_cst_compare (const_tree t1, const_tree t2)
    6740                 :             : {
    6741                 :   179828957 :   return wi::cmps (wi::to_widest (t1), wi::to_widest (t2));
    6742                 :             : }
    6743                 :             : 
    6744                 :             : /* FIXME - These declarations belong in builtins.h, expr.h and emit-rtl.h,
    6745                 :             :    but none of these files are allowed to be included from front ends.
    6746                 :             :    They should be split in two. One suitable for the FEs, the other suitable
    6747                 :             :    for the BE.  */
    6748                 :             : 
    6749                 :             : /* Assign the RTX to declaration.  */
    6750                 :             : extern void set_decl_rtl (tree, rtx);
    6751                 :             : extern bool complete_ctor_at_level_p (const_tree, HOST_WIDE_INT, const_tree);
    6752                 :             : 
    6753                 :             : /* Given an expression EXP that is a handled_component_p,
    6754                 :             :    look for the ultimate containing object, which is returned and specify
    6755                 :             :    the access position and size.  */
    6756                 :             : extern tree get_inner_reference (tree, poly_int64 *, poly_int64 *,
    6757                 :             :                                  tree *, machine_mode *, int *, int *, int *);
    6758                 :             : 
    6759                 :             : extern tree build_personality_function (const char *);
    6760                 :             : 
    6761                 :             : struct GTY(()) int_n_trees_t {
    6762                 :             :   /* These parts are initialized at runtime */
    6763                 :             :   tree signed_type;
    6764                 :             :   tree unsigned_type;
    6765                 :             : };
    6766                 :             : 
    6767                 :             : /* This is also in machmode.h */
    6768                 :             : extern bool int_n_enabled_p[NUM_INT_N_ENTS];
    6769                 :             : extern GTY(()) struct int_n_trees_t int_n_trees[NUM_INT_N_ENTS];
    6770                 :             : 
    6771                 :             : /* Like bit_position, but return as an integer.  It must be representable in
    6772                 :             :    that way (since it could be a signed value, we don't have the
    6773                 :             :    option of returning -1 like int_size_in_byte can.  */
    6774                 :             : 
    6775                 :             : inline HOST_WIDE_INT
    6776                 :    77851852 : int_bit_position (const_tree field)
    6777                 :             : {
    6778                 :   155703704 :   return ((wi::to_offset (DECL_FIELD_OFFSET (field)) << LOG2_BITS_PER_UNIT)
    6779                 :    77851852 :           + wi::to_offset (DECL_FIELD_BIT_OFFSET (field))).to_shwi ();
    6780                 :             : }
    6781                 :             : 
    6782                 :             : /* Return true if it makes sense to consider alias set for a type T.  */
    6783                 :             : 
    6784                 :             : inline bool
    6785                 :   142924885 : type_with_alias_set_p (const_tree t)
    6786                 :             : {
    6787                 :             :   /* Function and method types are never accessed as memory locations.  */
    6788                 :   142924885 :   if (TREE_CODE (t) == FUNCTION_TYPE || TREE_CODE (t) == METHOD_TYPE)
    6789                 :             :     return false;
    6790                 :             : 
    6791                 :   142614719 :   if (COMPLETE_TYPE_P (t))
    6792                 :             :     return true;
    6793                 :             : 
    6794                 :             :   /* Incomplete types cannot be accessed in general except for arrays
    6795                 :             :      where we can fetch its element despite we have no array bounds.  */
    6796                 :    10297914 :   if (TREE_CODE (t) == ARRAY_TYPE && COMPLETE_TYPE_P (TREE_TYPE (t)))
    6797                 :       89288 :     return true;
    6798                 :             : 
    6799                 :             :   return false;
    6800                 :             : }
    6801                 :             : 
    6802                 :             : extern location_t set_block (location_t loc, tree block);
    6803                 :             : 
    6804                 :             : extern void gt_ggc_mx (tree &);
    6805                 :             : extern void gt_pch_nx (tree &);
    6806                 :             : extern void gt_pch_nx (tree &, gt_pointer_operator, void *);
    6807                 :             : extern void gt_ggc_mx (tree_raw_data *);
    6808                 :             : extern void gt_pch_nx (tree_raw_data *);
    6809                 :             : extern void gt_pch_nx (tree_raw_data *, gt_pointer_operator, void *);
    6810                 :             : 
    6811                 :             : extern bool nonnull_arg_p (const_tree);
    6812                 :             : extern bool is_empty_type (const_tree);
    6813                 :             : extern bool default_is_empty_record (const_tree);
    6814                 :             : extern bool flexible_array_type_p (const_tree);
    6815                 :             : extern HOST_WIDE_INT arg_int_size_in_bytes (const_tree);
    6816                 :             : extern tree arg_size_in_bytes (const_tree);
    6817                 :             : extern bool expr_type_first_operand_type_p (tree_code);
    6818                 :             : 
    6819                 :             : extern location_t
    6820                 :             : set_source_range (tree expr, location_t start, location_t finish);
    6821                 :             : 
    6822                 :             : extern location_t
    6823                 :             : set_source_range (tree expr, source_range src_range);
    6824                 :             : 
    6825                 :             : /* Return true if it makes sense to promote/demote from_type to to_type. */
    6826                 :             : inline bool
    6827                 :      472492 : desired_pro_or_demotion_p (const_tree to_type, const_tree from_type)
    6828                 :             : {
    6829                 :      472492 :   unsigned int to_type_precision = TYPE_PRECISION (to_type);
    6830                 :             : 
    6831                 :             :   /* OK to promote if to_type is no bigger than word_mode. */
    6832                 :      472492 :   if (to_type_precision <= GET_MODE_PRECISION (word_mode))
    6833                 :             :     return true;
    6834                 :             : 
    6835                 :             :   /* Otherwise, allow only if narrowing or same precision conversions. */
    6836                 :       36752 :   return to_type_precision <= TYPE_PRECISION (from_type);
    6837                 :             : }
    6838                 :             : 
    6839                 :             : /* Pointer type used to declare builtins before we have seen its real
    6840                 :             :    declaration.  */
    6841                 :             : class builtin_structptr_type
    6842                 :             : {
    6843                 :             : public:
    6844                 :             :   tree& node;
    6845                 :             :   tree& base;
    6846                 :             :   const char *str;
    6847                 :             : };
    6848                 :             : extern const builtin_structptr_type builtin_structptr_types[6];
    6849                 :             : 
    6850                 :             : /* Return true if type T has the same precision as its underlying mode.  */
    6851                 :             : 
    6852                 :             : inline bool
    6853                 :   281317081 : type_has_mode_precision_p (const_tree t)
    6854                 :             : {
    6855                 :   281317081 :   return known_eq (TYPE_PRECISION (t), GET_MODE_PRECISION (TYPE_MODE (t)));
    6856                 :             : }
    6857                 :             : 
    6858                 :             : /* Helper functions for fndecl_built_in_p.  */
    6859                 :             : 
    6860                 :             : inline bool
    6861                 :             : built_in_function_equal_p (built_in_function name0, built_in_function name1)
    6862                 :             : {
    6863                 :             :   return name0 == name1;
    6864                 :             : }
    6865                 :             : 
    6866                 :             : /* Recursive case for two or more names.  */
    6867                 :             : 
    6868                 :             : template <typename... F>
    6869                 :             : inline bool
    6870                 :    38094875 : built_in_function_equal_p (built_in_function name0, built_in_function name1,
    6871                 :             :                            built_in_function name2, F... names)
    6872                 :             : {
    6873                 :    34615976 :   return name0 == name1 || built_in_function_equal_p (name0, name2, names...);
    6874                 :             : }
    6875                 :             : 
    6876                 :             : /* Return true if a FUNCTION_DECL NODE is a GCC built-in function.
    6877                 :             : 
    6878                 :             :    Note that it is different from the DECL_IS_UNDECLARED_BUILTIN
    6879                 :             :    accessor, as this is impervious to user declaration.  */
    6880                 :             : 
    6881                 :             : inline bool
    6882                 :  4039345327 : fndecl_built_in_p (const_tree node)
    6883                 :             : {
    6884                 :  4039345327 :   return DECL_BUILT_IN_CLASS (node) != NOT_BUILT_IN;
    6885                 :             : }
    6886                 :             : 
    6887                 :             : /* Return true if a FUNCTION_DECL NODE is a GCC built-in function
    6888                 :             :    of class KLASS.  */
    6889                 :             : 
    6890                 :             : inline bool
    6891                 :  3058520797 : fndecl_built_in_p (const_tree node, built_in_class klass)
    6892                 :             : {
    6893                 :  4010590821 :   return fndecl_built_in_p (node) && DECL_BUILT_IN_CLASS (node) == klass;
    6894                 :             : }
    6895                 :             : 
    6896                 :             : /* Return true if a FUNCTION_DECL NODE is a GCC built-in function
    6897                 :             :    of class KLASS with name equal to NAME.  */
    6898                 :             : 
    6899                 :             : inline bool
    6900                 :   134504734 : fndecl_built_in_p (const_tree node, unsigned int name, built_in_class klass)
    6901                 :             : {
    6902                 :   134504734 :   return (fndecl_built_in_p (node, klass)
    6903                 :   136380392 :           && DECL_UNCHECKED_FUNCTION_CODE (node) == name);
    6904                 :             : }
    6905                 :             : 
    6906                 :             : /* Return true if a FUNCTION_DECL NODE is a GCC built-in function
    6907                 :             :    of BUILT_IN_NORMAL class with name equal to NAME1 (or other mentioned
    6908                 :             :    NAMES).  */
    6909                 :             : 
    6910                 :             : template <typename... F>
    6911                 :             : inline bool
    6912                 :  1063129662 : fndecl_built_in_p (const_tree node, built_in_function name1, F... names)
    6913                 :             : {
    6914                 :  1063129662 :   return (fndecl_built_in_p (node, BUILT_IN_NORMAL)
    6915                 :  1063129662 :           && built_in_function_equal_p (DECL_FUNCTION_CODE (node),
    6916                 :  1063129662 :                                         name1, names...));
    6917                 :             : }
    6918                 :             : 
    6919                 :             : /* A struct for encapsulating location information about an operator
    6920                 :             :    and the operation built from it.
    6921                 :             : 
    6922                 :             :    m_operator_loc is the location of the operator
    6923                 :             :    m_combined_loc is the location of the compound expression.
    6924                 :             : 
    6925                 :             :    For example, given "a && b" the, operator location is:
    6926                 :             :       a && b
    6927                 :             :         ^~
    6928                 :             :    and the combined location is:
    6929                 :             :       a && b
    6930                 :             :       ~~^~~~
    6931                 :             :    Capturing this information allows for class binary_op_rich_location
    6932                 :             :    to provide detailed information about e.g. type mismatches in binary
    6933                 :             :    operations where enough location information is available:
    6934                 :             : 
    6935                 :             :      arg_0 op arg_1
    6936                 :             :      ~~~~~ ^~ ~~~~~
    6937                 :             :        |        |
    6938                 :             :        |        arg1 type
    6939                 :             :        arg0 type
    6940                 :             : 
    6941                 :             :    falling back to just showing the combined location:
    6942                 :             : 
    6943                 :             :      arg_0 op arg_1
    6944                 :             :      ~~~~~~^~~~~~~~
    6945                 :             : 
    6946                 :             :    where it is not.  */
    6947                 :             : 
    6948                 :             : class op_location_t
    6949                 :             : {
    6950                 :             : public:
    6951                 :             :   location_t m_operator_loc;
    6952                 :             :   location_t m_combined_loc;
    6953                 :             : 
    6954                 :             :   /* 1-argument ctor, for constructing from a combined location.  */
    6955                 :   141688034 :   op_location_t (location_t combined_loc)
    6956                 :   141601526 :   : m_operator_loc (UNKNOWN_LOCATION), m_combined_loc (combined_loc)
    6957                 :             :   {}
    6958                 :             : 
    6959                 :             :   /* 2-argument ctor, for distinguishing between the operator's location
    6960                 :             :      and the combined location.  */
    6961                 :   117587853 :   op_location_t (location_t operator_loc, location_t combined_loc)
    6962                 :   117587853 :   : m_operator_loc (operator_loc), m_combined_loc (combined_loc)
    6963                 :             :   {}
    6964                 :             : 
    6965                 :             :   /* Implicitly convert back to a location_t, using the combined location.  */
    6966                 :   403307119 :   operator location_t () const { return m_combined_loc; }
    6967                 :             : };
    6968                 :             : 
    6969                 :             : /* Code that doesn't refer to any warning.  Has no effect on suppression
    6970                 :             :    functions.  */
    6971                 :             : constexpr opt_code no_warning = opt_code ();
    6972                 :             : /* Wildcard code that refers to all warnings.  */
    6973                 :             : constexpr opt_code all_warnings = N_OPTS;
    6974                 :             : 
    6975                 :             : /* Return the disposition for a warning (or all warnings by default)
    6976                 :             :    at a location.  */
    6977                 :             : extern bool warning_suppressed_at (location_t, opt_code = all_warnings);
    6978                 :             : /* Set the disposition for a warning (or all warnings by default)
    6979                 :             :    at a location to disabled by default.  */
    6980                 :             : extern bool suppress_warning_at (location_t, opt_code = all_warnings,
    6981                 :             :                                  bool = true);
    6982                 :             : /* Overwrite warning disposition bitmap for a location with given spec.  */
    6983                 :             : extern void put_warning_spec_at (location_t loc, unsigned);
    6984                 :             : /* Copy warning disposition from one location to another.  */
    6985                 :             : extern void copy_warning (location_t, location_t);
    6986                 :             : 
    6987                 :             : /* Return the disposition for a warning (or all warnings by default)
    6988                 :             :    for an expression.  */
    6989                 :             : extern bool warning_suppressed_p (const_tree, opt_code = all_warnings);
    6990                 :             : /* Set the disposition for a warning (or all warnings by default)
    6991                 :             :    at a location to disabled by default.  */
    6992                 :             : extern void suppress_warning (tree, opt_code = all_warnings, bool = true)
    6993                 :             :   ATTRIBUTE_NONNULL (1);
    6994                 :             : /* Copy warning disposition from one expression to another.  */
    6995                 :             : extern void copy_warning (tree, const_tree);
    6996                 :             : 
    6997                 :             : /* Whether the tree might have a warning spec.  */
    6998                 :             : extern bool has_warning_spec (const_tree);
    6999                 :             : /* Retrieve warning spec bitmap for tree streaming.  */
    7000                 :             : extern unsigned get_warning_spec (const_tree);
    7001                 :             : /* Overwrite warning spec bitmap for a tree with given spec.  */
    7002                 :             : extern void put_warning_spec (tree, unsigned);
    7003                 :             : 
    7004                 :             : /* Return the zero-based number corresponding to the argument being
    7005                 :             :    deallocated if FNDECL is a deallocation function or an out-of-bounds
    7006                 :             :    value if it isn't.  */
    7007                 :             : extern unsigned fndecl_dealloc_argno (tree);
    7008                 :             : 
    7009                 :             : /* If an expression refers to a character array or pointer declared
    7010                 :             :    attribute nonstring, return a decl for that array or pointer and
    7011                 :             :    if nonnull, set the second argument to the referenced enclosing
    7012                 :             :    object or pointer.  Otherwise return null.  */
    7013                 :             : extern tree get_attr_nonstring_decl (tree, tree * = NULL);
    7014                 :             : 
    7015                 :             : extern int get_target_clone_attr_len (tree);
    7016                 :             : 
    7017                 :             : #endif  /* GCC_TREE_H  */
        

Generated by: LCOV version 2.1-beta

LCOV profile is generated on x86_64 machine using following configure options: configure --disable-bootstrap --enable-coverage=opt --enable-languages=c,c++,fortran,go,jit,lto,rust,m2 --enable-host-shared. GCC test suite is run with the built compiler.