From: Simon Pilgrim Date: Thu, 15 Nov 2018 15:17:15 +0000 (+0000) Subject: [X86] Fix MCNullStreamer support for modules with a CodeView flag X-Git-Tag: android-x86-9.0-r1~10581 X-Git-Url: http://git.osdn.net/view?a=commitdiff_plain;h=a1316f9816a5e7b184ee2398be32adf942d54022;p=android-x86%2Fexternal-llvm.git [X86] Fix MCNullStreamer support for modules with a CodeView flag This fixes -filetype=null support when compiling for a Win32 target and the module has a CodeView flag. The only places changed are the uses of getTargetStreamer function - this patch guards both of them with null checks. Committed on behalf of @eush (Eugene Sharygin) Differential Revision: https://reviews.llvm.org/D54008 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@346962 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/Target/X86/X86AsmPrinter.cpp b/lib/Target/X86/X86AsmPrinter.cpp index 74dbdcd2793..b164b4e1fcf 100644 --- a/lib/Target/X86/X86AsmPrinter.cpp +++ b/lib/Target/X86/X86AsmPrinter.cpp @@ -88,19 +88,19 @@ bool X86AsmPrinter::runOnMachineFunction(MachineFunction &MF) { void X86AsmPrinter::EmitFunctionBodyStart() { if (EmitFPOData) { - X86TargetStreamer *XTS = - static_cast(OutStreamer->getTargetStreamer()); - unsigned ParamsSize = - MF->getInfo()->getArgumentStackSize(); - XTS->emitFPOProc(CurrentFnSym, ParamsSize); + if (auto *XTS = + static_cast(OutStreamer->getTargetStreamer())) + XTS->emitFPOProc( + CurrentFnSym, + MF->getInfo()->getArgumentStackSize()); } } void X86AsmPrinter::EmitFunctionBodyEnd() { if (EmitFPOData) { - X86TargetStreamer *XTS = - static_cast(OutStreamer->getTargetStreamer()); - XTS->emitFPOEndProc(); + if (auto *XTS = + static_cast(OutStreamer->getTargetStreamer())) + XTS->emitFPOEndProc(); } } diff --git a/test/CodeGen/X86/null-streamer.ll b/test/CodeGen/X86/null-streamer.ll index 8528be3ca59..28a457f64d4 100644 --- a/test/CodeGen/X86/null-streamer.ll +++ b/test/CodeGen/X86/null-streamer.ll @@ -14,7 +14,7 @@ define void @f1() { } !llvm.dbg.cu = !{!0} -!llvm.module.flags = !{!7, !8} +!llvm.module.flags = !{!7, !8, !9} !0 = distinct !DICompileUnit(language: DW_LANG_C_plus_plus, file: !1, producer: " ", isOptimized: true, runtimeVersion: 0, emissionKind: FullDebug, enums: !2, retainedTypes: !2, globals: !3, imports: !2) !1 = !DIFile(filename: "file.c", directory: "") @@ -25,4 +25,4 @@ define void @f1() { !6 = !DIBasicType(size: 32, align: 32, encoding: DW_ATE_signed) !7 = !{i32 2, !"Dwarf Version", i32 3} !8 = !{i32 1, !"Debug Info Version", i32 3} - +!9 = !{i32 2, !"CodeView", i32 1}