Commit 7c36eff8 authored by jgruber's avatar jgruber Committed by Commit Bot

Add Int32 matching to CodeAssembler::ToInt32Constant

Prior to this, ToInt32Constant only matched Int64Constant nodes within
the int32_t range, but did not match actual Int32Constant nodes.

Change-Id: I4e67ea57f53f3b1d4b1f2b27f11ebdeffb2bf357
Reviewed-on: https://chromium-review.googlesource.com/1012022Reviewed-by: 's avatarMichael Starzinger <mstarzinger@chromium.org>
Commit-Queue: Jakob Gruber <jgruber@chromium.org>
Cr-Commit-Position: refs/heads/master@{#52590}
parent 2c7c8da1
...@@ -371,12 +371,21 @@ TNode<HeapNumber> CodeAssembler::NaNConstant() { ...@@ -371,12 +371,21 @@ TNode<HeapNumber> CodeAssembler::NaNConstant() {
} }
bool CodeAssembler::ToInt32Constant(Node* node, int32_t& out_value) { bool CodeAssembler::ToInt32Constant(Node* node, int32_t& out_value) {
Int64Matcher m(node); {
if (m.HasValue() && Int64Matcher m(node);
m.IsInRange(std::numeric_limits<int32_t>::min(), if (m.HasValue() && m.IsInRange(std::numeric_limits<int32_t>::min(),
std::numeric_limits<int32_t>::max())) { std::numeric_limits<int32_t>::max())) {
out_value = static_cast<int32_t>(m.Value()); out_value = static_cast<int32_t>(m.Value());
return true; return true;
}
}
{
Int32Matcher m(node);
if (m.HasValue()) {
out_value = m.Value();
return true;
}
} }
return false; return false;
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment