mirror of
				https://github.com/tc39/test262.git
				synced 2025-10-31 11:44:31 +01:00 
			
		
		
		
	sourceRevisionAtLastExport: 33f2fb0e53d135f0ee17cfccd9d993eb2a6f47de targetRevisionAtLastExport: 31340cbd9add103f586d501b0c3354b7b182abc0
		
			
				
	
	
		
			102 lines
		
	
	
		
			3.2 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			102 lines
		
	
	
		
			3.2 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| // 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)));
 | |
|     }
 | |
|   }
 | |
| })();
 |