| // Copyright 2018 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. |
| |
| let kMax31BitSmi = (1 << 30) - 1; |
| let k1MiB = 1 * 1024 * 1024; |
| let k1GiB = 1 * 1024 * 1024 * 1024; |
| let k4GiB = 4 * k1GiB; |
| let kPageSize = 65536; |
| let kMaxArrayBufferSize = 2 * k1GiB - kPageSize; // TODO(titzer): raise this to 4GiB |
| let kStrideLength = 65536; |
| |
| (function Test() { |
| var buffer; |
| try { |
| buffer = new ArrayBuffer(kMaxArrayBufferSize); |
| } catch (e) { |
| print("OOM: sorry, best effort max array buffer size test!"); |
| return; |
| } |
| |
| print("Allocated " + buffer.byteLength + " bytes"); |
| assertEquals(kMaxArrayBufferSize, buffer.byteLength); |
| |
| function probe(view, stride, f) { |
| print("--------------------"); |
| let max = view.length; |
| for (let i = 0; i < max; i += stride) { |
| view[i] = f(i); |
| } |
| for (let i = 0; i < max; i += stride) { |
| // print(`${i} = ${f(i)}`); |
| assertEquals(f(i), view[i]); |
| } |
| } |
| |
| { |
| // Make an uint32 view and probe it. |
| let elemSize = 4; |
| let viewSize = kMaxArrayBufferSize / elemSize; |
| // TODO(titzer): view sizes are limited to 31 bit SMIs. fix. |
| if (viewSize <= kMax31BitSmi) { |
| let uint32 = new Uint32Array(buffer); |
| assertEquals(kMaxArrayBufferSize / elemSize, uint32.length); |
| probe(uint32, kStrideLength / elemSize, |
| i => (0xaabbccee ^ ((i >> 11) * 0x110005)) >>> 0); |
| } |
| } |
| |
| { |
| // Make an uint16 view and probe it. |
| let elemSize = 2; |
| let viewSize = kMaxArrayBufferSize / elemSize; |
| // TODO(titzer): view sizes are limited to 31 bit SMIs. fix. |
| if (viewSize <= kMax31BitSmi) { |
| let uint16 = new Uint16Array(buffer); |
| assertEquals(kMaxArrayBufferSize / elemSize, uint16.length); |
| probe(uint16, kStrideLength / elemSize, |
| i => (0xccee ^ ((i >> 11) * 0x110005)) & 0xFFFF); |
| } |
| } |
| |
| { |
| // Make an uint8 view and probe it. |
| let elemSize = 1; |
| let viewSize = kMaxArrayBufferSize / elemSize; |
| // TODO(titzer): view sizes are limited to 31 bit SMIs. fix. |
| if (viewSize <= kMax31BitSmi) { |
| let uint8 = new Uint8Array(buffer); |
| assertEquals(kMaxArrayBufferSize / elemSize, uint8.length); |
| probe(uint8, kStrideLength / elemSize, |
| i => (0xee ^ ((i >> 11) * 0x05)) & 0xFF); |
| } |
| } |
| |
| { |
| // Make a float64 view and probe it. |
| let elemSize = 8; |
| let viewSize = kMaxArrayBufferSize / elemSize; |
| // TODO(titzer): view sizes are limited to 31 bit SMIs. fix. |
| if (viewSize <= kMax31BitSmi) { |
| let float64 = new Float64Array(buffer); |
| assertEquals(kMaxArrayBufferSize / elemSize, float64.length); |
| probe(float64, kStrideLength / elemSize, |
| i => 0xaabbccee ^ ((i >> 11) * 0x110005)); |
| } |
| } |
| |
| { |
| // Make a float32 view and probe it. |
| let elemSize = 4; |
| let viewSize = kMaxArrayBufferSize / elemSize; |
| // TODO(titzer): view sizes are limited to 31 bit SMIs. fix. |
| if (viewSize <= kMax31BitSmi) { |
| let float32 = new Float32Array(buffer); |
| assertEquals(kMaxArrayBufferSize / elemSize, float32.length); |
| probe(float32, kStrideLength / elemSize, |
| i => Math.fround(0xaabbccee ^ ((i >> 11) * 0x110005))); |
| } |
| } |
| })(); |