summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/passes/MemoryPacking.cpp12
-rw-r--r--test/lit/passes/memory-packing_all-features.wast28
2 files changed, 35 insertions, 5 deletions
diff --git a/src/passes/MemoryPacking.cpp b/src/passes/MemoryPacking.cpp
index 5178db3ac..b2798f4b6 100644
--- a/src/passes/MemoryPacking.cpp
+++ b/src/passes/MemoryPacking.cpp
@@ -278,8 +278,8 @@ bool MemoryPacking::canSplit(const std::unique_ptr<DataSegment>& segment,
return false;
}
}
- } else if (referrer->is<ArrayNewSeg>()) {
- // TODO: Split segments referenced by array.new_data instructions.
+ } else if (referrer->is<ArrayNewSeg>() || referrer->is<ArrayInit>()) {
+ // TODO: Split segments referenced by GC instructions.
return false;
}
}
@@ -479,8 +479,10 @@ void MemoryPacking::getSegmentReferrers(Module* module,
referrers[curr->segment].push_back(curr);
}
}
- void doWalkFunction(Function* func) {
- super::doWalkFunction(func);
+ void visitArrayInit(ArrayInit* curr) {
+ if (curr->op == InitData) {
+ referrers[curr->segment].push_back(curr);
+ }
}
} collector(referrers);
collector.walkFunctionInModule(func, module);
@@ -586,7 +588,7 @@ void MemoryPacking::createSplitSegments(
segment->memory,
segment->isPassive,
offset,
- &segment->data[range.start],
+ segment->data.data() + range.start,
range.end - range.start);
curr->hasExplicitName = hasExplicitName;
packed.push_back(std::move(curr));
diff --git a/test/lit/passes/memory-packing_all-features.wast b/test/lit/passes/memory-packing_all-features.wast
index bf07acd63..36ae10668 100644
--- a/test/lit/passes/memory-packing_all-features.wast
+++ b/test/lit/passes/memory-packing_all-features.wast
@@ -2389,3 +2389,31 @@
)
)
)
+(module
+ ;; CHECK: (type $array (array (mut i32)))
+ (type $array (array (mut i32)))
+ ;; CHECK: (type $ref|$array|_i32_i32_i32_=>_none (func (param (ref $array) i32 i32 i32)))
+
+ ;; CHECK: (memory $0 (shared 16 17))
+ (memory $0 (shared 16 17))
+ ;; CHECK: (data $0 "")
+ (data $0 "")
+ ;; CHECK: (func $0 (type $ref|$array|_i32_i32_i32_=>_none) (param $0 (ref $array)) (param $1 i32) (param $2 i32) (param $3 i32)
+ ;; CHECK-NEXT: (array.init_data $array $0
+ ;; CHECK-NEXT: (local.get $0)
+ ;; CHECK-NEXT: (i32.const 0)
+ ;; CHECK-NEXT: (i32.const 0)
+ ;; CHECK-NEXT: (i32.const 0)
+ ;; CHECK-NEXT: )
+ ;; CHECK-NEXT: )
+ (func $0 (param $0 (ref $array)) (param $1 i32) (param $2 i32) (param $3 i32)
+ ;; test that we do not improperly optimize out segments referred to by
+ ;; array.init_data instructions.
+ (array.init_data $array $0
+ (local.get $0)
+ (i32.const 0)
+ (i32.const 0)
+ (i32.const 0)
+ )
+ )
+)