22#ifndef GCC_VALUE_RANGE_H
23#define GCC_VALUE_RANGE_H
89 template <
typename T>
friend bool is_a (
vrange &);
123 void dump (FILE *)
const;
167 void dump (FILE *)
const;
209 return m_mask.get_precision ();
251 if (unknown1 || unknown2)
252 return unknown1 == unknown2;
384template<
unsigned N,
bool RESIZABLE = false>
433 bool operator== (const
prange &) const;
565 virtual tree type ()
const override;
571 void set_nan (
tree type,
bool sign);
573 virtual void set_varying (
tree type)
override;
574 virtual void set_undefined ()
override;
575 virtual bool union_ (
const vrange &)
override;
576 virtual bool intersect (
const vrange &)
override;
578 virtual bool singleton_p (
tree *result =
NULL)
const override;
582 virtual bool zero_p ()
const override;
583 virtual bool nonzero_p ()
const override;
584 virtual void set_nonzero (
tree type)
override;
585 virtual void set_zero (
tree type)
override;
586 virtual void set_nonnegative (
tree type)
override;
587 virtual bool fits_p (
const vrange &)
const override;
593 virtual tree lbound ()
const override;
594 virtual tree ubound ()
const override;
597 void update_nan (
bool sign);
671 const T &derived =
static_cast<const T &
> (v);
672 return is_a <T> (
const_cast<T &
> (derived));
680 return static_cast <T &
> (v);
688 return static_cast <const T &
> (v);
735 for (
unsigned i = 0;
i < n; ++
i)
741template<
unsigned N,
bool RESIZABLE>
793 operator const vrange &()
const;
794 void dump (FILE *)
const;
806 {
return m_vrange->singleton_p (result); }
816 {
return m_vrange->update_bitmask (bm); }
821 void init (
const vrange &);
972value_range::operator
const vrange &()
const
1098template<
unsigned N,
bool RESIZABLE>
1105template<
unsigned N,
bool RESIZABLE>
1112template<
unsigned N,
bool RESIZABLE>
1119template<
unsigned N,
bool RESIZABLE>
1126template<
unsigned N,
bool RESIZABLE>
1134template<
unsigned N,
bool RESIZABLE>
1141template<
unsigned N,
bool RESIZABLE>
1263 if (
r.undefined_p ())
1267 return r.contains_p (zero);
1467 set (min, max, kind);
1571 buf,
sizeof (buf),
false);
1771 signbit =
m_min.sign;
1779 || (nan_sign ==
m_min.sign && nan_sign ==
m_max.sign))
Definition value-range.h:548
tree m_type
Definition value-range.h:626
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:916
void update_nan()
Definition value-range.h:1527
void clear_nan()
Definition value-range.h:1553
REAL_VALUE_TYPE m_min
Definition value-range.h:627
bool known_isfinite() const
Definition value-range.h:1667
bool known_isdenormal_or_zero() const
Definition value-range.h:1691
REAL_VALUE_TYPE m_max
Definition value-range.h:628
bool intersect_nans(const frange &)
Definition value-range.cc:1081
bool maybe_isinf() const
Definition value-range.h:1704
bool internal_singleton_p(REAL_VALUE_TYPE *=NULL) const
Definition value-range.cc:1242
bool m_neg_nan
Definition value-range.h:630
bool known_isnormal() const
Definition value-range.h:1677
bool nan_signbit_p(bool &signbit) const
Definition value-range.h:1791
virtual void set_varying(tree type) override
Definition value-range.h:1478
bool m_pos_nan
Definition value-range.h:629
bool known_isnan() const
Definition value-range.h:1749
void flush_denormals_to_zero()
Definition value-range.cc:817
bool union_nans(const frange &)
Definition value-range.cc:1009
virtual void set_undefined() override
Definition value-range.h:1497
bool maybe_isnan() const
Definition value-range.h:1727
bool normalize_kind()
Definition value-range.cc:939
virtual void verify_range() const override
Definition value-range.cc:1297
bool known_isinf() const
Definition value-range.h:1716
const REAL_VALUE_TYPE & upper_bound() const
Definition value-range.h:641
void set_nan(tree type)
Definition value-range.h:1649
friend class vrange_printer
Definition value-range.h:550
frange()
Definition value-range.h:1430
const REAL_VALUE_TYPE & lower_bound() const
Definition value-range.h:634
bool combine_zeros(const frange &, bool union_p)
Definition value-range.cc:977
friend class frange_storage
Definition value-range.h:549
bool signbit_p(bool &signbit) const
Definition value-range.h:1758
bool contains_p(const REAL_VALUE_TYPE &) const
Definition value-range.cc:1203
static bool supports_p(const_tree type)
Definition value-range.h:558
virtual tree type() const override
Definition value-range.h:1471
nan_state get_nan_state() const
Definition value-range.h:650
Definition value-range.h:386
wide_int m_ranges[N *2]
Definition value-range.h:399
int_range()
Definition value-range.h:1100
int_range(tree type, const wide_int &, const wide_int &, value_range_kind=VR_RANGE)
Definition value-range.h:1127
int_range(tree type)
Definition value-range.h:1120
int_range(const irange &)
Definition value-range.h:1135
int_range(const int_range &)
Definition value-range.h:1106
int_range & operator=(const int_range &)
Definition value-range.h:1143
~int_range() final override
Definition value-range.h:743
Definition value-range.h:150
irange_bitmask(unsigned prec)
Definition value-range.h:153
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:2646
void set_nonzero_bits(const wide_int &bits)
Definition value-range.h:225
unsigned get_precision() const
Definition value-range.h:207
bool member_p(const wide_int &val) const
Definition value-range.h:236
void set_unknown(unsigned prec)
Definition value-range.h:181
bool unknown_p() const
Definition value-range.h:192
void union_(const irange_bitmask &src)
Definition value-range.h:257
bool operator==(const irange_bitmask &src) const
Definition value-range.h:247
wide_int get_nonzero_bits() const
Definition value-range.h:218
wide_int mask() const
Definition value-range.h:158
bool operator!=(const irange_bitmask &src) const
Definition value-range.h:165
bool intersect(const irange_bitmask &src)
Definition value-range.h:268
irange_bitmask()
Definition value-range.h:152
wide_int m_mask
Definition value-range.h:177
wide_int m_value
Definition value-range.h:176
wide_int value() const
Definition value-range.h:157
Definition value-range.h:289
friend class irange_storage
Definition value-range.h:290
void invert()
Definition value-range.cc:2277
bool union_bitmask(const irange &r)
Definition value-range.cc:2605
virtual bool nonzero_p() const override
Definition value-range.h:1051
virtual bool zero_p() const override
Definition value-range.h:1043
bool m_resizable
Definition value-range.h:369
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:1210
unsigned num_pairs() const
Definition value-range.h:996
unsigned char m_max_ranges
Definition value-range.h:370
virtual bool union_(const vrange &) override
Definition value-range.cc:1850
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:2384
void maybe_resize(int needed)
Definition value-range.h:725
bool union_append(const irange &r)
Definition value-range.cc:1812
virtual void set_varying(tree type) override
Definition value-range.h:1157
virtual tree lbound() const override
Definition value-range.cc:2634
bool intersect_bitmask(const irange &r)
Definition value-range.cc:2573
tree m_type
Definition value-range.h:371
virtual bool contains_p(tree cst) const override
Definition value-range.h:1067
virtual bool intersect(const vrange &) override
Definition value-range.cc:2040
bool nonnegative_p() const
Definition value-range.cc:474
virtual irange_bitmask get_bitmask() const override
Definition value-range.cc:2514
wide_int * m_base
Definition value-range.h:374
static const int HARD_MAX_RANGES
Definition value-range.h:356
bool operator==(const irange &) const
Definition value-range.cc:1654
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:1530
unsigned char m_num_ranges
Definition value-range.h:368
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:1745
virtual bool singleton_p(tree *result=NULL) const override
Definition value-range.cc:1691
static bool supports_p(const_tree type)
Definition value-range.h:1061
wide_int upper_bound() const
Definition value-range.h:1200
wide_int lower_bound(unsigned=0) const
Definition value-range.h:1179
irange_bitmask m_bitmask
Definition value-range.h:372
virtual void set_undefined() override
Definition value-range.h:1150
virtual tree ubound() const override
Definition value-range.cc:2640
bool nonpositive_p() const
Definition value-range.cc:480
irange & operator=(const irange &)
Definition value-range.cc:1409
friend class vrange_printer
Definition value-range.h:291
virtual void set_zero(tree type) override
Definition value-range.h:1236
virtual void update_bitmask(const class irange_bitmask &) override
Definition value-range.cc:2491
bool contains_p(const wide_int &) const
Definition value-range.cc:1720
bool set_range_from_bitmask()
Definition value-range.cc:2474
bool irange_contains_p(const irange &) const
Definition value-range.cc:1989
bool varying_compatible_p() const
Definition value-range.h:1009
virtual tree type() const override
Definition value-range.h:1002
void normalize_kind()
Definition value-range.h:1245
bool snap_subranges()
Definition value-range.cc:2435
wide_int upper_bound(unsigned) const
Definition value-range.h:1190
bool operator!=(const irange &r) const
Definition value-range.h:332
irange(wide_int *, unsigned nranges, bool resizable)
Definition value-range.h:1087
virtual void verify_range() const override
Definition value-range.cc:1607
Definition value-range.h:494
bool neg_p() const
Definition value-range.h:537
bool m_neg_nan
Definition value-range.h:502
bool pos_p() const
Definition value-range.h:529
bool m_pos_nan
Definition value-range.h:501
nan_state(bool)
Definition value-range.h:509
Definition value-range.h:403
virtual bool supports_type_p(const_tree type) const final override
Definition value-range.h:1320
wide_int m_min
Definition value-range.h:447
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:725
prange()
Definition value-range.h:1285
virtual void verify_range() const final override
Definition value-range.cc:757
virtual tree lbound() const final override
Definition value-range.cc:593
wide_int upper_bound() const
Definition value-range.h:1403
irange_bitmask get_bitmask() const final override
Definition value-range.h:1417
wide_int m_max
Definition value-range.h:448
virtual bool contains_p(tree cst) const final override
Definition value-range.h:1371
tree m_type
Definition value-range.h:446
bool varying_compatible_p() const
Definition value-range.h:1410
virtual void set_varying(tree type) final override
Definition value-range.h:1332
static bool supports_p(const_tree type)
Definition value-range.h:1314
virtual void set_zero(tree type) final override
Definition value-range.h:1358
wide_int lower_bound() const
Definition value-range.h:1396
virtual bool fits_p(const vrange &v) const final override
Definition value-range.h:1423
virtual bool zero_p() const final override
Definition value-range.h:1377
virtual void set_undefined() final override
Definition value-range.h:1326
void update_bitmask(const irange_bitmask &) final override
Definition value-range.cc:776
virtual void set_nonzero(tree type) final override
Definition value-range.h:1345
virtual bool nonzero_p() const final override
Definition value-range.h:1383
friend class vrange_printer
Definition value-range.h:405
friend class prange_storage
Definition value-range.h:404
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:1389
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:449
Definition value-range.h:456
unsupported_range & operator=(const unsupported_range &r)
Definition value-range.cc:310
unsupported_range(const unsupported_range &src)
Definition value-range.h:463
unsupported_range()
Definition value-range.h:458
Definition value-range.h:779
void verify_range() const
Definition value-range.h:818
void set_zero(tree type)
Definition value-range.h:807
~value_range()
Definition value-range.h:880
bool undefined_p() const
Definition value-range.h:799
bool contains_p(tree cst) const
Definition value-range.h:804
static bool supports_type_p(const_tree type)
Definition value-range.h:980
void accept(const vrange_visitor &v) const
Definition value-range.h:817
bool nonzero_p() const
Definition value-range.h:810
bool varying_p() const
Definition value-range.h:798
vrange * m_vrange
Definition value-range.h:823
tree type()
Definition value-range.h:797
irange_bitmask get_bitmask() const
Definition value-range.h:814
tree ubound() const
Definition value-range.h:813
value_range()
Definition value-range.h:838
bool intersect(const vrange &r)
Definition value-range.h:803
void update_bitmask(const class irange_bitmask &bm)
Definition value-range.h:815
bool union_(const vrange &r)
Definition value-range.h:802
void set_nonzero(tree type)
Definition value-range.h:808
void set_type(tree type)
Definition value-range.h:890
void set_undefined()
Definition value-range.h:801
bool zero_p() const
Definition value-range.h:811
bool operator!=(const value_range &r) const
Definition value-range.h:960
bool singleton_p(tree *result=NULL) const
Definition value-range.h:805
tree lbound() const
Definition value-range.h:812
void set_varying(tree type)
Definition value-range.h:800
vrange & operator=(const vrange &)
Definition value-range.h:936
union value_range::buffer_type m_buffer
bool operator==(const value_range &r) const
Definition value-range.h:954
void init(tree type)
Definition value-range.h:901
Definition value-range.h:756
virtual void visit(const unsupported_range &) const
Definition value-range.h:761
virtual void visit(const irange &) const
Definition value-range.h:758
virtual void visit(const frange &) const
Definition value-range.h:760
virtual void visit(const prange &) const
Definition value-range.h:759
Definition value-range.h:88
virtual void verify_range() const
Definition value-range.h:124
friend class value_range
Definition value-range.h:90
virtual irange_bitmask get_bitmask() const
Definition value-range.cc:188
vrange(enum value_range_discriminator d)
Definition value-range.h:126
enum value_range_kind m_kind
Definition value-range.h:127
virtual bool singleton_p(tree *result=NULL) const =0
bool operator!=(const vrange &r) const
Definition value-range.h:122
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:110
virtual bool nonzero_p() const =0
friend class range_op_handler
Definition value-range.h:92
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:1037
enum value_range_discriminator m_discriminator
Definition value-range.h:128
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:660
void set_nonzero_bits(const wide_int &bits)
Definition value-range.cc:2552
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:2562
virtual bool fits_p(const vrange &r) const =0
bool varying_p() const
Definition value-range.h:1031
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:4353
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:6588
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:844
#define gcc_checking_assert(EXPR)
Definition system.h:824
tree build_zero_cst(tree type)
Definition tree.cc:2782
#define DECIMAL_FLOAT_TYPE_P(TYPE)
Definition tree.h:681
#define TYPE_PRECISION(NODE)
Definition tree.h:2389
#define SCALAR_FLOAT_TYPE_P(TYPE)
Definition tree.h:649
#define TREE_REAL_CST_PTR(NODE)
Definition tree.h:1173
#define TYPE_UNSIGNED(NODE)
Definition tree.h:968
#define TYPE_MODE(NODE)
Definition tree.h:2398
#define TYPE_SIGN(NODE)
Definition tree.h:971
#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:4565
unsupported_range unsupported
Definition value-range.h:827
buffer_type()
Definition value-range.h:829
prange pointers
Definition value-range.h:828
~buffer_type()
Definition value-range.h:830
frange floats
Definition value-range.h:826
int_range_max ints
Definition value-range.h:825
T & as_a(vrange &v)
Definition value-range.h:677
REAL_VALUE_TYPE frange_val_max(const_tree type)
Definition value-range.h:1601
bool range_includes_zero_p(const vrange &vr)
Definition value-range.h:1073
wide_int irange_val_max(const_tree type)
Definition value-range.h:1278
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:2653
bool is_a< prange >(vrange &v)
Definition value-range.h:702
bool is_a< unsupported_range >(vrange &v)
Definition value-range.h:716
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:1580
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:753
value_range_kind get_legacy_range(const vrange &, tree &min, tree &max)
Definition value-range.cc:1512
bool is_a< frange >(vrange &v)
Definition value-range.h:709
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:1566
wide_int irange_val_min(const_tree type)
Definition value-range.h:1271
bool range_compatible_p(tree type1, tree type2)
Definition value-range.h:1812
bool frange_val_is_min(const REAL_VALUE_TYPE &r, const_tree type)
Definition value-range.h:1612
bool contains_zero_p(const irange &r)
Definition value-range.h:1261
bool frange_val_is_max(const REAL_VALUE_TYPE &r, const_tree type)
Definition value-range.h:1621
bool vrp_operand_equal_p(const_tree, const_tree)
Definition value-range.cc:2674
REAL_VALUE_TYPE frange_val_min(const_tree type)
Definition value-range.h:1590
bool is_a< irange >(vrange &v)
Definition value-range.h:695
generic_wide_int< wide_int_storage > wide_int
Definition wide-int.h:343