Ghidra 11.4.2
Ghidra internal decompiler documentation.
|
A standard model for parameters as an ordered list of storage resources. More...
#include <fspec.hh>
Public Member Functions | |
ParamListStandard (void) | |
Construct for use with decode() | |
ParamListStandard (const ParamListStandard &op2) | |
Copy constructor. | |
const list< ParamEntry > & | getEntry (void) const |
Get the list of parameter entries. | |
void | extractTiles (vector< const ParamEntry * > &tiles, type_class type) const |
Get registers of given storage class. | |
const ParamEntry * | getStackEntry (void) const |
Get the stack entry. | |
uint4 | assignAddressFallback (type_class resource, Datatype *tp, bool matchExact, vector< int4 > &status, ParameterPieces ¶m) const |
Assign storage for given parameter class, using the fallback assignment algorithm. | |
uint4 | assignAddress (Datatype *dt, const PrototypePieces &proto, int4 pos, TypeFactory &tlst, vector< int4 > &status, ParameterPieces &res) const |
Fill in the Address and other details for the given parameter. | |
virtual uint4 | getType (void) const |
Get the type of parameter list. | |
virtual void | assignMap (const PrototypePieces &proto, TypeFactory &typefactory, vector< ParameterPieces > &res) const |
Given list of data-types, map the list positions to storage locations. | |
virtual void | fillinMap (ParamActive *active) const |
Given an unordered list of storage locations, calculate a function prototype. | |
virtual bool | checkJoin (const Address &hiaddr, int4 hisize, const Address &loaddr, int4 losize) const |
Check if the given two storage locations can represent a single logical parameter. | |
virtual bool | checkSplit (const Address &loc, int4 size, int4 splitpoint) const |
Check if it makes sense to split a single storage location into two parameters. | |
virtual int4 | characterizeAsParam (const Address &loc, int4 size) const |
Characterize whether the given range overlaps parameter storage. | |
virtual bool | possibleParam (const Address &loc, int4 size) const |
Does the given storage location make sense as a parameter. | |
virtual bool | possibleParamWithSlot (const Address &loc, int4 size, int4 &slot, int4 &slotsize) const |
Pass-back the slot and slot size for the given storage location as a parameter. | |
virtual bool | getBiggestContainedParam (const Address &loc, int4 size, VarnodeData &res) const |
Pass-back the biggest parameter contained within the given range. | |
virtual bool | unjustifiedContainer (const Address &loc, int4 size, VarnodeData &res) const |
Check if the given storage location looks like an unjustified parameter. | |
virtual OpCode | assumedExtension (const Address &addr, int4 size, VarnodeData &res) const |
Get the type of extension and containing parameter for the given storage. | |
virtual AddrSpace * | getSpacebase (void) const |
Get the address space associated with any stack based parameters in this list. | |
virtual bool | isThisBeforeRetPointer (void) const |
Return true if this pointer occurs before an indirect return pointer. | |
virtual void | getRangeList (AddrSpace *spc, RangeList &res) const |
For a given address space, collect all the parameter locations within that space. | |
virtual int4 | getMaxDelay (void) const |
Return the maximum heritage delay across all possible parameters. | |
virtual bool | isAutoKilledByCall (void) const |
Return true if ParamEntry locations should automatically be considered killed by call. | |
virtual void | decode (Decoder &decoder, vector< EffectRecord > &effectlist, bool normalstack) |
Restore the model from an <input> or <output> element in the stream. | |
virtual ParamList * | clone (void) const |
Clone this parameter list model. | |
![]() | |
virtual | ~ParamList (void) |
Destructor. | |
Protected Member Functions | |
const ParamEntry * | findEntry (const Address &loc, int4 size, bool just) const |
Given storage location find matching ParamEntry. | |
const ParamEntry * | selectUnreferenceEntry (int4 grp, type_class prefType) const |
Select entry to fill an unreferenced param. | |
void | buildTrialMap (ParamActive *active) const |
Build map from parameter trials to model ParamEntrys. | |
void | separateSections (ParamActive *active, vector< int4 > &trialStart) const |
Calculate the range of trials in each resource sections. | |
void | calcDelay (void) |
Calculate the maximum heritage delay for any potential parameter in this list. | |
void | addResolverRange (AddrSpace *spc, uintb first, uintb last, ParamEntry *paramEntry, int4 position) |
Internal method for adding a single address range to the ParamEntryResolvers. | |
void | populateResolver (void) |
Build the ParamEntry resolver maps. | |
void | parsePentry (Decoder &decoder, vector< EffectRecord > &effectlist, int4 groupid, bool normalstack, bool splitFloat, bool grouped) |
Parse a <pentry> element and add it to this list. | |
void | parseGroup (Decoder &decoder, vector< EffectRecord > &effectlist, int4 groupid, bool normalstack, bool splitFloat) |
Parse a sequence of <pentry> elements that are allocated as a group. | |
Static Protected Member Functions | |
static void | markGroupNoUse (ParamActive *active, int4 activeTrial, int4 trialStart) |
Mark all the trials within the indicated groups as not used, except for one specified index. | |
static void | markBestInactive (ParamActive *active, int4 group, int4 groupStart, type_class prefType) |
From among multiple inactive trials, select the most likely to be active and mark others as not used. | |
static void | forceExclusionGroup (ParamActive *active) |
Enforce exclusion rules for the given set of parameter trials. | |
static void | forceNoUse (ParamActive *active, int4 start, int4 stop) |
Mark every trial above the first "definitely not used" as inactive. | |
static void | forceInactiveChain (ParamActive *active, int4 maxchain, int4 start, int4 stop, int4 groupstart) |
Enforce rules about chains of inactive slots. | |
Protected Attributes | |
int4 | numgroup |
Number of groups in this parameter convention. | |
int4 | maxdelay |
Maximum heritage delay across all parameters. | |
bool | thisbeforeret |
Does a this parameter come before a hidden return parameter. | |
bool | autoKilledByCall |
Are storage locations in this list automatically killed by call. | |
vector< int4 > | resourceStart |
The starting group for each resource section. | |
list< ParamEntry > | entry |
The ordered list of parameter entries. | |
vector< ParamEntryResolver * > | resolverMap |
Map from space id to resolver. | |
list< ModelRule > | modelRules |
Rules to apply when assigning addresses. | |
AddrSpace * | spacebase |
Address space containing relative offset parameters. | |
Additional Inherited Members | |
![]() | |
enum | { p_standard , p_standard_out , p_register , p_register_out , p_merged } |
A standard model for parameters as an ordered list of storage resources.
This is a configurable model for passing (input) parameters as a list to a function. The model allows 1 or more resource lists based on data-type, either TYPE_UNKNOWN for general purpose or TYPE_FLOAT for floating-point registers. Within a resource list, any number of parameters can be used but they must come starting at the beginning of the list with no holes (skipped resources). A resource list can include (at the end) stack parameters that are allocated based on an alignment. Optionally, the model supports converting data-types larger than a specified size to pointers within the parameter list.
|
protected |
Internal method for adding a single address range to the ParamEntryResolvers.
Specify the contiguous address range, the ParamEntry to map to it, and a position recording the order in which ranges are added.
spc | is address space of the memory range |
first | is the starting offset of the memory range |
last | is the ending offset of the memory range |
paramEntry | is the ParamEntry to associate with the memory range |
position | is the ordering position |
References ghidra::AddrSpace::getIndex(), and resolverMap.
Referenced by populateResolver().
uint4 ghidra::ParamListStandard::assignAddress | ( | Datatype * | dt, |
const PrototypePieces & | proto, | ||
int4 | pos, | ||
TypeFactory & | tlist, | ||
vector< int4 > & | status, | ||
ParameterPieces & | res | ||
) | const |
Fill in the Address and other details for the given parameter.
Attempt to apply a ModelRule first. If these do not succeed, use the fallback assignment algorithm.
dt | is the data-type assigned to the parameter |
proto | is the description of the function prototype |
pos | is the position of the parameter to assign (pos=-1 for output, pos >=0 for input) |
tlist | is the data-type factory for (possibly) transforming the parameter's data-type |
status | is the consumed resource status array |
res | is parameter description to be filled in |
References assignAddressFallback(), ghidra::AssignAction::fail, ghidra::Datatype::getMetatype(), and modelRules.
Referenced by ghidra::ConvertToPointer::assignAddress(), assignMap(), ghidra::ParamListStandardOut::assignMap(), and ghidra::ParamListRegisterOut::assignMap().
uint4 ghidra::ParamListStandard::assignAddressFallback | ( | type_class | resource, |
Datatype * | tp, | ||
bool | matchExact, | ||
vector< int4 > & | status, | ||
ParameterPieces & | param | ||
) | const |
Assign storage for given parameter class, using the fallback assignment algorithm.
Given a resource list, a data-type, and the status of previously allocated slots, select the storage location for the parameter. The status array is indexed by group: a positive value indicates how many slots have been allocated from that group, and a -1 indicates the group/resource is fully consumed. If an Address can be assigned to the parameter, it and other details are passed back in the ParameterPieces object and the success code is returned. Otherwise, the fail code is returned.
resource | is the resource list to allocate from |
tp | is the data-type of the parameter |
matchExact | is false if TYPECLASS_GENERAL is considered a match for any storage class |
status | is an array marking how many slots have already been consumed in a group |
param | will hold the address of the newly assigned parameter |
References ghidra::ParameterPieces::addr, entry, ghidra::AssignAction::fail, ghidra::ParameterPieces::flags, ghidra::ParamEntry::getAddrBySlot(), ghidra::Datatype::getAlignment(), ghidra::Datatype::getAlignSize(), ghidra::ParamEntry::getAllGroups(), ghidra::ParamEntry::getGroup(), ghidra::ParamEntry::getType(), ghidra::ParamEntry::isExclusion(), ghidra::Address::isInvalid(), ghidra::AssignAction::success, ghidra::ParameterPieces::type, and ghidra::TYPECLASS_GENERAL.
Referenced by ghidra::MultiMemberAssign::assignAddress(), ghidra::ConsumeAs::assignAddress(), assignAddress(), assignMap(), and ghidra::ParamListStandardOut::assignMap().
|
virtual |
Given list of data-types, map the list positions to storage locations.
If we know the function prototype, recover how parameters are actually stored using the model.
proto | is the ordered list of data-types |
typefactory | is the TypeFactory (for constructing pointers) |
res | will contain the storage locations corresponding to the datatypes |
Implements ghidra::ParamList.
Reimplemented in ghidra::ParamListStandardOut, ghidra::ParamListRegisterOut, and ghidra::ParamListMerged.
References assignAddress(), assignAddressFallback(), ghidra::AssignAction::fail, ghidra::Datatype::getMetatype(), ghidra::Datatype::getName(), ghidra::ParameterPieces::hiddenretparm, ghidra::PrototypePieces::intypes, ghidra::AssignAction::no_assignment, numgroup, and ghidra::TYPECLASS_HIDDENRET.
|
virtual |
Get the type of extension and containing parameter for the given storage.
If the given storage is properly contained within a normal parameter and the model typically extends a small value into the full container, pass back the full container and the type of extension.
addr | is the starting address of the given storage |
size | is the number of bytes in the given storage |
res | is the parameter storage to pass back |
Implements ghidra::ParamList.
References ghidra::CPUI_COPY, and entry.
|
protected |
Build map from parameter trials to model ParamEntrys.
Given a set of trials (putative Varnode parameters) as ParamTrial objects, associate each trial with a model ParamEntry within this list. Trials for for which there are no matching entries are marked as unused. Any holes in the resource list are filled with unreferenced trials. The trial list is sorted.
active | is the set of trials to map and organize |
References findEntry(), ghidra::ParamEntry::getAddrBySlot(), ghidra::ParamTrial::getAddress(), ghidra::ParamEntry::getAlign(), ghidra::ParamTrial::getEntry(), ghidra::ParamEntry::getGroup(), ghidra::ParamActive::getNumTrials(), ghidra::ParamEntry::getSize(), ghidra::ParamTrial::getSize(), ghidra::ParamEntry::getSlot(), ghidra::ParamActive::getTrial(), ghidra::ParamEntry::getType(), ghidra::ParamTrial::isActive(), ghidra::ParamEntry::isExclusion(), ghidra::ParamTrial::markNoUse(), ghidra::ParamTrial::markUnref(), ghidra::ParamActive::registerTrial(), selectUnreferenceEntry(), ghidra::ParamTrial::setEntry(), ghidra::ParamActive::sortTrials(), ghidra::TYPECLASS_FLOAT, and ghidra::TYPECLASS_GENERAL.
Referenced by fillinMap().
|
virtual |
Characterize whether the given range overlaps parameter storage.
Does the range naturally fit inside a potential parameter entry from this list or does it contain a parameter entry. Return one of four enumerations indicating this characterization:
loc | is the starting address of the given range |
size | is the number of bytes in the given range |
Implements ghidra::ParamList.
References ghidra::ParamEntry::contained_by, ghidra::ParamEntry::containedBy(), ghidra::ParamEntry::contains_justified, ghidra::ParamEntry::contains_unjustified, ghidra::AddrSpace::getIndex(), ghidra::Address::getOffset(), ghidra::Address::getSpace(), ghidra::ParamEntry::isExclusion(), ghidra::ParamEntry::justifiedContain(), ghidra::ParamEntry::no_containment, and resolverMap.
|
virtual |
Check if the given two storage locations can represent a single logical parameter.
Within the conventions of this model, do the two (hi/lo) locations represent consecutive parameter locations that can be replaced by a single logical parameter.
hiaddr | is the address of the most significant part of the value |
hisize | is the size of the most significant part in bytes |
loaddr | is the address of the least significant part of the value |
losize | is the size of the least significant part in bytes |
Implements ghidra::ParamList.
References entry, findEntry(), ghidra::ParamEntry::getAlign(), ghidra::ParamEntry::getBase(), ghidra::ParamEntry::getGroup(), ghidra::Address::getOffset(), ghidra::Address::isContiguous(), and ghidra::ParamEntry::isExclusion().
|
virtual |
Check if it makes sense to split a single storage location into two parameters.
A storage location and split point is provided, implying two new storage locations. Does this model allow these locations to be considered parameters.
loc | is the starting address of provided storage location |
size | is the size of the location in bytes |
splitpoint | is the number of bytes to consider in the first (in address order) piece |
Implements ghidra::ParamList.
References findEntry().
|
virtual |
Clone this parameter list model.
Implements ghidra::ParamList.
Reimplemented in ghidra::ParamListStandardOut, ghidra::ParamListRegisterOut, ghidra::ParamListRegister, and ghidra::ParamListMerged.
References ParamListStandard().
|
virtual |
Restore the model from an <input> or <output> element in the stream.
decoder | is the stream decoder |
effectlist | is a container collecting EffectRecords across all parameters |
normalstack | is true if parameters are pushed on the stack in the normal order |
Implements ghidra::ParamList.
Reimplemented in ghidra::ParamListStandardOut.
References autoKilledByCall, calcDelay(), ghidra::Decoder::closeElement(), ghidra::Decoder::getNextAttributeId(), modelRules, numgroup, ghidra::Decoder::openElement(), parseGroup(), parsePentry(), ghidra::Decoder::peekElement(), populateResolver(), ghidra::Decoder::readBool(), ghidra::Decoder::readSignedInteger(), resourceStart, spacebase, and thisbeforeret.
Referenced by ghidra::ParamListStandardOut::decode().
void ghidra::ParamListStandard::extractTiles | ( | vector< const ParamEntry * > & | tiles, |
type_class | type | ||
) | const |
Get registers of given storage class.
tiles | will contain the set of matching entries |
type | is the storage class |
References entry, ghidra::ParamEntry::getAllGroups(), ghidra::ParamEntry::getType(), and ghidra::ParamEntry::isExclusion().
Referenced by ghidra::MultiSlotAssign::initializeEntries(), ghidra::MultiSlotDualAssign::initializeEntries(), and ghidra::ConsumeExtra::initializeEntries().
|
virtual |
Given an unordered list of storage locations, calculate a function prototype.
A list of input (or output) trials is given, which may have holes, invalid inputs etc. Decide on the formal ordered parameter list. Trials within the ParamActive are added, removed, or reordered as needed.
active | is the given list of trials |
Implements ghidra::ParamList.
Reimplemented in ghidra::ParamListStandardOut, ghidra::ParamListRegister, and ghidra::ParamListMerged.
References buildTrialMap(), entry, forceExclusionGroup(), forceInactiveChain(), forceNoUse(), ghidra::ParamActive::getNumTrials(), ghidra::ParamActive::getTrial(), ghidra::ParamTrial::isActive(), ghidra::ParamTrial::markUsed(), resourceStart, and separateSections().
|
protected |
Given storage location find matching ParamEntry.
Find the (first) entry containing the given memory range
loc | is the starting address of the range |
size | is the number of bytes in the range |
just | is true if the search enforces a justified match |
References ghidra::AddrSpace::getIndex(), ghidra::ParamEntry::getMinSize(), ghidra::Address::getOffset(), ghidra::Address::getSpace(), ghidra::ParamEntry::justifiedContain(), and resolverMap.
Referenced by buildTrialMap(), checkJoin(), checkSplit(), ghidra::ParamListStandardOut::fillinMap(), ghidra::ParamListRegister::fillinMap(), possibleParam(), and possibleParamWithSlot().
|
staticprotected |
Enforce exclusion rules for the given set of parameter trials.
If there are more than one active trials in a single group, and if that group is an exclusion group, mark all but the first trial to defnouse.
active | is the set of trials |
References ghidra::ParamTrial::getEntry(), ghidra::ParamEntry::getGroup(), ghidra::ParamActive::getNumTrials(), ghidra::ParamActive::getTrial(), ghidra::ParamTrial::isActive(), ghidra::ParamTrial::isDefinitelyNotUsed(), ghidra::ParamEntry::isExclusion(), markBestInactive(), markGroupNoUse(), and ghidra::TYPECLASS_GENERAL.
Referenced by fillinMap().
|
staticprotected |
Enforce rules about chains of inactive slots.
If there is a chain of slots whose length is greater than maxchain, where all trials are inactive, mark trials in any later slot as inactive. Mark any inactive trials before this (that aren't in a maximal chain) as active. The parameter entries in the model may be split up into different resource sections, as in floating-point vs general purpose. This method must be called on a single section at a time. The start and stop indices describe the range of trials in the particular section.
active | is the set of trials, which must be sorted |
maxchain | is the maximum number of inactive trials to allow in a chain |
start | is the first index in the range of trials to consider |
stop | is the last index (+1) in the range of trials to consider |
groupstart | is the smallest group id in the particular section |
References ghidra::ParamTrial::getAddress(), ghidra::Address::getSpace(), ghidra::ParamActive::getTrial(), ghidra::AddrSpace::getType(), ghidra::IPTR_SPACEBASE, ghidra::ParamTrial::isActive(), ghidra::ParamTrial::isDefinitelyNotUsed(), ghidra::ParamActive::isRecoverSubcall(), ghidra::ParamTrial::isUnref(), ghidra::ParamTrial::markActive(), ghidra::ParamTrial::markInactive(), and ghidra::ParamTrial::slotGroup().
Referenced by fillinMap().
|
staticprotected |
Mark every trial above the first "definitely not used" as inactive.
Inspection and marking only occurs within an indicated range of trials, allowing floating-point and general purpose resources to be treated separately.
active | is the set of trials, which must already be ordered |
start | is the index of the first trial in the range to consider |
stop | is the index (+1) of the last trial in the range to consider |
References ghidra::ParamTrial::getEntry(), ghidra::ParamEntry::getGroup(), ghidra::ParamActive::getTrial(), ghidra::ParamTrial::isDefinitelyNotUsed(), ghidra::ParamEntry::isExclusion(), and ghidra::ParamTrial::markInactive().
Referenced by fillinMap().
|
virtual |
Pass-back the biggest parameter contained within the given range.
loc | is the starting address of the given range |
size | is the number of bytes in the range |
res | will hold the parameter storage description being passed back |
Implements ghidra::ParamList.
References ghidra::ParamEntry::containedBy(), ghidra::ParamEntry::getBase(), ghidra::AddrSpace::getIndex(), ghidra::Address::getOffset(), ghidra::ParamEntry::getSize(), ghidra::Address::getSpace(), ghidra::ParamEntry::getSpace(), ghidra::ParamEntry::isExclusion(), ghidra::VarnodeData::offset, resolverMap, ghidra::VarnodeData::size, and ghidra::VarnodeData::space.
|
inlinevirtual |
Return the maximum heritage delay across all possible parameters.
Depending on the address space, data-flow for a parameter may not be available until extra transform passes have completed. This method returns the number of passes that must occur before we can guarantee that all parameters have data-flow info.
Implements ghidra::ParamList.
References maxdelay.
For a given address space, collect all the parameter locations within that space.
Pass back the memory ranges for any parameter that is stored in the given address space.
spc | is the given address space |
res | will hold the set of matching memory ranges |
Implements ghidra::ParamList.
References entry, and ghidra::RangeList::insertRange().
|
inlinevirtual |
Get the address space associated with any stack based parameters in this list.
Implements ghidra::ParamList.
References spacebase.
Referenced by ghidra::ConvertToPointer::ConvertToPointer(), ghidra::AssignAction::decodeAction(), ghidra::ParamListMerged::foldIn(), ghidra::MultiSlotAssign::MultiSlotAssign(), and ghidra::MultiSlotDualAssign::MultiSlotDualAssign().
const ParamEntry * ghidra::ParamListStandard::getStackEntry | ( | void | ) | const |
Get the stack entry.
If the stack entry is not present, null is returned
References entry, ghidra::ParamEntry::getSpace(), ghidra::AddrSpace::getType(), ghidra::IPTR_SPACEBASE, and ghidra::ParamEntry::isExclusion().
Referenced by ghidra::MultiSlotAssign::initializeEntries(), ghidra::GotoStack::initializeEntry(), and ghidra::ExtraStack::initializeEntry().
|
inlinevirtual |
Get the type of parameter list.
Implements ghidra::ParamList.
Reimplemented in ghidra::ParamListStandardOut, ghidra::ParamListRegisterOut, ghidra::ParamListRegister, and ghidra::ParamListMerged.
References ghidra::ParamList::p_standard.
Referenced by ghidra::MultiSlotAssign::MultiSlotAssign().
|
inlinevirtual |
Return true if ParamEntry locations should automatically be considered killed by call.
Implements ghidra::ParamList.
References autoKilledByCall.
|
inlinevirtual |
Return true if this pointer occurs before an indirect return pointer.
The automatic parameters: this parameter and the hidden return value pointer both tend to be allocated from the initial general purpose registers reserved for parameter passing. This method returns true if the this parameter is allocated first.
Implements ghidra::ParamList.
References thisbeforeret.
|
staticprotected |
From among multiple inactive trials, select the most likely to be active and mark others as not used.
There can be at most one inactive trial in an exclusion group for the fill algorithms to work. Score all the trials and pick the one that is the most likely to actually be an active param. Mark all the others as definitely not used.
active | is the sorted set of trials |
group | is the group number |
groupStart | is the index of the first trial in the group |
prefType | is a preferred entry to type to use in scoring |
References entry, ghidra::ParamTrial::getEntry(), ghidra::ParamEntry::getGroup(), ghidra::ParamActive::getNumTrials(), ghidra::ParamActive::getTrial(), ghidra::ParamTrial::hasAncestorRealistic(), ghidra::ParamTrial::hasAncestorSolid(), ghidra::ParamTrial::isDefinitelyNotUsed(), and markGroupNoUse().
Referenced by forceExclusionGroup().
|
staticprotected |
Mark all the trials within the indicated groups as not used, except for one specified index.
Only one trial within an exclusion group can have active use, mark all others as unused.
active | is the set of trials, which must be sorted on group |
activeTrial | is the index of the trial whose groups are to be considered active |
trialStart | is the index of the first trial to mark |
References ghidra::ParamTrial::getEntry(), ghidra::ParamActive::getNumTrials(), ghidra::ParamActive::getTrial(), ghidra::ParamEntry::groupOverlap(), ghidra::ParamTrial::isDefinitelyNotUsed(), and ghidra::ParamTrial::markNoUse().
Referenced by forceExclusionGroup(), and markBestInactive().
|
protected |
Parse a sequence of <pentry> elements that are allocated as a group.
All ParamEntry objects will share the same group id.
decoder | is the stream decoder |
effectlist | holds any passed back effect records |
groupid | is the group to which all ParamEntry elements are assigned |
normalstack | is true if the parameters should be allocated from the front of the range |
splitFloat | is true if floating-point parameters are in their own resource section |
References ghidra::Decoder::closeElement(), entry, ghidra::ParamEntry::getSpace(), ghidra::AddrSpace::getType(), ghidra::IPTR_JOIN, numgroup, ghidra::Decoder::openElement(), ghidra::ParamEntry::orderWithinGroup(), parsePentry(), and ghidra::Decoder::peekElement().
Referenced by decode().
|
protected |
Parse a <pentry> element and add it to this list.
decoder | is the stream decoder |
effectlist | holds any passed back effect records |
groupid | is the group to which the new ParamEntry is assigned |
normalstack | is true if the parameters should be allocated from the front of the range |
splitFloat | is true if floating-point parameters are in their own resource section |
grouped | is true if the new ParamEntry is grouped with other entries |
References autoKilledByCall, entry, ghidra::AddrSpace::getType(), ghidra::IPTR_SPACEBASE, ghidra::EffectRecord::killedbycall, numgroup, resourceStart, spacebase, ghidra::TYPECLASS_CLASS4, and ghidra::TYPECLASS_GENERAL.
Referenced by decode(), and parseGroup().
|
protected |
Build the ParamEntry resolver maps.
Enter all the ParamEntry objects into an interval map (based on address space)
References addResolverRange(), entry, ghidra::ParamEntry::getBase(), ghidra::ParamEntry::getJoinRecord(), ghidra::JoinRecord::getPiece(), ghidra::ParamEntry::getSize(), ghidra::ParamEntry::getSpace(), ghidra::AddrSpace::getType(), ghidra::IPTR_JOIN, ghidra::JoinRecord::numPieces(), ghidra::VarnodeData::offset, ghidra::VarnodeData::size, and ghidra::VarnodeData::space.
Referenced by decode(), ghidra::ParamListMerged::finalize(), and ParamListStandard().
|
virtual |
Does the given storage location make sense as a parameter.
Within this model, decide if the storage location can be considered a parameter.
loc | is the starting address of the storage location |
size | is the number of bytes in the storage location |
Implements ghidra::ParamList.
Reimplemented in ghidra::ParamListStandardOut.
References findEntry().
|
virtual |
Pass-back the slot and slot size for the given storage location as a parameter.
This checks if the given storage location acts as a parameter in this model and passes back the number of slots that it occupies.
loc | is the starting address of the storage location |
size | is the number of bytes in the storage location |
slot | if the slot number to pass back |
slotsize | is the number of consumed slots to pass back |
Implements ghidra::ParamList.
References findEntry(), ghidra::ParamEntry::getAlign(), ghidra::ParamEntry::getAllGroups(), ghidra::ParamEntry::getSlot(), and ghidra::ParamEntry::isExclusion().
|
protected |
Select entry to fill an unreferenced param.
From among the ParamEntrys matching the given group, return the one that best matches the given metatype attribute. If there are no ParamEntrys in the group, null is returned.
grp | is the given group number |
prefType | is the preferred storage class attribute to match |
References entry, ghidra::ParamEntry::getGroup(), ghidra::ParamEntry::getType(), and ghidra::TYPECLASS_GENERAL.
Referenced by buildTrialMap().
|
protected |
Calculate the range of trials in each resource sections.
The trials must already be mapped, which should put them in group order. The sections split at the groups given by resourceStart. We pass back the starting index for each range of trials.
active | is the given set of parameter trials |
trialStart | will hold the starting index for each range of trials |
References ghidra::ParamTrial::getEntry(), ghidra::ParamEntry::getGroup(), ghidra::ParamActive::getNumTrials(), ghidra::ParamActive::getTrial(), and resourceStart.
Referenced by fillinMap().
|
virtual |
Check if the given storage location looks like an unjustified parameter.
The storage for a value may be contained in a normal parameter location but be unjustified within that container, i.e. the least significant bytes are not being used. If this is the case, pass back the full parameter location and return true.
loc | is the starting address of the given storage |
size | is the number of bytes in the given storage |
res | is the full parameter storage to pass back |
Implements ghidra::ParamList.
References entry.