Index: test/cctest/compiler/test-simplified-lowering.cc |
diff --git a/test/cctest/compiler/test-simplified-lowering.cc b/test/cctest/compiler/test-simplified-lowering.cc |
index 2c97379cbb0cd8eb1a85c6ae311feb6c8e9e8e22..4376f705c0649f7ccee814e203eb737e2338c980 100644 |
--- a/test/cctest/compiler/test-simplified-lowering.cc |
+++ b/test/cctest/compiler/test-simplified-lowering.cc |
@@ -207,8 +207,10 @@ TEST(RunLoadStoreMap) { |
TEST(RunLoadStoreFixedArrayIndex) { |
SimplifiedLoweringTester<Object*> t(kMachAnyTagged); |
ElementAccess access = AccessBuilder::ForFixedArrayElement(); |
- Node* load = t.LoadElement(access, t.Parameter(0), t.Int32Constant(0)); |
- t.StoreElement(access, t.Parameter(0), t.Int32Constant(1), load); |
+ Node* load = t.LoadElement(access, t.Parameter(0), t.Int32Constant(0), |
+ t.Int32Constant(2)); |
+ t.StoreElement(access, t.Parameter(0), t.Int32Constant(1), t.Int32Constant(2), |
+ load); |
t.Return(load); |
t.LowerAllNodes(); |
@@ -231,14 +233,16 @@ TEST(RunLoadStoreFixedArrayIndex) { |
TEST(RunLoadStoreArrayBuffer) { |
SimplifiedLoweringTester<Object*> t(kMachAnyTagged); |
const int index = 12; |
+ const int array_length = 2 * index; |
ElementAccess buffer_access = |
AccessBuilder::ForBackingStoreElement(kMachInt8); |
Node* backing_store = t.LoadField( |
AccessBuilder::ForJSArrayBufferBackingStore(), t.Parameter(0)); |
Node* load = |
- t.LoadElement(buffer_access, backing_store, t.Int32Constant(index)); |
+ t.LoadElement(buffer_access, backing_store, t.Int32Constant(index), |
+ t.Int32Constant(array_length)); |
t.StoreElement(buffer_access, backing_store, t.Int32Constant(index + 1), |
- load); |
+ t.Int32Constant(array_length), load); |
t.Return(t.jsgraph.TrueConstant()); |
t.LowerAllNodes(); |
@@ -246,7 +250,6 @@ TEST(RunLoadStoreArrayBuffer) { |
if (Pipeline::SupportedTarget()) { |
Handle<JSArrayBuffer> array = t.factory()->NewJSArrayBuffer(); |
- const int array_length = 2 * index; |
Runtime::SetupArrayBufferAllocatingData(t.isolate(), array, array_length); |
uint8_t* data = reinterpret_cast<uint8_t*>(array->backing_store()); |
for (int i = 0; i < array_length; i++) { |
@@ -326,8 +329,9 @@ TEST(RunLoadElementFromUntaggedBase) { |
kMachAnyTagged}; |
SimplifiedLoweringTester<Object*> t; |
- Node* load = t.LoadElement(access, t.PointerConstant(smis), |
- t.Int32Constant(static_cast<int>(j))); |
+ Node* load = t.LoadElement( |
+ access, t.PointerConstant(smis), t.Int32Constant(static_cast<int>(j)), |
+ t.Int32Constant(static_cast<int>(arraysize(smis)))); |
t.Return(load); |
t.LowerAllNodes(); |
@@ -356,7 +360,8 @@ TEST(RunStoreElementFromUntaggedBase) { |
SimplifiedLoweringTester<Object*> t(kMachAnyTagged); |
Node* p0 = t.Parameter(0); |
t.StoreElement(access, t.PointerConstant(smis), |
- t.Int32Constant(static_cast<int>(j)), p0); |
+ t.Int32Constant(static_cast<int>(j)), |
+ t.Int32Constant(static_cast<int>(arraysize(smis))), p0); |
t.Return(p0); |
t.LowerAllNodes(); |
@@ -422,8 +427,10 @@ class AccessTester : public HandleAndZoneScope { |
SimplifiedLoweringTester<Object*> t; |
Node* ptr = GetBaseNode(&t); |
- Node* load = t.LoadElement(access, ptr, t.Int32Constant(from_index)); |
- t.StoreElement(access, ptr, t.Int32Constant(to_index), load); |
+ Node* load = t.LoadElement(access, ptr, t.Int32Constant(from_index), |
+ t.Int32Constant(num_elements)); |
+ t.StoreElement(access, ptr, t.Int32Constant(to_index), |
+ t.Int32Constant(num_elements), load); |
t.Return(t.jsgraph.TrueConstant()); |
t.LowerAllNodes(); |
t.GenerateCode(); |
@@ -1341,8 +1348,9 @@ TEST(LowerLoadElement_to_load) { |
ElementAccess access = {kTaggedBase, FixedArrayBase::kHeaderSize, |
Type::Any(), machine_reps[i]}; |
- Node* load = t.graph()->NewNode(t.simplified()->LoadElement(access), t.p0, |
- t.p1, t.start); |
+ Node* load = |
+ t.graph()->NewNode(t.simplified()->LoadElement(access), t.p0, t.p1, |
+ t.jsgraph.Int32Constant(1024), t.start); |
Node* use = t.Use(load, machine_reps[i]); |
t.Return(use); |
t.Lower(); |
@@ -1365,7 +1373,8 @@ TEST(LowerStoreElement_to_store) { |
Node* val = t.ExampleWithOutput(machine_reps[i]); |
Node* store = t.graph()->NewNode(t.simplified()->StoreElement(access), t.p0, |
- t.p1, val, t.start, t.start); |
+ t.p1, t.jsgraph.Int32Constant(1024), val, |
+ t.start, t.start); |
t.Effect(store); |
t.Lower(); |
CHECK_EQ(IrOpcode::kStore, store->opcode()); |
@@ -1389,7 +1398,7 @@ TEST(InsertChangeForLoadElementIndex) { |
kMachAnyTagged}; |
Node* load = t.graph()->NewNode(t.simplified()->LoadElement(access), t.p0, |
- t.p1, t.start); |
+ t.p1, t.jsgraph.Int32Constant(1024), t.start); |
t.Return(load); |
t.Lower(); |
CHECK_EQ(IrOpcode::kLoad, load->opcode()); |
@@ -1407,9 +1416,9 @@ TEST(InsertChangeForStoreElementIndex) { |
ElementAccess access = {kTaggedBase, FixedArrayBase::kHeaderSize, Type::Any(), |
kMachAnyTagged}; |
- Node* store = |
- t.graph()->NewNode(t.simplified()->StoreElement(access), t.p0, t.p1, |
- t.jsgraph.TrueConstant(), t.start, t.start); |
+ Node* store = t.graph()->NewNode(t.simplified()->StoreElement(access), t.p0, |
+ t.p1, t.jsgraph.Int32Constant(1024), |
+ t.jsgraph.TrueConstant(), t.start, t.start); |
t.Effect(store); |
t.Lower(); |
CHECK_EQ(IrOpcode::kStore, store->opcode()); |
@@ -1427,7 +1436,7 @@ TEST(InsertChangeForLoadElement) { |
kMachFloat64}; |
Node* load = t.graph()->NewNode(t.simplified()->LoadElement(access), t.p0, |
- t.p1, t.start); |
+ t.p1, t.jsgraph.Int32Constant(1024), t.start); |
t.Return(load); |
t.Lower(); |
CHECK_EQ(IrOpcode::kLoad, load->opcode()); |
@@ -1458,9 +1467,9 @@ TEST(InsertChangeForStoreElement) { |
ElementAccess access = {kTaggedBase, FixedArrayBase::kHeaderSize, Type::Any(), |
kMachFloat64}; |
- Node* store = |
- t.graph()->NewNode(t.simplified()->StoreElement(access), t.p0, |
- t.jsgraph.Int32Constant(0), t.p1, t.start, t.start); |
+ Node* store = t.graph()->NewNode( |
+ t.simplified()->StoreElement(access), t.p0, t.jsgraph.Int32Constant(0), |
+ t.jsgraph.Int32Constant(1024), t.p1, t.start, t.start); |
t.Effect(store); |
t.Lower(); |