|  | 
|  | FuncCallSpecs (PcodeOp *call_op) | 
|  | Construct based on CALL or CALLIND.  More... 
 | 
|  | 
| void | setFuncdata (Funcdata *f) | 
|  | Set the Funcdata object associated with the called function. 
 | 
|  | 
| FuncCallSpecs * | clone (PcodeOp *newop) const | 
|  | Clone this given the mirrored p-code CALL.  More... 
 | 
|  | 
| void | initActiveInput (void) | 
|  | Turn on analysis recovering input parameters. 
 | 
|  | 
| bool | checkInputJoin (int4 slot1, bool ishislot, Varnode *vn1, Varnode *vn2) const | 
|  | Check if adjacent parameter trials can be combined into a single logical parameter.  More... 
 | 
|  | 
| void | doInputJoin (int4 slot1, bool ishislot) | 
|  | Join two parameter trials.  More... 
 | 
|  | 
| bool | lateRestriction (const FuncProto &restrictedProto, vector< Varnode * > &newinput, Varnode *&newoutput) | 
|  | Update this prototype to match a given (more specialized) prototype.  More... 
 | 
|  | 
| void | deindirect (Funcdata &data, Funcdata *newfd) | 
|  | Convert this call site from an indirect to a direct function call.  More... 
 | 
|  | 
| void | forceSet (Funcdata &data, const FuncProto &fp) | 
|  | Force a more restrictive prototype on this call site.  More... 
 | 
|  | 
| void | insertPcode (Funcdata &data) | 
|  | Inject any upon-return p-code at this call site.  More... 
 | 
|  | 
| void | resolveSpacebaseRelative (Funcdata &data, Varnode *phvn) | 
|  | Calculate the stack offset of this call site.  More... 
 | 
|  | 
| void | abortSpacebaseRelative (Funcdata &data) | 
|  | Abort the attempt to recover the relative stack offset for this function.  More... 
 | 
|  | 
| void | finalInputCheck (void) | 
|  | Make final activity check on trials that might have been affected by conditional execution.  More... 
 | 
|  | 
| void | checkInputTrialUse (Funcdata &data, AliasChecker &aliascheck) | 
|  | Mark if input trials are being actively used.  More... 
 | 
|  | 
| void | checkOutputTrialUse (Funcdata &data, vector< Varnode * > &trialvn) | 
|  | Mark if output trials are being actively used.  More... 
 | 
|  | 
| void | buildInputFromTrials (Funcdata &data) | 
|  | Set the final input Varnodes to this CALL based on ParamActive analysis.  More... 
 | 
|  | 
| void | buildOutputFromTrials (Funcdata &data, vector< Varnode * > &trialvn) | 
|  | Set the final output Varnode of this CALL based on ParamActive analysis of trials.  More... 
 | 
|  | 
| int4 | getInputBytesConsumed (int4 slot) const | 
|  | Get the estimated number of bytes within the given parameter that are consumed.  More... 
 | 
|  | 
| bool | setInputBytesConsumed (int4 slot, int4 val) const | 
|  | Set the estimated number of bytes within the given parameter that are consumed.  More... 
 | 
|  | 
| void | paramshiftModifyStart (void) | 
|  | Prepend any extra parameters if a paramshift is required. 
 | 
|  | 
| bool | paramshiftModifyStop (Funcdata &data) | 
|  | Throw out any paramshift parameters.  More... 
 | 
|  | 
| uint4 | hasEffectTranslate (const Address &addr, int4 size) const | 
|  | Calculate type of side-effect for a given storage location (with caller translation)  More... 
 | 
|  | 
|  | FuncProto (void) | 
|  | Constructor. 
 | 
|  | 
|  | ~FuncProto (void) | 
|  | Destructor. 
 | 
|  | 
| void | copy (const FuncProto &op2) | 
|  | Copy another function prototype.  More... 
 | 
|  | 
| void | copyFlowEffects (const FuncProto &op2) | 
|  | Copy properties that affect data-flow. 
 | 
|  | 
| void | getPieces (PrototypePieces &pieces) const | 
|  | Get the raw pieces of the prototype.  More... 
 | 
|  | 
| void | setPieces (const PrototypePieces &pieces) | 
|  | Set this prototype based on raw pieces.  More... 
 | 
|  | 
| void | setScope (Scope *s, const Address &startpoint) | 
|  | Set a backing symbol Scope for this.  More... 
 | 
|  | 
| void | setInternal (ProtoModel *m, Datatype *vt) | 
|  | Set internal backing storage for this.  More... 
 | 
|  | 
| void | setModel (ProtoModel *m) | 
|  | Set the prototype model for this.  More... 
 | 
|  | 
| bool | isInputLocked (void) const | 
|  | Are input data-types locked. 
 | 
|  | 
| void | setInputLock (bool val) | 
|  | Toggle the data-type lock on input parameters.  More... 
 | 
|  | 
| void | setOutputLock (bool val) | 
|  | Toggle the data-type lock on the return value.  More... 
 | 
|  | 
| void | setModelLock (bool val) | 
|  | Toggle the lock on the prototype model for this.  More... 
 | 
|  | 
| void | setInline (bool val) | 
|  | Toggle the in-line setting for functions with this prototype.  More... 
 | 
|  | 
| int4 | getInjectId (void) const | 
|  | Get the injection id associated with this.  More... 
 | 
|  | 
| int4 | getReturnBytesConsumed (void) const | 
|  | Get an estimate of the number of bytes consumed by callers of this prototype.  More... 
 | 
|  | 
| bool | setReturnBytesConsumed (int4 val) | 
|  | Set the number of bytes consumed by callers of this.  More... 
 | 
|  | 
| bool | isNoReturn (void) const | 
|  | Does a function with this prototype never return. 
 | 
|  | 
| void | setNoReturn (bool val) | 
|  | Toggle the no-return setting for functions with this prototype.  More... 
 | 
|  | 
| bool | hasThisPointer (void) const | 
|  | Is this a prototype for a class method, taking a this pointer. 
 | 
|  | 
| bool | isConstructor (void) const | 
|  | Is this prototype for a class constructor method. 
 | 
|  | 
| void | setConstructor (bool val) | 
|  | Toggle whether this prototype is a constructor method.  More... 
 | 
|  | 
| bool | isDestructor (void) const | 
|  | Is this prototype for a class destructor method. 
 | 
|  | 
| void | setDestructor (bool val) | 
|  | Toggle whether this prototype is a destructor method.  More... 
 | 
|  | 
| bool | hasInputErrors (void) const | 
|  | Has this prototype been marked as having an incorrect input parameter descriptions. 
 | 
|  | 
| bool | hasOutputErrors (void) const | 
|  | Has this prototype been marked as having an incorrect return value description. 
 | 
|  | 
| void | setInputErrors (bool val) | 
|  | Toggle the input error setting for this prototype.  More... 
 | 
|  | 
| void | setOutputErrors (bool val) | 
|  | Toggle the output error setting for this prototype.  More... 
 | 
|  | 
| void | resolveExtraPop (void) | 
|  | Assuming this prototype is locked, calculate the extrapop.  More... 
 | 
|  | 
| void | clearUnlockedInput (void) | 
|  | Clear input parameters that have not been locked. 
 | 
|  | 
| void | clearUnlockedOutput (void) | 
|  | Clear the return value if it has not been locked. 
 | 
|  | 
| void | clearInput (void) | 
|  | Clear all input parameters regardless of lock. 
 | 
|  | 
| void | cancelInjectId (void) | 
|  | Turn-off any in-lining for this function. 
 | 
|  | 
| void | resolveModel (ParamActive *active) | 
|  | If this has a merged model, pick the most likely model (from the merged set)  More... 
 | 
|  | 
| void | deriveInputMap (ParamActive *active) const | 
|  | Given a list of input trials, derive the most likely inputs for this prototype.  More... 
 | 
|  | 
| void | deriveOutputMap (ParamActive *active) const | 
|  | Given a list of output trials, derive the most likely return value for this prototype.  More... 
 | 
|  | 
| bool | checkInputJoin (const Address &hiaddr, int4 hisz, const Address &loaddr, int4 losz) const | 
|  | Check if the given two input storage locations can represent a single logical parameter.  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... 
 | 
|  | 
| void | updateInputTypes (Funcdata &data, const vector< Varnode * > &triallist, ParamActive *activeinput) | 
|  | Update input parameters based on Varnode trials.  More... 
 | 
|  | 
| void | updateInputNoTypes (Funcdata &data, const vector< Varnode * > &triallist, ParamActive *activeinput) | 
|  | Update input parameters based on Varnode trials, but do not store the data-type.  More... 
 | 
|  | 
| void | updateOutputTypes (const vector< Varnode * > &triallist) | 
|  | Update the return value based on Varnode trials.  More... 
 | 
|  | 
| void | updateOutputNoTypes (const vector< Varnode * > &triallist, TypeFactory *factory) | 
|  | Update the return value based on Varnode trials, but don't store the data-type.  More... 
 | 
|  | 
| void | updateAllTypes (const vector< string > &namelist, const vector< Datatype * > &typelist, bool dtdtdt) | 
|  | Set this entire function prototype based on a list of names and data-types.  More... 
 | 
|  | 
| uint4 | hasEffect (const Address &addr, int4 size) const | 
|  | Calculate the effect this has an a given storage location.  More... 
 | 
|  | 
| vector< EffectRecord >::const_iterator | effectBegin (void) const | 
|  | Get iterator to front of EffectRecord list. 
 | 
|  | 
| vector< EffectRecord >::const_iterator | effectEnd (void) const | 
|  | Get iterator to end of EffectRecord list. 
 | 
|  | 
| int4 | numLikelyTrash (void) const | 
|  | Get the number of likely-trash locations.  More... 
 | 
|  | 
| const VarnodeData & | getLikelyTrash (int4 i) const | 
|  | Get the i-th likely-trash location.  More... 
 | 
|  | 
| int4 | characterizeAsInputParam (const Address &addr, int4 size) const | 
|  | Decide whether a given storage location could be, or could hold, an input parameter.  More... 
 | 
|  | 
| bool | possibleInputParam (const Address &addr, int4 size) const | 
|  | Decide whether a given storage location could be an input parameter.  More... 
 | 
|  | 
| bool | possibleOutputParam (const Address &addr, int4 size) const | 
|  | Decide whether a given storage location could be a return value.  More... 
 | 
|  | 
| 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... 
 | 
|  | 
| bool | unjustifiedInputParam (const Address &addr, 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 potential input parameter contained within the given range.  More... 
 | 
|  | 
| bool | isCompatible (const FuncProto &op2) const | 
|  | Decide if this can be safely restricted to match another prototype.  More... 
 | 
|  | 
| void | printRaw (const string &funcname, ostream &s) const | 
|  | Print this prototype as a single line of text.  More... 
 | 
|  | 
| uint4 | getComparableFlags (void) const | 
|  | Get the comparable properties of this prototype.  More... 
 | 
|  | 
| void | saveXml (ostream &s) const | 
|  | Save this to an XML stream as a <prototype> tag.  More... 
 | 
|  | 
| void | restoreXml (const Element *el, Architecture *glb) | 
|  | Restore this from an XML stream.  More... 
 | 
|  | 
A class for analyzing parameters to a sub-function call. 
This can be viewed as a function prototype that evolves over the course of analysis. It derives off of FuncProto and includes facilities for analyzing data-flow for parameter information. This is the high-level object managing the examination of data-flow to recover a working prototype (ParamActive), holding a stack-pointer placeholder to facilitate stack analysis, and deciding on the working extrapop for the CALL.
A stack-pointer placeholder is a temporary Varnode in the input operands of the CALL or CALLIND that is defined by a LOAD from the stack-pointer. By examining the pointer, the exact value of the stack-pointer (relative to its incoming value) can be computed at the point of the CALL. The temporary can arise naturally if stack parameters are a possibility, otherwise a placeholder temporary is artificially inserted into the CALL input. At the time heritage of the stack space is computed, the placeholder is examined to read off the active stack-pointer offset for the CALL and the placeholder is removed.