21#ifndef GCC_VALUE_RELATION_H
22#define GCC_VALUE_RELATION_H
114 virtual void dump (FILE *)
const { }
148 void dump (FILE *f)
const;
178 void dump (FILE *f)
const override;
238 void dump (FILE *f)
const final override;
241 tree)
const override;
286 void dump (FILE *)
const final override;
302 bool full =
true,
bool partial =
false);
314#define FOR_EACH_EQUIVALENCE(oracle, bb, name, equiv_name) \
315 for (equiv_relation_iterator iter (oracle, bb, name, true, false); \
316 ((equiv_name) = iter.get_name ()); \
319#define FOR_EACH_PARTIAL_EQUIV(oracle, bb, name, equiv_name, equiv_rel) \
320 for (equiv_relation_iterator iter (oracle, bb, name, false, true); \
321 ((equiv_name) = iter.get_name (&equiv_rel)); \
324#define FOR_EACH_PARTIAL_AND_FULL_EQUIV(oracle, bb, name, equiv_name, \
326 for (equiv_relation_iterator iter (oracle, bb, name, true, true); \
327 ((equiv_name) = iter.get_name (&equiv_rel)); \
358#define TRIO_VARYING relation_trio ()
361#define TRIO_MASK 0x000F
447 void dump (FILE *f)
const;
496#define FOR_EACH_RELATION_BB(oracle, bb, vr) \
497 for (block_relation_iterator iter (oracle, bb, vr); \
499 iter.get_next_relation (vr))
501#define FOR_EACH_RELATION_NAME(oracle, bb, name, vr) \
502 for (block_relation_iterator iter (oracle, bb, vr, name); \
504 iter.get_next_relation (vr))
const relation_oracle * m_oracle
Definition value-relation.h:489
basic_block m_bb
Definition value-relation.h:490
void get_next_relation(value_relation &vr)
Definition value-relation.cc:1013
block_relation_iterator(const relation_oracle *oracle, basic_block bb, value_relation &, tree name=NULL)
Definition value-relation.cc:992
bool m_done
Definition value-relation.h:492
tree m_name
Definition value-relation.h:493
relation_chain * m_ptr
Definition value-relation.h:491
bool record(basic_block bb, relation_kind k, tree op1, tree op2) final override
Definition value-relation.cc:1162
bitmap m_tmp2
Definition value-relation.h:243
relation_chain * set_one_relation(basic_block bb, relation_kind k, tree op1, tree op2)
Definition value-relation.cc:1192
relation_kind find_relation_dom(basic_block bb, unsigned v1, unsigned v2) const
Definition value-relation.cc:1444
~dom_oracle()
Definition value-relation.cc:1076
void register_transitives(basic_block, const class value_relation &)
Definition value-relation.cc:1254
virtual relation_chain * next_relation(basic_block, relation_chain *, tree) const override
Definition value-relation.cc:965
bool m_do_trans_p
Definition value-relation.h:242
void dump(FILE *f, basic_block bb) const final override
Definition value-relation.cc:1502
bitmap m_relation_set
Definition value-relation.h:244
relation_kind query(basic_block bb, tree ssa1, tree ssa2) final override
Definition value-relation.cc:1465
relation_kind find_relation_block(unsigned bb, const_bitmap b1, const_bitmap b2) const
Definition value-relation.cc:1365
dom_oracle(bool do_trans_p=true)
Definition value-relation.cc:1064
bitmap m_tmp
Definition value-relation.h:243
vec< relation_chain_head > m_relations
Definition value-relation.h:245
Definition value-relation.h:143
void dump(FILE *f) const
Definition value-relation.cc:289
equiv_chain * find(unsigned ssa)
Definition value-relation.cc:272
equiv_chain * m_next
Definition value-relation.h:147
bitmap m_names
Definition value-relation.h:145
basic_block m_bb
Definition value-relation.h:146
relation_kind partial_equiv(tree ssa1, tree ssa2, tree *base=NULL) const
Definition value-relation.cc:435
bool has_equiv_p(unsigned v)
Definition value-relation.h:183
equiv_chain * find_equiv_dom(tree name, basic_block bb) const
Definition value-relation.cc:520
const_bitmap equiv_set(tree ssa, basic_block bb) final override
Definition value-relation.cc:459
bool record(basic_block bb, relation_kind k, tree ssa1, tree ssa2) override
Definition value-relation.cc:633
vec< pe_slice > m_partial
Definition value-relation.h:190
bitmap m_equiv_set
Definition value-relation.h:187
bitmap_obstack m_bitmaps
Definition value-relation.h:184
void limit_check(basic_block bb=NULL)
Definition value-relation.cc:723
struct obstack m_chain_obstack
Definition value-relation.h:185
vec< bitmap > m_self_equiv
Definition value-relation.h:189
~equiv_oracle()
Definition value-relation.cc:332
equiv_oracle()
Definition value-relation.cc:312
bool add_partial_equiv(relation_kind, tree, tree)
Definition value-relation.cc:345
void dump(FILE *f, basic_block bb) const override
Definition value-relation.cc:733
relation_kind query(basic_block, tree, tree) override
Definition value-relation.cc:482
equiv_chain * find_equiv_block(unsigned ssa, int bb) const
Definition value-relation.cc:508
vec< equiv_chain * > m_equiv
Definition value-relation.h:188
const pe_slice * partial_equiv_set(tree name) final override
Definition value-relation.cc:422
void add_equiv_to_block(basic_block bb, bitmap equiv)
Definition value-relation.cc:692
void register_initial_def(tree ssa)
Definition value-relation.cc:606
bitmap register_equiv(basic_block bb, unsigned v, equiv_chain *equiv_1)
Definition value-relation.cc:542
const pe_slice * m_pe
Definition value-relation.h:308
tree get_name(relation_kind *rel=NULL)
Definition value-relation.cc:1816
tree m_name
Definition value-relation.h:311
relation_oracle * m_oracle
Definition value-relation.h:306
unsigned m_y
Definition value-relation.h:310
bitmap_iterator m_bi
Definition value-relation.h:309
const_bitmap m_bm
Definition value-relation.h:307
void next()
Definition value-relation.cc:1807
equiv_relation_iterator(relation_oracle *oracle, basic_block bb, tree name, bool full=true, bool partial=false)
Definition value-relation.cc:1788
equiv_chain m_equiv
Definition value-relation.h:289
relation_kind query(basic_block, tree, tree) final override
Definition value-relation.cc:1723
relation_oracle * m_root
Definition value-relation.h:291
void reset_path(relation_oracle *oracle=NULL)
Definition value-relation.cc:1743
void dump(FILE *, basic_block) const final override
Definition value-relation.cc:1756
void killing_def(tree)
Definition value-relation.cc:1613
struct obstack m_chain_obstack
Definition value-relation.h:295
bitmap_obstack m_bitmaps
Definition value-relation.h:294
path_oracle(relation_oracle *oracle=NULL)
Definition value-relation.cc:1540
bitmap m_killed_defs
Definition value-relation.h:292
void set_root_oracle(relation_oracle *oracle)
Definition value-relation.h:284
bool record(basic_block, relation_kind, tree, tree) final override
Definition value-relation.cc:1660
~path_oracle()
Definition value-relation.cc:1555
const_bitmap equiv_set(tree, basic_block) final override
Definition value-relation.cc:1565
bool register_equiv(basic_block bb, tree ssa1, tree ssa2)
Definition value-relation.cc:1586
relation_chain_head m_relations
Definition value-relation.h:290
Definition value-relation.h:153
tree ssa_base
Definition value-relation.h:155
relation_kind code
Definition value-relation.h:156
bitmap members
Definition value-relation.h:157
Definition value-relation.h:206
relation_kind find_relation(const_bitmap b1, const_bitmap b2) const
Definition value-relation.cc:1038
bitmap m_names
Definition value-relation.h:208
int m_num_relations
Definition value-relation.h:210
class relation_chain * m_head
Definition value-relation.h:209
Definition value-relation.cc:954
Definition value-relation.h:98
relation_kind query(gimple *s, tree ssa1, tree ssa2)
Definition value-relation.cc:230
virtual void dump(FILE *, basic_block) const
Definition value-relation.h:113
bitmap m_lhs_equiv_set_p
Definition value-relation.h:133
virtual ~relation_oracle()
Definition value-relation.h:101
virtual relation_kind query(basic_block, tree, tree)
Definition value-relation.h:111
friend class path_oracle
Definition value-relation.h:131
virtual void dump(FILE *) const
Definition value-relation.h:114
void debug() const
Definition value-relation.cc:1535
virtual const class pe_slice * partial_equiv_set(tree)
Definition value-relation.h:126
void valid_equivs(bitmap b, const_bitmap equivs, basic_block bb)
Definition value-relation.cc:209
virtual relation_kind query(basic_block, const_bitmap, const_bitmap)
Definition value-relation.h:129
bool record(gimple *, relation_kind, tree, tree)
Definition value-relation.cc:1085
friend class block_relation_iterator
Definition value-relation.h:118
virtual const_bitmap equiv_set(tree, basic_block)
Definition value-relation.h:124
virtual bool record(basic_block, relation_kind, tree, tree)
Definition value-relation.h:106
relation_oracle()
Definition value-relation.h:100
virtual class relation_chain * next_relation(basic_block, relation_chain *, tree) const
Definition value-relation.h:119
friend class equiv_relation_iterator
Definition value-relation.h:117
Definition value-relation.h:339
relation_kind op1_op2()
Definition value-relation.h:413
relation_kind lhs_op2()
Definition value-relation.h:407
unsigned m_val
Definition value-relation.h:354
relation_trio swap_op1_op2()
Definition value-relation.h:419
relation_trio()
Definition value-relation.h:367
relation_kind lhs_op1()
Definition value-relation.h:401
Definition value-relation.h:431
tree name1
Definition value-relation.h:450
relation_trio create_trio(tree lhs, tree op1, tree op2)
Definition value-relation.cc:903
tree name2
Definition value-relation.h:450
bool union_(value_relation &p)
Definition value-relation.cc:817
void set_relation(relation_kind kind, tree n1, tree n2)
Definition value-relation.h:456
void dump(FILE *f) const
Definition value-relation.cc:937
value_relation()
Definition value-relation.h:468
relation_kind kind() const
Definition value-relation.h:437
relation_kind related
Definition value-relation.h:449
bool apply_transitive(const value_relation &rel)
Definition value-relation.cc:836
tree op1() const
Definition value-relation.h:438
void swap()
Definition value-relation.cc:787
tree op2() const
Definition value-relation.h:439
bool intersect(value_relation &p)
Definition value-relation.cc:799
Definition value-range.h:88
struct basic_block_def * basic_block
Definition coretypes.h:372
class edge_def * edge
Definition coretypes.h:369
const class bitmap_head * const_bitmap
Definition coretypes.h:52
class bitmap_head * bitmap
Definition coretypes.h:51
union tree_node * tree
Definition coretypes.h:97
int i2
Definition fp-test.cc:66
int i1
Definition fp-test.cc:66
static struct obstack obstack
Definition gcc.cc:366
#define bitmap_bit_p(bitstring, bitno)
Definition genautomata.cc:3429
poly_int< N, C > r
Definition poly-int.h:774
Ca const poly_int< N, Cb > & b
Definition poly-int.h:771
#define NULL
Definition system.h:50
#define MIN(X, Y)
Definition system.h:399
#define STATIC_ASSERT(X)
Definition system.h:867
#define gcc_checking_assert(EXPR)
Definition system.h:824
#define TREE_CODE(NODE)
Definition tree.h:325
#define NULL_TREE
Definition tree.h:318
relation_oracle default_relation_oracle
Definition value-query.cc:189
void adjust_equivalence_range(vrange &range)
Definition value-relation.cc:191
#define TRIO_MASK
Definition value-relation.h:361
enum relation_kind_t relation_kind
#define TRIO_SHIFT
Definition value-relation.h:360
relation_kind relation_intersect(relation_kind r1, relation_kind r2)
Definition value-relation.cc:105
int pe_to_bits(relation_kind t)
Definition value-relation.h:511
relation_kind_t
Definition value-relation.h:64
@ VREL_PE8
Definition value-relation.h:73
@ VREL_PE16
Definition value-relation.h:74
@ VREL_GT
Definition value-relation.h:69
@ VREL_LT
Definition value-relation.h:67
@ VREL_LE
Definition value-relation.h:68
@ VREL_LAST
Definition value-relation.h:77
@ VREL_NE
Definition value-relation.h:72
@ VREL_EQ
Definition value-relation.h:71
@ VREL_PE32
Definition value-relation.h:75
@ VREL_VARYING
Definition value-relation.h:65
@ VREL_UNDEFINED
Definition value-relation.h:66
@ VREL_GE
Definition value-relation.h:70
@ VREL_PE64
Definition value-relation.h:76
relation_kind relation_union(relation_kind r1, relation_kind r2)
Definition value-relation.cc:142
relation_kind pe_min(relation_kind t1, relation_kind t2)
Definition value-relation.h:552
void print_relation(FILE *f, relation_kind rel)
Definition value-relation.cc:42
bool relation_partial_equiv_p(relation_kind r)
Definition value-relation.h:87
relation_kind bits_to_pe(int bits)
Definition value-relation.h:532
bool relation_equiv_p(relation_kind r)
Definition value-relation.h:89
relation_kind relation_swap(relation_kind r)
Definition value-relation.cc:68
relation_kind relation_negate(relation_kind r)
Definition value-relation.cc:55
bool relation_lt_le_gt_ge_p(relation_kind r)
Definition value-relation.h:85