From: Dan Gohman Date: Thu, 27 Feb 2020 15:51:37 +0000 (-0800) Subject: [WebAssembly] Teach lld how to demangle "__main_argc_argv". X-Git-Tag: llvmorg-12-init~13461 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=197bda587b4bb5e7603ad05fc1106332edc6afbd;p=platform%2Fupstream%2Fllvm.git [WebAssembly] Teach lld how to demangle "__main_argc_argv". WebAssembly requires that caller and callee signatures match, so it can't do the usual trick of passing more arguments to main than it expects. Instead WebAssembly will mangle "main" with argc/argv parameters as "__main_argc_argv". This patch teaches lld how to demangle it. This patch is part of https://reviews.llvm.org/D70700. --- diff --git a/lld/wasm/Symbols.cpp b/lld/wasm/Symbols.cpp index 3d8fec4..349fc65 100644 --- a/lld/wasm/Symbols.cpp +++ b/lld/wasm/Symbols.cpp @@ -29,6 +29,10 @@ std::string toString(const wasm::Symbol &sym) { } std::string maybeDemangleSymbol(StringRef name) { + // WebAssembly requires caller and callee signatures to match, so we mangle + // `main` in the case where we need to pass it arguments. + if (name == "__main_argc_argv") + return "main"; if (wasm::config->demangle) return demangleItanium(name); return std::string(name);