]> git.ipfire.org Git - thirdparty/gcc.git/blame - gcc/gimple-expr.h
Optimize ODR enum streaming
[thirdparty/gcc.git] / gcc / gimple-expr.h
CommitLineData
2a0603f1 1/* Header file for gimple decl, type and expressions.
8d9254fc 2 Copyright (C) 2013-2020 Free Software Foundation, Inc.
2a0603f1
AM
3
4This file is part of GCC.
5
6GCC is free software; you can redistribute it and/or modify it under
7the terms of the GNU General Public License as published by the Free
8Software Foundation; either version 3, or (at your option) any later
9version.
10
11GCC is distributed in the hope that it will be useful, but WITHOUT ANY
12WARRANTY; without even the implied warranty of MERCHANTABILITY or
13FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
14 for more details.
15
16You should have received a copy of the GNU General Public License
17along with GCC; see the file COPYING3. If not see
18<http://www.gnu.org/licenses/>. */
19
20#ifndef GCC_GIMPLE_EXPR_H
21#define GCC_GIMPLE_EXPR_H
22
23extern bool useless_type_conversion_p (tree, tree);
24
45b0be94 25
2a0603f1
AM
26extern void gimple_set_body (tree, gimple_seq);
27extern gimple_seq gimple_body (tree);
28extern bool gimple_has_body_p (tree);
29extern const char *gimple_decl_printable_name (tree, int);
30extern tree copy_var_decl (tree, tree, tree);
45b0be94 31extern tree create_tmp_var_name (const char *);
b731b390
JJ
32extern tree create_tmp_var_raw (tree, const char * = NULL);
33extern tree create_tmp_var (tree, const char * = NULL);
34extern tree create_tmp_reg (tree, const char * = NULL);
45b62594 35extern tree create_tmp_reg_fn (struct function *, tree, const char *);
45b0be94 36
2a0603f1 37
d1e2bb2d
JJ
38extern void extract_ops_from_tree (tree, enum tree_code *, tree *, tree *,
39 tree *);
2a0603f1
AM
40extern void gimple_cond_get_ops_from_tree (tree, enum tree_code *, tree *,
41 tree *);
42extern bool is_gimple_lvalue (tree);
43extern bool is_gimple_condexpr (tree);
70e2a30a 44extern bool is_gimple_condexpr_for_cond (tree);
2a0603f1
AM
45extern bool is_gimple_address (const_tree);
46extern bool is_gimple_invariant_address (const_tree);
47extern bool is_gimple_ip_invariant_address (const_tree);
48extern bool is_gimple_min_invariant (const_tree);
49extern bool is_gimple_ip_invariant (const_tree);
50extern bool is_gimple_reg (tree);
51extern bool is_gimple_val (tree);
52extern bool is_gimple_asm_val (tree);
53extern bool is_gimple_min_lval (tree);
54extern bool is_gimple_call_addr (tree);
55extern bool is_gimple_mem_ref_addr (tree);
1b223a9f 56extern void flush_mark_addressable_queue (void);
45b0be94
AM
57extern void mark_addressable (tree);
58extern bool is_gimple_reg_rhs (tree);
2a0603f1
AM
59
60/* Return true if a conversion from either type of TYPE1 and TYPE2
61 to the other is not required. Otherwise return false. */
62
63static inline bool
64types_compatible_p (tree type1, tree type2)
65{
66 return (type1 == type2
67 || (useless_type_conversion_p (type1, type2)
68 && useless_type_conversion_p (type2, type1)));
69}
70
71/* Return true if TYPE is a suitable type for a scalar register variable. */
72
73static inline bool
74is_gimple_reg_type (tree type)
75{
76 return !AGGREGATE_TYPE_P (type);
77}
78
79/* Return true if T is a variable. */
80
81static inline bool
82is_gimple_variable (tree t)
83{
84 return (TREE_CODE (t) == VAR_DECL
85 || TREE_CODE (t) == PARM_DECL
86 || TREE_CODE (t) == RESULT_DECL
87 || TREE_CODE (t) == SSA_NAME);
88}
89
90/* Return true if T is a GIMPLE identifier (something with an address). */
91
92static inline bool
93is_gimple_id (tree t)
94{
95 return (is_gimple_variable (t)
96 || TREE_CODE (t) == FUNCTION_DECL
97 || TREE_CODE (t) == LABEL_DECL
98 || TREE_CODE (t) == CONST_DECL
99 /* Allow string constants, since they are addressable. */
100 || TREE_CODE (t) == STRING_CST);
101}
102
103/* Return true if OP, an SSA name or a DECL is a virtual operand. */
104
105static inline bool
106virtual_operand_p (tree op)
107{
108 if (TREE_CODE (op) == SSA_NAME)
e7960be7 109 return SSA_NAME_IS_VIRTUAL_OPERAND (op);
2a0603f1
AM
110
111 if (TREE_CODE (op) == VAR_DECL)
112 return VAR_DECL_IS_VIRTUAL_OPERAND (op);
113
114 return false;
115}
116
117/* Return true if T is something whose address can be taken. */
118
119static inline bool
120is_gimple_addressable (tree t)
121{
122 return (is_gimple_id (t) || handled_component_p (t)
65dd1346 123 || TREE_CODE (t) == TARGET_MEM_REF
2a0603f1
AM
124 || TREE_CODE (t) == MEM_REF);
125}
126
127/* Return true if T is a valid gimple constant. */
128
129static inline bool
130is_gimple_constant (const_tree t)
131{
132 switch (TREE_CODE (t))
133 {
134 case INTEGER_CST:
36fd6408 135 case POLY_INT_CST:
2a0603f1
AM
136 case REAL_CST:
137 case FIXED_CST:
2a0603f1
AM
138 case COMPLEX_CST:
139 case VECTOR_CST:
681a3d86 140 case STRING_CST:
2a0603f1
AM
141 return true;
142
143 default:
144 return false;
145 }
146}
147
d1e2bb2d
JJ
148/* A wrapper around extract_ops_from_tree with 3 ops, for callers which
149 expect to see only a maximum of two operands. */
2a0603f1
AM
150
151static inline void
152extract_ops_from_tree (tree expr, enum tree_code *code, tree *op0,
153 tree *op1)
154{
155 tree op2;
d1e2bb2d 156 extract_ops_from_tree (expr, code, op0, op1, &op2);
2a0603f1
AM
157 gcc_assert (op2 == NULL_TREE);
158}
159
160/* Given a valid GIMPLE_CALL function address return the FUNCTION_DECL
161 associated with the callee if known. Otherwise return NULL_TREE. */
162
163static inline tree
164gimple_call_addr_fndecl (const_tree fn)
165{
166 if (fn && TREE_CODE (fn) == ADDR_EXPR)
167 {
168 tree fndecl = TREE_OPERAND (fn, 0);
169 if (TREE_CODE (fndecl) == MEM_REF
170 && TREE_CODE (TREE_OPERAND (fndecl, 0)) == ADDR_EXPR
171 && integer_zerop (TREE_OPERAND (fndecl, 1)))
172 fndecl = TREE_OPERAND (TREE_OPERAND (fndecl, 0), 0);
173 if (TREE_CODE (fndecl) == FUNCTION_DECL)
174 return fndecl;
175 }
176 return NULL_TREE;
177}
178
179#endif /* GCC_GIMPLE_EXPR_H */