summaryrefslogtreecommitdiff
path: root/test/Frontend/optimization-remark.c
blob: a0921086767f0c39626fdabfb3dd814f20ae9537 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
// This file tests the -Rpass family of flags (-Rpass, -Rpass-missed
// and -Rpass-analysis) with the inliner. The test is designed to
// always trigger the inliner, so it should be independent of the
// optimization level.

// RUN: %clang_cc1 %s -Rpass=inline -Rpass-analysis=inline -Rpass-missed=inline -O0 -emit-llvm-only -verify
// RUN: %clang_cc1 %s -DNDEBUG -Rpass=inline -emit-llvm-only -verify
// RUN: %clang_cc1 %s -Rpass=inline -emit-llvm -o - 2>/dev/null | FileCheck %s

// -Rpass should produce source location annotations, exclusively (just
// like -gmlt).
// CHECK: , !dbg !
// CHECK-NOT: DW_TAG_base_type

// But llvm.dbg.cu should be missing (to prevent writing debug info to
// the final output).
// CHECK-NOT: !llvm.dbg.cu = !{

int foo(int x, int y) __attribute__((always_inline));
int foo(int x, int y) { return x + y; }

float foz(int x, int y) __attribute__((noinline));
float foz(int x, int y) { return x * y; }

// The negative diagnostics are emitted twice because the inliner runs
// twice.
//
int bar(int j) {
#ifndef NDEBUG
// expected-remark@+7 {{foz should never be inlined (cost=never)}}
// expected-remark@+6 {{foz will not be inlined into bar}}
// expected-remark@+5 {{foz should never be inlined}}
// expected-remark@+4 {{foz will not be inlined into bar}}
// expected-remark@+3 {{foo should always be inlined}}
// expected-remark@+2 {{foo inlined into bar}}
#endif
  return foo(j, j - 2) * foz(j - 2, j);
}
#ifdef NDEBUG
// expected-remark@-3 {{foo inlined into bar}}
#endif