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;
807 {
return m_vrange->singleton_p (result); }
817 {
return m_vrange->update_bitmask (bm); }
822 void init (
const vrange &);
975value_range::operator
const vrange &()
const
1101template<
unsigned N,
bool RESIZABLE>
1108template<
unsigned N,
bool RESIZABLE>
1115template<
unsigned N,
bool RESIZABLE>
1122template<
unsigned N,
bool RESIZABLE>
1129template<
unsigned N,
bool RESIZABLE>
1137template<
unsigned N,
bool RESIZABLE>
1144template<
unsigned N,
bool RESIZABLE>
1266 if (
r.undefined_p ())
1270 return r.contains_p (zero);
1470 set (min, max, kind);
1574 buf,
sizeof (buf),
false);
1774 signbit =
m_min.sign;
1782 || (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:928
void update_nan()
Definition value-range.h:1530
void clear_nan()
Definition value-range.h:1556
REAL_VALUE_TYPE m_min
Definition value-range.h:627
bool known_isfinite() const
Definition value-range.h:1670
bool known_isdenormal_or_zero() const
Definition value-range.h:1694
REAL_VALUE_TYPE m_max
Definition value-range.h:628
bool intersect_nans(const frange &)
Definition value-range.cc:1093
bool maybe_isinf() const
Definition value-range.h:1707
bool internal_singleton_p(REAL_VALUE_TYPE *=NULL) const
Definition value-range.cc:1254
bool m_neg_nan
Definition value-range.h:630
bool known_isnormal() const
Definition value-range.h:1680
bool nan_signbit_p(bool &signbit) const
Definition value-range.h:1794
virtual void set_varying(tree type) override
Definition value-range.h:1481
bool m_pos_nan
Definition value-range.h:629
bool known_isnan() const
Definition value-range.h:1752
void flush_denormals_to_zero()
Definition value-range.cc:829
bool union_nans(const frange &)
Definition value-range.cc:1021
virtual void set_undefined() override
Definition value-range.h:1500
bool maybe_isnan() const
Definition value-range.h:1730
bool normalize_kind()
Definition value-range.cc:951
virtual void verify_range() const override
Definition value-range.cc:1309
bool known_isinf() const
Definition value-range.h:1719
const REAL_VALUE_TYPE & upper_bound() const
Definition value-range.h:641
void set_nan(tree type)
Definition value-range.h:1652
friend class vrange_printer
Definition value-range.h:550
frange()
Definition value-range.h:1433
const REAL_VALUE_TYPE & lower_bound() const
Definition value-range.h:634
bool combine_zeros(const frange &, bool union_p)
Definition value-range.cc:989
friend class frange_storage
Definition value-range.h:549
bool signbit_p(bool &signbit) const
Definition value-range.h:1761
bool contains_p(const REAL_VALUE_TYPE &) const
Definition value-range.cc:1215
static bool supports_p(const_tree type)
Definition value-range.h:558
virtual tree type() const override
Definition value-range.h:1474
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:1103
int_range(tree type, const wide_int &, const wide_int &, value_range_kind=VR_RANGE)
Definition value-range.h:1130
int_range(tree type)
Definition value-range.h:1123
int_range(const irange &)
Definition value-range.h:1138
int_range(const int_range &)
Definition value-range.h:1109
int_range & operator=(const int_range &)
Definition value-range.h:1146
~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:393
bool range_from_mask(irange &r, tree type) const
Definition value-range.cc:63
void verify_mask() const
Definition value-range.cc:2674
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:2305
bool union_bitmask(const irange &r)
Definition value-range.cc:2633
virtual bool nonzero_p() const override
Definition value-range.h:1054
virtual bool zero_p() const override
Definition value-range.h:1046
bool m_resizable
Definition value-range.h:369
virtual bool supports_type_p(const_tree type) const override
Definition value-range.cc:498
virtual void set_nonzero(tree type) override
Definition value-range.h:1213
unsigned num_pairs() const
Definition value-range.h:999
unsigned char m_max_ranges
Definition value-range.h:370
virtual bool union_(const vrange &) override
Definition value-range.cc:1862
virtual void set_nonnegative(tree type) override
Definition value-range.cc:512
bool snap(const wide_int &, const wide_int &, wide_int &, wide_int &, bool &)
Definition value-range.cc:2412
void maybe_resize(int needed)
Definition value-range.h:725
bool union_append(const irange &r)
Definition value-range.cc:1824
virtual void set_varying(tree type) override
Definition value-range.h:1160
virtual tree lbound() const override
Definition value-range.cc:2662
bool intersect_bitmask(const irange &r)
Definition value-range.cc:2601
tree m_type
Definition value-range.h:371
virtual bool contains_p(tree cst) const override
Definition value-range.h:1070
virtual bool intersect(const vrange &) override
Definition value-range.cc:2052
bool nonnegative_p() const
Definition value-range.cc:486
virtual irange_bitmask get_bitmask() const override
Definition value-range.cc:2542
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:1666
virtual bool fits_p(const vrange &r) const override
Definition value-range.cc:506
void set(tree type, const wide_int &, const wide_int &, value_range_kind=VR_RANGE)
Definition value-range.cc:1542
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:1757
virtual bool singleton_p(tree *result=NULL) const override
Definition value-range.cc:1703
static bool supports_p(const_tree type)
Definition value-range.h:1064
wide_int upper_bound() const
Definition value-range.h:1203
wide_int lower_bound(unsigned=0) const
Definition value-range.h:1182
irange_bitmask m_bitmask
Definition value-range.h:372
virtual void set_undefined() override
Definition value-range.h:1153
virtual tree ubound() const override
Definition value-range.cc:2668
bool nonpositive_p() const
Definition value-range.cc:492
irange & operator=(const irange &)
Definition value-range.cc:1421
friend class vrange_printer
Definition value-range.h:291
virtual void set_zero(tree type) override
Definition value-range.h:1239
virtual void update_bitmask(const class irange_bitmask &) override
Definition value-range.cc:2519
bool contains_p(const wide_int &) const
Definition value-range.cc:1732
bool set_range_from_bitmask()
Definition value-range.cc:2502
bool irange_contains_p(const irange &) const
Definition value-range.cc:2001
bool varying_compatible_p() const
Definition value-range.h:1012
virtual tree type() const override
Definition value-range.h:1005
void normalize_kind()
Definition value-range.h:1248
bool snap_subranges()
Definition value-range.cc:2463
wide_int upper_bound(unsigned) const
Definition value-range.h:1193
bool operator!=(const irange &r) const
Definition value-range.h:332
irange(wide_int *, unsigned nranges, bool resizable)
Definition value-range.h:1090
virtual void verify_range() const override
Definition value-range.cc:1619
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:1323
wide_int m_min
Definition value-range.h:447
virtual bool intersect(const vrange &v) final override
Definition value-range.cc:657
virtual void set_nonnegative(tree type) final override
Definition value-range.cc:528
void invert()
Definition value-range.cc:737
prange()
Definition value-range.h:1288
virtual void verify_range() const final override
Definition value-range.cc:769
virtual tree lbound() const final override
Definition value-range.cc:605
wide_int upper_bound() const
Definition value-range.h:1406
irange_bitmask get_bitmask() const final override
Definition value-range.h:1420
wide_int m_max
Definition value-range.h:448
virtual bool contains_p(tree cst) const final override
Definition value-range.h:1374
tree m_type
Definition value-range.h:446
bool varying_compatible_p() const
Definition value-range.h:1413
virtual void set_varying(tree type) final override
Definition value-range.h:1335
static bool supports_p(const_tree type)
Definition value-range.h:1317
virtual void set_zero(tree type) final override
Definition value-range.h:1361
wide_int lower_bound() const
Definition value-range.h:1399
virtual bool fits_p(const vrange &v) const final override
Definition value-range.h:1426
virtual bool zero_p() const final override
Definition value-range.h:1380
virtual void set_undefined() final override
Definition value-range.h:1329
void update_bitmask(const irange_bitmask &) final override
Definition value-range.cc:788
virtual void set_nonzero(tree type) final override
Definition value-range.h:1348
virtual bool nonzero_p() const final override
Definition value-range.h:1386
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:593
virtual tree ubound() const final override
Definition value-range.cc:611
virtual tree type() const final override
Definition value-range.h:1392
virtual void set(tree, tree, value_range_kind=VR_RANGE) final override
Definition value-range.cc:536
virtual bool union_(const vrange &v) final override
Definition value-range.cc:617
irange_bitmask m_bitmask
Definition value-range.h:449
Definition pretty-print.h:241
Definition value-range.h:456
unsupported_range & operator=(const unsupported_range &r)
Definition value-range.cc:322
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:819
void set_zero(tree type)
Definition value-range.h:808
~value_range()
Definition value-range.h:881
bool undefined_p() const
Definition value-range.h:800
bool contains_p(tree cst) const
Definition value-range.h:805
static bool supports_type_p(const_tree type)
Definition value-range.h:983
void accept(const vrange_visitor &v) const
Definition value-range.h:818
bool nonzero_p() const
Definition value-range.h:811
bool varying_p() const
Definition value-range.h:799
vrange * m_vrange
Definition value-range.h:824
tree type()
Definition value-range.h:798
irange_bitmask get_bitmask() const
Definition value-range.h:815
tree ubound() const
Definition value-range.h:814
value_range()
Definition value-range.h:839
void print(pretty_printer *) const
Definition value-range.cc:161
bool intersect(const vrange &r)
Definition value-range.h:804
void update_bitmask(const class irange_bitmask &bm)
Definition value-range.h:816
bool union_(const vrange &r)
Definition value-range.h:803
void set_nonzero(tree type)
Definition value-range.h:809
void set_undefined()
Definition value-range.h:802
bool zero_p() const
Definition value-range.h:812
bool operator!=(const value_range &r) const
Definition value-range.h:963
void set_range_class(tree type)
Definition value-range.h:892
bool singleton_p(tree *result=NULL) const
Definition value-range.h:806
tree lbound() const
Definition value-range.h:813
void set_varying(tree type)
Definition value-range.h:801
vrange & operator=(const vrange &)
Definition value-range.h:939
union value_range::buffer_type m_buffer
bool operator==(const value_range &r) const
Definition value-range.h:957
void init(tree type)
Definition value-range.h:904
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:200
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:1040
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:195
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:2580
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:349
virtual tree lbound() const =0
virtual tree type() const =0
void dump(FILE *) const
Definition value-range.cc:382
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:2590
virtual bool fits_p(const vrange &r) const =0
bool varying_p() const
Definition value-range.h:1034
bool operator==(const vrange &) const
Definition value-range.cc:368
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:419
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:6598
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:2277
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:688
#define TYPE_PRECISION(NODE)
Definition tree.h:2396
#define SCALAR_FLOAT_TYPE_P(TYPE)
Definition tree.h:656
#define TREE_REAL_CST_PTR(NODE)
Definition tree.h:1180
#define TYPE_UNSIGNED(NODE)
Definition tree.h:975
#define TYPE_MODE(NODE)
Definition tree.h:2405
#define TYPE_SIGN(NODE)
Definition tree.h:978
#define POINTER_TYPE_P(TYPE)
Definition tree.h:708
#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:4572
unsupported_range unsupported
Definition value-range.h:828
buffer_type()
Definition value-range.h:830
prange pointers
Definition value-range.h:829
~buffer_type()
Definition value-range.h:831
frange floats
Definition value-range.h:827
int_range_max ints
Definition value-range.h:826
T & as_a(vrange &v)
Definition value-range.h:677
REAL_VALUE_TYPE frange_val_max(const_tree type)
Definition value-range.h:1604
bool range_includes_zero_p(const vrange &vr)
Definition value-range.h:1076
wide_int irange_val_max(const_tree type)
Definition value-range.h:1281
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:2681
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:1583
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:1524
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:1569
wide_int irange_val_min(const_tree type)
Definition value-range.h:1274
bool range_compatible_p(tree type1, tree type2)
Definition value-range.h:1815
bool frange_val_is_min(const REAL_VALUE_TYPE &r, const_tree type)
Definition value-range.h:1615
bool contains_zero_p(const irange &r)
Definition value-range.h:1264
bool frange_val_is_max(const REAL_VALUE_TYPE &r, const_tree type)
Definition value-range.h:1624
bool vrp_operand_equal_p(const_tree, const_tree)
Definition value-range.cc:2702
REAL_VALUE_TYPE frange_val_min(const_tree type)
Definition value-range.h:1593
bool is_a< irange >(vrange &v)
Definition value-range.h:695
generic_wide_int< wide_int_storage > wide_int
Definition wide-int.h:343