| // Copyright 2017 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. |
| |
| load("test/mjsunit/wasm/wasm-module-builder.js"); |
| |
| function testMemoryGrowOutOfBoundsOffset() { |
| print("testMemoryGrowOutOfBoundsOffset2"); |
| var builder = new WasmModuleBuilder(); |
| builder.addMemory(16, 128, false); |
| builder.addFunction("main", kSig_v_v) |
| .addBody([ |
| kExprI32Const, 20, |
| kExprI32Const, 29, |
| kExprMemoryGrow, kMemoryZero, |
| // Assembly equivalent Move <reg>,0xf5fffff |
| // with wasm memory reference relocation information |
| kExprI32StoreMem, 0, 0xFF, 0xFF, 0xFF, 0x7A |
| ]) |
| .exportAs("main"); |
| var module = builder.instantiate(); |
| assertTraps(kTrapMemOutOfBounds, module.exports.main); |
| } |
| |
| testMemoryGrowOutOfBoundsOffset(); |