summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--lldb/source/Plugins/Process/Linux/ProcessMonitor.cpp11
-rw-r--r--lldb/source/Plugins/Process/Linux/ProcessMonitor.h2
2 files changed, 8 insertions, 5 deletions
diff --git a/lldb/source/Plugins/Process/Linux/ProcessMonitor.cpp b/lldb/source/Plugins/Process/Linux/ProcessMonitor.cpp
index 8fe74511108..2c936386baa 100644
--- a/lldb/source/Plugins/Process/Linux/ProcessMonitor.cpp
+++ b/lldb/source/Plugins/Process/Linux/ProcessMonitor.cpp
@@ -607,7 +607,7 @@ ProcessMonitor::OperationThread(void *arg)
if (!Launch(args))
return NULL;
- ServeOperation(args->m_monitor);
+ ServeOperation(args);
return NULL;
}
@@ -716,8 +716,6 @@ ProcessMonitor::Launch(LaunchArgs *args)
process.SendMessage(ProcessMessage::Trace(pid));
FINISH:
- // Sync with our parent thread now that the launch operation is complete.
- sem_post(&args->m_semaphore);
return args->m_error.Success();
}
@@ -819,15 +817,20 @@ ProcessMonitor::MonitorSIGTRAP(ProcessMonitor *monitor, lldb::pid_t pid)
}
void
-ProcessMonitor::ServeOperation(ProcessMonitor *monitor)
+ProcessMonitor::ServeOperation(LaunchArgs *args)
{
int status;
pollfd fdset;
+ ProcessMonitor *monitor = args->m_monitor;
fdset.fd = monitor->m_server_fd;
fdset.events = POLLIN | POLLPRI;
fdset.revents = 0;
+ // We are finised with the arguments and are ready to go. Sync with the
+ // parent thread and start serving operations on the inferior.
+ sem_post(&args->m_semaphore);
+
for (;;)
{
if ((status = poll(&fdset, 1, -1)) < 0)
diff --git a/lldb/source/Plugins/Process/Linux/ProcessMonitor.h b/lldb/source/Plugins/Process/Linux/ProcessMonitor.h
index 86aad235f0b..c0160199652 100644
--- a/lldb/source/Plugins/Process/Linux/ProcessMonitor.h
+++ b/lldb/source/Plugins/Process/Linux/ProcessMonitor.h
@@ -197,7 +197,7 @@ private:
EnableIPC();
static void
- ServeOperation(ProcessMonitor *monitor);
+ ServeOperation(LaunchArgs *args);
static bool
DupDescriptor(const char *path, int fd, int flags);
OpenPOWER on IntegriCloud