diff options
Diffstat (limited to 'source/Plugins/Platform/gdb-server/PlatformRemoteGDBServer.cpp')
| -rw-r--r-- | source/Plugins/Platform/gdb-server/PlatformRemoteGDBServer.cpp | 44 | 
1 files changed, 39 insertions, 5 deletions
| diff --git a/source/Plugins/Platform/gdb-server/PlatformRemoteGDBServer.cpp b/source/Plugins/Platform/gdb-server/PlatformRemoteGDBServer.cpp index 248abaf6fea77..ce5645ea74fe3 100644 --- a/source/Plugins/Platform/gdb-server/PlatformRemoteGDBServer.cpp +++ b/source/Plugins/Platform/gdb-server/PlatformRemoteGDBServer.cpp @@ -119,9 +119,9 @@ PlatformRemoteGDBServer::ResolveExecutable (const FileSpec &exe_file,  }  Error -PlatformRemoteGDBServer::GetFile (const FileSpec &platform_file,  -                                  const UUID *uuid_ptr, -                                  FileSpec &local_file) +PlatformRemoteGDBServer::GetFileWithUUID (const FileSpec &platform_file,  +                                          const UUID *uuid_ptr, +                                          FileSpec &local_file)  {      // Default to the local case      local_file = platform_file; @@ -418,7 +418,21 @@ PlatformRemoteGDBServer::DebugProcess (lldb_private::ProcessLaunchInfo &launch_i          if (IsConnected())          {              lldb::pid_t debugserver_pid = LLDB_INVALID_PROCESS_ID; -            uint16_t port = m_gdb_client.LaunchGDBserverAndGetPort(debugserver_pid); +            ArchSpec remote_arch = GetRemoteSystemArchitecture(); +            llvm::Triple &remote_triple = remote_arch.GetTriple(); +            uint16_t port = 0; +            if (remote_triple.getVendor() == llvm::Triple::Apple && remote_triple.getOS() == llvm::Triple::IOS) +            { +                // When remote debugging to iOS, we use a USB mux that always talks +                // to localhost, so we will need the remote debugserver to accept connections +                // only from localhost, no matter what our current hostname is +                port = m_gdb_client.LaunchGDBserverAndGetPort(debugserver_pid, "localhost"); +            } +            else +            { +                // All other hosts should use their actual hostname +                port = m_gdb_client.LaunchGDBserverAndGetPort(debugserver_pid, NULL); +            }              if (port == 0)              { @@ -492,7 +506,21 @@ PlatformRemoteGDBServer::Attach (lldb_private::ProcessAttachInfo &attach_info,          if (IsConnected())          {              lldb::pid_t debugserver_pid = LLDB_INVALID_PROCESS_ID; -            uint16_t port = m_gdb_client.LaunchGDBserverAndGetPort(debugserver_pid); +            ArchSpec remote_arch = GetRemoteSystemArchitecture(); +            llvm::Triple &remote_triple = remote_arch.GetTriple(); +            uint16_t port = 0; +            if (remote_triple.getVendor() == llvm::Triple::Apple && remote_triple.getOS() == llvm::Triple::IOS) +            { +                // When remote debugging to iOS, we use a USB mux that always talks +                // to localhost, so we will need the remote debugserver to accept connections +                // only from localhost, no matter what our current hostname is +                port = m_gdb_client.LaunchGDBserverAndGetPort(debugserver_pid, "localhost"); +            } +            else +            { +                // All other hosts should use their actual hostname +                port = m_gdb_client.LaunchGDBserverAndGetPort(debugserver_pid, NULL); +            }              if (port == 0)              { @@ -673,3 +701,9 @@ PlatformRemoteGDBServer::RunShellCommand (const char *command,           // Shou  {      return m_gdb_client.RunShellCommand (command, working_dir, status_ptr, signo_ptr, command_output, timeout_sec);  } + +void +PlatformRemoteGDBServer::CalculateTrapHandlerSymbolNames () +{    +    m_trap_handlers.push_back (ConstString ("_sigtramp")); +}    | 
