22#ifndef GCC_VALUE_RANGE_H
23#define GCC_VALUE_RANGE_H
79 template <
typename T>
friend bool is_a (
vrange &);
113 void dump (FILE *)
const;
152 void dump (FILE *)
const;
194 return m_mask.get_precision ();
236 if (unknown1 || unknown2)
237 return unknown1 == unknown2;
260 unsigned prec =
m_mask.get_precision ();
371template<
unsigned N,
bool RESIZABLE = false>
420 bool operator== (const
prange &) const;
550 virtual tree type ()
const override;
556 void set_nan (
tree type,
bool sign);
558 virtual void set_varying (
tree type)
override;
559 virtual void set_undefined ()
override;
560 virtual bool union_ (
const vrange &)
override;
561 virtual bool intersect (
const vrange &)
override;
563 virtual bool singleton_p (
tree *result =
NULL)
const override;
567 virtual bool zero_p ()
const override;
568 virtual bool nonzero_p ()
const override;
569 virtual void set_nonzero (
tree type)
override;
570 virtual void set_zero (
tree type)
override;
571 virtual void set_nonnegative (
tree type)
override;
572 virtual bool fits_p (
const vrange &)
const override;
578 virtual tree lbound ()
const override;
579 virtual tree ubound ()
const override;
582 void update_nan (
bool sign);
656 const T &derived =
static_cast<const T &
> (v);
657 return is_a <T> (
const_cast<T &
> (derived));
665 return static_cast <T &
> (v);
673 return static_cast <const T &
> (v);
720 for (
unsigned i = 0;
i < n; ++
i)
726template<
unsigned N,
bool RESIZABLE>
778 operator const vrange &()
const;
779 void dump (FILE *)
const;
791 {
return m_vrange->singleton_p (result); }
801 {
return m_vrange->update_bitmask (bm); }
806 void init (
const vrange &);
957value_range::operator
const vrange &()
const
1083template<
unsigned N,
bool RESIZABLE>
1090template<
unsigned N,
bool RESIZABLE>
1097template<
unsigned N,
bool RESIZABLE>
1104template<
unsigned N,
bool RESIZABLE>
1111template<
unsigned N,
bool RESIZABLE>
1119template<
unsigned N,
bool RESIZABLE>
1126template<
unsigned N,
bool RESIZABLE>
1248 if (
r.undefined_p ())
1252 return r.contains_p (zero);
1452 set (min, max, kind);
1556 buf,
sizeof (buf),
false);
1756 signbit =
m_min.sign;
1764 || (nan_sign ==
m_min.sign && nan_sign ==
m_max.sign))
Definition value-range.h:533
tree m_type
Definition value-range.h:611
void update_nan(tree)=delete
void set(tree type, const REAL_VALUE_TYPE &, const REAL_VALUE_TYPE &, value_range_kind=VR_RANGE)
Definition value-range.cc:914
void update_nan()
Definition value-range.h:1512
void clear_nan()
Definition value-range.h:1538
REAL_VALUE_TYPE m_min
Definition value-range.h:612
bool known_isfinite() const
Definition value-range.h:1652
bool known_isdenormal_or_zero() const
Definition value-range.h:1676
REAL_VALUE_TYPE m_max
Definition value-range.h:613
bool intersect_nans(const frange &)
Definition value-range.cc:1079
bool maybe_isinf() const
Definition value-range.h:1689
bool internal_singleton_p(REAL_VALUE_TYPE *=NULL) const
Definition value-range.cc:1240
bool m_neg_nan
Definition value-range.h:615
bool known_isnormal() const
Definition value-range.h:1662
bool nan_signbit_p(bool &signbit) const
Definition value-range.h:1776
virtual void set_varying(tree type) override
Definition value-range.h:1463
bool m_pos_nan
Definition value-range.h:614
bool known_isnan() const
Definition value-range.h:1734
void flush_denormals_to_zero()
Definition value-range.cc:815
bool union_nans(const frange &)
Definition value-range.cc:1007
virtual void set_undefined() override
Definition value-range.h:1482
bool maybe_isnan() const
Definition value-range.h:1712
bool normalize_kind()
Definition value-range.cc:937
virtual void verify_range() const override
Definition value-range.cc:1295
bool known_isinf() const
Definition value-range.h:1701
const REAL_VALUE_TYPE & upper_bound() const
Definition value-range.h:626
void set_nan(tree type)
Definition value-range.h:1634
friend class vrange_printer
Definition value-range.h:535
frange()
Definition value-range.h:1415
const REAL_VALUE_TYPE & lower_bound() const
Definition value-range.h:619
bool combine_zeros(const frange &, bool union_p)
Definition value-range.cc:975
friend class frange_storage
Definition value-range.h:534
bool signbit_p(bool &signbit) const
Definition value-range.h:1743
bool contains_p(const REAL_VALUE_TYPE &) const
Definition value-range.cc:1201
static bool supports_p(const_tree type)
Definition value-range.h:543
virtual tree type() const override
Definition value-range.h:1456
nan_state get_nan_state() const
Definition value-range.h:635
Definition value-range.h:373
wide_int m_ranges[N *2]
Definition value-range.h:386
int_range()
Definition value-range.h:1085
int_range(tree type, const wide_int &, const wide_int &, value_range_kind=VR_RANGE)
Definition value-range.h:1112
int_range(tree type)
Definition value-range.h:1105
int_range(const irange &)
Definition value-range.h:1120
int_range(const int_range &)
Definition value-range.h:1091
int_range & operator=(const int_range &)
Definition value-range.h:1128
~int_range() final override
Definition value-range.h:728
Definition value-range.h:135
irange_bitmask(unsigned prec)
Definition value-range.h:138
void dump(FILE *) const
Definition value-range.cc:381
bool range_from_mask(irange &r, tree type) const
Definition value-range.cc:63
void verify_mask() const
Definition value-range.cc:2634
void set_nonzero_bits(const wide_int &bits)
Definition value-range.h:210
unsigned get_precision() const
Definition value-range.h:192
bool member_p(const wide_int &val) const
Definition value-range.h:221
void set_unknown(unsigned prec)
Definition value-range.h:166
bool unknown_p() const
Definition value-range.h:177
void union_(const irange_bitmask &src)
Definition value-range.h:242
bool operator==(const irange_bitmask &src) const
Definition value-range.h:232
wide_int get_nonzero_bits() const
Definition value-range.h:203
wide_int mask() const
Definition value-range.h:143
bool operator!=(const irange_bitmask &src) const
Definition value-range.h:150
irange_bitmask()
Definition value-range.h:137
wide_int m_mask
Definition value-range.h:162
void intersect(const irange_bitmask &src)
Definition value-range.h:251
wide_int m_value
Definition value-range.h:161
wide_int value() const
Definition value-range.h:142
Definition value-range.h:276
friend class irange_storage
Definition value-range.h:277
void invert()
Definition value-range.cc:2268
bool union_bitmask(const irange &r)
Definition value-range.cc:2593
virtual bool nonzero_p() const override
Definition value-range.h:1036
virtual bool zero_p() const override
Definition value-range.h:1028
bool m_resizable
Definition value-range.h:356
virtual bool supports_type_p(const_tree type) const override
Definition value-range.cc:486
virtual void set_nonzero(tree type) override
Definition value-range.h:1195
unsigned num_pairs() const
Definition value-range.h:981
unsigned char m_max_ranges
Definition value-range.h:357
virtual bool union_(const vrange &) override
Definition value-range.cc:1848
virtual void set_nonnegative(tree type) override
Definition value-range.cc:500
bool snap(const wide_int &, const wide_int &, wide_int &, wide_int &, bool &)
Definition value-range.cc:2375
void maybe_resize(int needed)
Definition value-range.h:710
bool union_append(const irange &r)
Definition value-range.cc:1810
virtual void set_varying(tree type) override
Definition value-range.h:1142
virtual tree lbound() const override
Definition value-range.cc:2622
bool intersect_bitmask(const irange &r)
Definition value-range.cc:2565
tree m_type
Definition value-range.h:358
virtual bool contains_p(tree cst) const override
Definition value-range.h:1052
virtual bool intersect(const vrange &) override
Definition value-range.cc:2038
bool nonnegative_p() const
Definition value-range.cc:474
virtual irange_bitmask get_bitmask() const override
Definition value-range.cc:2505
wide_int * m_base
Definition value-range.h:361
static const int HARD_MAX_RANGES
Definition value-range.h:343
bool operator==(const irange &) const
Definition value-range.cc:1652
virtual bool fits_p(const vrange &r) const override
Definition value-range.cc:494
void set(tree type, const wide_int &, const wide_int &, value_range_kind=VR_RANGE)
Definition value-range.cc:1528
unsigned char m_num_ranges
Definition value-range.h:355
virtual void accept(const vrange_visitor &v) const override
Definition value-range.cc:146
bool irange_single_pair_union(const irange &r)
Definition value-range.cc:1743
virtual bool singleton_p(tree *result=NULL) const override
Definition value-range.cc:1689
static bool supports_p(const_tree type)
Definition value-range.h:1046
wide_int upper_bound() const
Definition value-range.h:1185
wide_int lower_bound(unsigned=0) const
Definition value-range.h:1164
irange_bitmask m_bitmask
Definition value-range.h:359
virtual void set_undefined() override
Definition value-range.h:1135
virtual tree ubound() const override
Definition value-range.cc:2628
bool nonpositive_p() const
Definition value-range.cc:480
irange & operator=(const irange &)
Definition value-range.cc:1407
friend class vrange_printer
Definition value-range.h:278
virtual void set_zero(tree type) override
Definition value-range.h:1221
virtual void update_bitmask(const class irange_bitmask &) override
Definition value-range.cc:2482
bool contains_p(const wide_int &) const
Definition value-range.cc:1718
bool set_range_from_bitmask()
Definition value-range.cc:2465
bool irange_contains_p(const irange &) const
Definition value-range.cc:1987
bool varying_compatible_p() const
Definition value-range.h:994
virtual tree type() const override
Definition value-range.h:987
void normalize_kind()
Definition value-range.h:1230
bool snap_subranges()
Definition value-range.cc:2426
wide_int upper_bound(unsigned) const
Definition value-range.h:1175
bool operator!=(const irange &r) const
Definition value-range.h:319
irange(wide_int *, unsigned nranges, bool resizable)
Definition value-range.h:1072
virtual void verify_range() const override
Definition value-range.cc:1605
Definition value-range.h:479
bool neg_p() const
Definition value-range.h:522
bool m_neg_nan
Definition value-range.h:487
bool pos_p() const
Definition value-range.h:514
bool m_pos_nan
Definition value-range.h:486
nan_state(bool)
Definition value-range.h:494
Definition value-range.h:390
virtual bool supports_type_p(const_tree type) const final override
Definition value-range.h:1305
wide_int m_min
Definition value-range.h:434
virtual bool intersect(const vrange &v) final override
Definition value-range.cc:645
virtual void set_nonnegative(tree type) final override
Definition value-range.cc:516
void invert()
Definition value-range.cc:723
prange()
Definition value-range.h:1270
virtual void verify_range() const final override
Definition value-range.cc:755
virtual tree lbound() const final override
Definition value-range.cc:593
wide_int upper_bound() const
Definition value-range.h:1388
irange_bitmask get_bitmask() const final override
Definition value-range.h:1402
wide_int m_max
Definition value-range.h:435
virtual bool contains_p(tree cst) const final override
Definition value-range.h:1356
tree m_type
Definition value-range.h:433
bool varying_compatible_p() const
Definition value-range.h:1395
virtual void set_varying(tree type) final override
Definition value-range.h:1317
static bool supports_p(const_tree type)
Definition value-range.h:1299
virtual void set_zero(tree type) final override
Definition value-range.h:1343
wide_int lower_bound() const
Definition value-range.h:1381
virtual bool fits_p(const vrange &v) const final override
Definition value-range.h:1408
virtual bool zero_p() const final override
Definition value-range.h:1362
virtual void set_undefined() final override
Definition value-range.h:1311
void update_bitmask(const irange_bitmask &) final override
Definition value-range.cc:774
virtual void set_nonzero(tree type) final override
Definition value-range.h:1330
virtual bool nonzero_p() const final override
Definition value-range.h:1368
friend class vrange_printer
Definition value-range.h:392
friend class prange_storage
Definition value-range.h:391
virtual bool singleton_p(tree *result=NULL) const final override
Definition value-range.cc:581
virtual tree ubound() const final override
Definition value-range.cc:599
virtual tree type() const final override
Definition value-range.h:1374
virtual void set(tree, tree, value_range_kind=VR_RANGE) final override
Definition value-range.cc:524
virtual bool union_(const vrange &v) final override
Definition value-range.cc:605
irange_bitmask m_bitmask
Definition value-range.h:436
Definition value-range.h:443
unsupported_range & operator=(const unsupported_range &r)
Definition value-range.cc:310
unsupported_range(const unsupported_range &src)
Definition value-range.h:450
unsupported_range()
Definition value-range.h:445
Definition value-range.h:764
void verify_range() const
Definition value-range.h:803
void set_zero(tree type)
Definition value-range.h:792
~value_range()
Definition value-range.h:865
bool undefined_p() const
Definition value-range.h:784
bool contains_p(tree cst) const
Definition value-range.h:789
static bool supports_type_p(const_tree type)
Definition value-range.h:965
void accept(const vrange_visitor &v) const
Definition value-range.h:802
bool nonzero_p() const
Definition value-range.h:795
bool varying_p() const
Definition value-range.h:783
vrange * m_vrange
Definition value-range.h:808
tree type()
Definition value-range.h:782
irange_bitmask get_bitmask() const
Definition value-range.h:799
tree ubound() const
Definition value-range.h:798
value_range()
Definition value-range.h:823
bool intersect(const vrange &r)
Definition value-range.h:788
void update_bitmask(const class irange_bitmask &bm)
Definition value-range.h:800
bool union_(const vrange &r)
Definition value-range.h:787
void set_nonzero(tree type)
Definition value-range.h:793
void set_type(tree type)
Definition value-range.h:875
void set_undefined()
Definition value-range.h:786
bool zero_p() const
Definition value-range.h:796
bool operator!=(const value_range &r) const
Definition value-range.h:945
bool singleton_p(tree *result=NULL) const
Definition value-range.h:790
tree lbound() const
Definition value-range.h:797
void set_varying(tree type)
Definition value-range.h:785
vrange & operator=(const vrange &)
Definition value-range.h:921
union value_range::buffer_type m_buffer
bool operator==(const value_range &r) const
Definition value-range.h:939
void init(tree type)
Definition value-range.h:886
Definition value-range.h:741
virtual void visit(const unsupported_range &) const
Definition value-range.h:746
virtual void visit(const irange &) const
Definition value-range.h:743
virtual void visit(const frange &) const
Definition value-range.h:745
virtual void visit(const prange &) const
Definition value-range.h:744
Definition value-range.h:78
virtual void verify_range() const
Definition value-range.h:114
friend class value_range
Definition value-range.h:80
virtual irange_bitmask get_bitmask() const
Definition value-range.cc:188
vrange(enum value_range_discriminator d)
Definition value-range.h:116
enum value_range_kind m_kind
Definition value-range.h:117
virtual bool singleton_p(tree *result=NULL) const =0
bool operator!=(const vrange &r) const
Definition value-range.h:112
virtual bool supports_type_p(const_tree type) const =0
virtual void set_zero(tree type)=0
virtual bool union_(const vrange &)=0
virtual ~vrange()
Definition value-range.h:100
virtual bool nonzero_p() const =0
friend class range_op_handler
Definition value-range.h:82
virtual bool zero_p() const =0
virtual void set(tree, tree, value_range_kind=VR_RANGE)=0
virtual void set_varying(tree type)=0
bool undefined_p() const
Definition value-range.h:1022
enum value_range_discriminator m_discriminator
Definition value-range.h:118
virtual void set_undefined()=0
virtual bool intersect(const vrange &)=0
virtual void set_nonzero(tree type)=0
virtual void update_bitmask(const class irange_bitmask &)
Definition value-range.cc:183
virtual tree ubound() const =0
friend bool is_a(vrange &)
Definition value-range.h:645
void set_nonzero_bits(const wide_int &bits)
Definition value-range.cc:2544
virtual void set_nonnegative(tree type)=0
virtual void accept(const class vrange_visitor &v) const =0
virtual bool contains_p(tree cst) const =0
vrange & operator=(const vrange &)
Definition value-range.cc:337
virtual tree lbound() const =0
virtual tree type() const =0
void dump(FILE *) const
Definition value-range.cc:370
friend void streamer_write_vrange(struct output_block *, const vrange &)
Definition data-streamer-out.cc:408
wide_int get_nonzero_bits() const
Definition value-range.cc:2554
virtual bool fits_p(const vrange &r) const =0
bool varying_p() const
Definition value-range.h:1016
bool operator==(const vrange &) const
Definition value-range.cc:356
const union tree_node * const_tree
Definition coretypes.h:98
union tree_node * tree
Definition coretypes.h:97
static bool operator!=(cfa_reg &cfa, rtx reg)
Definition dwarf2cfi.cc:1174
static bool operator==(cfa_reg &cfa, rtx reg)
Definition dwarf2cfi.cc:1164
REAL_VALUE_TYPE dconstninf
Definition emit-rtl.cc:114
REAL_VALUE_TYPE dconstinf
Definition emit-rtl.cc:113
void final(rtx_insn *first, FILE *file, int optimize_p)
Definition final.cc:2009
static type_p type(options_p *optsp, bool nested)
Definition gengtype-parse.cc:883
static struct token T
Definition gengtype-parse.cc:45
tree_code
Definition genmatch.cc:1002
#define N
Definition gensupport.cc:202
Definition fold-const.cc:4345
void add_vrange(const vrange &v, inchash::hash &hstate, unsigned int)
Definition value-range.cc:407
wide_int min_value(machine_mode, signop)
Definition rtl.h:2364
hwi_with_prec minus_one(unsigned int)
Definition wide-int.h:2011
hwi_with_prec zero(unsigned int)
Definition wide-int.h:2018
BINARY_FUNCTION bit_and(const T1 &, const T2 &)
wide_int max_value(machine_mode, signop)
Definition rtl.h:2372
tree_to_wide_ref to_wide(const_tree)
Definition tree.h:6537
hwi_with_prec one(unsigned int)
Definition wide-int.h:2025
poly_int< N, C > r
Definition poly-int.h:774
i
Definition poly-int.h:776
static bool maybe_isnan(const frange &op1, const frange &op2)
Definition range-op-float.cc:239
static bool zero_p(const REAL_VALUE_TYPE &lb, const REAL_VALUE_TYPE &ub)
Definition range-op-float.cc:2266
int real_from_string(REAL_VALUE_TYPE *r, const char *str)
Definition real.cc:2011
bool HONOR_NANS(machine_mode m)
Definition real.cc:5517
REAL_VALUE_TYPE real_value_negate(const REAL_VALUE_TYPE *op0)
Definition real.cc:1115
bool real_isneg(const REAL_VALUE_TYPE *r)
Definition real.cc:1280
bool real_isinf(const REAL_VALUE_TYPE *r)
Definition real.cc:1242
static bool real_isdenormal(const REAL_VALUE_TYPE *r)
Definition real.cc:120
bool real_identical(const REAL_VALUE_TYPE *a, const REAL_VALUE_TYPE *b)
Definition real.cc:1312
bool HONOR_INFINITIES(machine_mode m)
Definition real.cc:5558
bool real_iszero(const REAL_VALUE_TYPE *r)
Definition real.cc:1288
void get_max_float(const struct real_format *fmt, char *buf, size_t len, bool norm_max)
Definition real.cc:5455
#define REAL_MODE_FORMAT(MODE)
Definition real.h:183
#define REAL_VALUE_TYPE
Definition real.h:68
signop
Definition signop.h:28
@ UNSIGNED
Definition signop.h:30
Definition lto-streamer.h:709
Definition gengtype.h:218
Definition gengtype.h:252
#define NULL
Definition system.h:50
#define gcc_unreachable()
Definition system.h:841
#define gcc_checking_assert(EXPR)
Definition system.h:821
tree build_zero_cst(tree type)
Definition tree.cc:2778
#define DECIMAL_FLOAT_TYPE_P(TYPE)
Definition tree.h:681
#define TYPE_PRECISION(NODE)
Definition tree.h:2360
#define SCALAR_FLOAT_TYPE_P(TYPE)
Definition tree.h:649
#define TREE_REAL_CST_PTR(NODE)
Definition tree.h:1174
#define TYPE_UNSIGNED(NODE)
Definition tree.h:963
#define TYPE_MODE(NODE)
Definition tree.h:2369
#define TYPE_SIGN(NODE)
Definition tree.h:966
#define POINTER_TYPE_P(TYPE)
Definition tree.h:701
#define TYPE_P(NODE)
Definition tree.h:227
#define TREE_TYPE(NODE)
Definition tree.h:513
#define INTEGRAL_TYPE_P(TYPE)
Definition tree.h:614
#define error_mark_node
Definition tree.h:4531
unsupported_range unsupported
Definition value-range.h:812
buffer_type()
Definition value-range.h:814
prange pointers
Definition value-range.h:813
~buffer_type()
Definition value-range.h:815
frange floats
Definition value-range.h:811
int_range_max ints
Definition value-range.h:810
T & as_a(vrange &v)
Definition value-range.h:662
REAL_VALUE_TYPE frange_val_max(const_tree type)
Definition value-range.h:1586
bool range_includes_zero_p(const vrange &vr)
Definition value-range.h:1058
wide_int irange_val_max(const_tree type)
Definition value-range.h:1263
value_range_kind
Definition value-range.h:29
@ VR_ANTI_RANGE
Definition value-range.h:37
@ VR_RANGE
Definition value-range.h:35
@ VR_LAST
Definition value-range.h:41
@ VR_NAN
Definition value-range.h:39
@ VR_VARYING
Definition value-range.h:33
@ VR_UNDEFINED
Definition value-range.h:31
void dump_value_range(FILE *, const vrange *)
Definition value-range.cc:2641
bool is_a< prange >(vrange &v)
Definition value-range.h:687
bool is_a< unsupported_range >(vrange &v)
Definition value-range.h:701
value_range_discriminator
Definition value-range.h:47
@ VR_UNKNOWN
Definition value-range.h:55
@ VR_IRANGE
Definition value-range.h:49
@ VR_PRANGE
Definition value-range.h:51
@ VR_FRANGE
Definition value-range.h:53
REAL_VALUE_TYPE real_min_representable(const_tree type)
Definition value-range.h:1565
void frange_arithmetic(enum tree_code, tree, REAL_VALUE_TYPE &, const REAL_VALUE_TYPE &, const REAL_VALUE_TYPE &, const REAL_VALUE_TYPE &)
Definition range-op-float.cc:331
int_range< 3, true > int_range_max
Definition value-range.h:738
value_range_kind get_legacy_range(const vrange &, tree &min, tree &max)
Definition value-range.cc:1510
bool is_a< frange >(vrange &v)
Definition value-range.h:694
void frange_nextafter(enum machine_mode, REAL_VALUE_TYPE &, const REAL_VALUE_TYPE &)
Definition range-op-float.cc:298
REAL_VALUE_TYPE real_max_representable(const_tree type)
Definition value-range.h:1551
wide_int irange_val_min(const_tree type)
Definition value-range.h:1256
bool range_compatible_p(tree type1, tree type2)
Definition value-range.h:1797
bool frange_val_is_min(const REAL_VALUE_TYPE &r, const_tree type)
Definition value-range.h:1597
bool contains_zero_p(const irange &r)
Definition value-range.h:1246
bool frange_val_is_max(const REAL_VALUE_TYPE &r, const_tree type)
Definition value-range.h:1606
bool vrp_operand_equal_p(const_tree, const_tree)
Definition value-range.cc:2662
REAL_VALUE_TYPE frange_val_min(const_tree type)
Definition value-range.h:1575
bool is_a< irange >(vrange &v)
Definition value-range.h:680
generic_wide_int< wide_int_storage > wide_int
Definition wide-int.h:343