Ghidra 11.4.2
Ghidra internal decompiler documentation.
|
A record describing how logical values are split. More...
#include <translate.hh>
Public Member Functions | |
int4 | numPieces (void) const |
Get number of pieces in this record. | |
bool | isFloatExtension (void) const |
Does this record extend a float varnode. | |
const VarnodeData & | getPiece (int4 i) const |
Get the i-th piece. | |
const VarnodeData & | getUnified (void) const |
Get the Varnode whole. | |
Address | getEquivalentAddress (uintb offset, int4 &pos) const |
Given offset in join space, get equivalent address of piece. | |
bool | operator< (const JoinRecord &op2) const |
Compare records lexigraphically by pieces. | |
Static Public Member Functions | |
static void | mergeSequence (vector< VarnodeData > &seq, const Translate *trans) |
Merge any contiguous ranges in a sequence. | |
Private Attributes | |
vector< VarnodeData > | pieces |
All the physical pieces of the symbol, most significant to least. | |
VarnodeData | unified |
Special entry representing entire symbol in one chunk. | |
Friends | |
class | AddrSpaceManager |
A record describing how logical values are split.
The decompiler can describe a logical value that is stored split across multiple physical memory locations. This record describes such a split. The pieces must be listed from most significant to least significant.
Address ghidra::JoinRecord::getEquivalentAddress | ( | uintb | offset, |
int4 & | pos | ||
) | const |
Given offset in join space, get equivalent address of piece.
The join space range maps to the underlying pieces in a natural endian aware way. Given an offset in the range, figure out what address it is mapping to. The particular piece is passed back as an index, and the Address is returned.
offset | is the offset within this range to map |
pos | will hold the passed back piece index |
References ghidra::VarnodeData::offset, pieces, and unified.
Referenced by ghidra::JoinSpace::overlapJoin(), and ghidra::AddrSpaceManager::renormalizeJoinAddress().
|
static |
Merge any contiguous ranges in a sequence.
Assuming the given list of VarnodeData go from most significant to least significant, merge any contiguous elements in the list. Varnodes that are not in the stack address space are only merged if the resulting byte range has a formal register name.
seq | is the given list of VarnodeData |
trans | is the language to use for register names |
References ghidra::Translate::getExactRegisterName(), ghidra::AddrSpace::getType(), ghidra::IPTR_SPACEBASE, ghidra::AddrSpace::isBigEndian(), ghidra::VarnodeData::isContiguous(), ghidra::VarnodeData::offset, ghidra::VarnodeData::size, and ghidra::VarnodeData::space.
Referenced by ghidra::ParameterPieces::assignAddressFromPieces().
bool ghidra::JoinRecord::operator< | ( | const JoinRecord & | op2 | ) | const |
Compare records lexigraphically by pieces.
Allow sorting on JoinRecords so that a collection of pieces can be quickly mapped to its logical whole, specified with a join address
References pieces, ghidra::VarnodeData::size, and unified.