Commit 6c497ee0 authored by Clemens Hammacher's avatar Clemens Hammacher Committed by Commit Bot

[wasm] Fix --dump-wasm-module

The generated file only contained the last section of the module, since
the decoder's range is reset in DecodeSection.
This CL fixes this by remembering the original module bytes and dumping
them instead.

R=ahaas@chromium.org

Change-Id: I5e0f97279886817d58caac6114994bb9c1a147fc
Reviewed-on: https://chromium-review.googlesource.com/892980Reviewed-by: 's avatarAndreas Haas <ahaas@chromium.org>
Commit-Queue: Clemens Hammacher <clemensh@chromium.org>
Cr-Commit-Position: refs/heads/master@{#50953}
parent 03da2d8c
...@@ -270,7 +270,7 @@ class ModuleDecoderImpl : public Decoder { ...@@ -270,7 +270,7 @@ class ModuleDecoderImpl : public Decoder {
pc_ = end_; // On error, terminate section decoding loop. pc_ = end_; // On error, terminate section decoding loop.
} }
void DumpModule(const ModuleResult& result) { void DumpModule(const Vector<const byte> module_bytes) {
std::string path; std::string path;
if (FLAG_dump_wasm_module_path) { if (FLAG_dump_wasm_module_path) {
path = FLAG_dump_wasm_module_path; path = FLAG_dump_wasm_module_path;
...@@ -280,12 +280,13 @@ class ModuleDecoderImpl : public Decoder { ...@@ -280,12 +280,13 @@ class ModuleDecoderImpl : public Decoder {
} }
} }
// File are named `HASH.{ok,failed}.wasm`. // File are named `HASH.{ok,failed}.wasm`.
size_t hash = base::hash_range(start_, end_); size_t hash = base::hash_range(module_bytes.start(), module_bytes.end());
EmbeddedVector<char, 32> buf; EmbeddedVector<char, 32> buf;
SNPrintF(buf, "%016zx.%s.wasm", hash, result.ok() ? "ok" : "failed"); SNPrintF(buf, "%016zx.%s.wasm", hash, ok() ? "ok" : "failed");
std::string name(buf.start()); std::string name(buf.start());
if (FILE* wasm_file = base::OS::FOpen((path + name).c_str(), "wb")) { if (FILE* wasm_file = base::OS::FOpen((path + name).c_str(), "wb")) {
if (fwrite(start_, end_ - start_, 1, wasm_file) != 1) { if (fwrite(module_bytes.start(), module_bytes.length(), 1, wasm_file) !=
1) {
OFStream os(stderr); OFStream os(stderr);
os << "Error while dumping wasm file" << std::endl; os << "Error while dumping wasm file" << std::endl;
} }
...@@ -848,7 +849,6 @@ class ModuleDecoderImpl : public Decoder { ...@@ -848,7 +849,6 @@ class ModuleDecoderImpl : public Decoder {
// Copy error code and location. // Copy error code and location.
result.MoveErrorFrom(intermediate_result_); result.MoveErrorFrom(intermediate_result_);
} }
if (FLAG_dump_wasm_module) DumpModule(result);
return result; return result;
} }
...@@ -856,6 +856,7 @@ class ModuleDecoderImpl : public Decoder { ...@@ -856,6 +856,7 @@ class ModuleDecoderImpl : public Decoder {
ModuleResult DecodeModule(Isolate* isolate, bool verify_functions = true) { ModuleResult DecodeModule(Isolate* isolate, bool verify_functions = true) {
StartDecoding(isolate); StartDecoding(isolate);
uint32_t offset = 0; uint32_t offset = 0;
Vector<const byte> orig_bytes(start(), end() - start());
DecodeModuleHeader(Vector<const uint8_t>(start(), end() - start()), offset); DecodeModuleHeader(Vector<const uint8_t>(start(), end() - start()), offset);
if (failed()) { if (failed()) {
return FinishDecoding(verify_functions); return FinishDecoding(verify_functions);
...@@ -878,6 +879,8 @@ class ModuleDecoderImpl : public Decoder { ...@@ -878,6 +879,8 @@ class ModuleDecoderImpl : public Decoder {
section_iter.advance(true); section_iter.advance(true);
} }
if (FLAG_dump_wasm_module) DumpModule(orig_bytes);
if (decoder.failed()) { if (decoder.failed()) {
return decoder.toResult<std::unique_ptr<WasmModule>>(nullptr); return decoder.toResult<std::unique_ptr<WasmModule>>(nullptr);
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment