| OLD | NEW |
| 1 // Copyright 2016 the V8 project authors. All rights reserved. | 1 // Copyright 2016 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 "src/wasm/wasm-interpreter.h" | 5 #include "src/wasm/wasm-interpreter.h" |
| 6 #include "src/wasm/ast-decoder.h" | 6 #include "src/wasm/ast-decoder.h" |
| 7 #include "src/wasm/decoder.h" | 7 #include "src/wasm/decoder.h" |
| 8 #include "src/wasm/wasm-external-refs.h" | 8 #include "src/wasm/wasm-external-refs.h" |
| 9 #include "src/wasm/wasm-module.h" | 9 #include "src/wasm/wasm-module.h" |
| 10 | 10 |
| (...skipping 480 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 491 | 491 |
| 492 static inline double ExecuteF64NearestInt(double a, TrapReason* trap) { | 492 static inline double ExecuteF64NearestInt(double a, TrapReason* trap) { |
| 493 return nearbyint(a); | 493 return nearbyint(a); |
| 494 } | 494 } |
| 495 | 495 |
| 496 static inline double ExecuteF64Sqrt(double a, TrapReason* trap) { | 496 static inline double ExecuteF64Sqrt(double a, TrapReason* trap) { |
| 497 return sqrt(a); | 497 return sqrt(a); |
| 498 } | 498 } |
| 499 | 499 |
| 500 static int32_t ExecuteI32SConvertF32(float a, TrapReason* trap) { | 500 static int32_t ExecuteI32SConvertF32(float a, TrapReason* trap) { |
| 501 if (a < static_cast<float>(INT32_MAX) && a >= static_cast<float>(INT32_MIN)) { | 501 // The upper bound is (INT32_MAX + 1), which is the lowest float-representable |
| 502 // number above INT32_MAX which cannot be represented as int32. |
| 503 float upper_bound = 2147483648.0f; |
| 504 // We use INT32_MIN as a lower bound because (INT32_MIN - 1) is not |
| 505 // representable as float, and no number between (INT32_MIN - 1) and INT32_MIN |
| 506 // is. |
| 507 float lower_bound = static_cast<float>(INT32_MIN); |
| 508 if (a < upper_bound && a >= lower_bound) { |
| 502 return static_cast<int32_t>(a); | 509 return static_cast<int32_t>(a); |
| 503 } | 510 } |
| 504 *trap = kTrapFloatUnrepresentable; | 511 *trap = kTrapFloatUnrepresentable; |
| 505 return 0; | 512 return 0; |
| 506 } | 513 } |
| 507 | 514 |
| 508 static int32_t ExecuteI32SConvertF64(double a, TrapReason* trap) { | 515 static int32_t ExecuteI32SConvertF64(double a, TrapReason* trap) { |
| 509 if (a < (static_cast<double>(INT32_MAX) + 1.0) && | 516 // The upper bound is (INT32_MAX + 1), which is the lowest double- |
| 510 a > (static_cast<double>(INT32_MIN) - 1.0)) { | 517 // representable number above INT32_MAX which cannot be represented as int32. |
| 518 double upper_bound = 2147483648.0; |
| 519 // The lower bound is (INT32_MIN - 1), which is the greatest double- |
| 520 // representable number below INT32_MIN which cannot be represented as int32. |
| 521 double lower_bound = -2147483649.0; |
| 522 if (a < upper_bound && a > lower_bound) { |
| 511 return static_cast<int32_t>(a); | 523 return static_cast<int32_t>(a); |
| 512 } | 524 } |
| 513 *trap = kTrapFloatUnrepresentable; | 525 *trap = kTrapFloatUnrepresentable; |
| 514 return 0; | 526 return 0; |
| 515 } | 527 } |
| 516 | 528 |
| 517 static uint32_t ExecuteI32UConvertF32(float a, TrapReason* trap) { | 529 static uint32_t ExecuteI32UConvertF32(float a, TrapReason* trap) { |
| 518 if (a < (static_cast<float>(UINT32_MAX) + 1.0) && a > -1) { | 530 // The upper bound is (UINT32_MAX + 1), which is the lowest |
| 531 // float-representable number above UINT32_MAX which cannot be represented as |
| 532 // uint32. |
| 533 double upper_bound = 4294967296.0f; |
| 534 double lower_bound = -1.0f; |
| 535 if (a < upper_bound && a > lower_bound) { |
| 519 return static_cast<uint32_t>(a); | 536 return static_cast<uint32_t>(a); |
| 520 } | 537 } |
| 521 *trap = kTrapFloatUnrepresentable; | 538 *trap = kTrapFloatUnrepresentable; |
| 522 return 0; | 539 return 0; |
| 523 } | 540 } |
| 524 | 541 |
| 525 static uint32_t ExecuteI32UConvertF64(double a, TrapReason* trap) { | 542 static uint32_t ExecuteI32UConvertF64(double a, TrapReason* trap) { |
| 526 if (a < (static_cast<float>(UINT32_MAX) + 1.0) && a > -1) { | 543 // The upper bound is (UINT32_MAX + 1), which is the lowest |
| 544 // double-representable number above UINT32_MAX which cannot be represented as |
| 545 // uint32. |
| 546 double upper_bound = 4294967296.0; |
| 547 double lower_bound = -1.0; |
| 548 if (a < upper_bound && a > lower_bound) { |
| 527 return static_cast<uint32_t>(a); | 549 return static_cast<uint32_t>(a); |
| 528 } | 550 } |
| 529 *trap = kTrapFloatUnrepresentable; | 551 *trap = kTrapFloatUnrepresentable; |
| 530 return 0; | 552 return 0; |
| 531 } | 553 } |
| 532 | 554 |
| 533 static inline uint32_t ExecuteI32ConvertI64(int64_t a, TrapReason* trap) { | 555 static inline uint32_t ExecuteI32ConvertI64(int64_t a, TrapReason* trap) { |
| 534 return static_cast<uint32_t>(a & 0xFFFFFFFF); | 556 return static_cast<uint32_t>(a & 0xFFFFFFFF); |
| 535 } | 557 } |
| 536 | 558 |
| (...skipping 1284 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1821 | 1843 |
| 1822 ControlTransferMap WasmInterpreter::ComputeControlTransfersForTesting( | 1844 ControlTransferMap WasmInterpreter::ComputeControlTransfersForTesting( |
| 1823 Zone* zone, const byte* start, const byte* end) { | 1845 Zone* zone, const byte* start, const byte* end) { |
| 1824 ControlTransfers targets(zone, 0, start, end); | 1846 ControlTransfers targets(zone, 0, start, end); |
| 1825 return targets.map_; | 1847 return targets.map_; |
| 1826 } | 1848 } |
| 1827 | 1849 |
| 1828 } // namespace wasm | 1850 } // namespace wasm |
| 1829 } // namespace internal | 1851 } // namespace internal |
| 1830 } // namespace v8 | 1852 } // namespace v8 |
| OLD | NEW |