blob: 6284ef40811d30570db0b6c9a0037b6f8116485d (
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
|
//===-- main.cpp ------------------------------------------------*- C++ -*-===//
//
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
// See https://llvm.org/LICENSE.txt for license information.
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
//
//===----------------------------------------------------------------------===//
volatile int x;
void __attribute__((noinline)) sink2() {
x++; //% self.filecheck("bt", "main.cpp", "-check-prefix=FROM-FUNC1")
// FROM-FUNC1: frame #0: 0x{{[0-9a-f]+}} a.out`sink{{.*}} at main.cpp:[[@LINE-1]]:{{.*}} [opt]
// FROM-FUNC1-NEXT: sink({{.*}} [opt]
// FROM-FUNC1-NEXT: func1{{.*}} [opt] [artificial]
// FROM-FUNC1-NEXT: main{{.*}} [opt]
}
void __attribute__((noinline)) sink(bool called_from_main) {
if (called_from_main) {
x++; //% self.filecheck("bt", "main.cpp", "-check-prefix=FROM-MAIN")
// FROM-MAIN: frame #0: 0x{{[0-9a-f]+}} a.out`sink{{.*}} at main.cpp:[[@LINE-1]]:{{.*}} [opt]
// FROM-MAIN-NEXT: main{{.*}} [opt]
} else {
sink2();
}
}
void __attribute__((noinline)) func1() { sink(false); /* tail */ }
int __attribute__((disable_tail_calls)) main(int argc, char **) {
// When func1 tail-calls sink, make sure that the former appears in the
// backtrace.
sink(true);
func1();
return 0;
}
|