summaryrefslogtreecommitdiff
path: root/src/tools
diff options
context:
space:
mode:
Diffstat (limited to 'src/tools')
-rw-r--r--src/tools/asm2wasm.cpp12
-rw-r--r--src/tools/optimization-options.h86
-rw-r--r--src/tools/wasm-opt.cpp26
3 files changed, 101 insertions, 23 deletions
diff --git a/src/tools/asm2wasm.cpp b/src/tools/asm2wasm.cpp
index cd500b0d9..def361066 100644
--- a/src/tools/asm2wasm.cpp
+++ b/src/tools/asm2wasm.cpp
@@ -30,7 +30,8 @@ using namespace cashew;
using namespace wasm;
int main(int argc, const char *argv[]) {
- bool opts = true;
+ PassOptions passOptions;
+ bool runOptimizationPasses = false;
bool imprecise = false;
bool wasmOnly = false;
@@ -54,9 +55,10 @@ int main(int argc, const char *argv[]) {
[](Options *o, const std::string &argument) {
o->extra["total memory"] = argument;
})
- .add("--no-opts", "-n", "Disable optimization passes", Options::Arguments::Zero,
- [&opts](Options *o, const std::string &) {
- opts = false;
+ #include "optimization-options.h"
+ .add("--no-opts", "-n", "Disable optimization passes (deprecated)", Options::Arguments::Zero,
+ [](Options *o, const std::string &) {
+ std::cerr << "--no-opts is deprecated (use -O0, etc.)\n";
})
.add("--imprecise", "-i", "Imprecise optimizations", Options::Arguments::Zero,
[&imprecise](Options *o, const std::string &) {
@@ -93,7 +95,7 @@ int main(int argc, const char *argv[]) {
if (options.debug) std::cerr << "wasming..." << std::endl;
Module wasm;
wasm.memory.initial = wasm.memory.max = totalMemory / Memory::kPageSize;
- Asm2WasmBuilder asm2wasm(wasm, pre.memoryGrowth, options.debug, imprecise, opts, wasmOnly);
+ Asm2WasmBuilder asm2wasm(wasm, pre.memoryGrowth, options.debug, imprecise, passOptions, runOptimizationPasses, wasmOnly);
asm2wasm.processAsm(asmjs);
// import mem init file, if provided
diff --git a/src/tools/optimization-options.h b/src/tools/optimization-options.h
new file mode 100644
index 000000000..0e57cd212
--- /dev/null
+++ b/src/tools/optimization-options.h
@@ -0,0 +1,86 @@
+/*
+ * Copyright 2016 WebAssembly Community Group participants
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+//
+// Shared optimization options for commandline tools
+//
+
+ .add("", "-O", "execute default optimization passes",
+ Options::Arguments::Zero,
+ [&runOptimizationPasses, &passOptions](Options*, const std::string&) {
+ passOptions.optimizeLevel = 2;
+ passOptions.shrinkLevel = 1;
+ passOptions.ignoreImplicitTraps = true;
+ runOptimizationPasses = true;
+ })
+ .add("", "-O0", "execute no optimization passes",
+ Options::Arguments::Zero,
+ [&runOptimizationPasses, &passOptions](Options*, const std::string&) {
+ passOptions.optimizeLevel = 0;
+ passOptions.shrinkLevel = 0;
+ passOptions.ignoreImplicitTraps = false;
+ })
+ .add("", "-O1", "execute -O1 optimization passes",
+ Options::Arguments::Zero,
+ [&runOptimizationPasses, &passOptions](Options*, const std::string&) {
+ passOptions.optimizeLevel = 1;
+ passOptions.shrinkLevel = 0;
+ passOptions.ignoreImplicitTraps = true;
+ runOptimizationPasses = true;
+ })
+ .add("", "-O2", "execute -O2 optimization passes",
+ Options::Arguments::Zero,
+ [&runOptimizationPasses, &passOptions](Options*, const std::string&) {
+ passOptions.optimizeLevel = 2;
+ passOptions.shrinkLevel = 0;
+ passOptions.ignoreImplicitTraps = true;
+ runOptimizationPasses = true;
+ })
+ .add("", "-O3", "execute -O3 optimization passes",
+ Options::Arguments::Zero,
+ [&runOptimizationPasses, &passOptions](Options*, const std::string&) {
+ passOptions.optimizeLevel = 3;
+ passOptions.shrinkLevel = 0;
+ passOptions.ignoreImplicitTraps = true;
+ runOptimizationPasses = true;
+ })
+ .add("", "-Os", "execute default optimization passes, focusing on code size",
+ Options::Arguments::Zero,
+ [&runOptimizationPasses, &passOptions](Options*, const std::string&) {
+ passOptions.optimizeLevel = 2;
+ passOptions.shrinkLevel = 1;
+ passOptions.ignoreImplicitTraps = true;
+ runOptimizationPasses = true;
+ })
+ .add("", "-Oz", "execute default optimization passes, super-focusing on code size",
+ Options::Arguments::Zero,
+ [&runOptimizationPasses, &passOptions](Options*, const std::string&) {
+ passOptions.optimizeLevel = 2;
+ passOptions.shrinkLevel = 2;
+ passOptions.ignoreImplicitTraps = true;
+ runOptimizationPasses = true;
+ })
+ .add("--optimize-level", "-ol", "How much to focus on optimizing code",
+ Options::Arguments::One,
+ [&passOptions](Options* o, const std::string& argument) {
+ passOptions.optimizeLevel = atoi(argument.c_str());
+ })
+ .add("--shrink-level", "-s", "How much to focus on shrinking code size",
+ Options::Arguments::One,
+ [&passOptions](Options* o, const std::string& argument) {
+ passOptions.shrinkLevel = atoi(argument.c_str());
+ })
+
diff --git a/src/tools/wasm-opt.cpp b/src/tools/wasm-opt.cpp
index aad87726b..1da038b8e 100644
--- a/src/tools/wasm-opt.cpp
+++ b/src/tools/wasm-opt.cpp
@@ -37,6 +37,7 @@ using namespace wasm;
int main(int argc, const char* argv[]) {
Name entry;
std::vector<std::string> passes;
+ bool runOptimizationPasses = false;
PassOptions passOptions;
Options options("wasm-opt", "Optimize .wast files");
@@ -47,24 +48,7 @@ int main(int argc, const char* argv[]) {
o->extra["output"] = argument;
Colors::disable();
})
- .add("", "-O", "execute default optimization passes",
- Options::Arguments::Zero,
- [&passes, &passOptions](Options*, const std::string&) {
- passOptions.setDefaultOptimizationOptions();
- passes.push_back("O");
- })
- .add("", "-Os", "execute default optimization passes, focusing on code size",
- Options::Arguments::Zero,
- [&passes, &passOptions](Options*, const std::string&) {
- passOptions.setDefaultOptimizationOptions();
- passOptions.shrinkLevel = 1;
- passes.push_back("O");
- })
- .add("--shrink-level", "-s", "How much to focus on shrinking code size",
- Options::Arguments::One,
- [&passOptions](Options* o, const std::string& argument) {
- passOptions.shrinkLevel = atoi(argument.c_str());
- })
+ #include "optimization-options.h"
.add_positional("INFILE", Options::Arguments::One,
[](Options* o, const std::string& argument) {
o->extra["infile"] = argument;
@@ -77,6 +61,12 @@ int main(int argc, const char* argv[]) {
}
options.parse(argc, argv);
+ if (runOptimizationPasses) {
+ passes.resize(passes.size() + 1);
+ std::move_backward(passes.begin(), passes.begin() + passes.size() - 1, passes.end());
+ passes[0] = "O";
+ }
+
auto input(read_file<std::string>(options.extra["infile"], Flags::Text, options.debug ? Flags::Debug : Flags::Release));
Module wasm;