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

Unified Diff: test/mjsunit/wasm/data-segments.js

Issue 2403823002: [wasm] Base address for data segments can also be the value of a global variable. (Closed)
Patch Set: Created 4 years, 2 months 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-module.cc ('k') | test/mjsunit/wasm/test-wasm-module-builder.js » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: test/mjsunit/wasm/data-segments.js
diff --git a/test/mjsunit/wasm/data-segments.js b/test/mjsunit/wasm/data-segments.js
new file mode 100644
index 0000000000000000000000000000000000000000..e73c96b7359ec48556b8752a4f78b91a4a0a0104
--- /dev/null
+++ b/test/mjsunit/wasm/data-segments.js
@@ -0,0 +1,90 @@
+// 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
+
+load("test/mjsunit/wasm/wasm-constants.js");
+load("test/mjsunit/wasm/wasm-module-builder.js");
+
+var debug = false;
+
+function SimpleDataSegmentTest(offset) {
+ print("SimpleDataSegmentTest(" + offset + ")...");
+ var builder = new WasmModuleBuilder();
+ builder.addMemory(1, 1, false);
+ builder.addFunction("load", kSig_i_i)
+ .addBody([kExprGetLocal, 0, kExprI32LoadMem, 0, 0])
+ .exportAs("load");
+ builder.addDataSegment(offset, [9, 9, 9, 9]);
+
+ var buffer = builder.toBuffer(debug);
+ var instance = Wasm.instantiateModule(buffer);
+ for (var i = offset - 20; i < offset + 20; i += 4) {
+ if (i < 0) continue;
+ var expected = (i == offset) ? 151587081 : 0;
+ assertEquals(expected, instance.exports.load(i));
+ }
+}
+
+SimpleDataSegmentTest(0);
+SimpleDataSegmentTest(4);
+SimpleDataSegmentTest(12);
+SimpleDataSegmentTest(1064);
+
+function GlobalInitTest(offset) {
+ print("GlobalInitTest(" + offset + ")...");
+ var builder = new WasmModuleBuilder();
+ builder.addMemory(1, 1, false);
+ var g = builder.addGlobal(kAstI32, false);
+ g.init = offset;
+ builder.addFunction("load", kSig_i_i)
+ .addBody([kExprGetLocal, 0, kExprI32LoadMem, 0, 0])
+ .exportAs("load");
+ builder.addDataSegment(g.index, [7, 7, 7, 7], true);
+
+ var buffer = builder.toBuffer(debug);
+ var instance = Wasm.instantiateModule(buffer);
+ for (var i = offset - 20; i < offset + 20; i += 4) {
+ if (i < 0) continue;
+ var expected = i == offset ? 117901063 : 0;
+ assertEquals(expected, instance.exports.load(i));
+ }
+}
+
+GlobalInitTest(0);
+GlobalInitTest(12);
+GlobalInitTest(3040);
+
+function GlobalImportedInitTest(pad) {
+ print("GlobaleImportedInitTest(" + pad + ")...");
+ var builder = new WasmModuleBuilder();
+ builder.addMemory(1, 1, false);
+
+ while (pad-- > 0) builder.addGlobal(kAstI32); // pad
+
+ var g = builder.addImportedGlobal("offset", undefined, kAstI32);
+
+ while (pad-- > 0) builder.addGlobal(kAstI32); // pad
+
+ builder.addFunction("load", kSig_i_i)
+ .addBody([kExprGetLocal, 0, kExprI32LoadMem, 0, 0])
+ .exportAs("load");
+ builder.addDataSegment(g.index, [5, 5, 5, 5], true);
+
+ var buffer = builder.toBuffer(debug);
+ var module = new WebAssembly.Module(buffer);
+
+ for (var offset of [0, 12, 192, 1024]) {
+ var instance = new WebAssembly.Instance(module, {offset: offset});
+ for (var i = offset - 20; i < offset + 20; i += 4) {
+ if (i < 0) continue;
+ var expected = i == offset ? 84215045 : 0;
+ assertEquals(expected, instance.exports.load(i));
+ }
+ }
+}
+
+GlobalImportedInitTest(0);
+GlobalImportedInitTest(1);
+GlobalImportedInitTest(4);
« no previous file with comments | « src/wasm/wasm-module.cc ('k') | test/mjsunit/wasm/test-wasm-module-builder.js » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698