//===-- GDBRemoteCommunicationServerPlatform.h ------------------*- C++ -*-===// // // The LLVM Compiler Infrastructure // // This file is distributed under the University of Illinois Open Source // License. See LICENSE.TXT for details. // //===----------------------------------------------------------------------===// #ifndef liblldb_GDBRemoteCommunicationServerPlatform_h_ #define liblldb_GDBRemoteCommunicationServerPlatform_h_ // C Includes // C++ Includes #include #include // Other libraries and framework includes // Project includes #include "GDBRemoteCommunicationServerCommon.h" #include "lldb/Host/Socket.h" namespace lldb_private { namespace process_gdb_remote { class GDBRemoteCommunicationServerPlatform : public GDBRemoteCommunicationServerCommon { public: typedef std::map PortMap; GDBRemoteCommunicationServerPlatform(const Socket::SocketProtocol socket_protocol, const char* socket_scheme); ~GDBRemoteCommunicationServerPlatform() override; Error LaunchProcess () override; // Set both ports to zero to let the platform automatically bind to // a port chosen by the OS. void SetPortMap (PortMap &&port_map); //---------------------------------------------------------------------- // If we are using a port map where we can only use certain ports, // get the next available port. // // If we are using a port map and we are out of ports, return UINT16_MAX // // If we aren't using a port map, return 0 to indicate we should bind to // port 0 and then figure out which port we used. //---------------------------------------------------------------------- uint16_t GetNextAvailablePort (); bool AssociatePortWithProcess (uint16_t port, lldb::pid_t pid); bool FreePort (uint16_t port); bool FreePortForProcess (lldb::pid_t pid); void SetPortOffset (uint16_t port_offset); void SetInferiorArguments (const lldb_private::Args& args); Error LaunchGDBServer(const lldb_private::Args& args, std::string hostname, lldb::pid_t& pid, uint16_t& port, std::string& socket_name); void SetPendingGdbServer(lldb::pid_t pid, uint16_t port, const std::string& socket_name); protected: const Socket::SocketProtocol m_socket_protocol; const std::string m_socket_scheme; Mutex m_spawned_pids_mutex; std::set m_spawned_pids; lldb::PlatformSP m_platform_sp; PortMap m_port_map; uint16_t m_port_offset; struct { lldb::pid_t pid; uint16_t port; std::string socket_name; } m_pending_gdb_server; PacketResult Handle_qLaunchGDBServer (StringExtractorGDBRemote &packet); PacketResult Handle_qQueryGDBServer (StringExtractorGDBRemote &packet); PacketResult Handle_qKillSpawnedProcess (StringExtractorGDBRemote &packet); PacketResult Handle_qProcessInfo (StringExtractorGDBRemote &packet); PacketResult Handle_qGetWorkingDir (StringExtractorGDBRemote &packet); PacketResult Handle_QSetWorkingDir (StringExtractorGDBRemote &packet); PacketResult Handle_qC (StringExtractorGDBRemote &packet); PacketResult Handle_jSignalsInfo(StringExtractorGDBRemote &packet); private: bool KillSpawnedProcess (lldb::pid_t pid); bool DebugserverProcessReaped (lldb::pid_t pid); static bool ReapDebugserverProcess (void *callback_baton, lldb::pid_t pid, bool exited, int signal, int status); static const FileSpec& GetDomainSocketDir(); static FileSpec GetDomainSocketPath(const char* prefix); DISALLOW_COPY_AND_ASSIGN (GDBRemoteCommunicationServerPlatform); }; } // namespace process_gdb_remote } // namespace lldb_private #endif // liblldb_GDBRemoteCommunicationServerPlatform_h_