size_t Communication::Read(void *dst, size_t dst_len, const Timeout<std::micro> &timeout, ConnectionStatus &status, Status *error_ptr) { Log *log = GetLogIfAllCategoriesSet(LIBLLDB_LOG_COMMUNICATION); LLDB_LOG( log, "this = {0}, dst = {1}, dst_len = {2}, timeout = {3}, connection = {4}", this, dst, dst_len, timeout, m_connection_sp.get()); if (m_read_thread_enabled) { // We have a dedicated read thread that is getting data for us size_t cached_bytes = GetCachedBytes(dst, dst_len); if (cached_bytes > 0 || (timeout && timeout->count() == 0)) { status = eConnectionStatusSuccess; return cached_bytes; } if (!m_connection_sp) { if (error_ptr) error_ptr->SetErrorString("Invalid connection."); status = eConnectionStatusNoConnection; return 0; } ListenerSP listener_sp(Listener::MakeListener("Communication::Read")); listener_sp->StartListeningForEvents( this, eBroadcastBitReadThreadGotBytes | eBroadcastBitReadThreadDidExit); EventSP event_sp; while (listener_sp->GetEvent(event_sp, timeout)) { const uint32_t event_type = event_sp->GetType(); if (event_type & eBroadcastBitReadThreadGotBytes) { return GetCachedBytes(dst, dst_len); } if (event_type & eBroadcastBitReadThreadDidExit) { if (GetCloseOnEOF()) Disconnect(nullptr); break; } } return 0; } // We aren't using a read thread, just read the data synchronously in this // thread. return ReadFromConnection(dst, dst_len, timeout, status, error_ptr); }