Ghidra 11.4.2
Ghidra internal decompiler documentation.
|
Information about the SEGMENTOP op-code. More...
#include <typeop.hh>
Public Member Functions | |
TypeOpSegment (TypeFactory *t) | |
Constructor. | |
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 * | getOutputToken (const PcodeOp *op, CastStrategy *castStrategy) const |
Find the data-type of the output that would be assigned by a compiler. | |
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 |
Push the specific PcodeOp to the emitter's RPN stack. | |
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 * | 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 string | getOperatorName (const PcodeOp *op) const |
Get the name of the op-code as it should be displayed in context. | |
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 | 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. | |
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. | |
Information about the SEGMENTOP op-code.
The segment operator is a placeholder for address mappings (i.e. from virtual to physical) that a compiler (or processor) may generate as part of its memory model. Typically this is of little concern to the high-level code, so this scheme allows the decompiler to track it but ignore it where appropriate, such as in type propagation and printing high-level expressions
|
virtual |
Find the data-type of the input to a specific PcodeOp.
Calculate the actual data-type of the input to the specific PcodeOp. A null result indicates the input data-type is the same as or otherwise doesn't need a cast from the data-type of the actual input Varnode
op | is the specific PcodeOp |
slot | is the input to consider |
castStrategy | is the current casting strategy |
Reimplemented from ghidra::TypeOp.
|
virtual |
Find the data-type of the output that would be assigned by a compiler.
Calculate the actual data-type of the output for a specific PcodeOp as would be assigned by a C compiler parsing a grammar containing this op.
op | is the specific PcodeOp |
castStrategy | is the current casting strategy |
Reimplemented from ghidra::TypeOp.
References ghidra::Varnode::getHighTypeReadFacing(), and ghidra::PcodeOp::getIn().
|
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::AddrSpace::getName(), ghidra::TypeOp::getOperatorName(), ghidra::PcodeOp::getOut(), ghidra::Varnode::getSpaceFromConst(), and ghidra::Varnode::printRaw().
|
virtual |
Propagate an incoming data-type across a specific PcodeOp.
The data-type can propagate between any two Varnodes attached to the PcodeOp, either in or out. The pair invn and inslot indicate the Varnode holding the incoming data-type. The pair outvn and outslot indicate the Varnode that will hold the outgoing data-type. The data-type for the outgoing Varnode is returned, which may be different then the incoming data-type as the PcodeOp can transform the data-type as it propagates.
alttype | is the incoming data-type |
op | is the PcodeOp to propagate across |
invn | is the Varnode holding the incoming data-type |
outvn | is the Varnode that will hold the outgoing data-type |
inslot | indicates how the incoming Varnode is attached to the PcodeOp (-1 indicates output >= indicates input) |
outslot | indicates how the outgoing Varnode is attached to the PcodeOp |
Reimplemented from ghidra::TypeOp.
References ghidra::Datatype::getMetatype(), ghidra::Varnode::getSize(), ghidra::Varnode::isSpacebase(), ghidra::TypeFactory::resizePointer(), ghidra::TypeOp::tlst, and ghidra::TYPE_PTR.
|
inlinevirtual |
Push the specific PcodeOp to the emitter's RPN stack.
Given a specific language and PcodeOp, emit the expression rooted at the operation.
lng | is the PrintLanguage to emit |
op | is the specific PcodeOp |
readOp | is the PcodeOp consuming the output (or null) |
Implements ghidra::TypeOp.
References ghidra::PrintLanguage::opSegmentOp().