Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(548)

Unified Diff: test/mjsunit/wasm/instance-memory-gc-stress.js

Issue 2544273002: [wasm] Fix WasmInstanceWrapper allocation. (Closed)
Patch Set: rename test Created 4 years ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « src/wasm/wasm-objects.cc ('k') | no next file » | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: test/mjsunit/wasm/instance-memory-gc-stress.js
diff --git a/test/mjsunit/wasm/instance-memory-gc-stress.js b/test/mjsunit/wasm/instance-memory-gc-stress.js
new file mode 100644
index 0000000000000000000000000000000000000000..fc824c2af7e56fe5d3cd29436249bc2c03f4b885
--- /dev/null
+++ b/test/mjsunit/wasm/instance-memory-gc-stress.js
@@ -0,0 +1,124 @@
+// Copyright 2016 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.
+
+// Flags: --expose-wasm --expose-gc
+
+load("test/mjsunit/wasm/wasm-constants.js");
+load("test/mjsunit/wasm/wasm-module-builder.js");
+
+// This test verifies that when instances are exported, Gc'ed, the other
+// instances in the chain still maintain a consistent view of the memory.
+(function InstanceMemoryGcStress() {
+ print("InstanceMemoryGcStress");
+ let memory = new WebAssembly.Memory({initial: 100, maximum: 1500});
+ var builder = new WasmModuleBuilder();
+ builder.addImportedMemory("imported_mem");
+ builder.addFunction("mem_size", kSig_i_v)
+ .addBody([kExprMemorySize, kMemoryZero])
+ .exportFunc();
+ builder.addFunction("grow", kSig_i_i)
+ .addBody([kExprGetLocal, 0, kExprGrowMemory, kMemoryZero])
+ .exportFunc();
+ var instances = [];
+ for (var i = 0; i < 5; i++) {
+ gc();
+ instances.push(builder.instantiate({imported_mem: memory}));
+ }
+ function grow_instance_0(pages) { return instances[0].exports.grow(pages); }
+ function grow_instance_1(pages) { return instances[1].exports.grow(pages); }
+ function grow_instance_2(pages) { return instances[2].exports.grow(pages); }
+ function grow_instance_3(pages) { return instances[3].exports.grow(pages); }
+ function grow_instance_4(pages) { return instances[4].exports.grow(pages); }
+
+ var start_index = 0;
+ var end_index = 5;
+ function verify_mem_size(expected_pages) {
+ assertEquals(expected_pages*kPageSize, memory.buffer.byteLength);
+ for (var i = start_index; i < end_index; i++) {
+ assertEquals(expected_pages, instances[i].exports.mem_size());
+ }
+ }
+
+ // Verify initial memory size of all instances, grow and verify that all
+ // instances are updated correctly.
+ verify_mem_size(100);
+ assertEquals(100, memory.grow(500));
+ verify_mem_size(600);
+
+ instances[1] = null;
+ gc();
+ gc();
+
+ // i[0] - i[2] - i[3] - i[4]
+ start_index = 2;
+ verify_mem_size(600);
+ assertEquals(600, instances[0].exports.mem_size());
+ assertEquals(600, grow_instance_2(200));
+ assertEquals(800*kPageSize, memory.buffer.byteLength);
+ verify_mem_size(800);
+ assertEquals(800, instances[0].exports.mem_size());
+
+ // Instantiate a new instance and verify that it can be grown correctly.
+ instances.push(builder.instantiate({imported_mem: memory}));
+ function grow_instance_5(pages) { return instances[5].exports.grow(pages); }
+ gc();
+ gc();
+
+ // i[0] - i[2] - i[3] - i[4] - i[5]
+ start_index = 2;
+ end_index = 6;
+ verify_mem_size(800);
+ assertEquals(800, instances[0].exports.mem_size());
+ assertEquals(800, grow_instance_2(100));
+ assertEquals(900*kPageSize, memory.buffer.byteLength);
+ verify_mem_size(900);
+ assertEquals(900, instances[0].exports.mem_size());
+
+ instances[4] = null;
+
+ gc();
+ gc();
+
+ // i[0] - i[2] - i[3] - i[5]
+ assertEquals(900, instances[0].exports.mem_size());
+ assertEquals(900, instances[2].exports.mem_size());
+ assertEquals(900, instances[3].exports.mem_size());
+ assertEquals(900, instances[5].exports.mem_size());
+ assertEquals(900, memory.grow(100));
+ assertEquals(1000*kPageSize, memory.buffer.byteLength);
+ assertEquals(1000, instances[0].exports.mem_size());
+ assertEquals(1000, instances[2].exports.mem_size());
+ assertEquals(1000, instances[3].exports.mem_size());
+ assertEquals(1000, instances[5].exports.mem_size());
+
+ gc();
+ gc();
+
+ instances[3] = null;
+
+ // i[0] - i[2] - i[5]
+ assertEquals(1000, instances[0].exports.mem_size());
+ assertEquals(1000, instances[2].exports.mem_size());
+ assertEquals(1000, instances[5].exports.mem_size());
+ assertEquals(1000, memory.grow(100));
+ assertEquals(1100*kPageSize, memory.buffer.byteLength);
+ assertEquals(1100, instances[0].exports.mem_size());
+ assertEquals(1100, instances[2].exports.mem_size());
+ assertEquals(1100, instances[5].exports.mem_size());
+
+ instances[0] = null;
+ gc();
+ gc();
+
+ // i[2] - i[5]
+ assertEquals(1100, instances[2].exports.mem_size());
+ assertEquals(1100, instances[5].exports.mem_size());
+ assertEquals(1100, grow_instance_5(1));
+ gc();
+ gc();
+
+ assertEquals(1101*kPageSize, memory.buffer.byteLength);
+ assertEquals(1101, instances[2].exports.mem_size());
+ assertEquals(1101, instances[5].exports.mem_size());
+})();
« no previous file with comments | « src/wasm/wasm-objects.cc ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698