|
Ghidra 11.4.2
Ghidra internal decompiler documentation.
|
Perform SubvariableFlow analysis triggered by INT_SEXT. More...
#include <subflow.hh>
Public Member Functions | |
| RuleSubvarSext (const string &g) | |
| Constructor. | |
| virtual Rule * | clone (const ActionGroupList &grouplist) const |
| Clone the Rule. | |
| virtual void | getOpList (vector< uint4 > &oplist) const |
| List of op codes this rule operates on. | |
| virtual int4 | applyOp (PcodeOp *op, Funcdata &data) |
| Attempt to apply this Rule. | |
| virtual void | reset (Funcdata &data) |
| Reset this Rule. | |
Public Member Functions inherited from ghidra::Rule | |
| Rule (const string &g, uint4 fl, const string &nm) | |
| Construct given group, properties name. | |
| virtual | ~Rule (void) |
| Destructor. | |
| const string & | getName (void) const |
| Return the name of this Rule. | |
| const string & | getGroup (void) const |
| Return the group this Rule belongs to. | |
| uint4 | getNumTests (void) |
| Get number of attempted applications. | |
| uint4 | getNumApply (void) |
| Get number of successful applications. | |
| void | setBreak (uint4 tp) |
| Set a breakpoint on this Rule. | |
| void | clearBreak (uint4 tp) |
| Clear a breakpoint on this Rule. | |
| void | clearBreakPoints (void) |
| Clear all breakpoints on this Rule. | |
| void | turnOnWarnings (void) |
| Enable warnings for this Rule. | |
| void | turnOffWarnings (void) |
| Disable warnings for this Rule. | |
| bool | isDisabled (void) const |
| Return true if this Rule is disabled. | |
| void | setDisable (void) |
| Disable this Rule (within its pool) | |
| void | clearDisable (void) |
| Enable this Rule (within its pool) | |
| bool | checkActionBreak (void) |
| Check if an action breakpoint is turned on. | |
| uint4 | getBreakPoint (void) const |
| Return breakpoint toggles. | |
| virtual void | resetStats (void) |
| Reset Rule statistics. | |
| virtual void | printStatistics (ostream &s) const |
| Print statistics for this Rule. | |
Private Attributes | |
| int4 | isaggressive |
| Is it guaranteed the root is a sub-variable needing to be trimmed. | |
Additional Inherited Members | |
Public Types inherited from ghidra::Rule | |
| enum | typeflags { type_disable = 1 , rule_debug = 2 , warnings_on = 4 , warnings_given = 8 } |
| Properties associated with a Rule. More... | |
Perform SubvariableFlow analysis triggered by INT_SEXT.
Attempt to apply this Rule.
This method contains the main logic for applying the Rule. It must use a given PcodeOp as the point at which the Rule applies. If it does apply, changes are made directly to the function and 1 (non-zero) is returned, otherwise 0 is returned.
Reimplemented from ghidra::Rule.
References ghidra::calc_mask(), ghidra::SubvariableFlow::doReplacement(), ghidra::SubvariableFlow::doTrace(), ghidra::PcodeOp::getIn(), ghidra::PcodeOp::getOut(), ghidra::Varnode::getSize(), and isaggressive.
|
inlinevirtual |
Clone the Rule.
If this Rule is a member of one of the groups in the grouplist, this returns a clone of the Rule, otherwise NULL is returned.
| grouplist | is the list of groups being cloned |
Implements ghidra::Rule.
References ghidra::ActionGroupList::contains(), and ghidra::Rule::getGroup().
|
virtual |
List of op codes this rule operates on.
Populate the given array with all possible OpCodes this Rule might apply to. By default, this method returns all possible OpCodes
| oplist | is the array to populate |
Reimplemented from ghidra::Rule.
References ghidra::CPUI_INT_SEXT.
|
virtual |
Reset this Rule.
Any state that is specific to a particular function is cleared by this method. This method can be used to initialize a Rule based on a new function it will apply to
| data | is the new function about to be transformed |
Reimplemented from ghidra::Rule.
References ghidra::Architecture::aggressive_ext_trim, ghidra::Funcdata::getArch(), and isaggressive.