summaryrefslogtreecommitdiff
path: root/src/passes/pass.cpp
diff options
context:
space:
mode:
authorAlon Zakai <alonzakai@gmail.com>2016-07-16 16:27:38 -0700
committerGitHub <noreply@github.com>2016-07-16 16:27:38 -0700
commitcd61f6a1ae959cc3ee22f4e72f0f4ba73c2abbd1 (patch)
treeeef538171ffef9c72ca9d319d93a1f56bd47cd85 /src/passes/pass.cpp
parentce8ee20462a465f00520dbe0dd2aa3e1601f4ca1 (diff)
parent07170478897c81aa973217ae8070d2d155d16b2e (diff)
downloadbinaryen-cd61f6a1ae959cc3ee22f4e72f0f4ba73c2abbd1.tar.gz
binaryen-cd61f6a1ae959cc3ee22f4e72f0f4ba73c2abbd1.tar.bz2
binaryen-cd61f6a1ae959cc3ee22f4e72f0f4ba73c2abbd1.zip
Merge pull request #644 from WebAssembly/fix-debug
Fix dce bug in non-parallel mode, which happens in debug mode
Diffstat (limited to 'src/passes/pass.cpp')
-rw-r--r--src/passes/pass.cpp9
1 files changed, 8 insertions, 1 deletions
diff --git a/src/passes/pass.cpp b/src/passes/pass.cpp
index e04033d90..f27eccf6a 100644
--- a/src/passes/pass.cpp
+++ b/src/passes/pass.cpp
@@ -149,7 +149,14 @@ void PassRunner::run() {
std::cerr << ' ';
}
before = std::chrono::high_resolution_clock::now();
- pass->run(this, wasm);
+ if (pass->isFunctionParallel()) {
+ // function-parallel passes should get a new instance per function
+ for (auto& func : wasm->functions) {
+ runPassOnFunction(pass, func.get());
+ }
+ } else {
+ pass->run(this, wasm);
+ }
auto after = std::chrono::high_resolution_clock::now();
std::chrono::duration<double> diff = after - before;
std::cerr << diff.count() << " seconds." << std::endl;