decompiler
1.0.0
|
A prototype model made by merging together other models. More...
#include <fspec.hh>
Public Member Functions | |
ProtoModelMerged (Architecture *g) | |
Constructor. | |
virtual | ~ProtoModelMerged (void) |
Destructor. | |
int4 | numModels (void) const |
Get the number of constituent models. | |
ProtoModel * | getModel (int4 i) const |
Get the i-th model. | |
void | foldIn (ProtoModel *model) |
Fold-in an additional prototype model. More... | |
ProtoModel * | selectModel (ParamActive *active) const |
Select the best model given a set of trials. More... | |
virtual bool | isMerged (void) const |
Is this a merged prototype model. | |
virtual void | restoreXml (const Element *el) |
Restore this model from an XML stream. More... | |
Public Member Functions inherited from ProtoModel | |
ProtoModel (Architecture *g) | |
Constructor for use with restoreXml() More... | |
ProtoModel (const string &nm, const ProtoModel &op2) | |
Copy constructor changing the name. More... | |
virtual | ~ProtoModel (void) |
Destructor. | |
const string & | getName (void) const |
Get the name of the prototype model. | |
Architecture * | getArch (void) const |
Get the owning Architecture. | |
uint4 | hasEffect (const Address &addr, int4 size) const |
Determine side-effect of this on the given memory range. More... | |
int4 | getExtraPop (void) const |
Get the stack-pointer extrapop for this model. | |
void | setExtraPop (int4 ep) |
Set the stack-pointer extrapop. | |
int4 | getInjectUponEntry (void) const |
Get the inject uponentry id. | |
int4 | getInjectUponReturn (void) const |
Get the inject uponreturn id. | |
bool | isCompatible (const ProtoModel *op2) const |
Return true if other given model can be substituted for this. More... | |
void | deriveInputMap (ParamActive *active) const |
Given a list of input trials, derive the most likely input prototype. More... | |
void | deriveOutputMap (ParamActive *active) const |
Given a list of output trials, derive the most likely output prototype. More... | |
void | assignParameterStorage (const vector< Datatype * > &typelist, vector< ParameterPieces > &res, bool ignoreOutputError) |
Calculate input and output storage locations given a function prototype. More... | |
bool | checkInputJoin (const Address &hiaddr, int4 hisize, const Address &loaddr, int4 losize) const |
Check if the given two input storage locations can represent a single logical parameter. More... | |
bool | checkOutputJoin (const Address &hiaddr, int4 hisize, const Address &loaddr, int4 losize) const |
Check if the given two output storage locations can represent a single logical return value. More... | |
bool | checkInputSplit (const Address &loc, int4 size, int4 splitpoint) const |
Check if it makes sense to split a single storage location into two input parameters. More... | |
const RangeList & | getLocalRange (void) const |
Get the range of (possible) local stack variables. | |
const RangeList & | getParamRange (void) const |
Get the range of (possible) stack parameters. | |
vector< EffectRecord >::const_iterator | effectBegin (void) const |
Get an iterator to the first EffectRecord. | |
vector< EffectRecord >::const_iterator | effectEnd (void) const |
Get an iterator to the last EffectRecord. | |
int4 | numLikelyTrash (void) const |
Get the number of likelytrash locations. | |
const VarnodeData & | getLikelyTrash (int4 i) const |
Get the i-th likelytrashh location. | |
int4 | characterizeAsInputParam (const Address &loc, int4 size) const |
Characterize whether the given range overlaps parameter storage. More... | |
bool | possibleInputParam (const Address &loc, int4 size) const |
Does the given storage location make sense as an input parameter. More... | |
bool | possibleOutputParam (const Address &loc, int4 size) const |
Does the given storage location make sense as a return value. More... | |
bool | possibleInputParamWithSlot (const Address &loc, int4 size, int4 &slot, int4 &slotsize) const |
Pass-back the slot and slot size for the given storage location as an input parameter. More... | |
bool | possibleOutputParamWithSlot (const Address &loc, int4 size, int4 &slot, int4 &slotsize) const |
Pass-back the slot and slot size for the given storage location as a return value. More... | |
bool | unjustifiedInputParam (const Address &loc, int4 size, VarnodeData &res) const |
Check if the given storage location looks like an unjustified input parameter. More... | |
OpCode | assumedInputExtension (const Address &addr, int4 size, VarnodeData &res) const |
Get the type of extension and containing input parameter for the given storage. More... | |
OpCode | assumedOutputExtension (const Address &addr, int4 size, VarnodeData &res) const |
Get the type of extension and containing return value location for the given storage. More... | |
bool | getBiggestContainedInputParam (const Address &loc, int4 size, VarnodeData &res) const |
Pass-back the biggest input parameter contained within the given range. More... | |
AddrSpace * | getSpacebase (void) const |
Get the stack space associated with this model. | |
bool | isStackGrowsNegative (void) const |
Return true if the stack grows toward smaller addresses. | |
bool | hasThisPointer (void) const |
Is this a model for (non-static) class methods. | |
bool | isConstructor (void) const |
Is this model for class constructors. | |
int4 | getMaxInputDelay (void) const |
Return the maximum heritage delay across all possible input parameters. More... | |
int4 | getMaxOutputDelay (void) const |
Return the maximum heritage delay across all possible return values. More... | |
Private Member Functions | |
void | intersectEffects (const vector< EffectRecord > &efflist) |
Fold EffectRecords into this model. More... | |
void | intersectLikelyTrash (const vector< VarnodeData > &trashlist) |
Fold likelytrash locations into this model. More... | |
Private Attributes | |
vector< ProtoModel * > | modellist |
Constituent models being merged. | |
Additional Inherited Members | |
Public Types inherited from ProtoModel | |
enum | { extrapop_unknown = 0x8000 } |
Static Public Member Functions inherited from ProtoModel | |
static uint4 | lookupEffect (const vector< EffectRecord > &efflist, const Address &addr, int4 size) |
Look up an effect from the given EffectRecord list. More... | |
A prototype model made by merging together other models.
This model serves as a placeholder for multiple models, when the exact model hasn't been immediately determined. At the time of active parameter recovery the correct model is selected for the given set of trials from among the constituent prototype models used to build this, by calling the method selectModel(). Up to this time, this serves as a merged form of the models so that all potential parameter trials will be included in the analysis. The parameter recovery for the output part of the model is currently limited, so the constituent models must all share the same output model, and this part is not currently merged.
void ProtoModelMerged::foldIn | ( | ProtoModel * | model | ) |
Fold-in an additional prototype model.
model | is the new prototype model to add to the merge |
References RangeList::begin(), ProtoModel::effectlist, RangeList::end(), ProtoModel::extrapop, ProtoModel::extrapop_unknown, ParamList::getType(), ProtoModel::glb, ProtoModel::injectUponEntry, ProtoModel::injectUponReturn, ProtoModel::input, ProtoModel::likelytrash, ProtoModel::localrange, ProtoModel::output, ParamList::p_register, ParamList::p_standard, and ProtoModel::paramrange.
|
private |
Fold EffectRecords into this model.
The EffectRecord lists are intersected. Anything in this that is not also in the given EffectRecord list is removed.
efflist | is the given EffectRecord list |
|
private |
Fold likelytrash locations into this model.
The likely-trash locations are intersected. Anything in this that is not also in the given likely-trash list is removed.
trashlist | is the given likely-trash list |
|
virtual |
Restore this model from an XML stream.
Read in details about this model from a <prototype> tag
el | is the <prototype> element |
Reimplemented from ProtoModel.
References Element::getAttributeValue(), Element::getChildren(), and AddrSpace::name.
Referenced by ProtoModel::isMerged().
ProtoModel * ProtoModelMerged::selectModel | ( | ParamActive * | active | ) | const |
Select the best model given a set of trials.
The model that best matches the given set of input parameter trials is returned. This method currently uses the ScoreProtoModel object to score the different prototype models.
active | is the set of parameter trials |
References ScoreProtoModel::addParameter(), ScoreProtoModel::doScore(), ParamActive::getNumTrials(), ScoreProtoModel::getScore(), and ParamActive::getTrial().
Referenced by FuncProto::resolveModel().