| 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();
|
|
|
|
|