Index: llvm/trunk/lib/CodeGen/TargetLoweringObjectFileImpl.cpp =================================================================== --- llvm/trunk/lib/CodeGen/TargetLoweringObjectFileImpl.cpp +++ llvm/trunk/lib/CodeGen/TargetLoweringObjectFileImpl.cpp @@ -1265,11 +1265,22 @@ "' cannot be lowered."); } +static SectionKind getWasmKindForNamedSection(StringRef Name, SectionKind K) { + // If we're told we have function data, then use that. + if (K.isText()) + return SectionKind::getText(); + + // Otherwise, ignore whatever section type the generic impl detected and use + // a plain data section. + return SectionKind::getData(); +} + MCSection *TargetLoweringObjectFileWasm::getExplicitSectionGlobal( const GlobalObject *GO, SectionKind Kind, const TargetMachine &TM) const { StringRef Name = GO->getSection(); checkWasmComdat(GO); - return getContext().getWasmSection(Name, SectionKind::getData()); + Kind = getWasmKindForNamedSection(Name, Kind); + return getContext().getWasmSection(Name, Kind); } static MCSectionWasm *selectWasmSectionForGlobal( Index: llvm/trunk/test/MC/WebAssembly/custom-code-section.ll =================================================================== --- llvm/trunk/test/MC/WebAssembly/custom-code-section.ll +++ llvm/trunk/test/MC/WebAssembly/custom-code-section.ll @@ -0,0 +1,9 @@ +; RUN: llc -mtriple wasm32-unknown-unknown-wasm -O2 -filetype=obj %s -o %t.o + +; Wasm silently ignores custom sections for code. +; We had a bug where this cause a crash + +define hidden void @call_indirect() section "some_section_name" { +entry: + ret void +}