Welcome to mirror list, hosted at ThFree Co, Russian Federation.

empirical_max_arraybuffer.js « mjsunit « test « v8 « deps - github.com/nodejs/node.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
blob: cacefd46928128adf96010d11970fd22ceb7c99f (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
// 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)));
    }
  }
})();