18 #ifndef __CPUI_PCODERAW__ 19 #define __CPUI_PCODERAW__ 98 vector<VarnodeData *> in;
102 OpCode getOpcode(
void)
const;
103 void setSeqNum(
const Address &a,uintm b);
104 const SeqNum &getSeqNum(
void)
const;
109 void clearInputs(
void);
110 int4 numInput(
void)
const;
138 return behave->getOpcode();
169 return seq.getAddr();
void clearInputs(void)
Remove all input varnodes to this op.
Definition: pcoderaw.hh:199
const Address & getAddr(void) const
Get address of this operation.
Definition: pcoderaw.hh:166
A region where processor data is stored.
Definition: space.hh:73
OpCode
The op-code defining a specific p-code operation (PcodeOp)
Definition: opcodes.hh:35
A manager for different address spaces.
Definition: translate.hh:218
bool operator!=(const VarnodeData &op2) const
Compare for inequality.
Definition: pcoderaw.hh:76
bool operator==(const VarnodeData &op2) const
Compare for equality.
Definition: pcoderaw.hh:66
OpBehavior * getBehavior(void) const
Retrieve the behavior for this op.
Definition: pcoderaw.hh:126
AddrSpace * space
The address space.
Definition: pcoderaw.hh:34
Class encapsulating the action/behavior of specific pcode opcodes.
Definition: opbehavior.hh:42
void addInput(VarnodeData *i)
Add an additional input varnode to this op.
Definition: pcoderaw.hh:191
A low-level representation of a single pcode operation.
Definition: pcoderaw.hh:94
A low-level machine address for labelling bytes and data.
Definition: address.hh:46
bool contains(const VarnodeData &op2) const
Does this container another given VarnodeData.
Definition: pcoderaw.cc:48
Classes for specifying addresses and other low-level constants.
uintb offset
The offset within the space.
Definition: pcoderaw.hh:35
Classes for describing the behavior of individual p-code operations.
void setBehavior(OpBehavior *be)
Set the opcode for this op.
Definition: pcoderaw.hh:117
bool operator<(const VarnodeData &op2) const
An ordering for VarnodeData.
Definition: pcoderaw.hh:56
void setOutput(VarnodeData *o)
Set the output varnode for this op.
Definition: pcoderaw.hh:174
An XML element. A node in the DOM tree.
Definition: xml.hh:150
void setSeqNum(const Address &a, uintm b)
Set the sequence number.
Definition: pcoderaw.hh:147
int4 numInput(void) const
Get the number of input varnodes to this op.
Definition: pcoderaw.hh:206
OpCode getOpcode(void) const
Get the opcode for this op.
Definition: pcoderaw.hh:135
uint4 size
The number of bytes in the location.
Definition: pcoderaw.hh:36
void restoreXml(const Element *el, const AddrSpaceManager *manage)
Recover this object from an XML tag.
Definition: pcoderaw.cc:22
const SeqNum & getSeqNum(void) const
Retrieve the sequence number.
Definition: pcoderaw.hh:157
VarnodeData * getInput(int4 i) const
Get the i-th input varnode for this op.
Definition: pcoderaw.hh:217
Address getAddr(void) const
Get the location of the varnode as an address.
Definition: pcoderaw.hh:85
VarnodeData * getOutput(void) const
Retrieve the output varnode for this op.
Definition: pcoderaw.hh:182
int4 getIndex(void) const
Get the integer identifier.
Definition: space.hh:317
Data defining a specific memory location.
Definition: pcoderaw.hh:33
A class for uniquely labelling and comparing PcodeOps.
Definition: address.hh:111