diff options
| author | Todd Fiala <todd.fiala@gmail.com> | 2014-08-29 17:35:57 +0000 |
|---|---|---|
| committer | Todd Fiala <todd.fiala@gmail.com> | 2014-08-29 17:35:57 +0000 |
| commit | 4ceced3f597f71e3b28d9e4f208d2786fff1ff45 (patch) | |
| tree | 362e9f32a697d2b21c9f68c67e09646f00249e4c /lldb/source/Plugins/Process | |
| parent | b5796cb40e6f7a5e504d8da41d0f31d4539d7110 (diff) | |
| download | bcm5719-llvm-4ceced3f597f71e3b28d9e4f208d2786fff1ff45.tar.gz bcm5719-llvm-4ceced3f597f71e3b28d9e4f208d2786fff1ff45.zip | |
Consolidate UnixSignals setting/getting in Process.
See http://reviews.llvm.org/D5108 for details.
This change does the following:
* eliminates the Process::GetUnixSignals() virtual method and replaces with a fixed getter.
* replaces the Process UnixSignals storage with a shared pointer.
* adds a Process constructor variant that can be passed the UnixSignalsSP. When the constructor without the UnixSignalsSP is specified, the Host's default UnixSignals is used.
* adds a host-specific version of GetUnixSignals() that is used when we need the host's appropriate UnixSignals variant.
* replaces GetUnixSignals() overrides in PlatformElfCore, ProcessGDBRemote, ProcessFreeBSD and ProcessLinux with code that appropriately sets the Process::UnixSignals for the process.
This change also enables some future patches that will enable llgs to be used for local Linux debugging.
llvm-svn: 216748
Diffstat (limited to 'lldb/source/Plugins/Process')
10 files changed, 48 insertions, 80 deletions
diff --git a/lldb/source/Plugins/Process/FreeBSD/ProcessFreeBSD.cpp b/lldb/source/Plugins/Process/FreeBSD/ProcessFreeBSD.cpp index 9fb022dc916..4b488444de1 100644 --- a/lldb/source/Plugins/Process/FreeBSD/ProcessFreeBSD.cpp +++ b/lldb/source/Plugins/Process/FreeBSD/ProcessFreeBSD.cpp @@ -22,12 +22,23 @@ #include "ProcessFreeBSD.h" #include "ProcessPOSIXLog.h" #include "Plugins/Process/Utility/InferiorCallPOSIX.h" +#include "Plugins/Process/Utility/FreeBSDSignals.h" #include "ProcessMonitor.h" #include "FreeBSDThread.h" using namespace lldb; using namespace lldb_private; +namespace +{ + UnixSignalsSP& + GetFreeBSDSignals () + { + static UnixSignalsSP s_freebsd_signals_sp (new FreeBSDSignals ()); + return s_freebsd_signals_sp; + } +} + //------------------------------------------------------------------------------ // Static functions. @@ -113,7 +124,7 @@ ProcessFreeBSD::EnablePluginLogging(Stream *strm, Args &command) // Constructors and destructors. ProcessFreeBSD::ProcessFreeBSD(Target& target, Listener &listener) - : ProcessPOSIX(target, listener), + : ProcessPOSIX(target, listener, GetFreeBSDSignals ()), m_resume_signo(0) { } @@ -271,4 +282,3 @@ ProcessFreeBSD::SendMessage(const ProcessMessage &message) m_message_queue.push(message); } - diff --git a/lldb/source/Plugins/Process/FreeBSD/ProcessFreeBSD.h b/lldb/source/Plugins/Process/FreeBSD/ProcessFreeBSD.h index 9702a65b9af..d6ae3462c73 100644 --- a/lldb/source/Plugins/Process/FreeBSD/ProcessFreeBSD.h +++ b/lldb/source/Plugins/Process/FreeBSD/ProcessFreeBSD.h @@ -18,7 +18,6 @@ // Other libraries and framework includes #include "lldb/Target/Process.h" #include "lldb/Target/ThreadList.h" -#include "Plugins/Process/Utility/FreeBSDSignals.h" #include "ProcessMessage.h" #include "ProcessPOSIX.h" @@ -90,21 +89,9 @@ public: EnablePluginLogging(lldb_private::Stream *strm, lldb_private::Args &command); - //------------------------------------------------------------------ - // Plugin process overrides - //------------------------------------------------------------------ - virtual lldb_private::UnixSignals & - GetUnixSignals() - { - return m_freebsd_signals; - } - protected: friend class FreeBSDThread; - // FreeBSD-specific signal set. - FreeBSDSignals m_freebsd_signals; - typedef std::vector<lldb::tid_t> tid_collection; tid_collection m_suspend_tids; tid_collection m_run_tids; diff --git a/lldb/source/Plugins/Process/Linux/ProcessLinux.cpp b/lldb/source/Plugins/Process/Linux/ProcessLinux.cpp index dae14d1c44c..81151b682d4 100644 --- a/lldb/source/Plugins/Process/Linux/ProcessLinux.cpp +++ b/lldb/source/Plugins/Process/Linux/ProcessLinux.cpp @@ -22,12 +22,23 @@ #include "ProcessLinux.h" #include "ProcessPOSIXLog.h" #include "Plugins/Process/Utility/InferiorCallPOSIX.h" +#include "Plugins/Process/Utility/LinuxSignals.h" #include "ProcessMonitor.h" #include "LinuxThread.h" using namespace lldb; using namespace lldb_private; +namespace +{ + UnixSignalsSP& + GetStaticLinuxSignalsSP () + { + static UnixSignalsSP s_unix_signals_sp (new process_linux::LinuxSignals ()); + return s_unix_signals_sp; + } +} + //------------------------------------------------------------------------------ // Static functions. @@ -64,7 +75,7 @@ ProcessLinux::Initialize() // Constructors and destructors. ProcessLinux::ProcessLinux(Target& target, Listener &listener, FileSpec *core_file) - : ProcessPOSIX(target, listener), m_core_file(core_file), m_stopping_threads(false) + : ProcessPOSIX(target, listener, GetStaticLinuxSignalsSP ()), m_core_file(core_file), m_stopping_threads(false) { #if 0 // FIXME: Putting this code in the ctor and saving the byte order in a diff --git a/lldb/source/Plugins/Process/Linux/ProcessLinux.h b/lldb/source/Plugins/Process/Linux/ProcessLinux.h index da7eb437ba3..8618bcc1ef8 100644 --- a/lldb/source/Plugins/Process/Linux/ProcessLinux.h +++ b/lldb/source/Plugins/Process/Linux/ProcessLinux.h @@ -20,8 +20,6 @@ #include "ProcessMessage.h" #include "ProcessPOSIX.h" -#include "Plugins/Process/Utility/LinuxSignals.h" - class ProcessMonitor; class ProcessLinux : @@ -84,15 +82,6 @@ public: EnablePluginLogging(lldb_private::Stream *strm, lldb_private::Args &command); - //------------------------------------------------------------------ - // Plug-in process overrides - //------------------------------------------------------------------ - virtual lldb_private::UnixSignals & - GetUnixSignals () - { - return m_linux_signals; - } - virtual bool CanDebug(lldb_private::Target &target, bool plugin_specified_by_name); @@ -107,9 +96,6 @@ public: private: - /// Linux-specific signal set. - process_linux::LinuxSignals m_linux_signals; - lldb_private::FileSpec *m_core_file; // Flag to avoid recursion when stopping all threads. diff --git a/lldb/source/Plugins/Process/POSIX/ProcessPOSIX.cpp b/lldb/source/Plugins/Process/POSIX/ProcessPOSIX.cpp index 858d8ae608e..f340631c7d0 100644 --- a/lldb/source/Plugins/Process/POSIX/ProcessPOSIX.cpp +++ b/lldb/source/Plugins/Process/POSIX/ProcessPOSIX.cpp @@ -70,8 +70,8 @@ ProcessPOSIX::Initialize() //------------------------------------------------------------------------------ // Constructors and destructors. -ProcessPOSIX::ProcessPOSIX(Target& target, Listener &listener) - : Process(target, listener), +ProcessPOSIX::ProcessPOSIX(Target& target, Listener &listener, UnixSignalsSP &unix_signals_sp) + : Process(target, listener, unix_signals_sp), m_byte_order(lldb::endian::InlHostByteOrder()), m_monitor(NULL), m_module(NULL), @@ -878,12 +878,6 @@ ProcessPOSIX::PutSTDIN(const char *buf, size_t len, Error &error) return status; } -UnixSignals & -ProcessPOSIX::GetUnixSignals() -{ - return m_signals; -} - //------------------------------------------------------------------------------ // Utility functions. diff --git a/lldb/source/Plugins/Process/POSIX/ProcessPOSIX.h b/lldb/source/Plugins/Process/POSIX/ProcessPOSIX.h index a429b3c8264..033accf17f2 100644 --- a/lldb/source/Plugins/Process/POSIX/ProcessPOSIX.h +++ b/lldb/source/Plugins/Process/POSIX/ProcessPOSIX.h @@ -18,7 +18,6 @@ // Other libraries and framework includes #include "lldb/Target/Process.h" -#include "lldb/Target/UnixSignals.h" #include "ProcessMessage.h" class ProcessMonitor; @@ -33,7 +32,8 @@ public: // Constructors and destructors //------------------------------------------------------------------ ProcessPOSIX(lldb_private::Target& target, - lldb_private::Listener &listener); + lldb_private::Listener &listener, + lldb_private::UnixSignalsSP &unix_signals_sp); virtual ~ProcessPOSIX(); @@ -154,9 +154,6 @@ public: ProcessMonitor & GetMonitor() { assert(m_monitor); return *m_monitor; } - lldb_private::UnixSignals & - GetUnixSignals(); - const char *GetFilePath(const lldb_private::FileAction *file_action, const char *default_path); /// Stops all threads in the process. @@ -192,9 +189,6 @@ protected: /// Drive any exit events to completion. bool m_exit_now; - /// OS-specific signal set. - lldb_private::UnixSignals m_signals; - /// Returns true if the process has exited. bool HasExited(); diff --git a/lldb/source/Plugins/Process/elf-core/ProcessElfCore.cpp b/lldb/source/Plugins/Process/elf-core/ProcessElfCore.cpp index 087ee4965fa..566816783c7 100644 --- a/lldb/source/Plugins/Process/elf-core/ProcessElfCore.cpp +++ b/lldb/source/Plugins/Process/elf-core/ProcessElfCore.cpp @@ -20,12 +20,14 @@ #include "lldb/Core/Log.h" #include "lldb/Target/Target.h" #include "lldb/Target/DynamicLoader.h" +#include "lldb/Target/UnixSignals.h" #include "llvm/Support/ELF.h" #include "Plugins/ObjectFile/ELF/ObjectFileELF.h" #include "Plugins/DynamicLoader/POSIX-DYLD/DynamicLoaderPOSIXDYLD.h" #include "Plugins/Process/Utility/FreeBSDSignals.h" +#include "Plugins/Process/Utility/LinuxSignals.h" // Project includes #include "ProcessElfCore.h" @@ -108,7 +110,6 @@ ProcessElfCore::ProcessElfCore(Target& target, Listener &listener, m_core_file (core_file), m_dyld_plugin_name (), m_os(llvm::Triple::UnknownOS), - m_signals_sp (), m_thread_data_valid(false), m_thread_data(), m_core_aranges () @@ -236,8 +237,17 @@ ProcessElfCore::DoLoadCore () switch (m_os) { case llvm::Triple::FreeBSD: - m_signals_sp.reset(new FreeBSDSignals()); + { + static UnixSignalsSP s_freebsd_signals_sp(new FreeBSDSignals ()); + SetUnixSignals(s_freebsd_signals_sp); + break; + } + case llvm::Triple::Linux: + { + static UnixSignalsSP s_linux_signals_sp(new process_linux::LinuxSignals ()); + SetUnixSignals(s_linux_signals_sp); break; + } default: break; } @@ -356,7 +366,9 @@ ProcessElfCore::Clear() { m_thread_list.Clear(); m_os = llvm::Triple::UnknownOS; - m_signals_sp.reset(); + + static UnixSignalsSP s_default_unix_signals_sp(new UnixSignals()); + SetUnixSignals(s_default_unix_signals_sp); } void @@ -587,4 +599,3 @@ ProcessElfCore::GetAuxvData() lldb::DataBufferSP buffer(new lldb_private::DataBufferHeap(start, len)); return buffer; } - diff --git a/lldb/source/Plugins/Process/elf-core/ProcessElfCore.h b/lldb/source/Plugins/Process/elf-core/ProcessElfCore.h index 6b4a857349d..2fc2e4ee794 100644 --- a/lldb/source/Plugins/Process/elf-core/ProcessElfCore.h +++ b/lldb/source/Plugins/Process/elf-core/ProcessElfCore.h @@ -104,18 +104,6 @@ public: IsAlive (); //------------------------------------------------------------------ - // Process Signals - //------------------------------------------------------------------ - virtual lldb_private::UnixSignals & - GetUnixSignals() - { - if (m_signals_sp) - return *m_signals_sp; - else - return Process::GetUnixSignals(); - } - - //------------------------------------------------------------------ // Process Memory //------------------------------------------------------------------ virtual size_t @@ -155,7 +143,6 @@ private: DISALLOW_COPY_AND_ASSIGN (ProcessElfCore); llvm::Triple::OSType m_os; - std::shared_ptr<lldb_private::UnixSignals> m_signals_sp; // True if m_thread_contexts contains valid entries bool m_thread_data_valid; diff --git a/lldb/source/Plugins/Process/gdb-remote/ProcessGDBRemote.cpp b/lldb/source/Plugins/Process/gdb-remote/ProcessGDBRemote.cpp index b50f071e980..f35d954caa7 100644 --- a/lldb/source/Plugins/Process/gdb-remote/ProcessGDBRemote.cpp +++ b/lldb/source/Plugins/Process/gdb-remote/ProcessGDBRemote.cpp @@ -287,8 +287,7 @@ ProcessGDBRemote::ProcessGDBRemote(Target& target, Listener &listener) : m_waiting_for_attach (false), m_destroy_tried_resuming (false), m_command_sp (), - m_breakpoint_pc_offset (0), - m_unix_signals_sp (new UnixSignals ()) + m_breakpoint_pc_offset (0) { m_async_broadcaster.SetEventName (eBroadcastBitAsyncThreadShouldExit, "async thread should exit"); m_async_broadcaster.SetEventName (eBroadcastBitAsyncContinue, "async thread continue"); @@ -713,19 +712,19 @@ ProcessGDBRemote::DoConnectRemote (Stream *strm, const char *remote_url) switch (arch_spec.GetTriple ().getOS ()) { case llvm::Triple::Linux: - m_unix_signals_sp.reset (new process_linux::LinuxSignals ()); + SetUnixSignals (UnixSignalsSP (new process_linux::LinuxSignals ())); if (log) log->Printf ("ProcessGDBRemote::%s using Linux unix signals type for pid %" PRIu64, __FUNCTION__, GetID ()); break; case llvm::Triple::OpenBSD: case llvm::Triple::FreeBSD: case llvm::Triple::NetBSD: - m_unix_signals_sp.reset (new FreeBSDSignals ()); + SetUnixSignals (UnixSignalsSP (new FreeBSDSignals ())); if (log) log->Printf ("ProcessGDBRemote::%s using *BSD unix signals type for pid %" PRIu64, __FUNCTION__, GetID ()); break; default: - m_unix_signals_sp.reset (new UnixSignals ()); + SetUnixSignals (UnixSignalsSP (new UnixSignals ())); if (log) log->Printf ("ProcessGDBRemote::%s using generic unix signals type for pid %" PRIu64, __FUNCTION__, GetID ()); break; @@ -1086,13 +1085,6 @@ ProcessGDBRemote::DidLaunch () DidLaunchOrAttach (process_arch); } -UnixSignals& -ProcessGDBRemote::GetUnixSignals () -{ - assert (m_unix_signals_sp && "m_unix_signals_sp is null"); - return *m_unix_signals_sp; -} - Error ProcessGDBRemote::DoAttachToProcessWithID (lldb::pid_t attach_pid) { diff --git a/lldb/source/Plugins/Process/gdb-remote/ProcessGDBRemote.h b/lldb/source/Plugins/Process/gdb-remote/ProcessGDBRemote.h index 39395af2ee5..942b31c84dd 100644 --- a/lldb/source/Plugins/Process/gdb-remote/ProcessGDBRemote.h +++ b/lldb/source/Plugins/Process/gdb-remote/ProcessGDBRemote.h @@ -25,6 +25,7 @@ #include "lldb/Core/StringList.h" #include "lldb/Core/StructuredData.h" #include "lldb/Core/ThreadSafeValue.h" +#include "lldb/lldb-private-forward.h" #include "lldb/Target/Process.h" #include "lldb/Target/Thread.h" @@ -91,9 +92,6 @@ public: virtual void DidLaunch (); - lldb_private::UnixSignals& - GetUnixSignals () override; - virtual lldb_private::Error WillAttachToProcessWithID (lldb::pid_t pid); @@ -360,8 +358,6 @@ protected: bool m_destroy_tried_resuming; lldb::CommandObjectSP m_command_sp; int64_t m_breakpoint_pc_offset; - std::shared_ptr<lldb_private::UnixSignals> m_unix_signals_sp; - bool StartAsyncThread (); |

