Commit 8c2af037 authored by cwhan.tunz's avatar cwhan.tunz Committed by Commit bot

Use internal byteOffset in TypedArray.prototype.set

Since byteOffset is configurable, we need to access byteOffset by
%_ArrayBufferViewGetByteOffset, instead of accessing .byteOffset
property.

BUG=v8:6120

Review-Url: https://codereview.chromium.org/2761673003
Cr-Commit-Position: refs/heads/master@{#44347}
parent 7a3a1eec
...@@ -255,10 +255,11 @@ function TypedArraySetFromOverlappingTypedArray(target, source, offset) { ...@@ -255,10 +255,11 @@ function TypedArraySetFromOverlappingTypedArray(target, source, offset) {
// Copy left part. // Copy left part.
function CopyLeftPart() { function CopyLeftPart() {
// First un-mutated byte after the next write // First un-mutated byte after the next write
var targetPtr = target.byteOffset + (offset + 1) * targetElementSize; var targetPtr = %_ArrayBufferViewGetByteOffset(target) +
(offset + 1) * targetElementSize;
// Next read at sourcePtr. We do not care for memory changing before // Next read at sourcePtr. We do not care for memory changing before
// sourcePtr - we have already copied it. // sourcePtr - we have already copied it.
var sourcePtr = source.byteOffset; var sourcePtr = %_ArrayBufferViewGetByteOffset(source);
for (var leftIndex = 0; for (var leftIndex = 0;
leftIndex < sourceLength && targetPtr <= sourcePtr; leftIndex < sourceLength && targetPtr <= sourcePtr;
leftIndex++) { leftIndex++) {
...@@ -273,12 +274,12 @@ function TypedArraySetFromOverlappingTypedArray(target, source, offset) { ...@@ -273,12 +274,12 @@ function TypedArraySetFromOverlappingTypedArray(target, source, offset) {
// Copy right part; // Copy right part;
function CopyRightPart() { function CopyRightPart() {
// First unmutated byte before the next write // First unmutated byte before the next write
var targetPtr = var targetPtr = %_ArrayBufferViewGetByteOffset(target) +
target.byteOffset + (offset + sourceLength - 1) * targetElementSize; (offset + sourceLength - 1) * targetElementSize;
// Next read before sourcePtr. We do not care for memory changing after // Next read before sourcePtr. We do not care for memory changing after
// sourcePtr - we have already copied it. // sourcePtr - we have already copied it.
var sourcePtr = var sourcePtr = %_ArrayBufferViewGetByteOffset(source) +
source.byteOffset + sourceLength * sourceElementSize; sourceLength * sourceElementSize;
for(var rightIndex = sourceLength - 1; for(var rightIndex = sourceLength - 1;
rightIndex >= leftIndex && targetPtr >= sourcePtr; rightIndex >= leftIndex && targetPtr >= sourcePtr;
rightIndex--) { rightIndex--) {
......
// Copyright 2017 the V8 project authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
/*---
esid: sec-%typedarray%.prototype.set-typedarray-offset
description: >
Uses typedArray's internal [[ByteOffset]]
info: >
22.2.3.23.2 %TypedArray%.prototype.set(typedArray [ , offset ] )
1. Assert: typedArray has a [[TypedArrayName]] internal slot. If it does not,
the definition in 22.2.3.23.1 applies.
...
21. Let srcByteOffset be typedArray.[[ByteOffset]].
...
includes: [testTypedArray.js]
---*/
var getCalls = 0;
var desc = {
get: function getLen() {
getCalls++;
return 0;
}
};
Object.defineProperty(TypedArray.prototype, "byteOffset", desc);
testWithTypedArrayConstructors(function(TA) {
var sample = new TA(2);
var src = new TA([42, 43]);
var differentTA = TA === Uint8Array ? Int8Array : Uint8Array;
var src2 = new differentTA([42, 43]);
var src3 = new differentTA(sample.buffer, 0, 2);
Object.defineProperty(TA.prototype, "byteOffset", desc);
Object.defineProperty(src, "byteOffset", desc);
Object.defineProperty(src2, "byteOffset", desc);
Object.defineProperty(src3, "byteOffset", desc);
sample.set(src);
sample.set(src2);
sample.set(src3);
assert.sameValue(getCalls, 0, "ignores byteOffset properties");
});
// Copyright 2017 the V8 project authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
/*---
esid: sec-%typedarray%.prototype.set-typedarray-offset
description: >
Uses target's internal [[ArrayLength]]
info: >
22.2.3.23.2 %TypedArray%.prototype.set(typedArray [ , offset ] )
1. Assert: typedArray has a [[TypedArrayName]] internal slot. If it does not,
the definition in 22.2.3.23.1 applies.
2. Let target be the this value.
...
16. Let targetByteOffset be target.[[ByteOffset]].
...
includes: [testTypedArray.js]
---*/
var getCalls = 0;
var desc = {
get: function() {
getCalls++;
return 0;
}
};
Object.defineProperty(TypedArray.prototype, "byteOffset", desc);
testWithTypedArrayConstructors(function(TA) {
var sample = new TA(2);
var src = new TA([42, 43]);
var differentTA = TA === Uint8Array ? Int8Array : Uint8Array;
var src2 = new differentTA([42, 43]);
var src3 = new differentTA(sample.buffer, 0, 2);
Object.defineProperty(TA.prototype, "byteOffset", desc);
Object.defineProperty(sample, "byteOffset", desc);
sample.set(src);
sample.set(src2);
sample.set(src3);
assert.sameValue(getCalls, 0, "ignores byteoffset properties");
});
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