Commit f3dfbe59 authored by Shu-yu Guo's avatar Shu-yu Guo Committed by V8 LUCI CQ

[typedarray] Remove per-comparator call detach check in TypedArray.prototype.sort

For the normative change, see https://github.com/tc39/ecma262/pull/2723

Bug: v8:12750, v8:11111
Change-Id: I8e8a2e9b443622b20bb5a4c2d453f782dfbd2ed6
Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/3570865
Commit-Queue: Shu-yu Guo <syg@chromium.org>
Reviewed-by: 's avatarMarja Hölttä <marja@chromium.org>
Cr-Commit-Position: refs/heads/main@{#79789}
parent a4641580
...@@ -15,25 +15,10 @@ transitioning macro CallCompare( ...@@ -15,25 +15,10 @@ transitioning macro CallCompare(
// a. Let v be ? ToNumber(? Call(comparefn, undefined, x, y)). // a. Let v be ? ToNumber(? Call(comparefn, undefined, x, y)).
const v: Number = ToNumber_Inline(Call(context, comparefn, Undefined, a, b)); const v: Number = ToNumber_Inline(Call(context, comparefn, Undefined, a, b));
// b. If IsDetachedBuffer(buffer) is true, throw a TypeError exception. // b. If v is NaN, return +0.
// c. Let getBufferByteLength be
// MakeIdempotentArrayBufferByteLengthGetter(SeqCst).
// d. If IsIntegerIndexedObjectOutOfBounds(obj, getBufferByteLength) is true,
// throw a TypeError exception.
// TODO(v8:11111): Update this, depending on how
// https://github.com/tc39/ecma262/pull/2646#issuecomment-1067456576 gets
// resolved.
try {
LoadJSTypedArrayLengthAndCheckDetached(array)
otherwise DetachedOrOutOfBounds;
} label DetachedOrOutOfBounds {
ThrowTypeError(MessageTemplate::kDetachedOperation, kBuiltinNameSort);
}
// e. If v is NaN, return +0.
if (NumberIsNaN(v)) return 0; if (NumberIsNaN(v)) return 0;
// f. return v. // c. return v.
return v; return v;
} }
...@@ -149,18 +134,18 @@ transitioning javascript builtin TypedArrayPrototypeSort( ...@@ -149,18 +134,18 @@ transitioning javascript builtin TypedArrayPrototypeSort(
TypedArrayMergeSort(work2, 0, len, work1, array, comparefn); TypedArrayMergeSort(work2, 0, len, work1, array, comparefn);
// Reload the length; it's possible the backing ArrayBuffer has been resized. // Reload the length; it's possible the backing ArrayBuffer has been resized
// It cannot be OOB here though, since we've checked it as part of the // to be OOB or detached, in which case treat it as length 0.
// comparison function.
// TODO(v8:11111): Update this, depending on how try {
// https://github.com/tc39/ecma262/pull/2646#issuecomment-1067456576 gets const newLen = LoadJSTypedArrayLengthAndCheckDetached(array)
// resolved. otherwise DetachedOrOutOfBounds;
const newLen =
LoadJSTypedArrayLengthAndCheckDetached(array) otherwise unreachable;
if (newLen < len) { if (newLen < len) {
len = newLen; len = newLen;
} }
} label DetachedOrOutOfBounds {
len = 0;
}
// work1 contains the sorted numbers. Write them back. // work1 contains the sorted numbers. Write them back.
for (let i: uintptr = 0; i < len; ++i) { for (let i: uintptr = 0; i < len; ++i) {
......
...@@ -1458,6 +1458,12 @@ d8.file.execute('test/mjsunit/typedarray-helpers.js'); ...@@ -1458,6 +1458,12 @@ d8.file.execute('test/mjsunit/typedarray-helpers.js');
return 0; return 0;
} }
function AssertIsDetached(ta) {
assertEquals(0, ta.byteLength);
assertEquals(0, ta.byteOffset);
assertEquals(0, ta.length);
}
// Fixed length TA. // Fixed length TA.
for (let ctor of ctors) { for (let ctor of ctors) {
rab = CreateResizableArrayBuffer(4 * ctor.BYTES_PER_ELEMENT, rab = CreateResizableArrayBuffer(4 * ctor.BYTES_PER_ELEMENT,
...@@ -1466,7 +1472,8 @@ d8.file.execute('test/mjsunit/typedarray-helpers.js'); ...@@ -1466,7 +1472,8 @@ d8.file.execute('test/mjsunit/typedarray-helpers.js');
const taFull = new ctor(rab, 0); const taFull = new ctor(rab, 0);
WriteUnsortedData(taFull); WriteUnsortedData(taFull);
assertThrows(() => { fixedLength.sort(CustomComparison); }); fixedLength.sort(CustomComparison);
AssertIsDetached(fixedLength);
} }
// Length-tracking TA. // Length-tracking TA.
...@@ -1477,7 +1484,8 @@ d8.file.execute('test/mjsunit/typedarray-helpers.js'); ...@@ -1477,7 +1484,8 @@ d8.file.execute('test/mjsunit/typedarray-helpers.js');
const taFull = new ctor(rab, 0); const taFull = new ctor(rab, 0);
WriteUnsortedData(taFull); WriteUnsortedData(taFull);
assertThrows(() => { lengthTracking.sort(CustomComparison); }); lengthTracking.sort(CustomComparison);
AssertIsDetached(lengthTracking);
} }
})(); })();
......
...@@ -6597,7 +6597,7 @@ function TestIterationAndResize(ta, expected, rab, resize_after, ...@@ -6597,7 +6597,7 @@ function TestIterationAndResize(ta, expected, rab, resize_after,
const taFull = new ctor(rab, 0); const taFull = new ctor(rab, 0);
WriteUnsortedData(taFull); WriteUnsortedData(taFull);
assertThrows(() => { fixedLength.sort(CustomComparison); }); fixedLength.sort(CustomComparison);
// The data is unchanged. // The data is unchanged.
assertEquals([10, 9], ToNumbers(taFull)); assertEquals([10, 9], ToNumbers(taFull));
......
...@@ -2907,7 +2907,6 @@ ...@@ -2907,7 +2907,6 @@
# https://bugs.chromium.org/p/v8/issues/detail?id=12750 # https://bugs.chromium.org/p/v8/issues/detail?id=12750
'built-ins/TypedArray/prototype/set/array-arg-targetbuffer-detached-on-get-src-value-no-throw': [FAIL], 'built-ins/TypedArray/prototype/set/array-arg-targetbuffer-detached-on-get-src-value-no-throw': [FAIL],
'built-ins/TypedArray/prototype/sort/sort-tonumber': [FAIL],
######################## NEEDS INVESTIGATION ########################### ######################## NEEDS INVESTIGATION ###########################
......
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