1;; Test mips:
2; RUN: llc -mtriple=mips-linux-gnu -emit-call-site-info %s -stop-after=finalize-isel -o -| FileCheck %s
3;; Test mipsel:
4; RUN: llc -mtriple=mipsel-linux-gnu -emit-call-site-info %s -stop-after=finalize-isel -o -| FileCheck %s
5
6;; Verify that call site info is not emitted for parameter passed through 64-bit register $d
7;; which splits into two 32-bit physical regs.
8;; Source:
9;; extern double bar(double,int);
10;; double foo(double self){
11;;   int b = 1;
12;;   double a = bar(self,b);
13;;   return a;
14;; }
15
16;; Test mips and mipsel:
17; CHECK: name:            foo
18; CHECK: callSites:
19; CHECK-NEXT: bb: {{.*}}, offset: {{.*}}, fwdArgRegs:
20; CHECK-NOT:   arg: 0, reg: '$a0'
21; CHECK-NOT:   arg: 0, reg: '$d6'
22; CHECK-NEXT:   arg: 1, reg: '$a2'
23
24; ModuleID = 'm.c'
25source_filename = "m.c"
26target datalayout = "E-m:m-p:32:32-i8:8:32-i16:16:32-i64:64-n32-S64"
27target triple = "mips-unknown-linux-gnu"
28
29; Function Attrs: nounwind
30define dso_local double @foo(double %self) local_unnamed_addr !dbg !13 {
31entry:
32  call void @llvm.dbg.value(metadata double %self, metadata !17, metadata !DIExpression()), !dbg !20
33  call void @llvm.dbg.value(metadata i32 1, metadata !18, metadata !DIExpression()), !dbg !20
34  %call = tail call double @bar(double %self, i32 signext 1), !dbg !20
35  call void @llvm.dbg.value(metadata double %call, metadata !19, metadata !DIExpression()), !dbg !20
36  ret double %call, !dbg !20
37}
38
39declare !dbg !4 dso_local double @bar(double, i32 signext) local_unnamed_addr
40
41; Function Attrs: nounwind readnone speculatable willreturn
42declare void @llvm.dbg.value(metadata, metadata, metadata)
43
44!llvm.dbg.cu = !{!0}
45!llvm.module.flags = !{!9, !10, !11}
46!llvm.ident = !{!12}
47
48!0 = distinct !DICompileUnit(language: DW_LANG_C99, file: !1, producer: "clang version 11.0.0", isOptimized: true, runtimeVersion: 0, emissionKind: FullDebug, enums: !2, retainedTypes: !3, splitDebugInlining: false, nameTableKind: None)
49!1 = !DIFile(filename: "m.c", directory: "/dir")
50!2 = !{}
51!3 = !{!4}
52!4 = !DISubprogram(name: "bar", scope: !1, file: !1, line: 1, type: !5, flags: DIFlagPrototyped, spFlags: DISPFlagOptimized, retainedNodes: !2)
53!5 = !DISubroutineType(types: !6)
54!6 = !{!7, !7, !8}
55!7 = !DIBasicType(name: "double", size: 64, encoding: DW_ATE_float)
56!8 = !DIBasicType(name: "int", size: 32, encoding: DW_ATE_signed)
57!9 = !{i32 7, !"Dwarf Version", i32 4}
58!10 = !{i32 2, !"Debug Info Version", i32 3}
59!11 = !{i32 1, !"wchar_size", i32 4}
60!12 = !{!"clang version 11.0.0"}
61!13 = distinct !DISubprogram(name: "foo", scope: !1, file: !1, line: 3, type: !14, scopeLine: 3, flags: DIFlagPrototyped | DIFlagAllCallsDescribed, spFlags: DISPFlagDefinition | DISPFlagOptimized, unit: !0, retainedNodes: !16)
62!14 = !DISubroutineType(types: !15)
63!15 = !{!7, !7}
64!16 = !{!17, !18, !19}
65!17 = !DILocalVariable(name: "self", arg: 1, scope: !13, file: !1, line: 3, type: !7)
66!18 = !DILocalVariable(name: "b", scope: !13, file: !1, line: 4, type: !8)
67!19 = !DILocalVariable(name: "a", scope: !13, file: !1, line: 5, type: !7)
68!20 = !DILocation(line: 0, scope: !13)
69