Ghidra 11.4.2
Ghidra internal decompiler documentation.
Loading...
Searching...
No Matches
ghidra::AddrSpaceManager Class Reference

A manager for different address spaces. More...

#include <translate.hh>

Inheritance diagram for ghidra::AddrSpaceManager:
[legend]
Collaboration diagram for ghidra::AddrSpaceManager:
[legend]

Public Member Functions

 AddrSpaceManager (void)
 Construct an empty address space manager.
 
virtual ~AddrSpaceManager (void)
 Destroy the manager.
 
int4 getDefaultSize (void) const
 Get size of addresses for the default space.
 
AddrSpacegetSpaceByName (const string &nm) const
 Get address space by name.
 
AddrSpacegetSpaceByShortcut (char sc) const
 Get address space from its shortcut.
 
AddrSpacegetIopSpace (void) const
 Get the internal pcode op space.
 
AddrSpacegetFspecSpace (void) const
 Get the internal callspec space.
 
AddrSpacegetJoinSpace (void) const
 Get the joining space.
 
AddrSpacegetStackSpace (void) const
 Get the stack space for this processor.
 
AddrSpacegetUniqueSpace (void) const
 Get the temporary register space for this processor.
 
AddrSpacegetDefaultCodeSpace (void) const
 Get the default address space of this processor.
 
AddrSpacegetDefaultDataSpace (void) const
 Get the default address space where data is stored.
 
AddrSpacegetConstantSpace (void) const
 Get the constant space.
 
Address getConstant (uintb val) const
 Get a constant encoded as an Address.
 
Address createConstFromSpace (AddrSpace *spc) const
 Create a constant address encoding an address space.
 
Address resolveConstant (AddrSpace *spc, uintb val, int4 sz, const Address &point, uintb &fullEncoding) const
 Resolve a native constant into an Address.
 
int4 numSpaces (void) const
 Get the number of address spaces for this processor.
 
AddrSpacegetSpace (int4 i) const
 Get an address space via its index.
 
AddrSpacegetNextSpaceInOrder (AddrSpace *spc) const
 Get the next contiguous address space.
 
JoinRecordfindAddJoin (const vector< VarnodeData > &pieces, uint4 logicalsize)
 Get (or create) JoinRecord for pieces.
 
JoinRecordfindJoin (uintb offset) const
 Find JoinRecord for offset in the join space.
 
void setDeadcodeDelay (AddrSpace *spc, int4 delaydelta)
 Set the deadcodedelay for a specific space.
 
void truncateSpace (const TruncationTag &tag)
 Mark a space as truncated from its original size.
 
Address constructFloatExtensionAddress (const Address &realaddr, int4 realsize, int4 logicalsize)
 Build a logically lower precision storage location for a bigger floating point register.
 
Address constructJoinAddress (const Translate *translate, const Address &hiaddr, int4 hisz, const Address &loaddr, int4 losz)
 Build a logical whole from register pairs.
 
void renormalizeJoinAddress (Address &addr, int4 size)
 Make sure a possibly offset join address has a proper JoinRecord.
 
Address parseAddressSimple (const string &val)
 Parse a string with just an address space name and a hex offset.
 

Protected Member Functions

AddrSpacedecodeSpace (Decoder &decoder, const Translate *trans)
 Add a space to the model based an on XML tag.
 
void decodeSpaces (Decoder &decoder, const Translate *trans)
 Restore address spaces in the model from a stream.
 
void setDefaultCodeSpace (int4 index)
 Set the default address space (for code)
 
void setDefaultDataSpace (int4 index)
 Set the default address space for data.
 
void setReverseJustified (AddrSpace *spc)
 Set reverse justified property on this space.
 
void assignShortcut (AddrSpace *spc)
 Select a shortcut character for a new space.
 
void markNearPointers (AddrSpace *spc, int4 size)
 Mark that given space can be accessed with near pointers.
 
void insertSpace (AddrSpace *spc)
 Add a new address space to the model.
 
void copySpaces (const AddrSpaceManager *op2)
 Copy spaces from another manager.
 
void addSpacebasePointer (SpacebaseSpace *basespace, const VarnodeData &ptrdata, int4 truncSize, bool stackGrowth)
 Set the base register of a spacebase space.
 
void insertResolver (AddrSpace *spc, AddressResolver *rsolv)
 Override the base resolver for a space.
 
void setInferPtrBounds (const Range &range)
 Set the range of addresses that can be inferred as pointers.
 
JoinRecordfindJoinInternal (uintb offset) const
 Find JoinRecord for offset in the join space.
 

Private Attributes

vector< AddrSpace * > baselist
 Every space we know about for this architecture.
 
vector< AddressResolver * > resolvelist
 Special constant resolvers.
 
map< string, AddrSpace * > name2Space
 Map from name -> space.
 
map< int4, AddrSpace * > shortcut2Space
 Map from shortcut -> space.
 
AddrSpaceconstantspace
 Quick reference to constant space.
 
AddrSpacedefaultcodespace
 Default space where code lives, generally main RAM.
 
AddrSpacedefaultdataspace
 Default space where data lives.
 
AddrSpaceiopspace
 Space for internal pcode op pointers.
 
AddrSpacefspecspace
 Space for internal callspec pointers.
 
AddrSpacejoinspace
 Space for unifying split variables.
 
AddrSpacestackspace
 Stack space associated with processor.
 
AddrSpaceuniqspace
 Temporary space associated with processor.
 
uintb joinallocate
 Next offset to be allocated in join space.
 
set< JoinRecord *, JoinRecordComparesplitset
 Different splits that have been defined in join space.
 
vector< JoinRecord * > splitlist
 JoinRecords indexed by join address.
 

Detailed Description

A manager for different address spaces.

Allow creation, lookup by name, lookup by shortcut, lookup by name, and iteration over address spaces

Constructor & Destructor Documentation

◆ AddrSpaceManager()

ghidra::AddrSpaceManager::AddrSpaceManager ( void  )

Construct an empty address space manager.

Initialize manager containing no address spaces. All the cached space slots are set to null.

References constantspace, defaultcodespace, defaultdataspace, fspecspace, iopspace, joinallocate, joinspace, stackspace, and uniqspace.

◆ ~AddrSpaceManager()

ghidra::AddrSpaceManager::~AddrSpaceManager ( void  )
virtual

Destroy the manager.

Base destructor class, cleans up AddrSpace pointers which must be explicited created via new

References baselist, ghidra::AddrSpace::refcount, resolvelist, and splitlist.

Member Function Documentation

◆ addSpacebasePointer()

void ghidra::AddrSpaceManager::addSpacebasePointer ( SpacebaseSpace basespace,
const VarnodeData ptrdata,
int4  truncSize,
bool  stackGrowth 
)
protected

Set the base register of a spacebase space.

Perform the privileged act of associating a base register with an existing virtual space

Parameters
basespaceis the virtual space
ptrdatais the location data for the base register
truncSizeis the size of the space covered by the base register
stackGrowthis true if the stack grows "normally" towards address 0

References ghidra::SpacebaseSpace::setBaseRegister().

Referenced by ghidra::Architecture::addSpacebase().

◆ assignShortcut()

void ghidra::AddrSpaceManager::assignShortcut ( AddrSpace spc)
protected

Select a shortcut character for a new space.

Assign a shortcut character to the given address space. This routine makes use of the desired type of the new space and info about shortcuts for spaces that already exist to pick a unique and consistent character. This method also builds up a map from short to AddrSpace object.

Parameters
spcis the given AddrSpace

References ghidra::AddrSpace::getName(), ghidra::AddrSpace::getType(), ghidra::IPTR_CONSTANT, ghidra::IPTR_FSPEC, ghidra::IPTR_INTERNAL, ghidra::IPTR_IOP, ghidra::IPTR_JOIN, ghidra::IPTR_PROCESSOR, ghidra::IPTR_SPACEBASE, ghidra::AddrSpace::shortcut, and shortcut2Space.

Referenced by insertSpace().

◆ constructFloatExtensionAddress()

Address ghidra::AddrSpaceManager::constructFloatExtensionAddress ( const Address realaddr,
int4  realsize,
int4  logicalsize 
)

Build a logically lower precision storage location for a bigger floating point register.

This handles the situation where we need to find a logical address to hold the lower precision floating-point value that is stored in a bigger register If the logicalsize (precision) requested matches the -realsize- of the register just return the real address. Otherwise construct a join address to hold the logical value

Parameters
realaddris the address of the real floating-point register
realsizeis the size of the real floating-point register
logicalsizeis the size (lower precision) size of the logical value

References findAddJoin(), ghidra::VarnodeData::getAddr(), ghidra::Address::getOffset(), ghidra::Address::getSpace(), and ghidra::JoinRecord::getUnified().

Referenced by ghidra::MultiSlotAssign::assignAddress(), and ghidra::ParamEntry::getAddrBySlot().

◆ constructJoinAddress()

Address ghidra::AddrSpaceManager::constructJoinAddress ( const Translate translate,
const Address hiaddr,
int4  hisz,
const Address loaddr,
int4  losz 
)

Build a logical whole from register pairs.

This handles the common case, of trying to find a join address given a high location and a low location. This may not return an address in the join address space. It checks for the case where the two pieces are contiguous locations in a mappable space, in which case it just returns the containing address

Parameters
translateis the Translate object used to find registers
hiaddris the address of the most significant piece to be joined
hiszis the size of the most significant piece
loaddris the address of the least significant piece
loszis the size of the least significant piece
Returns
an address representing the start of the joined range

References findAddJoin(), ghidra::VarnodeData::getAddr(), getDefaultCodeSpace(), ghidra::Address::getOffset(), ghidra::Translate::getRegisterName(), ghidra::Address::getSpace(), ghidra::AddrSpace::getType(), ghidra::JoinRecord::getUnified(), ghidra::IPTR_PROCESSOR, ghidra::IPTR_SPACEBASE, ghidra::Address::isBigEndian(), and ghidra::Address::isContiguous().

Referenced by ghidra::FuncCallSpecs::buildOutputFromTrials(), ghidra::ActionReturnRecovery::buildReturnOutput(), ghidra::SplitVarnode::createJoinedWhole(), and ghidra::FuncCallSpecs::doInputJoin().

◆ copySpaces()

void ghidra::AddrSpaceManager::copySpaces ( const AddrSpaceManager op2)
protected

Copy spaces from another manager.

Different managers may need to share the same spaces. I.e. if different programs being analyzed share the same processor. This routine pulls in a reference of every space in -op2- in order to manage it from within -this-

Parameters
op2is a pointer to space manager being copied

References baselist, getDefaultCodeSpace(), getDefaultDataSpace(), ghidra::AddrSpace::getIndex(), insertSpace(), setDefaultCodeSpace(), and setDefaultDataSpace().

Referenced by ghidra::Architecture::restoreFromSpec().

◆ createConstFromSpace()

Address ghidra::AddrSpaceManager::createConstFromSpace ( AddrSpace spc) const
inline

Create a constant address encoding an address space.

This routine is used to encode a pointer to an address space as a constant Address, for use in LOAD and STORE operations. This is used internally and is slightly more efficient than storing the formal index of the space param spc is the space pointer to be encoded

Returns
the encoded Address

References constantspace.

Referenced by ghidra::Funcdata::newVarnodeSpace().

◆ decodeSpace()

AddrSpace * ghidra::AddrSpaceManager::decodeSpace ( Decoder decoder,
const Translate trans 
)
protected

Add a space to the model based an on XML tag.

The initialization of address spaces is the same across all variants of the Translate object. This routine initializes a single address space from a decoder element. It knows which class derived from AddrSpace to instantiate based on the ElementId.

Parameters
decoderis the stream decoder
transis the translator object to be associated with the new space
Returns
a pointer to the initialized AddrSpace

References ghidra::AddrSpace::decode(), ghidra::IPTR_PROCESSOR, and ghidra::Decoder::peekElement().

Referenced by decodeSpaces().

◆ decodeSpaces()

void ghidra::AddrSpaceManager::decodeSpaces ( Decoder decoder,
const Translate trans 
)
protected

Restore address spaces in the model from a stream.

This routine initializes (almost) all the address spaces used for a particular processor by using a <spaces> element, which contains child elements for the specific address spaces. This also instantiates the builtin constant space. It should probably also instantiate the iop, fspec, and join spaces, but this is currently done by the Architecture class.

Parameters
decoderis the stream decoder
transis the processor translator to be associated with the spaces

References ghidra::Decoder::closeElement(), decodeSpace(), ghidra::AddrSpace::getIndex(), getSpaceByName(), insertSpace(), ghidra::Decoder::openElement(), ghidra::Decoder::peekElement(), ghidra::Decoder::readString(), and setDefaultCodeSpace().

Referenced by ghidra::GhidraTranslate::decode().

◆ findAddJoin()

JoinRecord * ghidra::AddrSpaceManager::findAddJoin ( const vector< VarnodeData > &  pieces,
uint4  logicalsize 
)

Get (or create) JoinRecord for pieces.

Given a list of memory locations, the pieces, either find a pre-existing JoinRecord or create a JoinRecord that represents the logical joining of the pieces. The pieces must be in order from most significant to least significant.

Parameters
piecesif the list memory locations to be joined
logicalsizeof a single piece join, or zero
Returns
a pointer to the JoinRecord

References joinallocate, joinspace, ghidra::VarnodeData::offset, ghidra::JoinRecord::pieces, ghidra::VarnodeData::size, ghidra::VarnodeData::space, splitlist, splitset, and ghidra::JoinRecord::unified.

Referenced by ghidra::ParameterPieces::assignAddressFromPieces(), constructFloatExtensionAddress(), constructJoinAddress(), ghidra::JoinSpace::decodeAttributes(), ghidra::JoinSpace::read(), and renormalizeJoinAddress().

◆ findJoin()

JoinRecord * ghidra::AddrSpaceManager::findJoin ( uintb  offset) const

Find JoinRecord for offset in the join space.

Given a specific offset into the join address space, recover the JoinRecord that lists the pieces corresponding to that offset. The offset must originally have come from a JoinRecord returned by findAddJoin, otherwise this method throws an exception.

Parameters
offsetis an offset into the join space
Returns
the JoinRecord for that offset

References ghidra::VarnodeData::offset, splitlist, and ghidra::JoinRecord::unified.

Referenced by ghidra::Scope::addMap(), ghidra::RulePullsubMulti::buildSubpiece(), ghidra::JoinSpace::encodeAttributes(), ghidra::JoinSpace::overlapJoin(), ghidra::JoinSpace::printRaw(), ghidra::Heritage::processJoins(), and ghidra::ParamEntry::resolveJoin().

◆ findJoinInternal()

JoinRecord * ghidra::AddrSpaceManager::findJoinInternal ( uintb  offset) const
protected

Find JoinRecord for offset in the join space.

Given a specific offset into the join address space, recover the JoinRecord that contains the offset, as a range in the join address space. If there is no existing record, null is returned.

Parameters
offsetis an offset into the join space
Returns
the JoinRecord containing that offset or null

References ghidra::VarnodeData::offset, ghidra::VarnodeData::size, splitlist, and ghidra::JoinRecord::unified.

Referenced by renormalizeJoinAddress().

◆ getConstant()

Address ghidra::AddrSpaceManager::getConstant ( uintb  val) const
inline

Get a constant encoded as an Address.

This routine encodes a specific value as a constant address. I.e. the address space of the resulting Address will be the constant space, and the offset will be the value.

Parameters
valis the constant value to encode
Returns
the constant address

References constantspace.

Referenced by ghidra::RuleCollapseConstants::applyOp(), ghidra::Funcdata::newConstant(), and ghidra::StringManager::registerInternalStringData().

◆ getConstantSpace()

AddrSpace * ghidra::AddrSpaceManager::getConstantSpace ( void  ) const
inline

Get the constant space.

Pcode represents constant values within an operation as offsets within a special constant address space. (See ConstantSpace)

Returns
a pointer to the constant space

References constantspace.

Referenced by ghidra::ActionConstantPtr::apply(), ghidra::PcodeOpRaw::decode(), ghidra::Sleigh::initialize(), ghidra::ActionNameVars::linkSymbols(), and ghidra::Sleigh::oneInstruction().

◆ getDefaultCodeSpace()

AddrSpace * ghidra::AddrSpaceManager::getDefaultCodeSpace ( void  ) const
inline

Get the default address space of this processor.

Most processors have a main address bus, on which the bulk of the processor's RAM is mapped. This matches SLEIGH's notion of the default space. For Harvard architectures, this is the space where code exists (as opposed to data).

Returns
a pointer to the default code space

References defaultcodespace.

Referenced by ghidra::ActionPrototypeTypes::apply(), ghidra::RulePtrFlow::applyOp(), ghidra::ExecutablePcode::build(), ghidra::Architecture::cacheAddrSpaceProperties(), constructJoinAddress(), copySpaces(), ghidra::Range::decodeFromAttributes(), ghidra::VarnodeData::decodeFromAttributes(), ghidra::SleighBase::encode(), ghidra::PrintC::pushPtrCodeConstant(), and ghidra::Range::Range().

◆ getDefaultDataSpace()

◆ getDefaultSize()

int4 ghidra::AddrSpaceManager::getDefaultSize ( void  ) const
inline

Get size of addresses for the default space.

Return the size of addresses for the processor's official default space. This space is usually the main RAM databus.

Returns
the size of an address in bytes

References defaultcodespace, and ghidra::AddrSpace::getAddrSize().

Referenced by ghidra::ActionParamDouble::apply(), ghidra::Varnode::printRawNoMarkup(), ghidra::AddrSpace::read(), and ghidra::TypeFactory::setupSizes().

◆ getFspecSpace()

AddrSpace * ghidra::AddrSpaceManager::getFspecSpace ( void  ) const
inline

Get the internal callspec space.

There is a special address space reserved for encoding pointers to the FuncCallSpecs object as addresses. This allows direct pointers to be hidden within an operation, when manipulating pcode internally. (See FspecSpace)

Returns
a pointer to the address space

References fspecspace.

Referenced by ghidra::Funcdata::newVarnodeCallSpecs().

◆ getIopSpace()

AddrSpace * ghidra::AddrSpaceManager::getIopSpace ( void  ) const
inline

Get the internal pcode op space.

There is a special address space reserved for encoding pointers to pcode operations as addresses. This allows a direct pointer to be hidden within an operation, when manipulating pcode internally. (See IopSpace)

Returns
a pointer to the address space

References iopspace.

Referenced by ghidra::TransformVar::createReplacement(), and ghidra::Funcdata::newVarnodeIop().

◆ getJoinSpace()

AddrSpace * ghidra::AddrSpaceManager::getJoinSpace ( void  ) const
inline

Get the joining space.

There is a special address space reserved for providing a logical contiguous memory location for variables that are really split between two physical locations. This allows the the decompiler to work with the logical value. (See JoinSpace)

Returns
a pointer to the address space

References joinspace.

Referenced by ghidra::Heritage::processJoins(), and ghidra::PackedDecode::readSpace().

◆ getNextSpaceInOrder()

AddrSpace * ghidra::AddrSpaceManager::getNextSpaceInOrder ( AddrSpace spc) const

Get the next contiguous address space.

Get the next space in the absolute order of addresses. This ordering is determined by the AddrSpace index.

Parameters
spcis the pointer to the space being queried
Returns
the pointer to the next space in absolute order

References baselist, and ghidra::AddrSpace::getIndex().

Referenced by ghidra::VarnodeBank::endLoc(), ghidra::VarnodeBank::endLoc(), and ghidra::Range::getLastAddrOpen().

◆ getSpace()

AddrSpace * ghidra::AddrSpaceManager::getSpace ( int4  i) const
inline

◆ getSpaceByName()

AddrSpace * ghidra::AddrSpaceManager::getSpaceByName ( const string &  nm) const

Get address space by name.

All address spaces have a unique name associated with them. This routine retrieves the AddrSpace object based on the desired name.

Parameters
nmis the name of the address space
Returns
a pointer to the AddrSpace object

References name2Space.

Referenced by ghidra::Architecture::addOtherSpace(), ghidra::PutsCallBack::addressCallback(), ghidra::PrintfCallBack::addressCallback(), ghidra::JoinSpace::decodeAttributes(), ghidra::SleighBase::decodeSlaSpaces(), decodeSpaces(), parseAddressSimple(), ghidra::Range::Range(), ghidra::XmlDecode::readSpace(), ghidra::XmlDecode::readSpace(), and truncateSpace().

◆ getSpaceByShortcut()

AddrSpace * ghidra::AddrSpaceManager::getSpaceByShortcut ( char  sc) const

Get address space from its shortcut.

All address spaces have a unique shortcut (ASCII) character assigned to them. This routine retrieves an AddrSpace object given a specific shortcut.

Parameters
scis the shortcut character
Returns
a pointer to an AddrSpace

References shortcut2Space.

Referenced by ghidra::JoinSpace::read().

◆ getStackSpace()

AddrSpace * ghidra::AddrSpaceManager::getStackSpace ( void  ) const
inline

Get the stack space for this processor.

Most processors have registers and instructions that are reserved for implementing a stack. In the pcode translation, these are translated into locations and operations on a dedicated stack address space. (See SpacebaseSpace)

Returns
a pointer to the stack space

References stackspace.

Referenced by ghidra::Heritage::analyzeNewLoadGuards(), ghidra::ActionConditionalConst::apply(), ghidra::ActionPrototypeTypes::apply(), ghidra::ActionActiveParam::apply(), ghidra::ProtoModel::decode(), ghidra::Funcdata::decode(), ghidra::ProtoModel::defaultLocalRange(), ghidra::ProtoModel::defaultParamRange(), ghidra::Funcdata::Funcdata(), ghidra::PackedDecode::readSpace(), ghidra::TypeFactory::setupSizes(), and ghidra::ActionDatabase::universalAction().

◆ getUniqueSpace()

AddrSpace * ghidra::AddrSpaceManager::getUniqueSpace ( void  ) const
inline

Get the temporary register space for this processor.

Both the pcode translation process and the simplification process need access to a pool of temporary registers that can be used for moving data around without affecting the address spaces used to formally model the processor's RAM and registers. These temporary locations are all allocated from a dedicated address space, referred to as the unique space. (See UniqueSpace)

Returns
a pointer to the unique space

References uniqspace.

Referenced by ghidra::ExecutablePcode::build(), ghidra::Sleigh::oneInstruction(), and ghidra::VarnodeBank::VarnodeBank().

◆ insertResolver()

void ghidra::AddrSpaceManager::insertResolver ( AddrSpace spc,
AddressResolver rsolv 
)
protected

Override the base resolver for a space.

Provide a new specialized resolver for a specific AddrSpace. The manager takes ownership of resolver.

Parameters
spcis the space to which the resolver is associated
rsolvis the new resolver object

References ghidra::AddrSpace::getIndex(), and resolvelist.

Referenced by ghidra::Architecture::initializeSegments().

◆ insertSpace()

void ghidra::AddrSpaceManager::insertSpace ( AddrSpace spc)
protected

Add a new address space to the model.

This adds a previously instantiated address space (AddrSpace) to the model for this processor. It checks a set of indexing and naming conventions for the space and throws an exception if the conventions are violated. Should only be called during initialization.

Todo:
This really shouldn't be public. Need to move the allocation of iop, fspec, and join out of Architecture
Parameters
spcthe address space to insert

References assignShortcut(), baselist, constantspace, fspecspace, ghidra::AddrSpace::getContain(), ghidra::AddrSpace::getName(), ghidra::AddrSpace::getType(), ghidra::AddrSpace::index, ghidra::ConstantSpace::INDEX, ghidra::OtherSpace::INDEX, iopspace, ghidra::IPTR_CONSTANT, ghidra::IPTR_FSPEC, ghidra::IPTR_INTERNAL, ghidra::IPTR_IOP, ghidra::IPTR_JOIN, ghidra::IPTR_PROCESSOR, ghidra::IPTR_SPACEBASE, ghidra::AddrSpace::isOtherSpace(), ghidra::AddrSpace::isOverlay(), joinspace, ghidra::ConstantSpace::NAME, ghidra::UniqueSpace::NAME, ghidra::JoinSpace::NAME, name2Space, ghidra::AddrSpace::overlaybase, ghidra::AddrSpace::refcount, ghidra::AddrSpace::setFlags(), stackspace, and uniqspace.

Referenced by ghidra::Architecture::addSpacebase(), copySpaces(), ghidra::SleighBase::decodeSlaSpaces(), decodeSpaces(), and ghidra::Architecture::restoreFromSpec().

◆ markNearPointers()

void ghidra::AddrSpaceManager::markNearPointers ( AddrSpace spc,
int4  size 
)
protected

Mark that given space can be accessed with near pointers.

Parameters
spcis the AddrSpace to mark
sizeis the (minimum) size of a near pointer in bytes

References ghidra::AddrSpace::addressSize, ghidra::AddrSpace::has_nearpointers, ghidra::AddrSpace::minimumPointerSize, and ghidra::AddrSpace::setFlags().

Referenced by ghidra::Architecture::cacheAddrSpaceProperties().

◆ numSpaces()

◆ parseAddressSimple()

Address ghidra::AddrSpaceManager::parseAddressSimple ( const string &  val)

Parse a string with just an address space name and a hex offset.

The string must contain a hexadecimal offset. The offset may be optionally prepended with "0x". The string may optionally start with the name of the address space to associate with the offset, followed by ':' to separate it from the offset. If the name is not present, the default data space is assumed.

Parameters
valis the string to parse
Returns
the parsed address

References ghidra::AddrSpace::addressToByte(), getDefaultDataSpace(), getSpaceByName(), and ghidra::AddrSpace::getWordSize().

Referenced by ghidra::ArchitectureGhidra::buildSymbols().

◆ renormalizeJoinAddress()

void ghidra::AddrSpaceManager::renormalizeJoinAddress ( Address addr,
int4  size 
)

Make sure a possibly offset join address has a proper JoinRecord.

If an Address in the join AddressSpace is shifted from its original offset, it may no longer have a valid JoinRecord. The shift or size change may even make the address of one of the pieces a more natural representation. Given a new Address and size, this method decides if there is a matching JoinRecord. If not it either constructs a new JoinRecord or computes the address within the containing piece. The given Address is changed if necessary either to the offset corresponding to the new JoinRecord or to a normal non-join Address.

Parameters
addris the given Address
sizeis the size of the range in bytes

References findAddJoin(), findJoinInternal(), ghidra::JoinRecord::getEquivalentAddress(), ghidra::Address::getOffset(), ghidra::Address::isInvalid(), ghidra::VarnodeData::offset, ghidra::JoinRecord::pieces, ghidra::VarnodeData::size, ghidra::VarnodeData::space, and ghidra::JoinRecord::unified.

Referenced by ghidra::Address::renormalize().

◆ resolveConstant()

Address ghidra::AddrSpaceManager::resolveConstant ( AddrSpace spc,
uintb  val,
int4  sz,
const Address point,
uintb &  fullEncoding 
) const

Resolve a native constant into an Address.

If there is a special resolver for the AddrSpace, this is invoked, otherwise basic wordsize conversion and wrapping is performed. If the address encoding is partial (as in a near pointer) and the full encoding can be recovered, it is passed back. The sz parameter indicates the number of bytes in constant and is used to determine if the constant is a partial or full pointer encoding. A value of -1 indicates the value is known to be a full encoding.

Parameters
spcis the space to generate the address from
valis the constant encoding of the address
szis the size of the constant encoding (or -1)
pointis the context address (for recovering full encoding info if necessary)
fullEncodingis used to pass back the recovered full encoding of the pointer
Returns
the formal Address associated with the encoding

References ghidra::AddrSpace::addressToByte(), ghidra::AddrSpace::getIndex(), ghidra::AddrSpace::getWordSize(), ghidra::AddressResolver::resolve(), resolvelist, and ghidra::AddrSpace::wrapOffset().

Referenced by ghidra::TypeSpacebase::getAddress(), ghidra::TypeSpacebase::getSubType(), ghidra::ActionConstantPtr::isPointer(), ghidra::TypeSpacebase::nearestArrayedComponentForward(), and ghidra::PrintC::pushPtrCharConstant().

◆ setDeadcodeDelay()

void ghidra::AddrSpaceManager::setDeadcodeDelay ( AddrSpace spc,
int4  delaydelta 
)

Set the deadcodedelay for a specific space.

Set the number of passes for a specific AddrSpace before deadcode removal is allowed for that space.

Parameters
spcis the AddrSpace to change
delaydeltais the number of rounds to the delay should be set to

References ghidra::AddrSpace::deadcodedelay.

Referenced by ghidra::Architecture::decodeDeadcodeDelay().

◆ setDefaultCodeSpace()

void ghidra::AddrSpaceManager::setDefaultCodeSpace ( int4  index)
protected

Set the default address space (for code)

Once all the address spaces have been initialized, this routine should be called once to establish the official default space for the processor, via its index. Should only be called during initialization.

Parameters
indexis the index of the desired default space

References baselist, defaultcodespace, and defaultdataspace.

Referenced by copySpaces(), ghidra::SleighBase::decodeSlaSpaces(), and decodeSpaces().

◆ setDefaultDataSpace()

void ghidra::AddrSpaceManager::setDefaultDataSpace ( int4  index)
protected

Set the default address space for data.

If the architecture has different code and data spaces, this routine can be called to set the data space after the code space has been set.

Parameters
indexis the index of the desired default space

References baselist, defaultcodespace, and defaultdataspace.

Referenced by copySpaces(), and ghidra::Architecture::parseProcessorConfig().

◆ setInferPtrBounds()

void ghidra::AddrSpaceManager::setInferPtrBounds ( const Range range)
protected

Set the range of addresses that can be inferred as pointers.

This method establishes for a single address space, what range of constants are checked as possible symbol starts, when it is not known apriori that a constant is a pointer.

Parameters
rangeis the range of values for a single address space

References ghidra::Range::getFirst(), ghidra::Range::getLast(), ghidra::Range::getSpace(), ghidra::AddrSpace::pointerLowerBound, and ghidra::AddrSpace::pointerUpperBound.

Referenced by ghidra::Architecture::decodeInferPtrBounds().

◆ setReverseJustified()

void ghidra::AddrSpaceManager::setReverseJustified ( AddrSpace spc)
protected

Set reverse justified property on this space.

For spaces with alignment restrictions, the address of a small variable must be justified within a larger aligned memory word, usually either to the left boundary for little endian encoding or to the right boundary for big endian encoding. Some compilers justify small variables to the opposite side of the one indicated by the endianness. Setting this property on a space causes the decompiler to use this justification

References ghidra::AddrSpace::reverse_justification, and ghidra::AddrSpace::setFlags().

Referenced by ghidra::Architecture::addSpacebase().

◆ truncateSpace()

void ghidra::AddrSpaceManager::truncateSpace ( const TruncationTag tag)

Mark a space as truncated from its original size.

Mark the named space as truncated from its original size

Parameters
tagis a description of the space and how it should be truncated

References ghidra::TruncationTag::getName(), ghidra::TruncationTag::getSize(), getSpaceByName(), and ghidra::AddrSpace::truncateSpace().

Referenced by ghidra::GhidraTranslate::decode().


The documentation for this class was generated from the following files: