[AMDGPU] Add True16 register classes.
[llvm-project.git] / llvm / test / Assembler / DIDefaultTemplateParam.ll
blob4ebd45a2749ef17a9e3f534286883377e1e4e852
1 ; RUN: llvm-as < %s | llvm-dis | llvm-as | llvm-dis | FileCheck %s
2 ; RUN: verify-uselistorder %s
4 ; ModuleID = '/dir/test.cpp'
5 source_filename = "test.cpp"
6 target datalayout = "e-m:e-p270:32:32-p271:32:32-p272:64:64-i64:64-f80:128-n8:16:32:64-S128"
7 target triple = "x86_64-unknown-linux-gnu"
9 %class.foo = type { i8 }
10 %class.foo.0 = type { i8 }
11 ; Function Attrs: noinline norecurse nounwind optnone uwtable
12 define dso_local i32 @main() #0 !dbg !7 {
13 entry:
14   %retval = alloca i32, align 4
15   %f1 = alloca %class.foo, align 1
16   %f2 = alloca %class.foo.0, align 1
17   store i32 0, ptr %retval, align 4
18   call void @llvm.dbg.declare(metadata ptr %f1, metadata !11, metadata !DIExpression()), !dbg !16
19   call void @llvm.dbg.declare(metadata ptr %f2, metadata !17, metadata !DIExpression()), !dbg !23
20   ret i32 0, !dbg !24
22 ; Function Attrs: nounwind readnone speculatable willreturn
23 declare void @llvm.dbg.declare(metadata, metadata, metadata) #1
25 attributes #0 = { noinline norecurse nounwind optnone uwtable }
26 attributes #1 = { nounwind readnone speculatable willreturn }
28 !llvm.dbg.cu = !{!0}
29 !llvm.module.flags = !{!3, !4, !5}
30 !llvm.ident = !{!6}
32 !0 = distinct !DICompileUnit(language: DW_LANG_C_plus_plus_14, file: !1, producer: "clang version 11.0.0", isOptimized: false, runtimeVersion: 0, emissionKind: FullDebug, enums: !2, splitDebugInlining: false, nameTableKind: None)
33 !1 = !DIFile(filename: "test.cpp", directory: "/dir/", checksumkind: CSK_MD5, checksum: "863d08522c2300490dea873efc4b2369")
34 !2 = !{}
35 !3 = !{i32 7, !"Dwarf Version", i32 5}
36 !4 = !{i32 2, !"Debug Info Version", i32 3}
37 !5 = !{i32 1, !"wchar_size", i32 4}
38 !6 = !{!"clang version 11.0.0"}
39 !7 = distinct !DISubprogram(name: "main", scope: !1, file: !1, line: 29, type: !8, scopeLine: 29, flags: DIFlagPrototyped, spFlags: DISPFlagDefinition, unit: !0, retainedNodes: !2)
40 !8 = !DISubroutineType(types: !9)
41 !9 = !{!10}
42 !10 = !DIBasicType(name: "int", size: 32, encoding: DW_ATE_signed)
43 !11 = !DILocalVariable(name: "f1", scope: !7, file: !1, line: 30, type: !12)
44 !12 = distinct !DICompositeType(tag: DW_TAG_class_type, name: "foo<int, 6>", file: !1, line: 26, size: 8, flags: DIFlagTypePassByValue, elements: !2, templateParams: !13, identifier: "_ZTS3fooIiLi6EE")
45 !13 = !{!14, !15}
47 ; CHECK: 14 = !DITemplateTypeParameter(name: "T", type: !{{[0-9]*}})
48 !14 = !DITemplateTypeParameter(name: "T", type: !10)
50 ; CHECK: 15 = !DITemplateValueParameter(name: "i", type: !{{[0-9]*}}, value: i32 6)
51 !15 = !DITemplateValueParameter(name: "i", type: !10, value: i32 6)
53 !16 = !DILocation(line: 30, column: 14, scope: !7)
54 !17 = !DILocalVariable(name: "f2", scope: !7, file: !1, line: 31, type: !18)
55 !18 = distinct !DICompositeType(tag: DW_TAG_class_type, name: "foo<char, 3>", file: !1, line: 26, size: 8, flags: DIFlagTypePassByValue, elements: !2, templateParams: !19, identifier: "_ZTS3fooIcLi3EE")
56 !19 = !{!20, !22}
58 ; CHECK: 20 = !DITemplateTypeParameter({{.*}}, defaulted: true
59 !20 = !DITemplateTypeParameter(name: "T", type: !21, defaulted: true)
60 !21 = !DIBasicType(name: "char", size: 8, encoding: DW_ATE_signed_char)
62 ; CHECK: 22 = !DITemplateValueParameter({{.*}}, defaulted: true
63 !22 = !DITemplateValueParameter(name: "i", type: !10, defaulted: true, value: i32 3)
64 !23 = !DILocation(line: 31, column: 9, scope: !7)
65 !24 = !DILocation(line: 32, column: 3, scope: !7)