OLD | NEW |
1 // Copyright 2015 the V8 project authors. All rights reserved. | 1 // Copyright 2015 the V8 project authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include <stdint.h> | 5 #include <stdint.h> |
6 #include <stdlib.h> | 6 #include <stdlib.h> |
7 #include <string.h> | 7 #include <string.h> |
8 | 8 |
9 #include "src/base/platform/elapsed-timer.h" | 9 #include "src/base/platform/elapsed-timer.h" |
10 | 10 |
(...skipping 591 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
602 FOR_FLOAT32_INPUTS(i) { | 602 FOR_FLOAT32_INPUTS(i) { |
603 CHECK_EQ(0x80000000, | 603 CHECK_EQ(0x80000000, |
604 bit_cast<uint32_t>(*i) ^ bit_cast<uint32_t>(r.Call(*i))); | 604 bit_cast<uint32_t>(*i) ^ bit_cast<uint32_t>(r.Call(*i))); |
605 } | 605 } |
606 } | 606 } |
607 | 607 |
608 WASM_EXEC_TEST(Float32SubMinusZero) { | 608 WASM_EXEC_TEST(Float32SubMinusZero) { |
609 WasmRunner<float> r(execution_mode, MachineType::Float32()); | 609 WasmRunner<float> r(execution_mode, MachineType::Float32()); |
610 BUILD(r, WASM_F32_SUB(WASM_F32(-0.0), WASM_GET_LOCAL(0))); | 610 BUILD(r, WASM_F32_SUB(WASM_F32(-0.0), WASM_GET_LOCAL(0))); |
611 | 611 |
612 CHECK_EQ(0x7fe00000, bit_cast<uint32_t>(r.Call(bit_cast<float>(0x7fa00000)))); | 612 uint32_t sNanValue = |
| 613 bit_cast<uint32_t>(std::numeric_limits<float>::signaling_NaN()); |
| 614 uint32_t qNanValue = |
| 615 bit_cast<uint32_t>(std::numeric_limits<float>::quiet_NaN()); |
| 616 uint32_t payload = 0x00200000; |
| 617 |
| 618 uint32_t expected = (qNanValue & 0xffc00000) | payload; |
| 619 uint32_t operand = (sNanValue & 0xffc00000) | payload; |
| 620 CHECK_EQ(expected, bit_cast<uint32_t>(r.Call(bit_cast<float>(operand)))); |
| 621 |
| 622 // Change the sign of the NaN. |
| 623 expected |= 0x80000000; |
| 624 operand |= 0x80000000; |
| 625 CHECK_EQ(expected, bit_cast<uint32_t>(r.Call(bit_cast<float>(operand)))); |
613 } | 626 } |
614 | 627 |
615 WASM_EXEC_TEST(Float64SubMinusZero) { | 628 WASM_EXEC_TEST(Float64SubMinusZero) { |
616 WasmRunner<double> r(execution_mode, MachineType::Float64()); | 629 WasmRunner<double> r(execution_mode, MachineType::Float64()); |
617 BUILD(r, WASM_F64_SUB(WASM_F64(-0.0), WASM_GET_LOCAL(0))); | 630 BUILD(r, WASM_F64_SUB(WASM_F64(-0.0), WASM_GET_LOCAL(0))); |
618 | 631 |
619 CHECK_EQ(0x7ff8123456789abc, | 632 uint64_t sNanValue = |
620 bit_cast<uint64_t>(r.Call(bit_cast<double>(0x7ff0123456789abc)))); | 633 bit_cast<uint64_t>(std::numeric_limits<double>::signaling_NaN()); |
| 634 uint64_t qNanValue = |
| 635 bit_cast<uint64_t>(std::numeric_limits<double>::quiet_NaN()); |
| 636 uint64_t payload = 0x0000123456789abc; |
| 637 |
| 638 uint64_t expected = (qNanValue & 0xfff8000000000000) | payload; |
| 639 uint64_t operand = (sNanValue & 0xfff8000000000000) | payload; |
| 640 CHECK_EQ(expected, bit_cast<uint64_t>(r.Call(bit_cast<double>(operand)))); |
| 641 |
| 642 // Change the sign of the NaN. |
| 643 expected |= 0x8000000000000000; |
| 644 operand |= 0x8000000000000000; |
| 645 CHECK_EQ(expected, bit_cast<uint64_t>(r.Call(bit_cast<double>(operand)))); |
621 } | 646 } |
622 | 647 |
623 WASM_EXEC_TEST(Float64Neg) { | 648 WASM_EXEC_TEST(Float64Neg) { |
624 WasmRunner<double> r(execution_mode, MachineType::Float64()); | 649 WasmRunner<double> r(execution_mode, MachineType::Float64()); |
625 BUILD(r, WASM_F64_NEG(WASM_GET_LOCAL(0))); | 650 BUILD(r, WASM_F64_NEG(WASM_GET_LOCAL(0))); |
626 | 651 |
627 FOR_FLOAT64_INPUTS(i) { | 652 FOR_FLOAT64_INPUTS(i) { |
628 CHECK_EQ(0x8000000000000000, | 653 CHECK_EQ(0x8000000000000000, |
629 bit_cast<uint64_t>(*i) ^ bit_cast<uint64_t>(r.Call(*i))); | 654 bit_cast<uint64_t>(*i) ^ bit_cast<uint64_t>(r.Call(*i))); |
630 } | 655 } |
(...skipping 2185 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
2816 MachineType::Int32()); | 2841 MachineType::Int32()); |
2817 BUILD(r, WASM_I32_REMS(WASM_GET_LOCAL(0), WASM_GET_LOCAL(1)), WASM_ZERO); | 2842 BUILD(r, WASM_I32_REMS(WASM_GET_LOCAL(0), WASM_GET_LOCAL(1)), WASM_ZERO); |
2818 const int32_t kMin = std::numeric_limits<int32_t>::min(); | 2843 const int32_t kMin = std::numeric_limits<int32_t>::min(); |
2819 CHECK_EQ(0, r.Call(133, 100)); | 2844 CHECK_EQ(0, r.Call(133, 100)); |
2820 CHECK_EQ(0, r.Call(kMin, -1)); | 2845 CHECK_EQ(0, r.Call(kMin, -1)); |
2821 CHECK_EQ(0, r.Call(0, 1)); | 2846 CHECK_EQ(0, r.Call(0, 1)); |
2822 CHECK_TRAP(r.Call(100, 0)); | 2847 CHECK_TRAP(r.Call(100, 0)); |
2823 CHECK_TRAP(r.Call(-1001, 0)); | 2848 CHECK_TRAP(r.Call(-1001, 0)); |
2824 CHECK_TRAP(r.Call(kMin, 0)); | 2849 CHECK_TRAP(r.Call(kMin, 0)); |
2825 } | 2850 } |
OLD | NEW |