9d7c63afc691db6f9100e849f558a0e33ba929aa
[oota-llvm.git] / test / DebugInfo / 2006-11-06-StackTrace.cpp
1 // This is a regression test on debug info to make sure that we can get a
2 // meaningful stack trace from a C++ program.
3 // RUN: %llvmgcc -S -O0 -g %s -o - | llvm-as | llc --disable-fp-elim -o Output/StackTrace.s -f
4 // RUN: as Output/StackTrace.s -o Output/StackTrace.o
5 // RUN: g++ Output/StackTrace.o -o Output/StackTrace.exe
6 // RUN: ( echo "break DeepStack::deepest"; echo "run 17" ; echo "where" ) > Output/StackTrace.gdbin 
7 // RUN: gdb -q -batch -n -x Output/StackTrace.gdbin Output/StackTrace.exe | tee Output/StackTrace.out | grep '#0  DeepStack::deepest.*(this=.*,.*x=33)'
8 // RUN: gdb -q -batch -n -x Output/StackTrace.gdbin Output/StackTrace.exe | grep '#7  0x.* in main.*(argc=[12],.*argv=.*)'
9 // XFAIL: i[1-9]86|alpha|ia64|arm|x86_64
10
11 #include <stdlib.h>
12
13 class DeepStack {
14   int seedVal;
15 public:
16   DeepStack(int seed) : seedVal(seed) {}
17
18   int shallowest( int x ) { return shallower(x + 1); }
19   int shallower ( int x ) { return shallow(x + 2); }
20   int shallow   ( int x ) { return deep(x + 3); }
21   int deep      ( int x ) { return deeper(x + 4); }
22   int deeper    ( int x ) { return deepest(x + 6); }
23   int deepest   ( int x ) { return x + 7; }
24
25   int runit() { return shallowest(seedVal); }
26 };
27
28 int main ( int argc, char** argv) {
29
30   DeepStack DS9( (argc > 1 ? atoi(argv[1]) : 0) );
31   return DS9.runit();
32 }