mirror of
https://github.com/intel/llvm.git
synced 2026-01-17 14:48:27 +08:00
Removed the "image" command and moved it to "target modules". Added an alias for "image" to "target modules". Added some new target commands to be able to add and load modules to a target: (lldb) target modules add <path> (lldb) target modules load [--file <path>] [--slide <offset>] [<sect-name> <sect-load-addr> ...] So you can load individual sections without running a target: (lldb) target modules load --file /usr/lib/libSystem.B.dylib __TEXT 0x7fccc80000 __DATA 0x1234000000 Or you can rigidly slide an entire shared library: (lldb) target modules load --file /usr/lib/libSystem.B.dylib --slid 0x7fccc80000 This should improve bare board debugging when symbol files need to be slid around manually. llvm-svn: 130796
110 lines
3.3 KiB
C++
110 lines
3.3 KiB
C++
//===-- OptionGroupPlatform.cpp ---------------------------------*- C++ -*-===//
|
|
//
|
|
// The LLVM Compiler Infrastructure
|
|
//
|
|
// This file is distributed under the University of Illinois Open Source
|
|
// License. See LICENSE.TXT for details.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#include "lldb/Interpreter/OptionGroupPlatform.h"
|
|
|
|
// C Includes
|
|
// C++ Includes
|
|
// Other libraries and framework includes
|
|
// Project includes
|
|
#include "lldb/Interpreter/CommandInterpreter.h"
|
|
#include "lldb/Target/Platform.h"
|
|
|
|
using namespace lldb;
|
|
using namespace lldb_private;
|
|
|
|
PlatformSP
|
|
OptionGroupPlatform::CreatePlatformWithOptions (CommandInterpreter &interpreter, bool make_selected, Error& error)
|
|
{
|
|
PlatformSP platform_sp;
|
|
if (!m_platform_name.empty())
|
|
{
|
|
platform_sp = Platform::Create (m_platform_name.c_str(), error);
|
|
|
|
if (platform_sp)
|
|
{
|
|
interpreter.GetDebugger().GetPlatformList().Append (platform_sp, make_selected);
|
|
if (m_os_version_major != UINT32_MAX)
|
|
{
|
|
platform_sp->SetOSVersion (m_os_version_major,
|
|
m_os_version_minor,
|
|
m_os_version_update);
|
|
}
|
|
}
|
|
}
|
|
return platform_sp;
|
|
}
|
|
|
|
void
|
|
OptionGroupPlatform::OptionParsingStarting (CommandInterpreter &interpreter)
|
|
{
|
|
m_platform_name.clear();
|
|
m_os_version_major = UINT32_MAX;
|
|
m_os_version_minor = UINT32_MAX;
|
|
m_os_version_update = UINT32_MAX;
|
|
}
|
|
|
|
static OptionDefinition
|
|
g_option_table[] =
|
|
{
|
|
{ LLDB_OPT_SET_ALL, false, "platform" , 'p', required_argument, NULL, 0, eArgTypePlatform, "Specify name of the platform to use for this target, creating the platform if necessary."},
|
|
{ LLDB_OPT_SET_ALL, false, "sdk-version", 'v', required_argument, NULL, 0, eArgTypeNone, "Specify the initial SDK version to use prior to connecting." }
|
|
};
|
|
|
|
static const uint32_t k_option_table_size = sizeof(g_option_table)/sizeof (OptionDefinition);
|
|
|
|
const OptionDefinition*
|
|
OptionGroupPlatform::GetDefinitions ()
|
|
{
|
|
if (m_include_platform_option)
|
|
return g_option_table;
|
|
return g_option_table + 1;
|
|
}
|
|
|
|
uint32_t
|
|
OptionGroupPlatform::GetNumDefinitions ()
|
|
{
|
|
if (m_include_platform_option)
|
|
return k_option_table_size;
|
|
return k_option_table_size - 1;
|
|
}
|
|
|
|
|
|
Error
|
|
OptionGroupPlatform::SetOptionValue (CommandInterpreter &interpreter,
|
|
uint32_t option_idx,
|
|
const char *option_arg)
|
|
{
|
|
Error error;
|
|
if (!m_include_platform_option)
|
|
++option_idx;
|
|
|
|
char short_option = (char) g_option_table[option_idx].short_option;
|
|
|
|
switch (short_option)
|
|
{
|
|
case 'p':
|
|
m_platform_name.assign (option_arg);
|
|
break;
|
|
|
|
case 'v':
|
|
if (Args::StringToVersion (option_arg,
|
|
m_os_version_major,
|
|
m_os_version_minor,
|
|
m_os_version_update) == option_arg)
|
|
error.SetErrorStringWithFormat ("invalid version string '%s'", option_arg);
|
|
break;
|
|
|
|
default:
|
|
error.SetErrorStringWithFormat ("Unrecognized option '%c'.\n", short_option);
|
|
break;
|
|
}
|
|
return error;
|
|
}
|