Chromium Code Reviews| Index: runtime/vm/intermediate_language.cc |
| =================================================================== |
| --- runtime/vm/intermediate_language.cc (revision 13823) |
| +++ runtime/vm/intermediate_language.cc (working copy) |
| @@ -2187,6 +2187,23 @@ |
| RangeBoundary::OverflowedMaxSmi()); |
| break; |
| + case Token::kBIT_AND: |
| + if (Range::ConstantMin(right_range).value() >= 0) { |
| + new_min = RangeBoundary::FromConstant(0); |
| + new_max = Range::ConstantMax(right_range); |
| + break; |
| + } |
| + if (Range::ConstantMin(left_range).value() >= 0) { |
| + new_min = RangeBoundary::FromConstant(0); |
| + new_max = Range::ConstantMax(left_range); |
| + break; |
| + } |
| + if (range_ == NULL) { |
|
Vyacheslav Egorov (Google)
2012/10/19 20:05:28
I sense a problem here. Range of a phi can start l
|
| + range_ = Range::Unknown(); |
| + return true; |
| + } |
| + return false; |
| + |
| default: |
| if (range_ == NULL) { |
| range_ = Range::Unknown(); |
| @@ -2207,6 +2224,14 @@ |
| } |
| +// Inclusive. |
| +bool Range::IsWithin(intptr_t min_int, intptr_t max_int) const { |
| + if (!min().IsConstant() || (min().value() < min_int)) return false; |
| + if (!max().IsConstant() || (max().value() > max_int)) return false; |
| + return true; |
| +} |
| + |
| + |
| #undef __ |
| } // namespace dart |