Ghidra 11.4.2
Ghidra internal decompiler documentation.
|
A generic functional operator. More...
#include <typeop.hh>
Public Member Functions | |
TypeOpFunc (TypeFactory *t, OpCode opc, const string &n, type_metatype mout, type_metatype min) | |
Constructor. | |
virtual Datatype * | getOutputLocal (const PcodeOp *op) const |
Find the minimal (or suggested) data-type of an output to this op-code. | |
virtual Datatype * | getInputLocal (const PcodeOp *op, int4 slot) const |
Find the minimal (or suggested) data-type of an input to this op-code. | |
virtual void | printRaw (ostream &s, const PcodeOp *op) |
Print (for debugging purposes) this specific PcodeOp to the stream. | |
![]() | |
TypeOp (TypeFactory *t, OpCode opc, const string &n) | |
Constructor. | |
virtual | ~TypeOp (void) |
Destructor. | |
const string & | getName (void) const |
Get the display name of the op-code. | |
OpCode | getOpcode (void) const |
Get the op-code value. | |
uint4 | getFlags (void) const |
Get the properties associated with the op-code. | |
OpBehavior * | getBehavior (void) const |
Get the behavior associated with the op-code. | |
uintb | evaluateUnary (int4 sizeout, int4 sizein, uintb in1) const |
Emulate the unary op-code on an input value. | |
uintb | evaluateBinary (int4 sizeout, int4 sizein, uintb in1, uintb in2) const |
Emulate the binary op-code on an input value. | |
uintb | recoverInputBinary (int4 slot, int4 sizeout, uintb out, int4 sizein, uintb in) const |
Reverse the binary op-code operation, recovering a constant input value. | |
uintb | recoverInputUnary (int4 sizeout, uintb out, int4 sizein) const |
Reverse the unary op-code operation, recovering a constant input value. | |
bool | isCommutative (void) const |
Return true if this op-code is commutative. | |
bool | inheritsSign (void) const |
Return true if the op-code inherits its signedness from its inputs. | |
bool | inheritsSignFirstParamOnly (void) const |
Return true if the op-code inherits its signedness from only its first input. | |
bool | isShiftOp (void) const |
Return true if the op-code is a shift (INT_LEFT, INT_RIGHT, or INT_SRIGHT) | |
bool | isArithmeticOp (void) const |
Return true if the opcode is INT_ADD, INT_MULT, INT_DIV, INT_REM, or other arithmetic op. | |
bool | isLogicalOp (void) const |
Return true if the opcode is INT_AND, INT_OR, INT_XOR, or other logical op. | |
bool | isFloatingPointOp (void) const |
Return true if the opcode is FLOAT_ADD, FLOAT_MULT, or other floating-point operation. | |
virtual Datatype * | getOutputToken (const PcodeOp *op, CastStrategy *castStrategy) const |
Find the data-type of the output that would be assigned by a compiler. | |
virtual Datatype * | getInputCast (const PcodeOp *op, int4 slot, const CastStrategy *castStrategy) const |
Find the data-type of the input to a specific PcodeOp. | |
virtual Datatype * | propagateType (Datatype *alttype, PcodeOp *op, Varnode *invn, Varnode *outvn, int4 inslot, int4 outslot) |
Propagate an incoming data-type across a specific PcodeOp. | |
virtual void | push (PrintLanguage *lng, const PcodeOp *op, const PcodeOp *readOp) const =0 |
Push the specific PcodeOp to the emitter's RPN stack. | |
virtual string | getOperatorName (const PcodeOp *op) const |
Get the name of the op-code as it should be displayed in context. | |
Private Member Functions | |
virtual void | setMetatypeIn (type_metatype val) |
Set the data-type (as a meta-type) associated with inputs to this opcode. | |
virtual void | setMetatypeOut (type_metatype val) |
Set the data-type (as a meta-type) associated with outputs of this opcode. | |
Private Attributes | |
type_metatype | metaout |
The metatype of the output. | |
type_metatype | metain |
The metatype of the inputs. | |
Additional Inherited Members | |
![]() | |
enum | { inherits_sign = 1 , inherits_sign_zero = 2 , shift_op = 4 , arithmetic_op = 8 , logical_op = 0x10 , floatingpoint_op = 0x20 } |
![]() | |
static void | registerInstructions (vector< TypeOp * > &inst, TypeFactory *tlst, const Translate *trans) |
Build a map from op-code value to the TypeOp information objects. | |
static void | selectJavaOperators (vector< TypeOp * > &inst, bool val) |
Toggle Java specific aspects of the op-code information. | |
static OpCode | floatSignManipulation (PcodeOp *op) |
Return the floating-point operation associated with the sign bit manipulation by the given PcodeOp. | |
static Datatype * | propagateToPointer (TypeFactory *t, Datatype *dt, int4 sz, int4 wordsz) |
Propagate a dereferenced data-type up to its pointer data-type through a LOAD or STORE. | |
static Datatype * | propagateFromPointer (TypeFactory *t, Datatype *dt, int4 sz) |
Propagate a pointer data-type down to its element data-type through a LOAD or STORE. | |
![]() | |
virtual void | setSymbol (const string &nm) |
Set the display symbol associated with the op-code. | |
![]() | |
TypeFactory * | tlst |
Pointer to data-type factory. | |
OpCode | opcode |
The op-code value. | |
uint4 | opflags |
Cached pcode-op properties for this op-code. | |
uint4 | addlflags |
Additional properties. | |
string | name |
Symbol denoting this operation. | |
OpBehavior * | behave |
Object for emulating the behavior of the op-code. | |
A generic functional operator.
The operator takes one or more inputs (with the same data-type by default) and produces one output with specific data-type
Find the minimal (or suggested) data-type of an input to this op-code.
The result should depend only on the op-code itself (and the size of the input)
op | is the PcodeOp being considered |
slot | is the input being considered |
Reimplemented from ghidra::TypeOp.
Reimplemented in ghidra::TypeOpInsert, and ghidra::TypeOpExtract.
References ghidra::TypeFactory::getBase(), ghidra::PcodeOp::getIn(), ghidra::Varnode::getSize(), metain, and ghidra::TypeOp::tlst.
Referenced by ghidra::TypeOpInsert::getInputLocal(), and ghidra::TypeOpExtract::getInputLocal().
Find the minimal (or suggested) data-type of an output to this op-code.
The result should depend only on the op-code itself (and the size of the output)
op | is the PcodeOp being considered |
Reimplemented from ghidra::TypeOp.
References ghidra::TypeFactory::getBase(), ghidra::PcodeOp::getOut(), ghidra::Varnode::getSize(), metaout, and ghidra::TypeOp::tlst.
|
virtual |
Print (for debugging purposes) this specific PcodeOp to the stream.
s | is the output stream |
op | is the specific PcodeOp to print |
Implements ghidra::TypeOp.
References ghidra::PcodeOp::getIn(), ghidra::TypeOp::getOperatorName(), ghidra::PcodeOp::getOut(), ghidra::PcodeOp::numInput(), and ghidra::Varnode::printRaw().
|
inlineprivatevirtual |
Set the data-type (as a meta-type) associated with inputs to this opcode.
val | is the data-type of inputs |
Reimplemented from ghidra::TypeOp.
References metain.
|
inlineprivatevirtual |
Set the data-type (as a meta-type) associated with outputs of this opcode.
val | is the data-type of outputs |
Reimplemented from ghidra::TypeOp.
References metaout.