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