Index: llvm/trunk/lib/MC/MCContext.cpp =================================================================== --- llvm/trunk/lib/MC/MCContext.cpp +++ llvm/trunk/lib/MC/MCContext.cpp @@ -105,6 +105,7 @@ MachOUniquingMap.clear(); ELFUniquingMap.clear(); COFFUniquingMap.clear(); + WasmUniquingMap.clear(); NextID.clear(); AllowTemporaryLabels = true; Index: llvm/trunk/lib/MC/WasmObjectWriter.cpp =================================================================== --- llvm/trunk/lib/MC/WasmObjectWriter.cpp +++ llvm/trunk/lib/MC/WasmObjectWriter.cpp @@ -270,9 +270,9 @@ Globals.clear(); DataSegments.clear(); SectionFunctions.clear(); - MCObjectWriter::reset(); NumFunctionImports = 0; NumGlobalImports = 0; + MCObjectWriter::reset(); } void writeHeader(const MCAssembler &Asm); Index: llvm/trunk/test/MC/WebAssembly/compile-twice.ll =================================================================== --- llvm/trunk/test/MC/WebAssembly/compile-twice.ll +++ llvm/trunk/test/MC/WebAssembly/compile-twice.ll @@ -0,0 +1,14 @@ +; Check that there is no persistent state in the WabAssembly emitter that cause +; issues when reusing the pass manager. +; RUN: llc -mtriple=wasm32-unknown-unknown -compile-twice -filetype=obj %s -o - + +; Force the creation of a DWARF section +!llvm.dbg.cu = !{!0} +!llvm.module.flags = !{!3, !4} + +@myglobal = global i32 0, align 4 + +!0 = distinct !DICompileUnit(language: DW_LANG_C99, file: !1, producer: "LLVM", isOptimized: true, emissionKind: FullDebug) +!1 = !DIFile(filename: "", directory: "/") +!3 = !{i32 2, !"Dwarf Version", i32 4} +!4 = !{i32 2, !"Debug Info Version", i32 3}