Files
clang-p2996/lldb/test/API/functionalities/thread/step_out/main.cpp
David Blaikie 615f63e149 Revert "[FastISel] Flush local value map on ever instruction" and dependent patches
This reverts commit cf1c774d6a.

This change caused several regressions in the gdb test suite - at least
a sample of which was due to line zero instructions making breakpoints
un-lined. I think they're worth investigating/understanding more (&
possibly addressing) before moving forward with this change.

Revert "[FastISel] NFC: Clean up unnecessary bookkeeping"
This reverts commit 3fd39d3694.

Revert "[FastISel] NFC: Remove obsolete -fast-isel-sink-local-values option"
This reverts commit a474657e30.

Revert "Remove static function unused after cf1c774."
This reverts commit dc35368ccf.

Revert "[lldb] Fix TestThreadStepOut.py after "Flush local value map on every instruction""
This reverts commit 53a14a47ee.
2020-12-01 14:26:23 -08:00

43 lines
920 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(); // Expect to stop here after step-out (clang)
// Return
return NULL; // Expect to stop here after step-out (icc and gcc)
}
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;
}