mirror of
https://github.com/llvm/llvm-project.git
synced 2025-05-12 00:46:06 +00:00

I found the race condition in: ScriptInterpreter *CommandInterpreter::GetScriptInterpreter(bool can_create); More than one "ScriptInterpreter *" was being returned due to the race which caused any clients with the first one to now be pointing to freed memory and we would quickly crash. Added a test to catch this so we don't regress. <rdar://problem/28356584> llvm-svn: 289169
32 lines
832 B
C++
32 lines
832 B
C++
#include <thread>
|
|
|
|
#include "lldb/API/LLDB.h"
|
|
#include "lldb/API/SBDebugger.h"
|
|
#include "lldb/API/SBTarget.h"
|
|
|
|
using namespace lldb;
|
|
int main (int argc, char **argv)
|
|
{
|
|
// We are expecting the program path and a path to an executable to load
|
|
if (argc != 2)
|
|
return 1;
|
|
const char *program_file = argv[1];
|
|
SBDebugger::Initialize();
|
|
SBDebugger debugger = SBDebugger::Create(false);
|
|
auto lambda = [&](){
|
|
SBError error;
|
|
SBTarget target = debugger.CreateTarget(program_file, nullptr, nullptr,
|
|
false, error);
|
|
};
|
|
|
|
// Create 3 targets at the same time and make sure we don't crash.
|
|
std::thread thread1(lambda);
|
|
std::thread thread2(lambda);
|
|
std::thread thread3(lambda);
|
|
thread1.join();
|
|
thread2.join();
|
|
thread3.join();
|
|
SBDebugger::Terminate();
|
|
return 0;
|
|
}
|