Index: test/cctest/compiler/test-run-machops.cc |
diff --git a/test/cctest/compiler/test-run-machops.cc b/test/cctest/compiler/test-run-machops.cc |
index bbe75db4bcab10508a7536c1a90bfdbcae3fb957..b05b830b7199432a6c5753a1fb29a9ac36053325 100644 |
--- a/test/cctest/compiler/test-run-machops.cc |
+++ b/test/cctest/compiler/test-run-machops.cc |
@@ -3232,6 +3232,46 @@ TEST(RunChangeFloat64ToInt32_spilled) { |
} |
+TEST(RunChangeFloat64ToUint32_spilled) { |
+ RawMachineAssemblerTester<uint32_t> m; |
+ const int kNumInputs = 32; |
+ int32_t magic = 0x786234; |
+ double input[kNumInputs]; |
+ uint32_t result[kNumInputs]; |
+ Node* input_node[kNumInputs]; |
+ |
+ for (int i = 0; i < kNumInputs; i++) { |
+ input_node[i] = |
+ m.Load(kMachFloat64, m.PointerConstant(&input), m.Int32Constant(i * 8)); |
+ } |
+ |
+ for (int i = 0; i < kNumInputs; i++) { |
+ m.Store(kMachUint32, m.PointerConstant(&result), m.Int32Constant(i * 4), |
+ m.ChangeFloat64ToUint32(input_node[i])); |
+ } |
+ |
+ m.Return(m.Int32Constant(magic)); |
+ |
+ for (int i = 0; i < kNumInputs; i++) { |
+ if (i % 2) { |
+ input[i] = 100 + i + 2147483648; |
+ } else { |
+ input[i] = 100 + i; |
+ } |
+ } |
+ |
+ CHECK_EQ(magic, m.Call()); |
+ |
+ for (int i = 0; i < kNumInputs; i++) { |
+ if (i % 2) { |
+ CHECK_EQ(result[i], 100 + i + 2147483648); |
+ } else { |
+ CHECK_EQ(result[i], 100 + i); |
+ } |
+ } |
+} |
+ |
+ |
TEST(RunDeadChangeFloat64ToInt32) { |
RawMachineAssemblerTester<int32_t> m; |
const int magic = 0x88abcda4; |