Package ghidra.program.model.lang
Interface InstructionPrototype
- 
- All Known Implementing Classes:
- InvalidPrototype,- SleighInstructionPrototype
 
 public interface InstructionPrototypeInstructionPrototype is designed to describe one machine level instruction. A language parser can return the same InstructionProtoype object for the same type node. Prototypes for instructions will normally be fixed for a node.
- 
- 
Field SummaryFields Modifier and Type Field Description static intINVALID_DEPTH_CHANGE
 - 
Method SummaryAll Methods Instance Methods Abstract Methods Modifier and Type Method Description AddressgetAddress(int opIndex, InstructionContext context)If the indicated operand is an address, this gets the address value for that operandintgetDelaySlotByteCount()intgetDelaySlotDepth(InstructionContext context)Get the number of delay slot instructions for this argument.AddressgetFallThrough(InstructionContext context)Get the Address for default flow after instruction.intgetFallThroughOffset(InstructionContext context)Get the byte offset to the default flow after instruction.Address[]getFlows(InstructionContext context)Get an array of Address objects for all flows other than a fall-through, null if no flows.FlowTypegetFlowType(InstructionContext context)Get the flow type of this instruction.java.lang.Object[]getInputObjects(InstructionContext context)Get the Result objects produced/affected by this instruction These would probably only be Register or AddressMaskgetInstructionMask()Get a Mask that describe which bits of this instruction determine the opcode.LanguagegetLanguage()Get processor language module associated with this prototype.intgetLength()Get the length of this CodeProtoype.java.lang.StringgetMnemonic(InstructionContext context)Get the mnemonic for this CodeProtype.intgetNumOperands()Return the number of operands in this instruction.RefTypegetOperandRefType(int opIndex, InstructionContext context, PcodeOverride override, UniqueAddressFactory uniqueFactory)Get the suggested operand reference type.MaskgetOperandValueMask(int operandIndex)Get a Mask that describe which bits of this instruction determine the operand value.java.lang.Object[]getOpObjects(int opIndex, InstructionContext context)Get objects used by this operand (Address, Scalar, Register ...)java.util.ArrayList<java.lang.Object>getOpRepresentationList(int opIndex, InstructionContext context)Get a List of Objects that can be used to render an operands representation.intgetOpType(int opIndex, InstructionContext context)Get the type of a specific operand.ParserContextgetParserContext(MemBuffer buf, ProcessorContextView processorContext)Get a new instance of a ParserContext.PcodeOp[]getPcode(InstructionContext context, int opIndex)Get an array of PCode operations (micro code) that a particular operand performs to compute its value.PcodeOp[]getPcode(InstructionContext context, PcodeOverride override, UniqueAddressFactory uniqueFactory)Get an array of PCode operations (micro code) that this instruction performs.PackedBytesgetPcodePacked(InstructionContext context, PcodeOverride override, UniqueAddressFactory uniqueFactory)Same as getPcode but returns the operations in a packed format to optimize transfer to other processesParserContextgetPseudoParserContext(Address addr, MemBuffer buffer, ProcessorContextView processorContext)Get a ParserContext by parsing bytes outside of the normal disassembly processRegistergetRegister(int opIndex, InstructionContext context)If the indicated operand is a register, this gets the register value for that operandjava.lang.Object[]getResultObjects(InstructionContext context)Get the Result objects produced/affected by this instruction These would probably only be Register or AddressScalargetScalar(int opIndex, InstructionContext context)If the indicated operand is a scalar, this gets the scalar value for that operandjava.lang.StringgetSeparator(int opIndex, InstructionContext context)Get the separator strings between an operand.booleanhasCrossBuildDependency()booleanhasDelaySlots()booleanhasDelimeter(int opIndex)Return true if the operand at opIndex should have a delimiter following it.booleanisInDelaySlot()Return true if this prototype was disassembled in a delay slot.
 
- 
- 
- 
Field Detail- 
INVALID_DEPTH_CHANGEstatic final int INVALID_DEPTH_CHANGE - See Also:
- Constant Field Values
 
 
- 
 - 
Method Detail- 
getParserContextParserContext getParserContext(MemBuffer buf, ProcessorContextView processorContext) throws MemoryAccessException Get a new instance of a ParserContext.- Parameters:
- buf-
- processorContext-
- Returns:
- instruction ParserContext
- Throws:
- MemoryAccessException
 
 - 
getPseudoParserContextParserContext getPseudoParserContext(Address addr, MemBuffer buffer, ProcessorContextView processorContext) throws InsufficientBytesException, UnknownInstructionException, UnknownContextException, MemoryAccessException Get a ParserContext by parsing bytes outside of the normal disassembly process- Parameters:
- addr- where the ParserContext is needed
- buffer- of actual bytes
- processorContext-
- Returns:
- Throws:
- InsufficientBytesException
- UnknownInstructionException
- UnknownContextException
- MemoryAccessException
 
 - 
hasDelaySlotsboolean hasDelaySlots() - Returns:
- true if instruction prototype expects one or more delay slotted instructions to exist.
 
 - 
hasCrossBuildDependencyboolean hasCrossBuildDependency() - Returns:
- true if instruction semantics have a CrossBuild instruction dependency which may require a robust InstructionContext with access to preceding instructions
 
 - 
getMnemonicjava.lang.String getMnemonic(InstructionContext context) Get the mnemonic for this CodeProtype. Examples: "MOV" and "CALL" for instructions and "DB" and "DA" for data.- Parameters:
- context- the instruction context
- Returns:
- the mnemonic for this CodePrototype.
 
 - 
getLengthint getLength() Get the length of this CodeProtoype.- Returns:
- the length of this CodeProtoype.
 
 - 
getInstructionMaskMask getInstructionMask() Get a Mask that describe which bits of this instruction determine the opcode.- Returns:
- a Mask for the opcode bits or null if unknown.
 
 - 
getOperandValueMaskMask getOperandValueMask(int operandIndex) Get a Mask that describe which bits of this instruction determine the operand value.- Returns:
- a Mask for the operand bits or null if unknown.
 
 - 
getFlowTypeFlowType getFlowType(InstructionContext context) Get the flow type of this instruction. Used for analysis purposes. i.e., how this instruction flows to the next instruction.- Parameters:
- context- the instruction context
- Returns:
- flow type.
 
 - 
getDelaySlotDepthint getDelaySlotDepth(InstructionContext context) Get the number of delay slot instructions for this argument. This should be 0 for instructions which don't have a delay slot. This is used to support the delay slots found on some RISC processors such as SPARC and the PA-RISC. This returns an integer instead of a boolean in case some other processor executes more than one instruction from a delay slot.- Parameters:
- context- the instruction context
- Returns:
- the number of delay slot instructions for this instruction.
 
 - 
getDelaySlotByteCountint getDelaySlotByteCount() - Returns:
- the number of delay-slot instruction bytes which correspond to this prototype.
 
 - 
isInDelaySlotboolean isInDelaySlot() Return true if this prototype was disassembled in a delay slot.
 - 
getNumOperandsint getNumOperands() Return the number of operands in this instruction.
 - 
getOpTypeint getOpType(int opIndex, InstructionContext context)Get the type of a specific operand.- Parameters:
- opIndex- the index of the operand. (zero based)
- context- the instruction context.
- Returns:
- the type of the operand.
 
 - 
getFallThroughAddress getFallThrough(InstructionContext context) Get the Address for default flow after instruction.- Parameters:
- context- the instruction context
- Returns:
- Address of fall through flow or null if flow does not fall through this instruction.
 
 - 
getFallThroughOffsetint getFallThroughOffset(InstructionContext context) Get the byte offset to the default flow after instruction. If this instruction does not have a fall-through due to flow behavior, this method will still return an offset which accounts for the instruction length including delay slotted instructions if applicable.- Parameters:
- context- the instruction context
- Returns:
- int how much to add to the current address to get the fall through address.
 
 - 
getFlowsAddress[] getFlows(InstructionContext context) Get an array of Address objects for all flows other than a fall-through, null if no flows.- Parameters:
- context- the instruction context.
- Returns:
- an array of Address objects for all flows other than a fall-through, null if no flows.
 
 - 
getSeparatorjava.lang.String getSeparator(int opIndex, InstructionContext context)Get the separator strings between an operand. The separator string for 0 are the characters before the first operand. The separator string for numOperands+1 are the characters after the last operand.- Parameters:
- opIndex- valid values are 0 thru numOperands+1
- context- the instruction context
- Returns:
- separator string, or null if there is no string
 
 - 
getOpRepresentationListjava.util.ArrayList<java.lang.Object> getOpRepresentationList(int opIndex, InstructionContext context)Get a List of Objects that can be used to render an operands representation.- Parameters:
- opIndex- operand to get the Representation List
- context- the instruction context
- Returns:
- ArrayList of Register, Address, Scalar, VariableOffset and Character objects of null if the operation isn't supported
 
 - 
getAddressAddress getAddress(int opIndex, InstructionContext context) If the indicated operand is an address, this gets the address value for that operand- Parameters:
- opIndex- index of the operand.
- context- the instruction context.
- Returns:
- the address indicated by the operand
 
 - 
getScalarScalar getScalar(int opIndex, InstructionContext context) If the indicated operand is a scalar, this gets the scalar value for that operand- Parameters:
- opIndex- index of the operand.
- context- the instruction context
- Returns:
- the scalar for the indicated operand
 
 - 
getRegisterRegister getRegister(int opIndex, InstructionContext context) If the indicated operand is a register, this gets the register value for that operand- Parameters:
- opIndex- index of the operand.
- context- the instruction context
- Returns:
- a register description for the indicated operand
 
 - 
getOpObjectsjava.lang.Object[] getOpObjects(int opIndex, InstructionContext context)Get objects used by this operand (Address, Scalar, Register ...)- Parameters:
- opIndex- the index of the operand. (zero based)
- context- the instruction context
- Returns:
- an array of objects found at this operand.
 
 - 
getOperandRefTypeRefType getOperandRefType(int opIndex, InstructionContext context, PcodeOverride override, UniqueAddressFactory uniqueFactory) Get the suggested operand reference type.- Parameters:
- opIndex- the index of the operand. (zero based)
- context- the instruction context
- override- if not null, steers local overrides of pcode generation
- uniqueFactory- must be specified if flowOverride is not null
- Returns:
- reference type.
 
 - 
hasDelimeterboolean hasDelimeter(int opIndex) Return true if the operand at opIndex should have a delimiter following it.- Parameters:
- opIndex- the index of the operand to test for having a delimiter.
 
 - 
getInputObjectsjava.lang.Object[] getInputObjects(InstructionContext context) Get the Result objects produced/affected by this instruction These would probably only be Register or Address- Parameters:
- context- the instruction context
- Returns:
- an array of objects that are used by this instruction
 
 - 
getResultObjectsjava.lang.Object[] getResultObjects(InstructionContext context) Get the Result objects produced/affected by this instruction These would probably only be Register or Address- Parameters:
- context- the instruction context
- Returns:
- an array of objects that are affected by this instruction
 
 - 
getPcodePcodeOp[] getPcode(InstructionContext context, PcodeOverride override, UniqueAddressFactory uniqueFactory) Get an array of PCode operations (micro code) that this instruction performs.- Parameters:
- context- the instruction context
- override- if not null, may indicate that different elements of the pcode generation are overridden
- uniqueFactory- must be specified if flowOverride is not null
- Returns:
- array of PCODE, zero length array if language doesn't support PCODE for this instruction
 
 - 
getPcodePackedPackedBytes getPcodePacked(InstructionContext context, PcodeOverride override, UniqueAddressFactory uniqueFactory) Same as getPcode but returns the operations in a packed format to optimize transfer to other processes- Parameters:
- context- the instruction context
- override- if not null, may indicate that different elements of the pcode generation are overridden
- uniqueFactory- must be specified if flowOverride is not null
- Returns:
 
 - 
getPcodePcodeOp[] getPcode(InstructionContext context, int opIndex) Get an array of PCode operations (micro code) that a particular operand performs to compute its value.- Parameters:
- context- the instruction context
- opIndex- the index of the operand for which to get PCode.
- Returns:
- array of PCODE, zero length array if language doesn't support PCODE for this instruction
 
 - 
getLanguageLanguage getLanguage() Get processor language module associated with this prototype.- Returns:
- language module
 
 
- 
 
-