Ghidra Decompiler Analysis Engine
|
Convert "shift and add" to PIECE: (zext(V) << 16) + zext(W) => concat(V,W) More...
Public Member Functions | |
virtual Rule * | clone (const ActionGroupList &grouplist) const |
Clone the Rule. More... | |
virtual void | getOpList (vector< uint4 > &oplist) const |
List of op codes this rule operates on. More... | |
virtual int4 | applyOp (PcodeOp *op, Funcdata &data) |
Attempt to apply this Rule. More... | |
Public Member Functions inherited from Rule | |
Rule (const string &g, uint4 fl, const string &nm) | |
Construct given group, properties name. More... | |
bool | checkActionBreak (void) |
Check if an action breakpoint is turned on. More... | |
virtual void | reset (Funcdata &data) |
Reset this Rule. More... | |
virtual void | resetStats (void) |
Reset Rule statistics. More... | |
virtual void | printStatistics (ostream &s) const |
Print statistics for this Rule. More... | |
Additional Inherited Members | |
Public Types inherited from Rule | |
enum | typeflags { type_disable = 1, rule_debug = 2, warnings_on = 4, warnings_given = 8 } |
Properties associated with a Rule. More... | |
Convert "shift and add" to PIECE: (zext(V) << 16) + zext(W) => concat(V,W)
The add operation can be INT_ADD, INT_OR, or INT_XOR. If the extension size is bigger than the concatentation size, the concatentation can be zero extended. This also supports other special forms where a value gets concatenated with its own sign extension bits.
(zext(V s>> 0x1f) << 0x20) + zext(V) => sext(V)
(zext(W s>> 0x1f) << 0x20) + X => sext(W) where W = sub(X,0)
|
inlinevirtual |
|
virtual |