159ec512cSGreg Clayton //===-- ProcessKDP.cpp ------------------------------------------*- C++ -*-===//
2f9765acdSGreg Clayton //
3f9765acdSGreg Clayton //                     The LLVM Compiler Infrastructure
4f9765acdSGreg Clayton //
5f9765acdSGreg Clayton // This file is distributed under the University of Illinois Open Source
6f9765acdSGreg Clayton // License. See LICENSE.TXT for details.
7f9765acdSGreg Clayton //
8f9765acdSGreg Clayton //===----------------------------------------------------------------------===//
9f9765acdSGreg Clayton 
10f9765acdSGreg Clayton // C Includes
11f9765acdSGreg Clayton #include <errno.h>
12f9765acdSGreg Clayton #include <stdlib.h>
13f9765acdSGreg Clayton 
14f9765acdSGreg Clayton // C++ Includes
15f9765acdSGreg Clayton // Other libraries and framework includes
163a29bdbeSGreg Clayton #include "lldb/Core/ConnectionFileDescriptor.h"
1707e66e3eSGreg Clayton #include "lldb/Core/Debugger.h"
18f9765acdSGreg Clayton #include "lldb/Core/PluginManager.h"
191f746071SGreg Clayton #include "lldb/Core/Module.h"
204bd4e7e3SJason Molenda #include "lldb/Core/ModuleSpec.h"
21f9765acdSGreg Clayton #include "lldb/Core/State.h"
224bd4e7e3SJason Molenda #include "lldb/Core/UUID.h"
23f9765acdSGreg Clayton #include "lldb/Host/Host.h"
244bd4e7e3SJason Molenda #include "lldb/Host/Symbols.h"
251f746071SGreg Clayton #include "lldb/Symbol/ObjectFile.h"
267925fbbaSGreg Clayton #include "lldb/Target/RegisterContext.h"
2757508026SGreg Clayton #include "lldb/Target/Target.h"
28a63d08c9SGreg Clayton #include "lldb/Target/Thread.h"
29f9765acdSGreg Clayton 
30f9765acdSGreg Clayton // Project includes
31f9765acdSGreg Clayton #include "ProcessKDP.h"
32f9765acdSGreg Clayton #include "ProcessKDPLog.h"
33a63d08c9SGreg Clayton #include "ThreadKDP.h"
345e8534efSJason Molenda #include "Plugins/DynamicLoader/Darwin-Kernel/DynamicLoaderDarwinKernel.h"
35f9765acdSGreg Clayton 
36f9765acdSGreg Clayton using namespace lldb;
37f9765acdSGreg Clayton using namespace lldb_private;
38f9765acdSGreg Clayton 
39f9765acdSGreg Clayton const char *
40f9765acdSGreg Clayton ProcessKDP::GetPluginNameStatic()
41f9765acdSGreg Clayton {
42f9765acdSGreg Clayton     return "kdp-remote";
43f9765acdSGreg Clayton }
44f9765acdSGreg Clayton 
45f9765acdSGreg Clayton const char *
46f9765acdSGreg Clayton ProcessKDP::GetPluginDescriptionStatic()
47f9765acdSGreg Clayton {
48f9765acdSGreg Clayton     return "KDP Remote protocol based debugging plug-in for darwin kernel debugging.";
49f9765acdSGreg Clayton }
50f9765acdSGreg Clayton 
51f9765acdSGreg Clayton void
52f9765acdSGreg Clayton ProcessKDP::Terminate()
53f9765acdSGreg Clayton {
54f9765acdSGreg Clayton     PluginManager::UnregisterPlugin (ProcessKDP::CreateInstance);
55f9765acdSGreg Clayton }
56f9765acdSGreg Clayton 
57f9765acdSGreg Clayton 
58c3776bf2SGreg Clayton lldb::ProcessSP
59c3776bf2SGreg Clayton ProcessKDP::CreateInstance (Target &target,
60c3776bf2SGreg Clayton                             Listener &listener,
61c3776bf2SGreg Clayton                             const FileSpec *crash_file_path)
62f9765acdSGreg Clayton {
63c3776bf2SGreg Clayton     lldb::ProcessSP process_sp;
64c3776bf2SGreg Clayton     if (crash_file_path == NULL)
65c3776bf2SGreg Clayton         process_sp.reset(new ProcessKDP (target, listener));
66c3776bf2SGreg Clayton     return process_sp;
67f9765acdSGreg Clayton }
68f9765acdSGreg Clayton 
69f9765acdSGreg Clayton bool
703a29bdbeSGreg Clayton ProcessKDP::CanDebug(Target &target, bool plugin_specified_by_name)
71f9765acdSGreg Clayton {
72596ed24eSGreg Clayton     if (plugin_specified_by_name)
73596ed24eSGreg Clayton         return true;
74596ed24eSGreg Clayton 
75f9765acdSGreg Clayton     // For now we are just making sure the file exists for a given module
76aa149cbdSGreg Clayton     Module *exe_module = target.GetExecutableModulePointer();
77aa149cbdSGreg Clayton     if (exe_module)
78f9765acdSGreg Clayton     {
79f9765acdSGreg Clayton         const llvm::Triple &triple_ref = target.GetArchitecture().GetTriple();
8070512317SGreg Clayton         switch (triple_ref.getOS())
8170512317SGreg Clayton         {
8270512317SGreg Clayton             case llvm::Triple::Darwin:  // Should use "macosx" for desktop and "ios" for iOS, but accept darwin just in case
8370512317SGreg Clayton             case llvm::Triple::MacOSX:  // For desktop targets
8470512317SGreg Clayton             case llvm::Triple::IOS:     // For arm targets
8570512317SGreg Clayton                 if (triple_ref.getVendor() == llvm::Triple::Apple)
86f9765acdSGreg Clayton                 {
87aa149cbdSGreg Clayton                     ObjectFile *exe_objfile = exe_module->GetObjectFile();
88f9765acdSGreg Clayton                     if (exe_objfile->GetType() == ObjectFile::eTypeExecutable &&
89f9765acdSGreg Clayton                         exe_objfile->GetStrata() == ObjectFile::eStrataKernel)
90f9765acdSGreg Clayton                         return true;
91f9765acdSGreg Clayton                 }
9270512317SGreg Clayton                 break;
9370512317SGreg Clayton 
9470512317SGreg Clayton             default:
9570512317SGreg Clayton                 break;
9670512317SGreg Clayton         }
97f9765acdSGreg Clayton     }
98596ed24eSGreg Clayton     return false;
993a29bdbeSGreg Clayton }
100f9765acdSGreg Clayton 
101f9765acdSGreg Clayton //----------------------------------------------------------------------
102f9765acdSGreg Clayton // ProcessKDP constructor
103f9765acdSGreg Clayton //----------------------------------------------------------------------
104f9765acdSGreg Clayton ProcessKDP::ProcessKDP(Target& target, Listener &listener) :
105f9765acdSGreg Clayton     Process (target, listener),
106f9765acdSGreg Clayton     m_comm("lldb.process.kdp-remote.communication"),
1074bddaeb5SJim Ingham     m_async_broadcaster (NULL, "lldb.process.kdp-remote.async-broadcaster"),
10897d5cf05SGreg Clayton     m_async_thread (LLDB_INVALID_HOST_THREAD),
1095e8534efSJason Molenda     m_destroy_in_process (false),
1105e8534efSJason Molenda     m_dyld_plugin_name (),
1115e8534efSJason Molenda     m_kernel_load_addr (LLDB_INVALID_ADDRESS)
112f9765acdSGreg Clayton {
1137925fbbaSGreg Clayton     m_async_broadcaster.SetEventName (eBroadcastBitAsyncThreadShouldExit,   "async thread should exit");
1147925fbbaSGreg Clayton     m_async_broadcaster.SetEventName (eBroadcastBitAsyncContinue,           "async thread continue");
115f9765acdSGreg Clayton }
116f9765acdSGreg Clayton 
117f9765acdSGreg Clayton //----------------------------------------------------------------------
118f9765acdSGreg Clayton // Destructor
119f9765acdSGreg Clayton //----------------------------------------------------------------------
120f9765acdSGreg Clayton ProcessKDP::~ProcessKDP()
121f9765acdSGreg Clayton {
122f9765acdSGreg Clayton     Clear();
123e24c4acfSGreg Clayton     // We need to call finalize on the process before destroying ourselves
124e24c4acfSGreg Clayton     // to make sure all of the broadcaster cleanup goes as planned. If we
125e24c4acfSGreg Clayton     // destruct this class, then Process::~Process() might have problems
126e24c4acfSGreg Clayton     // trying to fully destroy the broadcaster.
127e24c4acfSGreg Clayton     Finalize();
128f9765acdSGreg Clayton }
129f9765acdSGreg Clayton 
130f9765acdSGreg Clayton //----------------------------------------------------------------------
131f9765acdSGreg Clayton // PluginInterface
132f9765acdSGreg Clayton //----------------------------------------------------------------------
133f9765acdSGreg Clayton const char *
134f9765acdSGreg Clayton ProcessKDP::GetPluginName()
135f9765acdSGreg Clayton {
136f9765acdSGreg Clayton     return "Process debugging plug-in that uses the Darwin KDP remote protocol";
137f9765acdSGreg Clayton }
138f9765acdSGreg Clayton 
139f9765acdSGreg Clayton const char *
140f9765acdSGreg Clayton ProcessKDP::GetShortPluginName()
141f9765acdSGreg Clayton {
142f9765acdSGreg Clayton     return GetPluginNameStatic();
143f9765acdSGreg Clayton }
144f9765acdSGreg Clayton 
145f9765acdSGreg Clayton uint32_t
146f9765acdSGreg Clayton ProcessKDP::GetPluginVersion()
147f9765acdSGreg Clayton {
148f9765acdSGreg Clayton     return 1;
149f9765acdSGreg Clayton }
150f9765acdSGreg Clayton 
151f9765acdSGreg Clayton Error
152f9765acdSGreg Clayton ProcessKDP::WillLaunch (Module* module)
153f9765acdSGreg Clayton {
154f9765acdSGreg Clayton     Error error;
155f9765acdSGreg Clayton     error.SetErrorString ("launching not supported in kdp-remote plug-in");
156f9765acdSGreg Clayton     return error;
157f9765acdSGreg Clayton }
158f9765acdSGreg Clayton 
159f9765acdSGreg Clayton Error
160f9765acdSGreg Clayton ProcessKDP::WillAttachToProcessWithID (lldb::pid_t pid)
161f9765acdSGreg Clayton {
162f9765acdSGreg Clayton     Error error;
163f9765acdSGreg Clayton     error.SetErrorString ("attaching to a by process ID not supported in kdp-remote plug-in");
164f9765acdSGreg Clayton     return error;
165f9765acdSGreg Clayton }
166f9765acdSGreg Clayton 
167f9765acdSGreg Clayton Error
168f9765acdSGreg Clayton ProcessKDP::WillAttachToProcessWithName (const char *process_name, bool wait_for_launch)
169f9765acdSGreg Clayton {
170f9765acdSGreg Clayton     Error error;
171f9765acdSGreg Clayton     error.SetErrorString ("attaching to a by process name not supported in kdp-remote plug-in");
172f9765acdSGreg Clayton     return error;
173f9765acdSGreg Clayton }
174f9765acdSGreg Clayton 
175f9765acdSGreg Clayton Error
1764bd4e7e3SJason Molenda ProcessKDP::DoConnectRemote (Stream *strm, const char *remote_url)
177f9765acdSGreg Clayton {
178f9765acdSGreg Clayton     Error error;
1793a29bdbeSGreg Clayton 
1807925fbbaSGreg Clayton     // Don't let any JIT happen when doing KDP as we can't allocate
1817925fbbaSGreg Clayton     // memory and we don't want to be mucking with threads that might
1827925fbbaSGreg Clayton     // already be handling exceptions
1837925fbbaSGreg Clayton     SetCanJIT(false);
1847925fbbaSGreg Clayton 
1853a29bdbeSGreg Clayton     if (remote_url == NULL || remote_url[0] == '\0')
1867925fbbaSGreg Clayton     {
1877925fbbaSGreg Clayton         error.SetErrorStringWithFormat ("invalid connection URL '%s'", remote_url);
1887925fbbaSGreg Clayton         return error;
1897925fbbaSGreg Clayton     }
1903a29bdbeSGreg Clayton 
1913a29bdbeSGreg Clayton     std::auto_ptr<ConnectionFileDescriptor> conn_ap(new ConnectionFileDescriptor());
1923a29bdbeSGreg Clayton     if (conn_ap.get())
1933a29bdbeSGreg Clayton     {
1943a29bdbeSGreg Clayton         // Only try once for now.
1953a29bdbeSGreg Clayton         // TODO: check if we should be retrying?
1963a29bdbeSGreg Clayton         const uint32_t max_retry_count = 1;
1973a29bdbeSGreg Clayton         for (uint32_t retry_count = 0; retry_count < max_retry_count; ++retry_count)
1983a29bdbeSGreg Clayton         {
1993a29bdbeSGreg Clayton             if (conn_ap->Connect(remote_url, &error) == eConnectionStatusSuccess)
2003a29bdbeSGreg Clayton                 break;
2013a29bdbeSGreg Clayton             usleep (100000);
2023a29bdbeSGreg Clayton         }
2033a29bdbeSGreg Clayton     }
2043a29bdbeSGreg Clayton 
2053a29bdbeSGreg Clayton     if (conn_ap->IsConnected())
2063a29bdbeSGreg Clayton     {
2073a29bdbeSGreg Clayton         const uint16_t reply_port = conn_ap->GetReadPort ();
2083a29bdbeSGreg Clayton 
2093a29bdbeSGreg Clayton         if (reply_port != 0)
2103a29bdbeSGreg Clayton         {
2113a29bdbeSGreg Clayton             m_comm.SetConnection(conn_ap.release());
2123a29bdbeSGreg Clayton 
2133a29bdbeSGreg Clayton             if (m_comm.SendRequestReattach(reply_port))
2143a29bdbeSGreg Clayton             {
2153a29bdbeSGreg Clayton                 if (m_comm.SendRequestConnect(reply_port, reply_port, "Greetings from LLDB..."))
2163a29bdbeSGreg Clayton                 {
2173a29bdbeSGreg Clayton                     m_comm.GetVersion();
2183a29bdbeSGreg Clayton                     uint32_t cpu = m_comm.GetCPUType();
2193a29bdbeSGreg Clayton                     uint32_t sub = m_comm.GetCPUSubtype();
2203a29bdbeSGreg Clayton                     ArchSpec kernel_arch;
2213a29bdbeSGreg Clayton                     kernel_arch.SetArchitecture(eArchTypeMachO, cpu, sub);
2223a29bdbeSGreg Clayton                     m_target.SetArchitecture(kernel_arch);
2234bd4e7e3SJason Molenda 
2244bd4e7e3SJason Molenda                     /* Get the kernel's UUID and load address via kdp-kernelversion packet.  */
2254bd4e7e3SJason Molenda 
2264bd4e7e3SJason Molenda                     UUID kernel_uuid = m_comm.GetUUID ();
2274bd4e7e3SJason Molenda                     addr_t kernel_load_addr = m_comm.GetLoadAddress ();
2284bd4e7e3SJason Molenda 
2295e8534efSJason Molenda                     if (kernel_load_addr != LLDB_INVALID_ADDRESS)
2304bd4e7e3SJason Molenda                     {
2315e8534efSJason Molenda                         m_kernel_load_addr = kernel_load_addr;
2325e8534efSJason Molenda                         m_dyld_plugin_name = DynamicLoaderDarwinKernel::GetPluginNameStatic();
2334bd4e7e3SJason Molenda                     }
2344bd4e7e3SJason Molenda 
23597d5cf05SGreg Clayton                     // Set the thread ID
23697d5cf05SGreg Clayton                     UpdateThreadListIfNeeded ();
237a63d08c9SGreg Clayton                     SetID (1);
23856d9a1b3SGreg Clayton                     GetThreadList ();
239a63d08c9SGreg Clayton                     SetPrivateState (eStateStopped);
24007e66e3eSGreg Clayton                     StreamSP async_strm_sp(m_target.GetDebugger().GetAsyncOutputStream());
24107e66e3eSGreg Clayton                     if (async_strm_sp)
24207e66e3eSGreg Clayton                     {
2435b88216dSGreg Clayton                         const char *cstr;
2445b88216dSGreg Clayton                         if ((cstr = m_comm.GetKernelVersion ()) != NULL)
24507e66e3eSGreg Clayton                         {
2465b88216dSGreg Clayton                             async_strm_sp->Printf ("Version: %s\n", cstr);
24707e66e3eSGreg Clayton                             async_strm_sp->Flush();
24807e66e3eSGreg Clayton                         }
2495b88216dSGreg Clayton //                      if ((cstr = m_comm.GetImagePath ()) != NULL)
2505b88216dSGreg Clayton //                      {
2515b88216dSGreg Clayton //                          async_strm_sp->Printf ("Image Path: %s\n", cstr);
2525b88216dSGreg Clayton //                          async_strm_sp->Flush();
2535b88216dSGreg Clayton //                      }
25407e66e3eSGreg Clayton                     }
2553a29bdbeSGreg Clayton                 }
25697d5cf05SGreg Clayton                 else
25797d5cf05SGreg Clayton                 {
25897d5cf05SGreg Clayton                     error.SetErrorString("KDP_REATTACH failed");
25997d5cf05SGreg Clayton                 }
2603a29bdbeSGreg Clayton             }
2613a29bdbeSGreg Clayton             else
2623a29bdbeSGreg Clayton             {
26397d5cf05SGreg Clayton                 error.SetErrorString("KDP_REATTACH failed");
2643a29bdbeSGreg Clayton             }
2653a29bdbeSGreg Clayton         }
2663a29bdbeSGreg Clayton         else
2673a29bdbeSGreg Clayton         {
2683a29bdbeSGreg Clayton             error.SetErrorString("invalid reply port from UDP connection");
2693a29bdbeSGreg Clayton         }
2703a29bdbeSGreg Clayton     }
2713a29bdbeSGreg Clayton     else
2723a29bdbeSGreg Clayton     {
2733a29bdbeSGreg Clayton         if (error.Success())
2743a29bdbeSGreg Clayton             error.SetErrorStringWithFormat ("failed to connect to '%s'", remote_url);
2753a29bdbeSGreg Clayton     }
2763a29bdbeSGreg Clayton     if (error.Fail())
2773a29bdbeSGreg Clayton         m_comm.Disconnect();
2783a29bdbeSGreg Clayton 
279f9765acdSGreg Clayton     return error;
280f9765acdSGreg Clayton }
281f9765acdSGreg Clayton 
282f9765acdSGreg Clayton //----------------------------------------------------------------------
283f9765acdSGreg Clayton // Process Control
284f9765acdSGreg Clayton //----------------------------------------------------------------------
285f9765acdSGreg Clayton Error
286982c9762SGreg Clayton ProcessKDP::DoLaunch (Module *exe_module,
287982c9762SGreg Clayton                       const ProcessLaunchInfo &launch_info)
288f9765acdSGreg Clayton {
289f9765acdSGreg Clayton     Error error;
290f9765acdSGreg Clayton     error.SetErrorString ("launching not supported in kdp-remote plug-in");
291f9765acdSGreg Clayton     return error;
292f9765acdSGreg Clayton }
293f9765acdSGreg Clayton 
294f9765acdSGreg Clayton 
295f9765acdSGreg Clayton Error
296f9765acdSGreg Clayton ProcessKDP::DoAttachToProcessWithID (lldb::pid_t attach_pid)
297f9765acdSGreg Clayton {
298f9765acdSGreg Clayton     Error error;
299f9765acdSGreg Clayton     error.SetErrorString ("attach to process by ID is not suppported in kdp remote debugging");
300f9765acdSGreg Clayton     return error;
301f9765acdSGreg Clayton }
302f9765acdSGreg Clayton 
303f9765acdSGreg Clayton Error
30484647048SHan Ming Ong ProcessKDP::DoAttachToProcessWithID (lldb::pid_t attach_pid, const ProcessAttachInfo &attach_info)
30584647048SHan Ming Ong {
30684647048SHan Ming Ong     Error error;
30784647048SHan Ming Ong     error.SetErrorString ("attach to process by ID is not suppported in kdp remote debugging");
30884647048SHan Ming Ong     return error;
30984647048SHan Ming Ong }
31084647048SHan Ming Ong 
31184647048SHan Ming Ong Error
31284647048SHan Ming Ong ProcessKDP::DoAttachToProcessWithName (const char *process_name, bool wait_for_launch, const ProcessAttachInfo &attach_info)
313f9765acdSGreg Clayton {
314f9765acdSGreg Clayton     Error error;
315f9765acdSGreg Clayton     error.SetErrorString ("attach to process by name is not suppported in kdp remote debugging");
316f9765acdSGreg Clayton     return error;
317f9765acdSGreg Clayton }
318f9765acdSGreg Clayton 
319f9765acdSGreg Clayton 
320f9765acdSGreg Clayton void
321f9765acdSGreg Clayton ProcessKDP::DidAttach ()
322f9765acdSGreg Clayton {
323f9765acdSGreg Clayton     LogSP log (ProcessKDPLog::GetLogIfAllCategoriesSet (KDP_LOG_PROCESS));
324f9765acdSGreg Clayton     if (log)
32554cb8f83SJohnny Chen         log->Printf ("ProcessKDP::DidAttach()");
326f9765acdSGreg Clayton     if (GetID() != LLDB_INVALID_PROCESS_ID)
327f9765acdSGreg Clayton     {
328f9765acdSGreg Clayton         // TODO: figure out the register context that we will use
329f9765acdSGreg Clayton     }
330f9765acdSGreg Clayton }
331f9765acdSGreg Clayton 
3325e8534efSJason Molenda addr_t
3335e8534efSJason Molenda ProcessKDP::GetImageInfoAddress()
3345e8534efSJason Molenda {
3355e8534efSJason Molenda     return m_kernel_load_addr;
3365e8534efSJason Molenda }
3375e8534efSJason Molenda 
3385e8534efSJason Molenda lldb_private::DynamicLoader *
3395e8534efSJason Molenda ProcessKDP::GetDynamicLoader ()
3405e8534efSJason Molenda {
3415e8534efSJason Molenda     if (m_dyld_ap.get() == NULL)
3425e8534efSJason Molenda         m_dyld_ap.reset (DynamicLoader::FindPlugin(this, m_dyld_plugin_name.empty() ? NULL : m_dyld_plugin_name.c_str()));
3435e8534efSJason Molenda     return m_dyld_ap.get();
3445e8534efSJason Molenda }
3455e8534efSJason Molenda 
346f9765acdSGreg Clayton Error
347f9765acdSGreg Clayton ProcessKDP::WillResume ()
348f9765acdSGreg Clayton {
349f9765acdSGreg Clayton     return Error();
350f9765acdSGreg Clayton }
351f9765acdSGreg Clayton 
352f9765acdSGreg Clayton Error
353f9765acdSGreg Clayton ProcessKDP::DoResume ()
354f9765acdSGreg Clayton {
355f9765acdSGreg Clayton     Error error;
3567925fbbaSGreg Clayton     LogSP log (ProcessKDPLog::GetLogIfAllCategoriesSet (KDP_LOG_PROCESS));
3577925fbbaSGreg Clayton     // Only start the async thread if we try to do any process control
3587925fbbaSGreg Clayton     if (!IS_VALID_LLDB_HOST_THREAD(m_async_thread))
3597925fbbaSGreg Clayton         StartAsyncThread ();
3607925fbbaSGreg Clayton 
36197d5cf05SGreg Clayton     bool resume = false;
3627925fbbaSGreg Clayton 
36397d5cf05SGreg Clayton     // With KDP there is only one thread we can tell what to do
36497d5cf05SGreg Clayton     ThreadSP kernel_thread_sp (GetKernelThread(m_thread_list, m_thread_list));
36597d5cf05SGreg Clayton     if (kernel_thread_sp)
3664b1b8b3eSGreg Clayton     {
36797d5cf05SGreg Clayton         const StateType thread_resume_state = kernel_thread_sp->GetTemporaryResumeState();
3687925fbbaSGreg Clayton         switch (thread_resume_state)
3694b1b8b3eSGreg Clayton         {
3707925fbbaSGreg Clayton             case eStateSuspended:
3717925fbbaSGreg Clayton                 // Nothing to do here when a thread will stay suspended
3727925fbbaSGreg Clayton                 // we just leave the CPU mask bit set to zero for the thread
3737925fbbaSGreg Clayton                 break;
3747925fbbaSGreg Clayton 
3757925fbbaSGreg Clayton             case eStateStepping:
37697d5cf05SGreg Clayton                 kernel_thread_sp->GetRegisterContext()->HardwareSingleStep (true);
37797d5cf05SGreg Clayton                 resume = true;
3787925fbbaSGreg Clayton                 break;
3797925fbbaSGreg Clayton 
38097d5cf05SGreg Clayton             case eStateRunning:
38197d5cf05SGreg Clayton                 kernel_thread_sp->GetRegisterContext()->HardwareSingleStep (false);
38297d5cf05SGreg Clayton                 resume = true;
3837925fbbaSGreg Clayton                 break;
3847925fbbaSGreg Clayton 
3857925fbbaSGreg Clayton             default:
38697d5cf05SGreg Clayton                 // The only valid thread resume states are listed above
3877925fbbaSGreg Clayton                 assert (!"invalid thread resume state");
3887925fbbaSGreg Clayton                 break;
3894b1b8b3eSGreg Clayton         }
3904b1b8b3eSGreg Clayton     }
3917925fbbaSGreg Clayton 
39297d5cf05SGreg Clayton     if (resume)
39397d5cf05SGreg Clayton     {
39497d5cf05SGreg Clayton         if (log)
39597d5cf05SGreg Clayton             log->Printf ("ProcessKDP::DoResume () sending resume");
39697d5cf05SGreg Clayton 
39797d5cf05SGreg Clayton         if (m_comm.SendRequestResume ())
3987925fbbaSGreg Clayton         {
3997925fbbaSGreg Clayton             m_async_broadcaster.BroadcastEvent (eBroadcastBitAsyncContinue);
4007925fbbaSGreg Clayton             SetPrivateState(eStateRunning);
4017925fbbaSGreg Clayton         }
4024b1b8b3eSGreg Clayton         else
40307e66e3eSGreg Clayton             error.SetErrorString ("KDP resume failed");
4047925fbbaSGreg Clayton     }
4057925fbbaSGreg Clayton     else
4067925fbbaSGreg Clayton     {
40797d5cf05SGreg Clayton         error.SetErrorString ("kernel thread is suspended");
4087925fbbaSGreg Clayton     }
4097925fbbaSGreg Clayton 
410f9765acdSGreg Clayton     return error;
411f9765acdSGreg Clayton }
412f9765acdSGreg Clayton 
41397d5cf05SGreg Clayton lldb::ThreadSP
41497d5cf05SGreg Clayton ProcessKDP::GetKernelThread(ThreadList &old_thread_list, ThreadList &new_thread_list)
41597d5cf05SGreg Clayton {
41697d5cf05SGreg Clayton     // KDP only tells us about one thread/core. Any other threads will usually
41797d5cf05SGreg Clayton     // be the ones that are read from memory by the OS plug-ins.
41897d5cf05SGreg Clayton     const lldb::tid_t kernel_tid = 1;
41997d5cf05SGreg Clayton     ThreadSP thread_sp (old_thread_list.FindThreadByID (kernel_tid, false));
42097d5cf05SGreg Clayton     if (!thread_sp)
42197d5cf05SGreg Clayton     {
422*4f465cffSJim Ingham         thread_sp.reset(new ThreadKDP (*this, kernel_tid));
42397d5cf05SGreg Clayton         new_thread_list.AddThread(thread_sp);
42497d5cf05SGreg Clayton     }
42597d5cf05SGreg Clayton     return thread_sp;
42697d5cf05SGreg Clayton }
42797d5cf05SGreg Clayton 
42897d5cf05SGreg Clayton 
42997d5cf05SGreg Clayton 
43097d5cf05SGreg Clayton 
4319fc13556SGreg Clayton bool
43256d9a1b3SGreg Clayton ProcessKDP::UpdateThreadList (ThreadList &old_thread_list, ThreadList &new_thread_list)
433f9765acdSGreg Clayton {
434f9765acdSGreg Clayton     // locker will keep a mutex locked until it goes out of scope
435f9765acdSGreg Clayton     LogSP log (ProcessKDPLog::GetLogIfAllCategoriesSet (KDP_LOG_THREAD));
436f9765acdSGreg Clayton     if (log && log->GetMask().Test(KDP_LOG_VERBOSE))
43781c22f61SGreg Clayton         log->Printf ("ProcessKDP::%s (pid = %llu)", __FUNCTION__, GetID());
438f9765acdSGreg Clayton 
43997d5cf05SGreg Clayton     // Even though there is a CPU mask, it doesn't mean to can see each CPU
44097d5cf05SGreg Clayton     // indivudually, there is really only one. Lets call this thread 1.
44197d5cf05SGreg Clayton     GetKernelThread (old_thread_list, new_thread_list);
44297d5cf05SGreg Clayton 
4439fc13556SGreg Clayton     return new_thread_list.GetSize(false) > 0;
444f9765acdSGreg Clayton }
445f9765acdSGreg Clayton 
446f9765acdSGreg Clayton void
447f9765acdSGreg Clayton ProcessKDP::RefreshStateAfterStop ()
448f9765acdSGreg Clayton {
449f9765acdSGreg Clayton     // Let all threads recover from stopping and do any clean up based
450f9765acdSGreg Clayton     // on the previous thread state (if any).
451f9765acdSGreg Clayton     m_thread_list.RefreshStateAfterStop();
452f9765acdSGreg Clayton }
453f9765acdSGreg Clayton 
454f9765acdSGreg Clayton Error
455f9765acdSGreg Clayton ProcessKDP::DoHalt (bool &caused_stop)
456f9765acdSGreg Clayton {
457f9765acdSGreg Clayton     Error error;
458f9765acdSGreg Clayton 
45997d5cf05SGreg Clayton     if (m_comm.IsRunning())
460f9765acdSGreg Clayton     {
46197d5cf05SGreg Clayton         if (m_destroy_in_process)
46297d5cf05SGreg Clayton         {
46397d5cf05SGreg Clayton             // If we are attemping to destroy, we need to not return an error to
46497d5cf05SGreg Clayton             // Halt or DoDestroy won't get called.
46597d5cf05SGreg Clayton             // We are also currently running, so send a process stopped event
46697d5cf05SGreg Clayton             SetPrivateState (eStateStopped);
467f9765acdSGreg Clayton         }
468f9765acdSGreg Clayton         else
469f9765acdSGreg Clayton         {
47097d5cf05SGreg Clayton             error.SetErrorString ("KDP cannot interrupt a running kernel");
471f9765acdSGreg Clayton         }
472f9765acdSGreg Clayton     }
473f9765acdSGreg Clayton     return error;
474f9765acdSGreg Clayton }
475f9765acdSGreg Clayton 
476f9765acdSGreg Clayton Error
477f9765acdSGreg Clayton ProcessKDP::DoDetach()
478f9765acdSGreg Clayton {
479f9765acdSGreg Clayton     Error error;
480f9765acdSGreg Clayton     LogSP log (ProcessKDPLog::GetLogIfAllCategoriesSet(KDP_LOG_PROCESS));
481f9765acdSGreg Clayton     if (log)
482f9765acdSGreg Clayton         log->Printf ("ProcessKDP::DoDetach()");
483f9765acdSGreg Clayton 
48497d5cf05SGreg Clayton     if (m_comm.IsRunning())
48597d5cf05SGreg Clayton     {
48697d5cf05SGreg Clayton         // We are running and we can't interrupt a running kernel, so we need
48797d5cf05SGreg Clayton         // to just close the connection to the kernel and hope for the best
48897d5cf05SGreg Clayton     }
48997d5cf05SGreg Clayton     else
49097d5cf05SGreg Clayton     {
491f9765acdSGreg Clayton         DisableAllBreakpointSites ();
492f9765acdSGreg Clayton 
493f9765acdSGreg Clayton         m_thread_list.DiscardThreadPlans();
494f9765acdSGreg Clayton 
4953a29bdbeSGreg Clayton         if (m_comm.IsConnected())
4963a29bdbeSGreg Clayton         {
4973a29bdbeSGreg Clayton 
4983a29bdbeSGreg Clayton             m_comm.SendRequestDisconnect();
4993a29bdbeSGreg Clayton 
50057508026SGreg Clayton             size_t response_size = m_comm.Disconnect ();
501f9765acdSGreg Clayton             if (log)
502f9765acdSGreg Clayton             {
503f9765acdSGreg Clayton                 if (response_size)
504f9765acdSGreg Clayton                     log->PutCString ("ProcessKDP::DoDetach() detach packet sent successfully");
505f9765acdSGreg Clayton                 else
506f9765acdSGreg Clayton                     log->PutCString ("ProcessKDP::DoDetach() detach packet send failed");
507f9765acdSGreg Clayton             }
5083a29bdbeSGreg Clayton         }
50997d5cf05SGreg Clayton     }
510f9765acdSGreg Clayton     StopAsyncThread ();
51174d4193eSGreg Clayton     m_comm.Clear();
512f9765acdSGreg Clayton 
513f9765acdSGreg Clayton     SetPrivateState (eStateDetached);
514f9765acdSGreg Clayton     ResumePrivateStateThread();
515f9765acdSGreg Clayton 
516f9765acdSGreg Clayton     //KillDebugserverProcess ();
517f9765acdSGreg Clayton     return error;
518f9765acdSGreg Clayton }
519f9765acdSGreg Clayton 
520f9765acdSGreg Clayton Error
52197d5cf05SGreg Clayton ProcessKDP::WillDestroy ()
52297d5cf05SGreg Clayton {
52397d5cf05SGreg Clayton     Error error;
52497d5cf05SGreg Clayton     m_destroy_in_process = true;
52597d5cf05SGreg Clayton     return error;
52697d5cf05SGreg Clayton }
52797d5cf05SGreg Clayton 
52897d5cf05SGreg Clayton Error
529f9765acdSGreg Clayton ProcessKDP::DoDestroy ()
530f9765acdSGreg Clayton {
5317925fbbaSGreg Clayton     // For KDP there really is no difference between destroy and detach
5327925fbbaSGreg Clayton     return DoDetach();
533f9765acdSGreg Clayton }
534f9765acdSGreg Clayton 
535f9765acdSGreg Clayton //------------------------------------------------------------------
536f9765acdSGreg Clayton // Process Queries
537f9765acdSGreg Clayton //------------------------------------------------------------------
538f9765acdSGreg Clayton 
539f9765acdSGreg Clayton bool
540f9765acdSGreg Clayton ProcessKDP::IsAlive ()
541f9765acdSGreg Clayton {
542f9765acdSGreg Clayton     return m_comm.IsConnected() && m_private_state.GetValue() != eStateExited;
543f9765acdSGreg Clayton }
544f9765acdSGreg Clayton 
545f9765acdSGreg Clayton //------------------------------------------------------------------
546f9765acdSGreg Clayton // Process Memory
547f9765acdSGreg Clayton //------------------------------------------------------------------
548f9765acdSGreg Clayton size_t
549f9765acdSGreg Clayton ProcessKDP::DoReadMemory (addr_t addr, void *buf, size_t size, Error &error)
550f9765acdSGreg Clayton {
551a63d08c9SGreg Clayton     if (m_comm.IsConnected())
552a63d08c9SGreg Clayton         return m_comm.SendRequestReadMemory (addr, buf, size, error);
553a63d08c9SGreg Clayton     error.SetErrorString ("not connected");
554f9765acdSGreg Clayton     return 0;
555f9765acdSGreg Clayton }
556f9765acdSGreg Clayton 
557f9765acdSGreg Clayton size_t
558f9765acdSGreg Clayton ProcessKDP::DoWriteMemory (addr_t addr, const void *buf, size_t size, Error &error)
559f9765acdSGreg Clayton {
5607925fbbaSGreg Clayton     if (m_comm.IsConnected())
5617925fbbaSGreg Clayton         return m_comm.SendRequestWriteMemory (addr, buf, size, error);
5627925fbbaSGreg Clayton     error.SetErrorString ("not connected");
563f9765acdSGreg Clayton     return 0;
564f9765acdSGreg Clayton }
565f9765acdSGreg Clayton 
566f9765acdSGreg Clayton lldb::addr_t
567f9765acdSGreg Clayton ProcessKDP::DoAllocateMemory (size_t size, uint32_t permissions, Error &error)
568f9765acdSGreg Clayton {
569f9765acdSGreg Clayton     error.SetErrorString ("memory allocation not suppported in kdp remote debugging");
570f9765acdSGreg Clayton     return LLDB_INVALID_ADDRESS;
571f9765acdSGreg Clayton }
572f9765acdSGreg Clayton 
573f9765acdSGreg Clayton Error
574f9765acdSGreg Clayton ProcessKDP::DoDeallocateMemory (lldb::addr_t addr)
575f9765acdSGreg Clayton {
576f9765acdSGreg Clayton     Error error;
577f9765acdSGreg Clayton     error.SetErrorString ("memory deallocation not suppported in kdp remote debugging");
578f9765acdSGreg Clayton     return error;
579f9765acdSGreg Clayton }
580f9765acdSGreg Clayton 
581f9765acdSGreg Clayton Error
582f9765acdSGreg Clayton ProcessKDP::EnableBreakpoint (BreakpointSite *bp_site)
583f9765acdSGreg Clayton {
58407e66e3eSGreg Clayton     if (m_comm.LocalBreakpointsAreSupported ())
58507e66e3eSGreg Clayton     {
58607e66e3eSGreg Clayton         Error error;
5875b88216dSGreg Clayton         if (!bp_site->IsEnabled())
5885b88216dSGreg Clayton         {
5895b88216dSGreg Clayton             if (m_comm.SendRequestBreakpoint(true, bp_site->GetLoadAddress()))
5905b88216dSGreg Clayton             {
5915b88216dSGreg Clayton                 bp_site->SetEnabled(true);
5925b88216dSGreg Clayton                 bp_site->SetType (BreakpointSite::eExternal);
5935b88216dSGreg Clayton             }
5945b88216dSGreg Clayton             else
5955b88216dSGreg Clayton             {
59607e66e3eSGreg Clayton                 error.SetErrorString ("KDP set breakpoint failed");
5975b88216dSGreg Clayton             }
5985b88216dSGreg Clayton         }
59907e66e3eSGreg Clayton         return error;
60007e66e3eSGreg Clayton     }
601f9765acdSGreg Clayton     return EnableSoftwareBreakpoint (bp_site);
602f9765acdSGreg Clayton }
603f9765acdSGreg Clayton 
604f9765acdSGreg Clayton Error
605f9765acdSGreg Clayton ProcessKDP::DisableBreakpoint (BreakpointSite *bp_site)
606f9765acdSGreg Clayton {
60707e66e3eSGreg Clayton     if (m_comm.LocalBreakpointsAreSupported ())
60807e66e3eSGreg Clayton     {
60907e66e3eSGreg Clayton         Error error;
6105b88216dSGreg Clayton         if (bp_site->IsEnabled())
6115b88216dSGreg Clayton         {
6125b88216dSGreg Clayton             BreakpointSite::Type bp_type = bp_site->GetType();
6135b88216dSGreg Clayton             if (bp_type == BreakpointSite::eExternal)
6145b88216dSGreg Clayton             {
61597d5cf05SGreg Clayton                 if (m_destroy_in_process && m_comm.IsRunning())
61697d5cf05SGreg Clayton                 {
61797d5cf05SGreg Clayton                     // We are trying to destroy our connection and we are running
61897d5cf05SGreg Clayton                     bp_site->SetEnabled(false);
61997d5cf05SGreg Clayton                 }
62097d5cf05SGreg Clayton                 else
62197d5cf05SGreg Clayton                 {
6225b88216dSGreg Clayton                     if (m_comm.SendRequestBreakpoint(false, bp_site->GetLoadAddress()))
6235b88216dSGreg Clayton                         bp_site->SetEnabled(false);
6245b88216dSGreg Clayton                     else
62507e66e3eSGreg Clayton                         error.SetErrorString ("KDP remove breakpoint failed");
6265b88216dSGreg Clayton                 }
62797d5cf05SGreg Clayton             }
6285b88216dSGreg Clayton             else
6295b88216dSGreg Clayton             {
6305b88216dSGreg Clayton                 error = DisableSoftwareBreakpoint (bp_site);
6315b88216dSGreg Clayton             }
6325b88216dSGreg Clayton         }
63307e66e3eSGreg Clayton         return error;
63407e66e3eSGreg Clayton     }
635f9765acdSGreg Clayton     return DisableSoftwareBreakpoint (bp_site);
636f9765acdSGreg Clayton }
637f9765acdSGreg Clayton 
638f9765acdSGreg Clayton Error
63901a67860SJohnny Chen ProcessKDP::EnableWatchpoint (Watchpoint *wp)
640f9765acdSGreg Clayton {
641f9765acdSGreg Clayton     Error error;
642f9765acdSGreg Clayton     error.SetErrorString ("watchpoints are not suppported in kdp remote debugging");
643f9765acdSGreg Clayton     return error;
644f9765acdSGreg Clayton }
645f9765acdSGreg Clayton 
646f9765acdSGreg Clayton Error
64701a67860SJohnny Chen ProcessKDP::DisableWatchpoint (Watchpoint *wp)
648f9765acdSGreg Clayton {
649f9765acdSGreg Clayton     Error error;
650f9765acdSGreg Clayton     error.SetErrorString ("watchpoints are not suppported in kdp remote debugging");
651f9765acdSGreg Clayton     return error;
652f9765acdSGreg Clayton }
653f9765acdSGreg Clayton 
654f9765acdSGreg Clayton void
655f9765acdSGreg Clayton ProcessKDP::Clear()
656f9765acdSGreg Clayton {
657f9765acdSGreg Clayton     m_thread_list.Clear();
658f9765acdSGreg Clayton }
659f9765acdSGreg Clayton 
660f9765acdSGreg Clayton Error
661f9765acdSGreg Clayton ProcessKDP::DoSignal (int signo)
662f9765acdSGreg Clayton {
663f9765acdSGreg Clayton     Error error;
664f9765acdSGreg Clayton     error.SetErrorString ("sending signals is not suppported in kdp remote debugging");
665f9765acdSGreg Clayton     return error;
666f9765acdSGreg Clayton }
667f9765acdSGreg Clayton 
668f9765acdSGreg Clayton void
669f9765acdSGreg Clayton ProcessKDP::Initialize()
670f9765acdSGreg Clayton {
671f9765acdSGreg Clayton     static bool g_initialized = false;
672f9765acdSGreg Clayton 
673f9765acdSGreg Clayton     if (g_initialized == false)
674f9765acdSGreg Clayton     {
675f9765acdSGreg Clayton         g_initialized = true;
676f9765acdSGreg Clayton         PluginManager::RegisterPlugin (GetPluginNameStatic(),
677f9765acdSGreg Clayton                                        GetPluginDescriptionStatic(),
678f9765acdSGreg Clayton                                        CreateInstance);
679f9765acdSGreg Clayton 
680f9765acdSGreg Clayton         Log::Callbacks log_callbacks = {
681f9765acdSGreg Clayton             ProcessKDPLog::DisableLog,
682f9765acdSGreg Clayton             ProcessKDPLog::EnableLog,
683f9765acdSGreg Clayton             ProcessKDPLog::ListLogCategories
684f9765acdSGreg Clayton         };
685f9765acdSGreg Clayton 
686f9765acdSGreg Clayton         Log::RegisterLogChannel (ProcessKDP::GetPluginNameStatic(), log_callbacks);
687f9765acdSGreg Clayton     }
688f9765acdSGreg Clayton }
689f9765acdSGreg Clayton 
690f9765acdSGreg Clayton bool
691f9765acdSGreg Clayton ProcessKDP::StartAsyncThread ()
692f9765acdSGreg Clayton {
693f9765acdSGreg Clayton     LogSP log (ProcessKDPLog::GetLogIfAllCategoriesSet(KDP_LOG_PROCESS));
694f9765acdSGreg Clayton 
695f9765acdSGreg Clayton     if (log)
6967925fbbaSGreg Clayton         log->Printf ("ProcessKDP::StartAsyncThread ()");
697f9765acdSGreg Clayton 
6987925fbbaSGreg Clayton     if (IS_VALID_LLDB_HOST_THREAD(m_async_thread))
6997925fbbaSGreg Clayton         return true;
7007925fbbaSGreg Clayton 
701f9765acdSGreg Clayton     m_async_thread = Host::ThreadCreate ("<lldb.process.kdp-remote.async>", ProcessKDP::AsyncThread, this, NULL);
702f9765acdSGreg Clayton     return IS_VALID_LLDB_HOST_THREAD(m_async_thread);
703f9765acdSGreg Clayton }
704f9765acdSGreg Clayton 
705f9765acdSGreg Clayton void
706f9765acdSGreg Clayton ProcessKDP::StopAsyncThread ()
707f9765acdSGreg Clayton {
708f9765acdSGreg Clayton     LogSP log (ProcessKDPLog::GetLogIfAllCategoriesSet(KDP_LOG_PROCESS));
709f9765acdSGreg Clayton 
710f9765acdSGreg Clayton     if (log)
7117925fbbaSGreg Clayton         log->Printf ("ProcessKDP::StopAsyncThread ()");
712f9765acdSGreg Clayton 
713f9765acdSGreg Clayton     m_async_broadcaster.BroadcastEvent (eBroadcastBitAsyncThreadShouldExit);
714f9765acdSGreg Clayton 
715f9765acdSGreg Clayton     // Stop the stdio thread
716f9765acdSGreg Clayton     if (IS_VALID_LLDB_HOST_THREAD(m_async_thread))
717f9765acdSGreg Clayton     {
718f9765acdSGreg Clayton         Host::ThreadJoin (m_async_thread, NULL, NULL);
7197925fbbaSGreg Clayton         m_async_thread = LLDB_INVALID_HOST_THREAD;
720f9765acdSGreg Clayton     }
721f9765acdSGreg Clayton }
722f9765acdSGreg Clayton 
723f9765acdSGreg Clayton 
724f9765acdSGreg Clayton void *
725f9765acdSGreg Clayton ProcessKDP::AsyncThread (void *arg)
726f9765acdSGreg Clayton {
727f9765acdSGreg Clayton     ProcessKDP *process = (ProcessKDP*) arg;
728f9765acdSGreg Clayton 
7297925fbbaSGreg Clayton     const lldb::pid_t pid = process->GetID();
7307925fbbaSGreg Clayton 
731f9765acdSGreg Clayton     LogSP log (ProcessKDPLog::GetLogIfAllCategoriesSet (KDP_LOG_PROCESS));
732f9765acdSGreg Clayton     if (log)
7337925fbbaSGreg Clayton         log->Printf ("ProcessKDP::AsyncThread (arg = %p, pid = %llu) thread starting...", arg, pid);
734f9765acdSGreg Clayton 
735f9765acdSGreg Clayton     Listener listener ("ProcessKDP::AsyncThread");
736f9765acdSGreg Clayton     EventSP event_sp;
737f9765acdSGreg Clayton     const uint32_t desired_event_mask = eBroadcastBitAsyncContinue |
738f9765acdSGreg Clayton                                         eBroadcastBitAsyncThreadShouldExit;
739f9765acdSGreg Clayton 
7407925fbbaSGreg Clayton 
741f9765acdSGreg Clayton     if (listener.StartListeningForEvents (&process->m_async_broadcaster, desired_event_mask) == desired_event_mask)
742f9765acdSGreg Clayton     {
743f9765acdSGreg Clayton         bool done = false;
744f9765acdSGreg Clayton         while (!done)
745f9765acdSGreg Clayton         {
746f9765acdSGreg Clayton             if (log)
7477925fbbaSGreg Clayton                 log->Printf ("ProcessKDP::AsyncThread (pid = %llu) listener.WaitForEvent (NULL, event_sp)...",
7487925fbbaSGreg Clayton                              pid);
749f9765acdSGreg Clayton             if (listener.WaitForEvent (NULL, event_sp))
750f9765acdSGreg Clayton             {
7517925fbbaSGreg Clayton                 uint32_t event_type = event_sp->GetType();
752f9765acdSGreg Clayton                 if (log)
7537925fbbaSGreg Clayton                     log->Printf ("ProcessKDP::AsyncThread (pid = %llu) Got an event of type: %d...",
7547925fbbaSGreg Clayton                                  pid,
7557925fbbaSGreg Clayton                                  event_type);
756f9765acdSGreg Clayton 
7577925fbbaSGreg Clayton                 // When we are running, poll for 1 second to try and get an exception
7587925fbbaSGreg Clayton                 // to indicate the process has stopped. If we don't get one, check to
7597925fbbaSGreg Clayton                 // make sure no one asked us to exit
7607925fbbaSGreg Clayton                 bool is_running = false;
7617925fbbaSGreg Clayton                 DataExtractor exc_reply_packet;
7627925fbbaSGreg Clayton                 do
7637925fbbaSGreg Clayton                 {
764f9765acdSGreg Clayton                     switch (event_type)
765f9765acdSGreg Clayton                     {
766f9765acdSGreg Clayton                     case eBroadcastBitAsyncContinue:
767f9765acdSGreg Clayton                         {
7687925fbbaSGreg Clayton                             is_running = true;
7697925fbbaSGreg Clayton                             if (process->m_comm.WaitForPacketWithTimeoutMicroSeconds (exc_reply_packet, 1 * USEC_PER_SEC))
770f9765acdSGreg Clayton                             {
77197d5cf05SGreg Clayton                                 ThreadSP thread_sp (process->GetKernelThread(process->GetThreadList(), process->GetThreadList()));
77297d5cf05SGreg Clayton                                 thread_sp->GetRegisterContext()->InvalidateAllRegisters();
77397d5cf05SGreg Clayton                                 static_cast<ThreadKDP *>(thread_sp.get())->SetStopInfoFrom_KDP_EXCEPTION (exc_reply_packet);
77497d5cf05SGreg Clayton 
7757925fbbaSGreg Clayton                                 // TODO: parse the stop reply packet
7767925fbbaSGreg Clayton                                 is_running = false;
7777925fbbaSGreg Clayton                                 process->SetPrivateState(eStateStopped);
7787925fbbaSGreg Clayton                             }
7797925fbbaSGreg Clayton                             else
7807925fbbaSGreg Clayton                             {
7817925fbbaSGreg Clayton                                 // Check to see if we are supposed to exit. There is no way to
7827925fbbaSGreg Clayton                                 // interrupt a running kernel, so all we can do is wait for an
7837925fbbaSGreg Clayton                                 // exception or detach...
7847925fbbaSGreg Clayton                                 if (listener.GetNextEvent(event_sp))
7857925fbbaSGreg Clayton                                 {
7867925fbbaSGreg Clayton                                     // We got an event, go through the loop again
7877925fbbaSGreg Clayton                                     event_type = event_sp->GetType();
7887925fbbaSGreg Clayton                                 }
789f9765acdSGreg Clayton                             }
790f9765acdSGreg Clayton                         }
791f9765acdSGreg Clayton                         break;
792f9765acdSGreg Clayton 
793f9765acdSGreg Clayton                     case eBroadcastBitAsyncThreadShouldExit:
794f9765acdSGreg Clayton                         if (log)
7957925fbbaSGreg Clayton                             log->Printf ("ProcessKDP::AsyncThread (pid = %llu) got eBroadcastBitAsyncThreadShouldExit...",
7967925fbbaSGreg Clayton                                          pid);
797f9765acdSGreg Clayton                         done = true;
7987925fbbaSGreg Clayton                         is_running = false;
799f9765acdSGreg Clayton                         break;
800f9765acdSGreg Clayton 
801f9765acdSGreg Clayton                     default:
802f9765acdSGreg Clayton                         if (log)
8037925fbbaSGreg Clayton                             log->Printf ("ProcessKDP::AsyncThread (pid = %llu) got unknown event 0x%8.8x",
8047925fbbaSGreg Clayton                                          pid,
8057925fbbaSGreg Clayton                                          event_type);
806f9765acdSGreg Clayton                         done = true;
8077925fbbaSGreg Clayton                         is_running = false;
808f9765acdSGreg Clayton                         break;
809f9765acdSGreg Clayton                     }
8107925fbbaSGreg Clayton                 } while (is_running);
811f9765acdSGreg Clayton             }
812f9765acdSGreg Clayton             else
813f9765acdSGreg Clayton             {
814f9765acdSGreg Clayton                 if (log)
8157925fbbaSGreg Clayton                     log->Printf ("ProcessKDP::AsyncThread (pid = %llu) listener.WaitForEvent (NULL, event_sp) => false",
8167925fbbaSGreg Clayton                                  pid);
817f9765acdSGreg Clayton                 done = true;
818f9765acdSGreg Clayton             }
819f9765acdSGreg Clayton         }
820f9765acdSGreg Clayton     }
821f9765acdSGreg Clayton 
822f9765acdSGreg Clayton     if (log)
8237925fbbaSGreg Clayton         log->Printf ("ProcessKDP::AsyncThread (arg = %p, pid = %llu) thread exiting...",
8247925fbbaSGreg Clayton                      arg,
8257925fbbaSGreg Clayton                      pid);
826f9765acdSGreg Clayton 
827f9765acdSGreg Clayton     process->m_async_thread = LLDB_INVALID_HOST_THREAD;
828f9765acdSGreg Clayton     return NULL;
829f9765acdSGreg Clayton }
830f9765acdSGreg Clayton 
831f9765acdSGreg Clayton 
832