99 changes: 77 additions & 22 deletions clang/test/CodeGenCXX/mangle-class-nttp.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,7 @@ template<B> void f() {}

int n = 0;
// CHECK: define weak_odr void @_Z1fIXtl1BadL_Z1nEEEEvv(
// MSABI: define {{.*}} @"??$f@$2UB@@PEBH1?n@@3HAH0A@@@@YAXXZ"
// MSABI: define {{.*}} @"??$f@$2UB@@PEBHE?n@@3HAH0A@@@@YAXXZ"
template void f<B{&n}>();
// CHECK: define weak_odr void @_Z1fIXtl1BLPKi0ELi1EEEEvv(
// MSABI: define {{.*}} @"??$f@$2UB@@PEBH0A@H00@@@YAXXZ"
Expand All @@ -36,15 +36,19 @@ template void f<B{fold(reinterpret_cast<int*>(0))}>();

// Pointers to subobjects.
struct Nested { union { int k; int arr[2]; }; } nested[2];
struct Derived : A, Nested { int z; } extern derived;
struct Derived : A, Nested { int z; A a_field; } extern derived;
// CHECK: define weak_odr void @_Z1fIXtl1BadsoKiL_Z7derivedE16EEEEvv
// MSABI: define {{.*}} void @"??$f@$2UB@@PEBH56E?derived@@3UDerived@@Az@@@H0A@@@@YAXXZ"
template void f<B{&derived.z}>();
// FIXME: We don't know the MS ABI mangling for array subscripting and
// past-the-end pointers yet.
#ifndef _WIN32
// CHECK: define weak_odr void @_Z1fIXtl1BadsoKiL_Z7derivedE20EEEEvv
// MSABI: define {{.*}} void @"??$f@$2UB@@PEBH566E?derived@@3UDerived@@Aa_field@@a@@@H0A@@@@YAXXZ"
template void f<B{&derived.a_field.a}>();
// CHECK: define weak_odr void @_Z1fIXtl1BadsoKiL_Z6nestedE_EEEEvv
// MSABI: define {{.*}} void @"??$f@$2UB@@PEBH56CE?nested@@3PAUNested@@A0A@@k@@@H0A@@@@YAXXZ"
template void f<B{&nested[0].k}>();
// Mangling of pointers to nested array elements and past-the-end pointers
// is still incorrect in MSVC.
#ifndef _WIN32
// CHECK: define weak_odr void @_Z1fIXtl1BadsoKiL_Z6nestedE16_0pEEEEvv
template void f<B{&nested[1].arr[2]}>();
// CHECK: define weak_odr void @_Z1fIXtl1BadsoKiL_Z7derivedE8pEEEEvv
Expand All @@ -59,14 +63,16 @@ template<BR> void f() {}
// CHECK: define weak_odr void @_Z1fIXtl2BRsoKiL_Z7derivedE16EEEEvv
// MSABI: define {{.*}} void @"??$f@$2UBR@@AEBH6E?derived@@3UDerived@@Az@@@@@YAXXZ"
template void f<BR{derived.z}>();
// FIXME: We don't know the MS ABI mangling for array subscripting yet.
#ifndef _WIN32
// CHECK: define weak_odr void @_Z1fIXtl2BRsoKiL_Z6nestedE_EEEEvv
// MSABI: define {{.*}} void @"??$f@$2UBR@@AEBH6CE?nested@@3PAUNested@@A0A@@k@@@@@YAXXZ"
template void f<BR{nested[0].k}>();
// CHECK: define weak_odr void @_Z1fIXtl2BRsoKiL_Z6nestedE12_0EEEEvv
// MSABI: define {{.*}} void @"??$f@$2UBR@@AEBHC6CE?nested@@3PAUNested@@A00@arr@@00@@@@YAXXZ"
template void f<BR{nested[1].arr[1]}>();
// CHECK: define weak_odr void @_Z1fIXtl2BRsoKiL_Z7derivedE4EEEEvv
// MSABI: define {{.*}} void @"??$f@$2UBR@@AEBH66E?derived@@3UDerived@@AA@@b@@@@@YAXXZ"
template void f<BR{derived.b}>();
#ifndef _WIN32
// CHECK: define weak_odr void @_Z1fIXtl2BRdecvPKiplcvPcadL_Z7derivedELl16EEEEvv
template void f<BR{fold(*(&derived.b + 3))}>();
#endif
Expand All @@ -77,42 +83,93 @@ template<C> void f() {}
// CHECK: define weak_odr void @_Z1fIXtl1CadsoKiL_Z7derivedE16EEEEvv
// MSABI: define {{.*}} void @"??$f@$2UC@@PEBH56E?derived@@3UDerived@@Az@@@@@@YAXXZ"
template void f<C{&derived.z}>();
#ifndef _WIN32
// CHECK: define weak_odr void @_Z1fIXtl1CadsoKiL_Z7derivedE4EEEEvv
// MSABI: define {{.*}} void @"??$f@$2UC@@PEBH566E?derived@@3UDerived@@AA@@b@@@@@@YAXXZ"
template void f<C{&derived.b}>();
#endif

// Pointers to members.
struct D { const int Derived::*p; int k; };
template<D> void f() {}
// CHECK: define weak_odr void @_Z1fIXtl1DLM7DerivedKi0ELi1EEEEvv
// MSABI: define {{.*}} @"??$f@$2UD@@PERDerived@@H0?0H00@@@YAXXZ"
// MSABI: define {{.*}} @"??$f@$2UD@@PERDerived@@HNH00@@@YAXXZ"
template void f<D{nullptr, 1}>();
// CHECK: define weak_odr void @_Z1fIXtl1DEEEvv
// MSABI: define {{.*}} @"??$f@$2UD@@PERDerived@@H0?0H0A@@@@YAXXZ"
// MSABI: define {{.*}} @"??$f@$2UD@@PERDerived@@HNH0A@@@@YAXXZ"
template void f<D{nullptr}>();
// CHECK: define weak_odr void @_Z1fIXtl1DadL_ZN7Derived1zEEEEEvv
// MSABI: define {{.*}} @"??$f@$2UD@@PERDerived@@H0BA@H0A@@@@YAXXZ"
// MSABI: define {{.*}} @"??$f@$2UD@@PERDerived@@H82@z@@H0A@@@@YAXXZ"
template void f<D{&Derived::z}>();
#ifndef _WIN32
// CHECK: define weak_odr void @_Z1fIXtl1DmcM7DerivedKiadL_ZN1A1aEEEEEEvv
// MSABI-FIXME: define {{.*}} @"??$f@$2UD@@PERDerived@@H0A@H0A@@@@YAXXZ"
// MSABI: define {{.*}} @"??$f@$2UD@@PERDerived@@H8A@@a@@H0A@@@@YAXXZ"
template void f<D{&A::a}>();
// CHECK: define weak_odr void @_Z1fIXtl1DmcM7DerivedKiadL_ZN1A1bEEEEEEvv
// MSABI-FIXME: define {{.*}} @"??$f@$2UD@@PERDerived@@H03H0A@@@@YAXXZ"
// MSABI: define {{.*}} @"??$f@$2UD@@PERDerived@@H8A@@b@@H0A@@@@YAXXZ"
template void f<D{&A::b}>();
// FIXME: Is the Ut_1 mangling here correct?
// CHECK: define weak_odr void @_Z1fIXtl1DmcM7DerivedKiadL_ZN6NestedUt_1kEE8ELi2EEEEvv
// FIXME: This mangles the same as &A::a (bug in the MS ABI).
// MSABI-FIXME: define {{.*}} @"??$f@$2UD@@PERDerived@@H0A@H01@@@YAXXZ"
// MSABI: define {{.*}} @"??$f@$2UD@@PERDerived@@H8<unnamed-tag>@Nested@@k@@H01@@@YAXXZ"
template void f<D{&Nested::k, 2}>();
struct MoreDerived : A, Derived { int z; };
// CHECK: define weak_odr void @_Z1fIXtl1DmcM7DerivedKiadL_ZN11MoreDerived1zEEn8EEEEvv
// MSABI-FIXME: define {{.*}} @"??$f@$2UD@@PERDerived@@H0BI@H0A@@@@YAXXZ"
// MSABI: define {{.*}} @"??$f@$2UD@@PERDerived@@H8MoreDerived@@z@@H0A@@@@YAXXZ"
template void f<D{(int Derived::*)&MoreDerived::z}>();
#endif

// FIXME: Pointers to member functions.
struct DerivedVirtually : virtual A, Nested { int z; };
struct D2 { const int DerivedVirtually::*p; int k; };
template<D2> void f() {}
// CHECK: define weak_odr void @_Z1fIXtl2D2LM16DerivedVirtuallyKi0ELi1EEEEvv
// MSABI: define {{.*}} @"??$f@$2UD2@@PERDerivedVirtually@@HFA@?0H00@@@YAXXZ"
template void f<D2{nullptr, 1}>();
// CHECK: define weak_odr void @_Z1fIXtl2D2EEEvv
// MSABI: define {{.*}} @"??$f@$2UD2@@PERDerivedVirtually@@HFA@?0H0A@@@@YAXXZ"
template void f<D2{nullptr}>();
// CHECK: define weak_odr void @_Z1fIXtl2D2adL_ZN16DerivedVirtually1zEEEEEvv
// MSABI: define {{.*}} @"??$f@$2UD2@@PERDerivedVirtually@@HFBA@A@H0A@@@@YAXXZ"
template void f<D2{&DerivedVirtually::z}>();

// Forward-decl without MS inheritance keyword means unspecified inheritance
// which is different from e. g. single inheritance.
struct UnspecInherStruct;
struct D3 { const int UnspecInherStruct::*p; };
template<D3> void f() {}
struct UnspecInherStruct { int i; };
// CHECK: define weak_odr void @_Z1fIXtl2D3adL_ZN17UnspecInherStruct1iEEEEEvv
// MSABI: define {{.*}} @"??$f@$2UD3@@PERUnspecInherStruct@@HGA@A@A@@@@YAXXZ"
template void f<D3{&UnspecInherStruct::i}>();

// Pointers to member functions.
// Test struct templates instead of function templates so as to cover
// the separate code which handles nullptr in their pointer-to-member arguments.
struct Derived2 : A, Nested { void f(); virtual void g(); };
struct D4 { void (Derived2::*p)(); };
template <D4> struct S1 { static void fn() {} };
// CHECK: define weak_odr void @_ZN2S1IXtl2D4adL_ZN8Derived21fEvEEEE2fnEv
// MSABI: define {{.*}} @"?fn@?$S1@$2UD4@@P8Derived2@@EAAXXZE?f@2@QEAAXXZ@@@SAXXZ"
template void S1<D4{&Derived2::f}>::fn();
// CHECK: define weak_odr void @_ZN2S1IXtl2D4adL_ZN8Derived21gEvEEEE2fnEv
// MSABI: define {{.*}} @"?fn@?$S1@$2UD4@@P8Derived2@@EAAXXZE??_92@$BA@AA@@@SAXXZ"
template void S1<D4{&Derived2::g}>::fn();
// CHECK: define weak_odr void @_ZN2S1IXtl2D4EEE2fnEv
// MSABI: define {{.*}} @"?fn@?$S1@$2UD4@@P8Derived2@@EAAXXZHA@@@@SAXXZ"
template void S1<D4{nullptr}>::fn();

struct NoInheritance { void f(); };
struct D5 { void (NoInheritance::*p)(); };
template <D5> struct S2 { static void fn() {} };
// CHECK: define weak_odr void @_ZN2S2IXtl2D5adL_ZN13NoInheritance1fEvEEEE2fnEv
// MSABI: define {{.*}} @"?fn@?$S2@$2UD5@@P8NoInheritance@@EAAXXZE?f@2@QEAAXXZ@@@SAXXZ"
template void S2<D5{&NoInheritance::f}>::fn();
// CHECK: define weak_odr void @_ZN2S2IXtl2D5EEE2fnEv
// MSABI: define {{.*}} @"?fn@?$S2@$2UD5@@P8NoInheritance@@EAAXXZN@@@SAXXZ"
template void S2<D5{nullptr}>::fn();

struct NoInheritanceButUnspecified;
struct D6 { void (NoInheritanceButUnspecified::*p)(); };
template <D6> struct S3 { static void fn() {} };
// CHECK: define weak_odr void @_ZN2S3IXtl2D6EEE2fnEv
// MSABI: define {{.*}} @"?fn@?$S3@$2UD6@@P8NoInheritanceButUnspecified@@EAAXXZJA@A@?0@@@SAXXZ"
template void S3<D6{nullptr}>::fn();


union E {
int n;
Expand Down Expand Up @@ -204,8 +261,6 @@ template void f<G{1, 2}>();
template void f<G{-8, -32}>();

// Empty and nearly-empty unions.
// Some of the MSVC manglings here are our invention, because MSVC rejects, but
// seem likely to be right.
union H1 {};
union H2 { int : 1, : 2, : 3; };
union H3 { int : 1, a, : 2, b, : 3; };
Expand Down
4 changes: 2 additions & 2 deletions clang/test/CodeGenCXX/mangle-ms-templates.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -272,7 +272,7 @@ struct type1 {
};
extern const record inst;
void recref(type1<inst>) {}
// CHECK: "?recref@@YAXU?$type1@$E?inst@@3Urecord@@B@@@Z"
// CHECK: "?recref@@YAXU?$type1@$1?inst@@3Urecord@@B@@@Z"

struct _GUID {};
struct __declspec(uuid("{12345678-1234-1234-1234-1234567890aB}")) uuid;
Expand All @@ -286,7 +286,7 @@ struct UUIDType2 {};
void fun(UUIDType1<uuid> a) {}
// CHECK: "?fun@@YAXU?$UUIDType1@Uuuid@@$1?_GUID_12345678_1234_1234_1234_1234567890ab@@3U__s_GUID@@B@@@Z"
void fun(UUIDType2<uuid> b) {}
// CHECK: "?fun@@YAXU?$UUIDType2@Uuuid@@$E?_GUID_12345678_1234_1234_1234_1234567890ab@@3U__s_GUID@@B@@@Z"
// CHECK: "?fun@@YAXU?$UUIDType2@Uuuid@@$1?_GUID_12345678_1234_1234_1234_1234567890ab@@3U__s_GUID@@B@@@Z"

template <typename T> struct TypeWithFriendDefinition {
friend void FunctionDefinedWithInjectedName(TypeWithFriendDefinition<T>) {}
Expand Down
10 changes: 9 additions & 1 deletion llvm/lib/CodeGen/AsmPrinter/CodeViewDebug.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -1160,7 +1160,14 @@ void CodeViewDebug::emitDebugInfoForFunction(const Function *GV,
OS.AddComment("Function section index");
OS.emitCOFFSectionIndex(Fn);
OS.AddComment("Flags");
OS.emitInt8(0);
ProcSymFlags ProcFlags = ProcSymFlags::HasOptimizedDebugInfo;
if (FI.HasFramePointer)
ProcFlags |= ProcSymFlags::HasFP;
if (GV->hasFnAttribute(Attribute::NoReturn))
ProcFlags |= ProcSymFlags::IsNoReturn;
if (GV->hasFnAttribute(Attribute::NoInline))
ProcFlags |= ProcSymFlags::IsNoInline;
OS.emitInt8(static_cast<uint8_t>(ProcFlags));
// Emit the function display name as a null-terminated string.
OS.AddComment("Function name");
// Truncate the name so we won't overflow the record length field.
Expand Down Expand Up @@ -1478,6 +1485,7 @@ void CodeViewDebug::beginFunctionImpl(const MachineFunction *MF) {
CurFn->EncodedLocalFramePtrReg = EncodedFramePtrReg::StackPtr;
CurFn->EncodedParamFramePtrReg = EncodedFramePtrReg::StackPtr;
} else {
CurFn->HasFramePointer = true;
// If there is an FP, parameters are always relative to it.
CurFn->EncodedParamFramePtrReg = EncodedFramePtrReg::FramePtr;
if (CurFn->HasStackRealignment) {
Expand Down
2 changes: 2 additions & 0 deletions llvm/lib/CodeGen/AsmPrinter/CodeViewDebug.h
Original file line number Diff line number Diff line change
Expand Up @@ -191,6 +191,8 @@ class LLVM_LIBRARY_VISIBILITY CodeViewDebug : public DebugHandlerBase {
bool HasStackRealignment = false;

bool HaveLineInfo = false;

bool HasFramePointer = false;
};
FunctionInfo *CurFn = nullptr;

Expand Down
10 changes: 10 additions & 0 deletions llvm/test/DebugInfo/COFF/fpo-realign-alloca.ll
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
; RUN: llc < %s | FileCheck %s
; RUN: llc -mtriple=i686-windows-msvc < %s -filetype=obj | llvm-readobj --codeview - | FileCheck %s --check-prefix=OBJ

; C source:
; void usethings(ptr, ptr p);
Expand Down Expand Up @@ -33,6 +34,15 @@
; CHECK: retl
; CHECK: .cv_fpo_endproc

; OBJ-LABEL: FunctionType: realign_and_alloca (0x1002)
; OBJ-NEXT: CodeOffset: _realign_and_alloca+0x0
; OBJ-NEXT: Segment: 0x0
; OBJ-NEXT: Flags [ (0x81)
; OBJ-NEXT: HasFP (0x1)
; OBJ-NEXT: HasOptimizedDebugInfo (0x80)
; OBJ-NEXT: ]
; OBJ-NEXT: DisplayName: realign_and_alloca
; OBJ-NEXT: LinkageName: _realign_and_alloca

; ModuleID = 't.c'
source_filename = "t.c"
Expand Down
4 changes: 4 additions & 0 deletions llvm/test/DebugInfo/COFF/fpo-realign-vframe.ll
Original file line number Diff line number Diff line change
Expand Up @@ -95,6 +95,10 @@
; OBJ: SubSectionType: Symbols (0xF1)
; OBJ: GlobalProcIdSym {
; OBJ: Kind: S_GPROC32_ID (0x1147)
; OBJ: Flags [ (0x81)
; OBJ: HasFP (0x1)
; OBJ: HasOptimizedDebugInfo (0x80)
; OBJ: ]
; OBJ: DisplayName: realign_with_csrs
; OBJ: LinkageName: _realign_with_csrs
; OBJ: }
Expand Down
8 changes: 8 additions & 0 deletions llvm/test/DebugInfo/COFF/frameproc-flags.ll
Original file line number Diff line number Diff line change
Expand Up @@ -63,22 +63,27 @@
; }

; CHECK-LABEL: S_GPROC32_ID [size = 52] `use_alloca`
; CHECK: type = `0x1002 (use_alloca)`, debug start = 0, debug end = 0, flags = has fp | opt debuginfo
; CHECK: S_FRAMEPROC [size = 32]
; CHECK: local fp reg = VFRAME, param fp reg = EBP
; CHECK: flags = has alloca | secure checks | strict secure checks | opt speed
; CHECK-LABEL: S_GPROC32_ID [size = 52] `call_setjmp`
; CHECK: type = `0x1003 (call_setjmp)`, debug start = 0, debug end = 0, flags = opt debuginfo
; CHECK: S_FRAMEPROC [size = 32]
; CHECK: local fp reg = NONE, param fp reg = NONE
; CHECK: flags = has setjmp | opt speed
; CHECK-LABEL: S_GPROC32_ID [size = 56] `use_inlineasm`
; CHECK: type = `0x1006 (use_inlineasm)`, debug start = 0, debug end = 0, flags = opt debuginfo
; CHECK: S_FRAMEPROC [size = 32]
; CHECK: local fp reg = NONE, param fp reg = NONE
; CHECK: flags = has inline asm | safe buffers | opt speed
; CHECK-LABEL: S_GPROC32_ID [size = 48] `cpp_eh`
; CHECK: type = `0x1007 (cpp_eh)`, debug start = 0, debug end = 0, flags = has fp | opt debuginfo
; CHECK: S_FRAMEPROC [size = 32]
; CHECK: local fp reg = EBP, param fp reg = EBP
; CHECK: flags = has eh | opt speed
; CHECK-LABEL: S_GPROC32_ID [size = 52] `use_inline`
; CHECK: type = `0x100C (use_inline)`, debug start = 0, debug end = 0, flags = opt debuginfo
; CHECK: S_FRAMEPROC [size = 32]
; CHECK: local fp reg = NONE, param fp reg = NONE
; CHECK: flags = safe buffers | opt speed
Expand All @@ -87,6 +92,7 @@
; CHECK: local fp reg = NONE, param fp reg = NONE
; CHECK: flags = marked inline | safe buffers | opt speed
; CHECK-LABEL: S_GPROC32_ID [size = 44] `seh`
; CHECK: type = `0x100E (seh)`, debug start = 0, debug end = 0, flags = has fp | opt debuginfo
; CHECK: S_FRAMEPROC [size = 32]
; CHECK: local fp reg = EBP, param fp reg = EBP
; CHECK: flags = has seh | opt speed
Expand All @@ -95,10 +101,12 @@
; CHECK: local fp reg = EBP, param fp reg = EBP
; CHECK: flags = safe buffers | opt speed
; CHECK-LABEL: S_GPROC32_ID [size = 52] `use_naked`
; CHECK: type = `0x1010 (use_naked)`, debug start = 0, debug end = 0, flags = noinline | opt debuginfo
; CHECK: S_FRAMEPROC [size = 32]
; CHECK: local fp reg = NONE, param fp reg = NONE
; CHECK: flags = has inline asm | naked | safe buffers | opt speed
; CHECK-LABEL: S_GPROC32_ID [size = 52] `stack_guard`
; CHECK: type = `0x1011 (stack_guard)`, debug start = 0, debug end = 0, flags = opt debuginfo
; CHECK: S_FRAMEPROC [size = 32]
; CHECK: local fp reg = VFRAME, param fp reg = VFRAME
; CHECK: flags = secure checks | strict secure checks | opt speed
Expand Down
91 changes: 91 additions & 0 deletions llvm/test/DebugInfo/COFF/function-options.ll
Original file line number Diff line number Diff line change
Expand Up @@ -376,6 +376,97 @@
; CHECK: }
; CHECK: ]

; CHECK-LABEL: FunctionType: Func_AClass (0x1008)
; CHECK-NEXT: CodeOffset: ?Func_AClass@@YA?AVAClass@@AEAV1@@Z+0x0
; CHECK-NEXT: Segment: 0x0
; CHECK-NEXT: Flags [ (0xC0)
; CHECK-NEXT: HasOptimizedDebugInfo (0x80)
; CHECK-NEXT: IsNoInline (0x40)
; CHECK-NEXT: ]
; CHECK-NEXT: DisplayName: Func_AClass
; CHECK-NEXT: LinkageName: ?Func_AClass@@YA?AVAClass@@AEAV1@@Z
; CHECK-LABEL: FunctionType: Func_BClass (0x1013)
; CHECK-NEXT: CodeOffset: ?Func_BClass@@YA?AVBClass@@AEAV1@@Z+0x0
; CHECK-NEXT: Segment: 0x0
; CHECK-NEXT: Flags [ (0xC0)
; CHECK-NEXT: HasOptimizedDebugInfo (0x80)
; CHECK-NEXT: IsNoInline (0x40)
; CHECK-NEXT: ]
; CHECK-NEXT: DisplayName: Func_BClass
; CHECK-NEXT: LinkageName: ?Func_BClass@@YA?AVBClass@@AEAV1@@Z
; CHECK-LABEL: FunctionType: Func_C1Class (0x101D)
; CHECK-NEXT: CodeOffset: ?Func_C1Class@@YA?AVC1Class@@AEAV1@@Z+0x0
; CHECK-NEXT: Segment: 0x0
; CHECK-NEXT: Flags [ (0xC0)
; CHECK-NEXT: HasOptimizedDebugInfo (0x80)
; CHECK-NEXT: IsNoInline (0x40)
; CHECK-NEXT: ]
; CHECK-NEXT: DisplayName: Func_C1Class
; CHECK-NEXT: LinkageName: ?Func_C1Class@@YA?AVC1Class@@AEAV1@@Z
; CHECK-LABEL: FunctionType: Func_C2Class (0x1027)
; CHECK-NEXT: CodeOffset: ?Func_C2Class@@YA?AVC2Class@@AEAV1@@Z+0x0
; CHECK-NEXT: Segment: 0x0
; CHECK-NEXT: Flags [ (0xC0)
; CHECK-NEXT: HasOptimizedDebugInfo (0x80)
; CHECK-NEXT: IsNoInline (0x40)
; CHECK-NEXT: ]
; CHECK-NEXT: DisplayName: Func_C2Class
; CHECK-NEXT: LinkageName: ?Func_C2Class@@YA?AVC2Class@@AEAV1@@Z
; CHECK-LABEL: FunctionType: Func_DClass (0x102F)
; CHECK-NEXT: CodeOffset: ?Func_DClass@@YA?AVDClass@@AEAV1@@Z+0x0
; CHECK-NEXT: Segment: 0x0
; CHECK-NEXT: Flags [ (0xC0)
; CHECK-NEXT: HasOptimizedDebugInfo (0x80)
; CHECK-NEXT: IsNoInline (0x40)
; CHECK-NEXT: ]
; CHECK-NEXT: DisplayName: Func_DClass
; CHECK-NEXT: LinkageName: ?Func_DClass@@YA?AVDClass@@AEAV1@@Z
; CHECK-LABEL: FunctionType: Func_FClass (0x103A)
; CHECK-NEXT: CodeOffset: ?Func_FClass@@YA?AVFClass@@AEAV1@@Z+0x0
; CHECK-NEXT: Segment: 0x0
; CHECK-NEXT: Flags [ (0xC0)
; CHECK-NEXT: HasOptimizedDebugInfo (0x80)
; CHECK-NEXT: IsNoInline (0x40)
; CHECK-NEXT: ]
; CHECK-NEXT: DisplayName: Func_FClass
; CHECK-NEXT: LinkageName: ?Func_FClass@@YA?AVFClass@@AEAV1@@Z
; CHECK-LABEL: FunctionType: Func_AStruct (0x1041)
; CHECK-NEXT: CodeOffset: ?Func_AStruct@@YA?AUAStruct@@AEAU1@@Z+0x0
; CHECK-NEXT: Segment: 0x0
; CHECK-NEXT: Flags [ (0xC0)
; CHECK-NEXT: HasOptimizedDebugInfo (0x80)
; CHECK-NEXT: IsNoInline (0x40)
; CHECK-NEXT: ]
; CHECK-NEXT: DisplayName: Func_AStruct
; CHECK-NEXT: LinkageName: ?Func_AStruct@@YA?AUAStruct@@AEAU1@@Z
; CHECK-LABEL: FunctionType: Func_BStruct (0x104B)
; CHECK-NEXT: CodeOffset: ?Func_BStruct@@YA?AUBStruct@@AEAU1@@Z+0x0
; CHECK-NEXT: Segment: 0x0
; CHECK-NEXT: Flags [ (0xC0)
; CHECK-NEXT: HasOptimizedDebugInfo (0x80)
; CHECK-NEXT: IsNoInline (0x40)
; CHECK-NEXT: ]
; CHECK-NEXT: DisplayName: Func_BStruct
; CHECK-NEXT: LinkageName: ?Func_BStruct@@YA?AUBStruct@@AEAU1@@Z
; CHECK-LABEL: FunctionType: Func_AUnion (0x1052)
; CHECK-NEXT: CodeOffset: ?Func_AUnion@@YA?ATAUnion@@AEAT1@@Z+0x0
; CHECK-NEXT: Segment: 0x0
; CHECK-NEXT: Flags [ (0xC0)
; CHECK-NEXT: HasOptimizedDebugInfo (0x80)
; CHECK-NEXT: IsNoInline (0x40)
; CHECK-NEXT: ]
; CHECK-NEXT: DisplayName: Func_AUnion
; CHECK-NEXT: LinkageName: ?Func_AUnion@@YA?ATAUnion@@AEAT1@@Z
; CHECK-LABEL: FunctionType: Func_BUnion (0x105C)
; CHECK-NEXT: CodeOffset: ?Func_BUnion@@YA?ATBUnion@@AEAT1@@Z+0x0
; CHECK-NEXT: Segment: 0x0
; CHECK-NEXT: Flags [ (0xC0)
; CHECK-NEXT: HasOptimizedDebugInfo (0x80)
; CHECK-NEXT: IsNoInline (0x40)
; CHECK-NEXT: ]
; CHECK-NEXT: DisplayName: Func_BUnion
; CHECK-NEXT: LinkageName: ?Func_BUnion@@YA?ATBUnion@@AEAT1@@Z

; ModuleID = 't.cpp'
source_filename = "t.cpp"
target datalayout = "e-m:w-p270:32:32-p271:32:32-p272:64:64-i64:64-f80:128-n8:16:32:64-S128"
Expand Down
3 changes: 2 additions & 1 deletion llvm/test/DebugInfo/COFF/inlining-header.ll
Original file line number Diff line number Diff line change
Expand Up @@ -68,7 +68,8 @@
; OBJ: FunctionType: main (0x1005)
; OBJ: CodeOffset: _main+0x0
; OBJ: Segment: 0x0
; OBJ: Flags [ (0x0)
; OBJ: Flags [ (0x80)
; OBJ: HasOptimizedDebugInfo (0x80)
; OBJ: ]
; OBJ: DisplayName: main
; OBJ: LinkageName: _main
Expand Down
3 changes: 2 additions & 1 deletion llvm/test/DebugInfo/COFF/inlining.ll
Original file line number Diff line number Diff line change
Expand Up @@ -160,7 +160,8 @@
; OBJ: FunctionType: baz (0x1004)
; OBJ: CodeOffset: ?baz@@YAXXZ+0x0
; OBJ: Segment: 0x0
; OBJ: Flags [ (0x0)
; OBJ: Flags [ (0x80)
; OBJ: HasOptimizedDebugInfo (0x80)
; OBJ: ]
; OBJ: DisplayName: baz
; OBJ: LinkageName: ?baz@@YAXXZ
Expand Down
3 changes: 2 additions & 1 deletion llvm/test/DebugInfo/COFF/long-name.ll
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,8 @@
; CHECK: FunctionType: {{A+}} (0x1002)
; CHECK: CodeOffset: f+0x0
; CHECK: Segment: 0x0
; CHECK: Flags [ (0x0)
; CHECK: Flags [ (0x80)
; CHECK: HasOptimizedDebugInfo (0x80)
; CHECK: ]
; CHECK: DisplayName: {{A+$}}
; CHECK: LinkageName: f
Expand Down
12 changes: 6 additions & 6 deletions llvm/test/DebugInfo/COFF/multifunction.ll
Original file line number Diff line number Diff line change
Expand Up @@ -78,7 +78,7 @@
; X86-NEXT: .long 4098
; X86-NEXT: .secrel32 _x
; X86-NEXT: .secidx _x
; X86-NEXT: .byte 0
; X86-NEXT: .byte 128
; X86-NEXT: .asciz "x"
; X86-NEXT: .p2align 2
; X86-NEXT: [[PROC_SEGMENT_END]]:
Expand Down Expand Up @@ -117,7 +117,7 @@
; X86-NEXT: .long 4099
; X86-NEXT: .secrel32 _y
; X86-NEXT: .secidx _y
; X86-NEXT: .byte 0
; X86-NEXT: .byte 128
; X86-NEXT: .asciz "y"
; X86-NEXT: .p2align 2
; X86-NEXT: [[PROC_SEGMENT_END]]:
Expand Down Expand Up @@ -156,7 +156,7 @@
; X86-NEXT: .long 4100
; X86-NEXT: .secrel32 _f
; X86-NEXT: .secidx _f
; X86-NEXT: .byte 0
; X86-NEXT: .byte 128
; X86-NEXT: .asciz "f"
; X86-NEXT: .p2align 2
; X86-NEXT: [[PROC_SEGMENT_END]]:
Expand Down Expand Up @@ -390,7 +390,7 @@
; X64-NEXT: .long 4098
; X64-NEXT: .secrel32 x
; X64-NEXT: .secidx x
; X64-NEXT: .byte 0
; X64-NEXT: .byte 128
; X64-NEXT: .asciz "x"
; X64-NEXT: .p2align 2
; X64-NEXT: [[PROC_SEGMENT_END]]:
Expand Down Expand Up @@ -428,7 +428,7 @@
; X64-NEXT: .long 4099
; X64-NEXT: .secrel32 y
; X64-NEXT: .secidx y
; X64-NEXT: .byte 0
; X64-NEXT: .byte 128
; X64-NEXT: .asciz "y"
; X64-NEXT: .p2align 2
; X64-NEXT: [[PROC_SEGMENT_END]]:
Expand Down Expand Up @@ -466,7 +466,7 @@
; X64-NEXT: .long 4100
; X64-NEXT: .secrel32 f
; X64-NEXT: .secidx f
; X64-NEXT: .byte 0
; X64-NEXT: .byte 128
; X64-NEXT: .asciz "f"
; X64-NEXT: .p2align 2
; X64-NEXT: [[PROC_SEGMENT_END]]:
Expand Down
4 changes: 2 additions & 2 deletions llvm/test/DebugInfo/COFF/simple.ll
Original file line number Diff line number Diff line change
Expand Up @@ -58,7 +58,7 @@
; X86-NEXT: .long 4098
; X86-NEXT: .secrel32 _f
; X86-NEXT: .secidx _f
; X86-NEXT: .byte 0
; X86-NEXT: .byte 128
; X86-NEXT: .asciz "f"
; X86-NEXT: .p2align 2
; X86-NEXT: [[PROC_SEGMENT_END]]:
Expand Down Expand Up @@ -188,7 +188,7 @@
; X64-NEXT: .long 4098
; X64-NEXT: .secrel32 f
; X64-NEXT: .secidx f
; X64-NEXT: .byte 0
; X64-NEXT: .byte 128
; X64-NEXT: .asciz "f"
; X64-NEXT: .p2align 2
; X64-NEXT: [[PROC_SEGMENT_END]]:
Expand Down
4 changes: 3 additions & 1 deletion llvm/test/DebugInfo/COFF/types-array.ll
Original file line number Diff line number Diff line change
Expand Up @@ -58,7 +58,9 @@
; CHECK: FunctionType: f (0x1002)
; CHECK: CodeOffset: ?f@@YAXXZ+0x0
; CHECK: Segment: 0x0
; CHECK: Flags [ (0x0)
; CHECK: Flags [ (0x81)
; CHECK: HasFP (0x1)
; CHECK: HasOptimizedDebugInfo (0x80)
; CHECK: ]
; CHECK: DisplayName: f
; CHECK: LinkageName: ?f@@YAXXZ
Expand Down
3 changes: 2 additions & 1 deletion llvm/test/DebugInfo/COFF/types-basic.ll
Original file line number Diff line number Diff line change
Expand Up @@ -221,7 +221,8 @@
; CHECK: FunctionType: f (0x1002)
; CHECK: CodeOffset: ?f@@YAXMN_J@Z+0x0
; CHECK: Segment: 0x0
; CHECK: Flags [ (0x0)
; CHECK: Flags [ (0x80)
; CHECK: HasOptimizedDebugInfo (0x80)
; CHECK: ]
; CHECK: DisplayName: f
; CHECK: LinkageName: ?f@@YAXMN_J@Z
Expand Down
4 changes: 3 additions & 1 deletion llvm/test/MC/AArch64/coff-debug.ll
Original file line number Diff line number Diff line change
Expand Up @@ -95,7 +95,9 @@ attributes #0 = { noinline nounwind optnone "correctly-rounded-divide-sqrt-fp-ma
; CHECK: FunctionType: main (0x1002)
; CHECK: CodeOffset: main+0x0
; CHECK: Segment: 0x0
; CHECK: Flags [ (0x0)
; CHECK: Flags [ (0xC0)
; CHECK: HasOptimizedDebugInfo (0x80)
; CHECK: IsNoInline (0x40)
; CHECK: ]
; CHECK: DisplayName: main
; CHECK: LinkageName: main
Expand Down