[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: Marja Hölttä <marja@chromium.org>
Cr-Commit-Position: refs/heads/main@{#79789}
This commit is contained in:
Shu-yu Guo 2022-04-05 17:15:33 -07:00 committed by V8 LUCI CQ
parent a464158091
commit f3dfbe59ed
4 changed files with 23 additions and 31 deletions

View File

@ -15,25 +15,10 @@ transitioning macro CallCompare(
// a. Let v be ? ToNumber(? Call(comparefn, undefined, x, y)).
const v: Number = ToNumber_Inline(Call(context, comparefn, Undefined, a, b));
// b. If IsDetachedBuffer(buffer) is true, throw a TypeError exception.
// 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.
// b. If v is NaN, return +0.
if (NumberIsNaN(v)) return 0;
// f. return v.
// c. return v.
return v;
}
@ -149,17 +134,17 @@ transitioning javascript builtin TypedArrayPrototypeSort(
TypedArrayMergeSort(work2, 0, len, work1, array, comparefn);
// 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
// comparison function.
// Reload the length; it's possible the backing ArrayBuffer has been resized
// to be OOB or detached, in which case treat it as length 0.
// TODO(v8:11111): Update this, depending on how
// https://github.com/tc39/ecma262/pull/2646#issuecomment-1067456576 gets
// resolved.
const newLen =
LoadJSTypedArrayLengthAndCheckDetached(array) otherwise unreachable;
if (newLen < len) {
len = newLen;
try {
const newLen = LoadJSTypedArrayLengthAndCheckDetached(array)
otherwise DetachedOrOutOfBounds;
if (newLen < len) {
len = newLen;
}
} label DetachedOrOutOfBounds {
len = 0;
}
// work1 contains the sorted numbers. Write them back.

View File

@ -1458,6 +1458,12 @@ d8.file.execute('test/mjsunit/typedarray-helpers.js');
return 0;
}
function AssertIsDetached(ta) {
assertEquals(0, ta.byteLength);
assertEquals(0, ta.byteOffset);
assertEquals(0, ta.length);
}
// Fixed length TA.
for (let ctor of ctors) {
rab = CreateResizableArrayBuffer(4 * ctor.BYTES_PER_ELEMENT,
@ -1466,7 +1472,8 @@ d8.file.execute('test/mjsunit/typedarray-helpers.js');
const taFull = new ctor(rab, 0);
WriteUnsortedData(taFull);
assertThrows(() => { fixedLength.sort(CustomComparison); });
fixedLength.sort(CustomComparison);
AssertIsDetached(fixedLength);
}
// Length-tracking TA.
@ -1477,7 +1484,8 @@ d8.file.execute('test/mjsunit/typedarray-helpers.js');
const taFull = new ctor(rab, 0);
WriteUnsortedData(taFull);
assertThrows(() => { lengthTracking.sort(CustomComparison); });
lengthTracking.sort(CustomComparison);
AssertIsDetached(lengthTracking);
}
})();

View File

@ -6597,7 +6597,7 @@ function TestIterationAndResize(ta, expected, rab, resize_after,
const taFull = new ctor(rab, 0);
WriteUnsortedData(taFull);
assertThrows(() => { fixedLength.sort(CustomComparison); });
fixedLength.sort(CustomComparison);
// The data is unchanged.
assertEquals([10, 9], ToNumbers(taFull));

View File

@ -2907,7 +2907,6 @@
# 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/sort/sort-tonumber': [FAIL],
######################## NEEDS INVESTIGATION ###########################