xref: /llvm-project/llvm/test/MC/ARM/inline-asm-srcloc.ll (revision ca21488eace67fa9207b14ab0e32e2815ad5fbe1)
1; RUN: not llc -filetype=obj 2>&1 -o /dev/null < %s | FileCheck %s
2
3target datalayout = "e-m:e-p:32:32-i64:64-v128:64:128-a:0:32-n32-S64"
4target triple = "armv7-arm-none-eabi"
5
6; Function Attrs: noinline nounwind
7define void @foo2() #0 {
8entry:
9  call void asm sideeffect " wibble", ""() #1, !srcloc !3
10; CHECK: note: !srcloc = 107
11  ret void
12}
13
14; Function Attrs: noinline nounwind
15define void @foo() #0 {
16entry:
17  call void asm sideeffect " .word -bar", ""() #1, !srcloc !4
18; CHECK: note: !srcloc = 181
19  call void asm sideeffect " .word -foo", ""() #1, !srcloc !5
20; CHECK: note: !srcloc = 257
21  call void asm sideeffect " .word -stoat", ""() #1, !srcloc !6
22; CHECK: note: !srcloc = 534
23  ret void
24}
25
26attributes #0 = { noinline nounwind "correctly-rounded-divide-sqrt-fp-math"="false" "disable-tail-calls"="false" "less-precise-fpmad"="false" "frame-pointer"="all" "no-infs-fp-math"="false" "no-jump-tables"="false" "no-nans-fp-math"="false" "no-signed-zeros-fp-math"="false" "no-trapping-math"="false" "stack-protector-buffer-size"="8" "target-cpu"="cortex-a8" "target-features"="+dsp,+neon,+strict-align,+vfp3" "unsafe-fp-math"="false" "use-soft-float"="false" }
27attributes #1 = { nounwind }
28
29!llvm.module.flags = !{!0, !1}
30!llvm.ident = !{!2}
31
32!0 = !{i32 1, !"wchar_size", i32 4}
33!1 = !{i32 1, !"min_enum_size", i32 4}
34!2 = !{!"clang version 5.0.0 "}
35!3 = !{i32 107}
36
37; These !srcloc metadata nodes are intentionally not all the same type: D105491
38; changed the creation of !srcloc to generate i64 instead of the previous i32.
39; So one thing we're testing here is that both types are acceptable on input,
40; i.e. IR generated both before and after the change can be consumed.
41!4 = !{i32 181}
42!5 = !{i32 257}
43!6 = !{i64 534}
44