Files
clang-p2996/lldb/test/API/functionalities/thread/step_out/main.cpp
Raphael Isemann ed2853d2c8 Reland [lldb] Fix TestThreadStepOut.py after "Flush local value map on every instruction"
The original patch got reverted as a dependency of cf1c774d6a .
That patch got relanded so it's also necessary to reland this patch.

Original summary:

After cf1c774d6a, Clang seems to generate code
that is more similar to icc/Clang, so we can use the same line numbers for
all compilers in this test.
2021-01-21 13:35:13 +01:00

43 lines
861 B
C++

// This test is intended to create a situation in which two threads are stopped
// at a breakpoint and the debugger issues a step-out command.
#include "pseudo_barrier.h"
#include <thread>
pseudo_barrier_t g_barrier;
volatile int g_test = 0;
void step_out_of_here() {
g_test += 5; // Set breakpoint here
}
void *
thread_func ()
{
// Wait until both threads are running
pseudo_barrier_wait(g_barrier);
// Do something
step_out_of_here();
// Return
return NULL; // Expect to stop here after step-out.
}
int main ()
{
// Don't let either thread do anything until they're both ready.
pseudo_barrier_init(g_barrier, 2);
// Create two threads
std::thread thread_1(thread_func);
std::thread thread_2(thread_func);
// Wait for the threads to finish
thread_1.join();
thread_2.join();
return 0;
}