mirror of
https://github.com/opnsense/src.git
synced 2026-02-28 04:10:49 -05:00
320 lines
9.5 KiB
C++
320 lines
9.5 KiB
C++
//===-- ExpressionVariable.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_ExpressionVariable_h_
|
|
#define liblldb_ExpressionVariable_h_
|
|
|
|
// C Includes
|
|
// C++ Includes
|
|
#include <memory>
|
|
#include <vector>
|
|
|
|
// Other libraries and framework includes
|
|
// Project includes
|
|
#include "lldb/lldb-public.h"
|
|
#include "lldb/Core/ConstString.h"
|
|
#include "lldb/Core/ValueObject.h"
|
|
|
|
namespace lldb_private
|
|
{
|
|
|
|
class ClangExpressionVariable;
|
|
|
|
class ExpressionVariable :
|
|
public std::enable_shared_from_this<ExpressionVariable>
|
|
{
|
|
public:
|
|
//----------------------------------------------------------------------
|
|
// See TypeSystem.h for how to add subclasses to this.
|
|
//----------------------------------------------------------------------
|
|
enum LLVMCastKind {
|
|
eKindClang,
|
|
eKindSwift,
|
|
eKindGo,
|
|
kNumKinds
|
|
};
|
|
|
|
LLVMCastKind getKind() const { return m_kind; }
|
|
|
|
ExpressionVariable(LLVMCastKind kind) :
|
|
m_flags(0),
|
|
m_kind(kind)
|
|
{
|
|
}
|
|
|
|
virtual ~ExpressionVariable();
|
|
|
|
size_t
|
|
GetByteSize ()
|
|
{
|
|
return m_frozen_sp->GetByteSize();
|
|
}
|
|
|
|
const ConstString &
|
|
GetName ()
|
|
{
|
|
return m_frozen_sp->GetName();
|
|
}
|
|
|
|
lldb::ValueObjectSP
|
|
GetValueObject()
|
|
{
|
|
return m_frozen_sp;
|
|
}
|
|
|
|
uint8_t *GetValueBytes();
|
|
|
|
void
|
|
ValueUpdated ()
|
|
{
|
|
m_frozen_sp->ValueUpdated ();
|
|
}
|
|
|
|
RegisterInfo *
|
|
GetRegisterInfo()
|
|
{
|
|
return m_frozen_sp->GetValue().GetRegisterInfo();
|
|
}
|
|
|
|
void
|
|
SetRegisterInfo (const RegisterInfo *reg_info)
|
|
{
|
|
return m_frozen_sp->GetValue().SetContext (Value::eContextTypeRegisterInfo, const_cast<RegisterInfo *>(reg_info));
|
|
}
|
|
|
|
CompilerType
|
|
GetCompilerType()
|
|
{
|
|
return m_frozen_sp->GetCompilerType();
|
|
}
|
|
|
|
void
|
|
SetCompilerType(const CompilerType &compiler_type)
|
|
{
|
|
m_frozen_sp->GetValue().SetCompilerType(compiler_type);
|
|
}
|
|
|
|
void
|
|
SetName (const ConstString &name)
|
|
{
|
|
m_frozen_sp->SetName (name);
|
|
}
|
|
|
|
// this function is used to copy the address-of m_live_sp into m_frozen_sp
|
|
// this is necessary because the results of certain cast and pointer-arithmetic
|
|
// operations (such as those described in bugzilla issues 11588 and 11618) generate
|
|
// frozen objects that do not have a valid address-of, which can be troublesome when
|
|
// using synthetic children providers. Transferring the address-of the live object
|
|
// solves these issues and provides the expected user-level behavior
|
|
void
|
|
TransferAddress (bool force = false)
|
|
{
|
|
if (m_live_sp.get() == nullptr)
|
|
return;
|
|
|
|
if (m_frozen_sp.get() == nullptr)
|
|
return;
|
|
|
|
if (force || (m_frozen_sp->GetLiveAddress() == LLDB_INVALID_ADDRESS))
|
|
m_frozen_sp->SetLiveAddress(m_live_sp->GetLiveAddress());
|
|
}
|
|
|
|
enum Flags
|
|
{
|
|
EVNone = 0,
|
|
EVIsLLDBAllocated = 1 << 0, ///< This variable is resident in a location specifically allocated for it by LLDB in the target process
|
|
EVIsProgramReference = 1 << 1, ///< This variable is a reference to a (possibly invalid) area managed by the target program
|
|
EVNeedsAllocation = 1 << 2, ///< Space for this variable has yet to be allocated in the target process
|
|
EVIsFreezeDried = 1 << 3, ///< This variable's authoritative version is in m_frozen_sp (for example, for statically-computed results)
|
|
EVNeedsFreezeDry = 1 << 4, ///< Copy from m_live_sp to m_frozen_sp during dematerialization
|
|
EVKeepInTarget = 1 << 5, ///< Keep the allocation after the expression is complete rather than freeze drying its contents and freeing it
|
|
EVTypeIsReference = 1 << 6, ///< The original type of this variable is a reference, so materialize the value rather than the location
|
|
EVUnknownType = 1 << 7, ///< This is a symbol of unknown type, and the type must be resolved after parsing is complete
|
|
EVBareRegister = 1 << 8 ///< This variable is a direct reference to $pc or some other entity.
|
|
};
|
|
|
|
typedef uint16_t FlagType;
|
|
|
|
FlagType m_flags; // takes elements of Flags
|
|
|
|
// these should be private
|
|
lldb::ValueObjectSP m_frozen_sp;
|
|
lldb::ValueObjectSP m_live_sp;
|
|
LLVMCastKind m_kind;
|
|
};
|
|
|
|
//----------------------------------------------------------------------
|
|
/// @class ExpressionVariableList ExpressionVariable.h "lldb/Expression/ExpressionVariable.h"
|
|
/// @brief A list of variable references.
|
|
///
|
|
/// This class stores variables internally, acting as the permanent store.
|
|
//----------------------------------------------------------------------
|
|
class ExpressionVariableList
|
|
{
|
|
public:
|
|
//----------------------------------------------------------------------
|
|
/// Implementation of methods in ExpressionVariableListBase
|
|
//----------------------------------------------------------------------
|
|
size_t
|
|
GetSize()
|
|
{
|
|
return m_variables.size();
|
|
}
|
|
|
|
lldb::ExpressionVariableSP
|
|
GetVariableAtIndex(size_t index)
|
|
{
|
|
lldb::ExpressionVariableSP var_sp;
|
|
if (index < m_variables.size())
|
|
var_sp = m_variables[index];
|
|
return var_sp;
|
|
}
|
|
|
|
size_t
|
|
AddVariable (const lldb::ExpressionVariableSP &var_sp)
|
|
{
|
|
m_variables.push_back(var_sp);
|
|
return m_variables.size() - 1;
|
|
}
|
|
|
|
lldb::ExpressionVariableSP
|
|
AddNewlyConstructedVariable (ExpressionVariable *var)
|
|
{
|
|
lldb::ExpressionVariableSP var_sp(var);
|
|
m_variables.push_back(var_sp);
|
|
return m_variables.back();
|
|
}
|
|
|
|
bool
|
|
ContainsVariable (const lldb::ExpressionVariableSP &var_sp)
|
|
{
|
|
const size_t size = m_variables.size();
|
|
for (size_t index = 0; index < size; ++index)
|
|
{
|
|
if (m_variables[index].get() == var_sp.get())
|
|
return true;
|
|
}
|
|
return false;
|
|
}
|
|
|
|
//----------------------------------------------------------------------
|
|
/// Finds a variable by name in the list.
|
|
///
|
|
/// @param[in] name
|
|
/// The name of the requested variable.
|
|
///
|
|
/// @return
|
|
/// The variable requested, or nullptr if that variable is not in the list.
|
|
//----------------------------------------------------------------------
|
|
lldb::ExpressionVariableSP
|
|
GetVariable (const ConstString &name)
|
|
{
|
|
lldb::ExpressionVariableSP var_sp;
|
|
for (size_t index = 0, size = GetSize(); index < size; ++index)
|
|
{
|
|
var_sp = GetVariableAtIndex(index);
|
|
if (var_sp->GetName() == name)
|
|
return var_sp;
|
|
}
|
|
var_sp.reset();
|
|
return var_sp;
|
|
}
|
|
|
|
lldb::ExpressionVariableSP
|
|
GetVariable (const char *name)
|
|
{
|
|
lldb::ExpressionVariableSP var_sp;
|
|
if (name && name[0])
|
|
{
|
|
for (size_t index = 0, size = GetSize(); index < size; ++index)
|
|
{
|
|
var_sp = GetVariableAtIndex(index);
|
|
const char *var_name_cstr = var_sp->GetName().GetCString();
|
|
if (!var_name_cstr || !name)
|
|
continue;
|
|
if (::strcmp (var_name_cstr, name) == 0)
|
|
return var_sp;
|
|
}
|
|
var_sp.reset();
|
|
}
|
|
return var_sp;
|
|
}
|
|
|
|
void
|
|
RemoveVariable (lldb::ExpressionVariableSP var_sp)
|
|
{
|
|
for (std::vector<lldb::ExpressionVariableSP>::iterator vi = m_variables.begin(), ve = m_variables.end();
|
|
vi != ve;
|
|
++vi)
|
|
{
|
|
if (vi->get() == var_sp.get())
|
|
{
|
|
m_variables.erase(vi);
|
|
return;
|
|
}
|
|
}
|
|
}
|
|
|
|
void
|
|
Clear()
|
|
{
|
|
m_variables.clear();
|
|
}
|
|
|
|
private:
|
|
std::vector <lldb::ExpressionVariableSP> m_variables;
|
|
};
|
|
|
|
class PersistentExpressionState : public ExpressionVariableList {
|
|
public:
|
|
//----------------------------------------------------------------------
|
|
// See TypeSystem.h for how to add subclasses to this.
|
|
//----------------------------------------------------------------------
|
|
enum LLVMCastKind {
|
|
eKindClang,
|
|
eKindSwift,
|
|
eKindGo,
|
|
kNumKinds
|
|
};
|
|
|
|
LLVMCastKind getKind() const { return m_kind; }
|
|
|
|
PersistentExpressionState(LLVMCastKind kind) :
|
|
m_kind(kind)
|
|
{
|
|
}
|
|
|
|
virtual ~PersistentExpressionState();
|
|
|
|
virtual lldb::ExpressionVariableSP
|
|
CreatePersistentVariable (const lldb::ValueObjectSP &valobj_sp) = 0;
|
|
|
|
virtual lldb::ExpressionVariableSP
|
|
CreatePersistentVariable (ExecutionContextScope *exe_scope,
|
|
const ConstString &name,
|
|
const CompilerType &type,
|
|
lldb::ByteOrder byte_order,
|
|
uint32_t addr_byte_size) = 0;
|
|
|
|
virtual ConstString
|
|
GetNextPersistentVariableName () = 0;
|
|
|
|
virtual void
|
|
RemovePersistentVariable (lldb::ExpressionVariableSP variable) = 0;
|
|
|
|
virtual lldb::addr_t
|
|
LookupSymbol (const ConstString &name) = 0;
|
|
|
|
private:
|
|
LLVMCastKind m_kind;
|
|
};
|
|
|
|
} // namespace lldb_private
|
|
|
|
#endif // liblldb_ExpressionVariable_h_
|