Index: llvm/trunk/lib/Target/WebAssembly/WebAssemblyCFGStackify.cpp =================================================================== --- llvm/trunk/lib/Target/WebAssembly/WebAssemblyCFGStackify.cpp +++ llvm/trunk/lib/Target/WebAssembly/WebAssemblyCFGStackify.cpp @@ -880,5 +880,6 @@ .isOSBinFormatELF()) appendEndToFunction(MF, TII); + MF.getInfo()->setCFGStackified(); return true; } Index: llvm/trunk/lib/Target/WebAssembly/WebAssemblyMachineFunctionInfo.h =================================================================== --- llvm/trunk/lib/Target/WebAssembly/WebAssemblyMachineFunctionInfo.h +++ llvm/trunk/lib/Target/WebAssembly/WebAssemblyMachineFunctionInfo.h @@ -56,6 +56,9 @@ // overaligned values on the user stack. unsigned BasePtrVreg = -1U; + // Function properties. + bool CFGStackified = false; + public: explicit WebAssemblyFunctionInfo(MachineFunction &MF) : MF(MF) {} ~WebAssemblyFunctionInfo() override; @@ -123,6 +126,9 @@ assert(Reg & INT32_MIN); return Reg & INT32_MAX; } + + bool isCFGStackified() const { return CFGStackified; } + void setCFGStackified(bool Value = true) { CFGStackified = Value; } }; void computeLegalValueVTs(const Function &F, const TargetMachine &TM, Type *Ty, @@ -144,6 +150,8 @@ namespace yaml { struct WebAssemblyFunctionInfo final : public yaml::MachineFunctionInfo { + bool CFGStackified = false; + WebAssemblyFunctionInfo() = default; WebAssemblyFunctionInfo(const llvm::WebAssemblyFunctionInfo &MFI); @@ -152,7 +160,9 @@ }; template <> struct MappingTraits { - static void mapping(IO &YamlIO, WebAssemblyFunctionInfo &MFI) {} + static void mapping(IO &YamlIO, WebAssemblyFunctionInfo &MFI) { + YamlIO.mapOptional("isCFGStackified", MFI.CFGStackified, false); + } }; } // end namespace yaml Index: llvm/trunk/lib/Target/WebAssembly/WebAssemblyMachineFunctionInfo.cpp =================================================================== --- llvm/trunk/lib/Target/WebAssembly/WebAssemblyMachineFunctionInfo.cpp +++ llvm/trunk/lib/Target/WebAssembly/WebAssemblyMachineFunctionInfo.cpp @@ -79,11 +79,14 @@ } yaml::WebAssemblyFunctionInfo::WebAssemblyFunctionInfo( - const llvm::WebAssemblyFunctionInfo &MFI) {} + const llvm::WebAssemblyFunctionInfo &MFI) + : CFGStackified(MFI.isCFGStackified()) {} void yaml::WebAssemblyFunctionInfo::mappingImpl(yaml::IO &YamlIO) { MappingTraits::mapping(YamlIO, *this); } void WebAssemblyFunctionInfo::initializeBaseYamlFields( - const yaml::WebAssemblyFunctionInfo &YamlMFI) {} + const yaml::WebAssemblyFunctionInfo &YamlMFI) { + CFGStackified = YamlMFI.CFGStackified; +} Index: llvm/trunk/test/CodeGen/WebAssembly/function-info.mir =================================================================== --- llvm/trunk/test/CodeGen/WebAssembly/function-info.mir +++ llvm/trunk/test/CodeGen/WebAssembly/function-info.mir @@ -1,7 +1,8 @@ # RUN: llc -mtriple=wasm32-unknown-unknown -run-pass wasm-cfg-stackify %s -o - | FileCheck %s # CHECK-LABEL: function_property_test -# CHECK: machineFunctionInfo: {} +# CHECK: machineFunctionInfo: +# CHECK: isCFGStackified: true name: function_property_test liveins: - { reg: '$arguments' }