Author: amccarth Date: Fri Nov 20 12:18:21 2015 New Revision: 253685 URL: http://llvm.org/viewvc/llvm-project?rev=253685&view=rev Log: Revert "FOO"
Accidentally commited before I was done. This reverts commit 2ec2da4ee52780582d5e9c88b2e982a688fbdbe1. Removed: lldb/trunk/packages/Python/lldbsuite/test/functionalities/process_save_core/Makefile lldb/trunk/packages/Python/lldbsuite/test/functionalities/process_save_core/TestProcessSaveCore.py lldb/trunk/packages/Python/lldbsuite/test/functionalities/process_save_core/main.cpp lldb/trunk/source/Plugins/ObjectFile/PECOFF/WindowsMiniDump.cpp lldb/trunk/source/Plugins/ObjectFile/PECOFF/WindowsMiniDump.h Modified: lldb/trunk/include/lldb/API/SBProcess.h lldb/trunk/include/lldb/API/SBTarget.h lldb/trunk/scripts/interface/SBProcess.i lldb/trunk/source/API/SBProcess.cpp lldb/trunk/source/Commands/CommandObjectTarget.cpp lldb/trunk/source/Plugins/ObjectFile/PECOFF/CMakeLists.txt lldb/trunk/source/Plugins/ObjectFile/PECOFF/ObjectFilePECOFF.cpp lldb/trunk/source/Plugins/ObjectFile/PECOFF/ObjectFilePECOFF.h Modified: lldb/trunk/include/lldb/API/SBProcess.h URL: http://llvm.org/viewvc/llvm-project/lldb/trunk/include/lldb/API/SBProcess.h?rev=253685&r1=253684&r2=253685&view=diff ============================================================================== --- lldb/trunk/include/lldb/API/SBProcess.h (original) +++ lldb/trunk/include/lldb/API/SBProcess.h Fri Nov 20 12:18:21 2015 @@ -341,10 +341,6 @@ public: bool IsInstrumentationRuntimePresent(InstrumentationRuntimeType type); - // Save the state of the process in a core file (or mini dump on Windows). - lldb::SBError - SaveCore(const char *file_name); - protected: friend class SBAddress; friend class SBBreakpoint; Modified: lldb/trunk/include/lldb/API/SBTarget.h URL: http://llvm.org/viewvc/llvm-project/lldb/trunk/include/lldb/API/SBTarget.h?rev=253685&r1=253684&r2=253685&view=diff ============================================================================== --- lldb/trunk/include/lldb/API/SBTarget.h (original) +++ lldb/trunk/include/lldb/API/SBTarget.h Fri Nov 20 12:18:21 2015 @@ -180,9 +180,6 @@ public: bool stop_at_entry, lldb::SBError& error); - SBProcess - LoadCore (const char *core_file); - //------------------------------------------------------------------ /// Launch a new process with sensible defaults. /// @@ -218,6 +215,9 @@ public: Launch (SBLaunchInfo &launch_info, SBError& error); SBProcess + LoadCore (const char *core_file); + + SBProcess Attach (SBAttachInfo &attach_info, SBError& error); //------------------------------------------------------------------ Removed: lldb/trunk/packages/Python/lldbsuite/test/functionalities/process_save_core/Makefile URL: http://llvm.org/viewvc/llvm-project/lldb/trunk/packages/Python/lldbsuite/test/functionalities/process_save_core/Makefile?rev=253684&view=auto ============================================================================== --- lldb/trunk/packages/Python/lldbsuite/test/functionalities/process_save_core/Makefile (original) +++ lldb/trunk/packages/Python/lldbsuite/test/functionalities/process_save_core/Makefile (removed) @@ -1,6 +0,0 @@ -LEVEL = ../../make - -CXX_SOURCES := main.cpp - -include $(LEVEL)/Makefile.rules - Removed: lldb/trunk/packages/Python/lldbsuite/test/functionalities/process_save_core/TestProcessSaveCore.py URL: http://llvm.org/viewvc/llvm-project/lldb/trunk/packages/Python/lldbsuite/test/functionalities/process_save_core/TestProcessSaveCore.py?rev=253684&view=auto ============================================================================== --- lldb/trunk/packages/Python/lldbsuite/test/functionalities/process_save_core/TestProcessSaveCore.py (original) +++ lldb/trunk/packages/Python/lldbsuite/test/functionalities/process_save_core/TestProcessSaveCore.py (removed) @@ -1,58 +0,0 @@ -""" -Test saving a core file (or mini dump). -""" - -from __future__ import print_function - -import os, time -import lldb -from lldbsuite.test.lldbtest import * - -class ProcessSaveCoreTestCase(TestBase): - - mydir = TestBase.compute_mydir(__file__) - - @not_remote_testsuite_ready - @skipIf(oslist=not_in(['windows'])) - def test_cannot_save_core_unless_process_stopped(self): - """Test that SaveCore fails if the process isn't stopped.""" - self.build() - exe = os.path.join(os.getcwd(), "a.out") - core = os.path.join(os.getcwd(), "core.dmp") - target = self.dbg.CreateTarget(exe) - process = target.LaunchSimple(None, None, self.get_process_working_directory()) - self.assertNotEqual(process.GetState(), lldb.eStateStopped) - error = process.SaveCore(core) - self.assertTrue(error.Fail()) - - @not_remote_testsuite_ready - @skipIf(oslist=not_in(['windows'])) - def test_save_windows_mini_dump(self): - """Test that we can save a Windows mini dump.""" - self.build() - exe = os.path.join(os.getcwd(), "a.out") - core = os.path.join(os.getcwd(), "core.dmp") - try: - target = self.dbg.CreateTarget(exe) - breakpoint = target.BreakpointCreateByName("bar") - process = target.LaunchSimple(None, None, self.get_process_working_directory()) - self.assertEqual(process.GetState(), lldb.eStateStopped) - self.assertTrue(process.SaveCore(core)) - self.assertTrue(os.path.isfile(core)) - self.assertTrue(process.Kill().Success()) - - # To verify, we'll launch with the mini dump, and ensure that we see - # the executable in the module list. - target = self.dbg.CreateTarget(None) - process = target.LoadCore(core) - files = [target.GetModuleAtIndex(i).GetFileSpec() for i in range(0, target.GetNumModules())] - paths = [os.path.join(f.GetDirectory(), f.GetFilename()) for f in files] - self.assertTrue(exe in paths) - - finally: - # Clean up the mini dump file. - self.assertTrue(self.dbg.DeleteTarget(target)) - if (os.path.isfile(core)): - os.unlink(core) - - Removed: lldb/trunk/packages/Python/lldbsuite/test/functionalities/process_save_core/main.cpp URL: http://llvm.org/viewvc/llvm-project/lldb/trunk/packages/Python/lldbsuite/test/functionalities/process_save_core/main.cpp?rev=253684&view=auto ============================================================================== --- lldb/trunk/packages/Python/lldbsuite/test/functionalities/process_save_core/main.cpp (original) +++ lldb/trunk/packages/Python/lldbsuite/test/functionalities/process_save_core/main.cpp (removed) @@ -1,21 +0,0 @@ -int global = 42; - -int -bar(int x) -{ - int y = 4*x + global; - return y; -} - -int -foo(int x) -{ - int y = 2*bar(3*x); - return y; -} - -int -main() -{ - return 0 * foo(1); -} Modified: lldb/trunk/scripts/interface/SBProcess.i URL: http://llvm.org/viewvc/llvm-project/lldb/trunk/scripts/interface/SBProcess.i?rev=253685&r1=253684&r2=253685&view=diff ============================================================================== --- lldb/trunk/scripts/interface/SBProcess.i (original) +++ lldb/trunk/scripts/interface/SBProcess.i Fri Nov 20 12:18:21 2015 @@ -398,9 +398,6 @@ public: bool IsInstrumentationRuntimePresent(lldb::InstrumentationRuntimeType type); - lldb::SBError - SaveCore(const char *file_name); - %pythoncode %{ def __get_is_alive__(self): '''Returns "True" if the process is currently alive, "False" otherwise''' Modified: lldb/trunk/source/API/SBProcess.cpp URL: http://llvm.org/viewvc/llvm-project/lldb/trunk/source/API/SBProcess.cpp?rev=253685&r1=253684&r2=253685&view=diff ============================================================================== --- lldb/trunk/source/API/SBProcess.cpp (original) +++ lldb/trunk/source/API/SBProcess.cpp Fri Nov 20 12:18:21 2015 @@ -19,7 +19,6 @@ #include "lldb/Core/Debugger.h" #include "lldb/Core/Log.h" #include "lldb/Core/Module.h" -#include "lldb/Core/PluginManager.h" #include "lldb/Core/State.h" #include "lldb/Core/Stream.h" #include "lldb/Core/StreamFile.h" @@ -1426,27 +1425,3 @@ SBProcess::IsInstrumentationRuntimePrese return runtime_sp->IsActive(); } - -lldb::SBError -SBProcess::SaveCore(const char *file_name) -{ - lldb::SBError error; - ProcessSP process_sp(GetSP()); - if (!process_sp) - { - error.SetErrorString("SBProcess is invalid"); - return error; - } - - Mutex::Locker api_locker(process_sp->GetTarget().GetAPIMutex()); - - if (process_sp->GetState() != eStateStopped) - { - error.SetErrorString("the process is not stopped"); - return error; - } - - FileSpec core_file(file_name, false); - error.ref() = PluginManager::SaveCore(process_sp, core_file); - return error; -} Modified: lldb/trunk/source/Commands/CommandObjectTarget.cpp URL: http://llvm.org/viewvc/llvm-project/lldb/trunk/source/Commands/CommandObjectTarget.cpp?rev=253685&r1=253684&r2=253685&view=diff ============================================================================== --- lldb/trunk/source/Commands/CommandObjectTarget.cpp (original) +++ lldb/trunk/source/Commands/CommandObjectTarget.cpp Fri Nov 20 12:18:21 2015 @@ -256,7 +256,7 @@ protected: { if (!symfile.Readable()) { - result.AppendErrorWithFormat("symbol file '%s' is not readable", symfile.GetPath().c_str()); + result.AppendErrorWithFormat("symbol file '%s' is not readable", core_file.GetPath().c_str()); result.SetStatus (eReturnStatusFailed); return false; } Modified: lldb/trunk/source/Plugins/ObjectFile/PECOFF/CMakeLists.txt URL: http://llvm.org/viewvc/llvm-project/lldb/trunk/source/Plugins/ObjectFile/PECOFF/CMakeLists.txt?rev=253685&r1=253684&r2=253685&view=diff ============================================================================== --- lldb/trunk/source/Plugins/ObjectFile/PECOFF/CMakeLists.txt (original) +++ lldb/trunk/source/Plugins/ObjectFile/PECOFF/CMakeLists.txt Fri Nov 20 12:18:21 2015 @@ -1,4 +1,3 @@ add_lldb_library(lldbPluginObjectFilePECOFF ObjectFilePECOFF.cpp - WindowsMiniDump.cpp ) Modified: lldb/trunk/source/Plugins/ObjectFile/PECOFF/ObjectFilePECOFF.cpp URL: http://llvm.org/viewvc/llvm-project/lldb/trunk/source/Plugins/ObjectFile/PECOFF/ObjectFilePECOFF.cpp?rev=253685&r1=253684&r2=253685&view=diff ============================================================================== --- lldb/trunk/source/Plugins/ObjectFile/PECOFF/ObjectFilePECOFF.cpp (original) +++ lldb/trunk/source/Plugins/ObjectFile/PECOFF/ObjectFilePECOFF.cpp Fri Nov 20 12:18:21 2015 @@ -8,7 +8,6 @@ //===----------------------------------------------------------------------===// #include "ObjectFilePECOFF.h" -#include "WindowsMiniDump.h" #include "llvm/Support/COFF.h" @@ -25,7 +24,6 @@ #include "lldb/Core/Timer.h" #include "lldb/Core/UUID.h" #include "lldb/Symbol/ObjectFile.h" -#include "lldb/Target/Process.h" #include "lldb/Target/SectionLoadList.h" #include "lldb/Target/Target.h" @@ -44,8 +42,7 @@ ObjectFilePECOFF::Initialize() GetPluginDescriptionStatic(), CreateInstance, CreateMemoryInstance, - GetModuleSpecifications, - SaveCore); + GetModuleSpecifications); } void @@ -151,14 +148,6 @@ ObjectFilePECOFF::GetModuleSpecification return specs.GetSize() - initial_count; } -bool -ObjectFilePECOFF::SaveCore(const lldb::ProcessSP &process_sp, - const lldb_private::FileSpec &outfile, - lldb_private::Error &error) -{ - return SaveMiniDump(process_sp, outfile, error); -} - bool ObjectFilePECOFF::MagicBytesMatch (DataBufferSP& data_sp) Modified: lldb/trunk/source/Plugins/ObjectFile/PECOFF/ObjectFilePECOFF.h URL: http://llvm.org/viewvc/llvm-project/lldb/trunk/source/Plugins/ObjectFile/PECOFF/ObjectFilePECOFF.h?rev=253685&r1=253684&r2=253685&view=diff ============================================================================== --- lldb/trunk/source/Plugins/ObjectFile/PECOFF/ObjectFilePECOFF.h (original) +++ lldb/trunk/source/Plugins/ObjectFile/PECOFF/ObjectFilePECOFF.h Fri Nov 20 12:18:21 2015 @@ -95,11 +95,6 @@ public: lldb_private::ModuleSpecList &specs); static bool - SaveCore (const lldb::ProcessSP &process_sp, - const lldb_private::FileSpec &outfile, - lldb_private::Error &error); - - static bool MagicBytesMatch (lldb::DataBufferSP& data_sp); bool Removed: lldb/trunk/source/Plugins/ObjectFile/PECOFF/WindowsMiniDump.cpp URL: http://llvm.org/viewvc/llvm-project/lldb/trunk/source/Plugins/ObjectFile/PECOFF/WindowsMiniDump.cpp?rev=253684&view=auto ============================================================================== --- lldb/trunk/source/Plugins/ObjectFile/PECOFF/WindowsMiniDump.cpp (original) +++ lldb/trunk/source/Plugins/ObjectFile/PECOFF/WindowsMiniDump.cpp (removed) @@ -1,55 +0,0 @@ -//===-- WindowsMiniDump.cpp -------------------------------------*- C++ -*-===// -// -// The LLVM Compiler Infrastructure -// -// This file is distributed under the University of Illinois Open Source -// License. See LICENSE.TXT for details. -// -//===----------------------------------------------------------------------===// - -// This function is separated out from ObjectFilePECOFF.cpp to name avoid name -// collisions with WinAPI preprocessor macros. - -#include "WindowsMiniDump.h" -#include "lldb/Host/FileSpec.h" -#include "llvm/Support/ConvertUTF.h" - -#ifdef _WIN32 -#include "lldb/Host/windows/windows.h" -#include <DbgHelp.h> // for MiniDumpWriteDump -#endif - -namespace lldb_private { - -bool -SaveMiniDump(const lldb::ProcessSP &process_sp, - const lldb_private::FileSpec &outfile, - lldb_private::Error &error) -{ - if (!process_sp) return false; -#ifdef _WIN32 - HANDLE process_handle = ::OpenProcess(PROCESS_QUERY_INFORMATION | PROCESS_VM_READ, FALSE, process_sp->GetID()); - const std::string file_name = outfile.GetCString(); - std::wstring wide_name; - wide_name.resize(file_name.size() + 1); - char * result_ptr = reinterpret_cast<char *>(&wide_name[0]); - const UTF8 *error_ptr = nullptr; - if (!llvm::ConvertUTF8toWide(sizeof(wchar_t), file_name, result_ptr, error_ptr)) { - error.SetErrorString("cannot convert file name"); - return false; - } - HANDLE file_handle = ::CreateFileW(wide_name.c_str(), GENERIC_WRITE, FILE_SHARE_READ, NULL, CREATE_ALWAYS, FILE_ATTRIBUTE_NORMAL, NULL); - const auto result = ::MiniDumpWriteDump(process_handle, process_sp->GetID(), file_handle, MiniDumpNormal, NULL, NULL, NULL); - ::CloseHandle(file_handle); - ::CloseHandle(process_handle); - if (!result) - { - error.SetError(::GetLastError(), lldb::eErrorTypeWin32); - return false; - } - return true; -#endif - return false; -} - -} // namesapce lldb_private Removed: lldb/trunk/source/Plugins/ObjectFile/PECOFF/WindowsMiniDump.h URL: http://llvm.org/viewvc/llvm-project/lldb/trunk/source/Plugins/ObjectFile/PECOFF/WindowsMiniDump.h?rev=253684&view=auto ============================================================================== --- lldb/trunk/source/Plugins/ObjectFile/PECOFF/WindowsMiniDump.h (original) +++ lldb/trunk/source/Plugins/ObjectFile/PECOFF/WindowsMiniDump.h (removed) @@ -1,24 +0,0 @@ -//===-- WindowsMiniDump.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_WindowsMiniDump_h_ -#define liblldb_WindowsMiniDump_h_ - -#include "lldb/Target/Process.h" - -namespace lldb_private { - -bool -SaveMiniDump(const lldb::ProcessSP &process_sp, - const lldb_private::FileSpec &outfile, - lldb_private::Error &error); - -} // namespace lldb_private - -#endif _______________________________________________ lldb-commits mailing list lldb-commits@lists.llvm.org http://lists.llvm.org/cgi-bin/mailman/listinfo/lldb-commits