Commit 2a383f4c authored by Joshua Litt's avatar Joshua Litt Committed by Commit Bot

Revert "[atomics] Wire up 64 bit atomic Wait in JS"

This reverts commit 6a87a478.

Reason for revert: breaks ubsan

Original change's description:
> [atomics] Wire up 64 bit atomic Wait in JS
> 
> Bug: v8:8100
> Change-Id: Ia93319493352e81e727596582cbb23e6e7d604fd
> Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/1728260
> Commit-Queue: Joshua Litt <joshualitt@chromium.org>
> Reviewed-by: Jakob Kummerow <jkummerow@chromium.org>
> Cr-Commit-Position: refs/heads/master@{#63040}

TBR=jkummerow@chromium.org,joshualitt@chromium.org

Change-Id: Iac014af8238d4eef8fc95128b4603b8118ed3dc4
No-Presubmit: true
No-Tree-Checks: true
No-Try: true
Bug: v8:8100
Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/1733387
Auto-Submit: Joshua Litt <joshualitt@chromium.org>
Commit-Queue: Jakob Kummerow <jkummerow@chromium.org>
Reviewed-by: 's avatarJakob Kummerow <jkummerow@chromium.org>
Cr-Commit-Position: refs/heads/master@{#63046}
parent 0b02ebfb
...@@ -37,16 +37,12 @@ BUILTIN(AtomicsIsLockFree) { ...@@ -37,16 +37,12 @@ BUILTIN(AtomicsIsLockFree) {
// ES #sec-validatesharedintegertypedarray // ES #sec-validatesharedintegertypedarray
V8_WARN_UNUSED_RESULT MaybeHandle<JSTypedArray> ValidateSharedIntegerTypedArray( V8_WARN_UNUSED_RESULT MaybeHandle<JSTypedArray> ValidateSharedIntegerTypedArray(
Isolate* isolate, Handle<Object> object, Isolate* isolate, Handle<Object> object, bool only_int32 = false) {
bool only_int32_and_big_int64 = false) {
if (object->IsJSTypedArray()) { if (object->IsJSTypedArray()) {
Handle<JSTypedArray> typed_array = Handle<JSTypedArray>::cast(object); Handle<JSTypedArray> typed_array = Handle<JSTypedArray>::cast(object);
if (typed_array->GetBuffer()->is_shared()) { if (typed_array->GetBuffer()->is_shared()) {
if (only_int32_and_big_int64) { if (only_int32) {
if (typed_array->type() == kExternalInt32Array || if (typed_array->type() == kExternalInt32Array) return typed_array;
typed_array->type() == kExternalBigInt64Array) {
return typed_array;
}
} else { } else {
if (typed_array->type() != kExternalFloat32Array && if (typed_array->type() != kExternalFloat32Array &&
typed_array->type() != kExternalFloat64Array && typed_array->type() != kExternalFloat64Array &&
...@@ -58,9 +54,8 @@ V8_WARN_UNUSED_RESULT MaybeHandle<JSTypedArray> ValidateSharedIntegerTypedArray( ...@@ -58,9 +54,8 @@ V8_WARN_UNUSED_RESULT MaybeHandle<JSTypedArray> ValidateSharedIntegerTypedArray(
THROW_NEW_ERROR( THROW_NEW_ERROR(
isolate, isolate,
NewTypeError(only_int32_and_big_int64 NewTypeError(only_int32 ? MessageTemplate::kNotInt32SharedTypedArray
? MessageTemplate::kNotInt32OrBigInt64SharedTypedArray : MessageTemplate::kNotIntegerSharedTypedArray,
: MessageTemplate::kNotIntegerSharedTypedArray,
object), object),
JSTypedArray); JSTypedArray);
} }
...@@ -162,16 +157,9 @@ BUILTIN(AtomicsWait) { ...@@ -162,16 +157,9 @@ BUILTIN(AtomicsWait) {
if (maybe_index.IsNothing()) return ReadOnlyRoots(isolate).exception(); if (maybe_index.IsNothing()) return ReadOnlyRoots(isolate).exception();
size_t i = maybe_index.FromJust(); size_t i = maybe_index.FromJust();
// According to the spec, we have to check value's type before ASSIGN_RETURN_FAILURE_ON_EXCEPTION(isolate, value,
// looking at the timeout. Object::ToInt32(isolate, value));
if (sta->type() == kExternalBigInt64Array) { int32_t value_int32 = NumberToInt32(*value);
ASSIGN_RETURN_FAILURE_ON_EXCEPTION(isolate, value,
BigInt::FromObject(isolate, value));
} else {
DCHECK(sta->type() == kExternalInt32Array);
ASSIGN_RETURN_FAILURE_ON_EXCEPTION(isolate, value,
Object::ToInt32(isolate, value));
}
double timeout_number; double timeout_number;
if (timeout->IsUndefined(isolate)) { if (timeout->IsUndefined(isolate)) {
...@@ -194,15 +182,8 @@ BUILTIN(AtomicsWait) { ...@@ -194,15 +182,8 @@ BUILTIN(AtomicsWait) {
Handle<JSArrayBuffer> array_buffer = sta->GetBuffer(); Handle<JSArrayBuffer> array_buffer = sta->GetBuffer();
size_t addr = (i << 2) + sta->byte_offset(); size_t addr = (i << 2) + sta->byte_offset();
if (sta->type() == kExternalBigInt64Array) { return FutexEmulation::WaitJs(isolate, array_buffer, addr, value_int32,
return FutexEmulation::WaitJs64(isolate, array_buffer, addr, timeout_number);
Handle<BigInt>::cast(value)->AsInt64(),
timeout_number);
} else {
DCHECK(sta->type() == kExternalInt32Array);
return FutexEmulation::WaitJs32(isolate, array_buffer, addr,
NumberToInt32(*value), timeout_number);
}
} }
} // namespace internal } // namespace internal
......
...@@ -146,8 +146,7 @@ namespace internal { ...@@ -146,8 +146,7 @@ namespace internal {
T(NotSuperConstructorAnonymousClass, \ T(NotSuperConstructorAnonymousClass, \
"Super constructor % of anonymous class is not a constructor") \ "Super constructor % of anonymous class is not a constructor") \
T(NotIntegerSharedTypedArray, "% is not an integer shared typed array.") \ T(NotIntegerSharedTypedArray, "% is not an integer shared typed array.") \
T(NotInt32OrBigInt64SharedTypedArray, \ T(NotInt32SharedTypedArray, "% is not an int32 shared typed array.") \
"% is not an int32 or BigInt64 shared typed array.") \
T(ObjectGetterExpectingFunction, \ T(ObjectGetterExpectingFunction, \
"Object.prototype.__defineGetter__: Expecting function") \ "Object.prototype.__defineGetter__: Expecting function") \
T(ObjectGetterCallable, "Getter must be a function: %") \ T(ObjectGetterCallable, "Getter must be a function: %") \
......
...@@ -11,7 +11,6 @@ ...@@ -11,7 +11,6 @@
#include "src/execution/isolate.h" #include "src/execution/isolate.h"
#include "src/handles/handles-inl.h" #include "src/handles/handles-inl.h"
#include "src/numbers/conversions.h" #include "src/numbers/conversions.h"
#include "src/objects/bigint.h"
#include "src/objects/js-array-buffer-inl.h" #include "src/objects/js-array-buffer-inl.h"
#include "src/objects/objects-inl.h" #include "src/objects/objects-inl.h"
...@@ -81,9 +80,10 @@ void AtomicsWaitWakeHandle::Wake() { ...@@ -81,9 +80,10 @@ void AtomicsWaitWakeHandle::Wake() {
enum WaitReturnValue : int { kOk = 0, kNotEqual = 1, kTimedOut = 2 }; enum WaitReturnValue : int { kOk = 0, kNotEqual = 1, kTimedOut = 2 };
namespace { Object FutexEmulation::WaitJs(Isolate* isolate,
Handle<JSArrayBuffer> array_buffer, size_t addr,
Object WaitJsTranslateReturn(Isolate* isolate, Object res) { int32_t value, double rel_timeout_ms) {
Object res = Wait32(isolate, array_buffer, addr, value, rel_timeout_ms);
if (res.IsSmi()) { if (res.IsSmi()) {
int val = Smi::ToInt(res); int val = Smi::ToInt(res);
switch (val) { switch (val) {
...@@ -100,22 +100,6 @@ Object WaitJsTranslateReturn(Isolate* isolate, Object res) { ...@@ -100,22 +100,6 @@ Object WaitJsTranslateReturn(Isolate* isolate, Object res) {
return res; return res;
} }
} // namespace
Object FutexEmulation::WaitJs32(Isolate* isolate,
Handle<JSArrayBuffer> array_buffer, size_t addr,
int32_t value, double rel_timeout_ms) {
Object res = Wait32(isolate, array_buffer, addr, value, rel_timeout_ms);
return WaitJsTranslateReturn(isolate, res);
}
Object FutexEmulation::WaitJs64(Isolate* isolate,
Handle<JSArrayBuffer> array_buffer, size_t addr,
int64_t value, double rel_timeout_ms) {
Object res = Wait64(isolate, array_buffer, addr, value, rel_timeout_ms);
return WaitJsTranslateReturn(isolate, res);
}
Object FutexEmulation::Wait32(Isolate* isolate, Object FutexEmulation::Wait32(Isolate* isolate,
Handle<JSArrayBuffer> array_buffer, size_t addr, Handle<JSArrayBuffer> array_buffer, size_t addr,
int32_t value, double rel_timeout_ms) { int32_t value, double rel_timeout_ms) {
......
...@@ -117,12 +117,8 @@ class FutexEmulation : public AllStatic { ...@@ -117,12 +117,8 @@ class FutexEmulation : public AllStatic {
// |rel_timeout_ms| can be Infinity. // |rel_timeout_ms| can be Infinity.
// If woken, return "ok", otherwise return "timed-out". The initial check and // If woken, return "ok", otherwise return "timed-out". The initial check and
// the decision to wait happen atomically. // the decision to wait happen atomically.
static Object WaitJs32(Isolate* isolate, Handle<JSArrayBuffer> array_buffer, static Object WaitJs(Isolate* isolate, Handle<JSArrayBuffer> array_buffer,
size_t addr, int32_t value, double rel_timeout_ms); size_t addr, int32_t value, double rel_timeout_ms);
// An version of WaitJs32 for int64_t values.
static Object WaitJs64(Isolate* isolate, Handle<JSArrayBuffer> array_buffer,
size_t addr, int64_t value, double rel_timeout_ms);
// Same as WaitJs above except it returns 0 (ok), 1 (not equal) and 2 (timed // Same as WaitJs above except it returns 0 (ok), 1 (not equal) and 2 (timed
// out) as expected by Wasm. // out) as expected by Wasm.
......
...@@ -450,6 +450,10 @@ ...@@ -450,6 +450,10 @@
'built-ins/TypedArrayConstructors/internals/Set/key-is-out-of-bounds': [FAIL], 'built-ins/TypedArrayConstructors/internals/Set/key-is-out-of-bounds': [FAIL],
'built-ins/TypedArrayConstructors/internals/Set/BigInt/key-is-out-of-bounds': [FAIL], 'built-ins/TypedArrayConstructors/internals/Set/BigInt/key-is-out-of-bounds': [FAIL],
# https://bugs.chromium.org/p/v8/issues/detail?id=8100
'built-ins/Atomics/notify/bigint/*': [SKIP],
'built-ins/Atomics/wait/bigint/*': [SKIP],
# https://bugs.chromium.org/p/v8/issues/detail?id=6049 # https://bugs.chromium.org/p/v8/issues/detail?id=6049
'built-ins/Object/internals/DefineOwnProperty/consistent-value-function-caller': [FAIL_SLOPPY], 'built-ins/Object/internals/DefineOwnProperty/consistent-value-function-caller': [FAIL_SLOPPY],
'built-ins/Object/internals/DefineOwnProperty/consistent-value-function-arguments': [FAIL_SLOPPY], 'built-ins/Object/internals/DefineOwnProperty/consistent-value-function-arguments': [FAIL_SLOPPY],
...@@ -567,11 +571,7 @@ ...@@ -567,11 +571,7 @@
######################## NEEDS INVESTIGATION ########################### ######################## NEEDS INVESTIGATION ###########################
# https://bugs.chromium.org/p/v8/issues/detail?id=7833 # https://bugs.chromium.org/p/v8/issues/detail?id=7833
#
# Test262 needs to expose CanBlock
'built-ins/Atomics/wait/bigint/cannot-suspend-throws': [SKIP],
'built-ins/Atomics/wait/cannot-suspend-throws': [SKIP], 'built-ins/Atomics/wait/cannot-suspend-throws': [SKIP],
# Flaky
'built-ins/Atomics/wait/undefined-index-defaults-to-zero': [SKIP], 'built-ins/Atomics/wait/undefined-index-defaults-to-zero': [SKIP],
##################### DELIBERATE INCOMPATIBILITIES ##################### ##################### DELIBERATE INCOMPATIBILITIES #####################
......
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