diff options
author | Eric Christopher <echristo@gmail.com> | 2019-12-10 12:19:30 -0800 |
---|---|---|
committer | Eric Christopher <echristo@gmail.com> | 2019-12-10 12:29:46 -0800 |
commit | c9e0b354e2749ce7ab553974692cb35c8651a869 (patch) | |
tree | b15ce91461b0a934920362f501071702f0f7464a /lldb/source/Plugins/Process/gdb-remote/ProcessGDBRemote.cpp | |
parent | a2602bdd7316e3e41366f946a83a5a654b909957 (diff) | |
download | llvm-c9e0b354e2749ce7ab553974692cb35c8651a869.zip llvm-c9e0b354e2749ce7ab553974692cb35c8651a869.tar.gz llvm-c9e0b354e2749ce7ab553974692cb35c8651a869.tar.bz2 |
Temporarily revert [lldb] e81268d - [lldb/Reproducers] Support multiple GDB remotes
This was causing a crash in opt+assert builds on linux and a follow-up
message was posted.
This reverts commit e81268d03e73aef4f9c7bd8ece8ad02f5b017dcf
Diffstat (limited to 'lldb/source/Plugins/Process/gdb-remote/ProcessGDBRemote.cpp')
-rw-r--r-- | lldb/source/Plugins/Process/gdb-remote/ProcessGDBRemote.cpp | 31 |
1 files changed, 14 insertions, 17 deletions
diff --git a/lldb/source/Plugins/Process/gdb-remote/ProcessGDBRemote.cpp b/lldb/source/Plugins/Process/gdb-remote/ProcessGDBRemote.cpp index 95f3d1fc..dfef06a 100644 --- a/lldb/source/Plugins/Process/gdb-remote/ProcessGDBRemote.cpp +++ b/lldb/source/Plugins/Process/gdb-remote/ProcessGDBRemote.cpp @@ -279,9 +279,12 @@ ProcessGDBRemote::ProcessGDBRemote(lldb::TargetSP target_sp, "async thread did exit"); if (repro::Generator *g = repro::Reproducer::Instance().GetGenerator()) { - repro::GDBRemoteProvider &provider = - g->GetOrCreate<repro::GDBRemoteProvider>(); - m_gdb_comm.SetPacketRecorder(provider.GetNewPacketRecorder()); + repro::ProcessGDBRemoteProvider &provider = + g->GetOrCreate<repro::ProcessGDBRemoteProvider>(); + // Set the history stream to the stream owned by the provider. + m_gdb_comm.SetHistoryStream(provider.GetHistoryStream()); + // Make sure to clear the stream again when we're finished. + provider.SetCallback([&]() { m_gdb_comm.SetHistoryStream(nullptr); }); } Log *log(ProcessGDBRemoteLog::GetLogIfAllCategoriesSet(GDBR_LOG_ASYNC)); @@ -3359,20 +3362,17 @@ Status ProcessGDBRemote::ConnectToReplayServer(repro::Loader *loader) { if (!loader) return Status("No loader provided."); - static std::unique_ptr<repro::MultiLoader<repro::GDBRemoteProvider>> - multi_loader = repro::MultiLoader<repro::GDBRemoteProvider>::Create( - repro::Reproducer::Instance().GetLoader()); - - if (!multi_loader) - return Status("No gdb remote provider found."); - - llvm::Optional<std::string> history_file = multi_loader->GetNextFile(); + // Construct replay history path. + FileSpec history_file = + loader->GetFile<repro::ProcessGDBRemoteProvider::Info>(); if (!history_file) - return Status("No gdb remote packet log found."); + return Status("No provider for gdb-remote."); + + // Enable replay mode. + m_replay_mode = true; // Load replay history. - if (auto error = - m_gdb_replay_server.LoadReplayHistory(FileSpec(*history_file))) + if (auto error = m_gdb_replay_server.LoadReplayHistory(history_file)) return Status("Unable to load replay history"); // Make a local connection. @@ -3380,9 +3380,6 @@ Status ProcessGDBRemote::ConnectToReplayServer(repro::Loader *loader) { m_gdb_replay_server)) return Status("Unable to connect to replay server"); - // Enable replay mode. - m_replay_mode = true; - // Start server thread. m_gdb_replay_server.StartAsyncThread(); |