blob: 4905d57893d77d37f397496bdd412cb0fb8b6bfa [file] [log] [blame]
Adam Nemet7b796f82017-01-26 04:07:11 +00001// RUN: %clang_cc1 -triple arm64-apple-ios -S -o /dev/null %s -O2 -dwarf-column-info -Rpass-missed=regalloc 2>&1 | FileCheck -check-prefix=REMARK %s
2// RUN: %clang_cc1 -triple arm64-apple-ios -S -o /dev/null %s -O2 -dwarf-column-info 2>&1 | FileCheck -allow-empty -check-prefix=NO_REMARK %s
3// RUN: %clang_cc1 -triple arm64-apple-ios -S -o /dev/null %s -O2 -dwarf-column-info -opt-record-file %t.yaml
4// RUN: cat %t.yaml | FileCheck -check-prefix=YAML %s
5
6void bar(float);
7
8void foo(float *p, int i) {
9 while (i--) {
10 float f = *p;
11 asm("" ::
12 : "d0", "d1", "d2", "d3", "d4", "d5", "d6", "d7", "d8", "d9", "d10", "d11", "d12", "d13", "d14", "d15", "d16", "d17", "d18", "d19", "d20", "d21", "d22", "d23", "d24", "d25", "d26", "d27", "d28", "d29", "d30", "d31", "x0", "x1", "x2", "x3", "x4", "x5", "x6", "x7", "x8", "x9", "x10", "x11", "x12", "x13", "x14", "x15", "x16", "x17", "x18", "x19", "x20", "x21", "x22", "x23", "x24", "x25", "x26", "x27", "x28", "fp", "lr", "sp", "memory");
13 bar(f);
14 }
15}
16
17// REMARK: opt-record-MIR.c:9:11: remark: {{.}} spills {{.}} reloads generated in loop
18// NO_REMARK-NOT: remark:
19
20// YAML: --- !Missed
21// YAML: Pass: regalloc
22// YAML: Name: LoopSpillReload
23// YAML: DebugLoc: { File: /Users/adam/proj/org/llvm/tools/clang/test/CodeGen/opt-record-MIR.c,
24// YAML: Line: 9, Column: 11 }
25// YAML: Function: foo
26// YAML: Args:
27// YAML: - NumSpills: '{{.}}'
28// YAML: - String: ' spills '
29// YAML: - NumReloads: '{{.}}'
30// YAML: - String: ' reloads '
31// YAML: - String: generated
32// YAML: ...