Class BasicBlock<InsnType extends IInstruction>
- Type Parameters:
InsnType-
- All Implemented Interfaces:
IBasicBlock<InsnType>,Comparable<BasicBlock<InsnType>>,Iterable<InsnType>
- See Also:
-
Constructor Summary
ConstructorsConstructorDescriptionBasicBlock(long base) Create a new empty basic block.BasicBlock(long base, List<InsnType> insns, List<Long> dstOffsets, List<Long> irrdstOffsets, boolean unknownDst) Create a new basic block. -
Method Summary
Modifier and TypeMethodDescriptionvoidDANGEROUS METHOD. Add an instruction into the block.voidDANGEROUS METHOD. Append an instruction to the block.voidaddAll(int index, Collection<InsnType> coll) DANGEROUS METHOD. Add instructions into the block.voidaddAll(Collection<InsnType> coll) DANGEROUS METHOD. Append instructions to the block.intGet the total number of input edges to this block.intbooleancanThrow()intget(int index) Get the instruction at the specified index.get2(int index) Get the instruction at the specified index, in an addressable form.longlong[]Get a list of the addresses of each instruction in the block.longgetAddressOfInstruction(int index) Retrieve a read-only iterable of regular and irregular input blocks.Get regular and irregular output blocks.Retrieve a read-only iterable of regular and irregular output blocks.longgetBase()Address of first instruction in the block.Same asgetBranchingInstruction2(true, true).getBranchingInstruction2(boolean includeBreaking, boolean includeCalling) Retrieve the branching instruction, if any.May return null if the custom object does not exist.longAddress following the last instruction of the block (ie, last exclusive address).longAddress of first instruction in the block.intgetIndexOfInstruction(long address) intLocate an instruction in the block.getInputBlock(int index) Get a regular input block.Get the regular input blocks.Retrieve a read-only list of input blocks (regular).getInstruction(long address) Get the instruction located at the exact address.Get a copy of the list of instructions that make up this basic block.getIrregularInputBlock(int index) Get an irregular input block.Retrieve a read-only list of irregular input blocks.getIrregularOutputBlock(int index) Get an irregular output block.Get irregular output blocks.Retrieve a read-only list of irregular output blocks.getLast()Get the last instruction of the block.getLast2()Get the last instruction of the block, in an addressable form.longAddress of last instruction in the block.getOutputBlock(int index) Get a regular output block.Get the regular output blocks.Retrieve a read-only list of output blocks (regular).intbooleanintinsize()Get the number of regular input edges to this block.intGet the number of irregular input edges to this block.intbooleanisEmpty()Determine if the block has 0 instruction.booleanCheck if the block has a single regular out-edge which points to itself.booleanCheck if the block has at least one regular out-edge pointing to itself.iterator()intoutsize()booleanremove(int index) Remove an instruction from the block as well as associated chains.booleanremoveData(String name) DANGEROUS METHOD. Replace an instruction.voidCustom data is reset when a DFA is invalidated.voidsetUnknownDst(boolean unknownDst) shallowCopy(boolean copyBlockReferences) Shallow duplication of a basic block.intsize()Get the number of instructions in the block.toString()Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, waitMethods inherited from interface java.lang.Iterable
forEach, spliterator
-
Constructor Details
-
Method Details
-
shallowCopy
Shallow duplication of a basic block. USE THE RESULTING BLOCK WITH CAUTION. - Instructions references are copied
- Block references (edges) are optionally copied (the blocks are not)
- DFA data is not copied- Parameters:
copyBlockReferences-- Returns:
- a new block
-
getBase
public long getBase()Description copied from interface:IBasicBlockAddress of first instruction in the block.- Specified by:
getBasein interfaceIBasicBlock<InsnType extends IInstruction>- Returns:
-
getAddress
public long getAddress() -
getFirstAddress
public long getFirstAddress()Description copied from interface:IBasicBlockAddress of first instruction in the block.- Specified by:
getFirstAddressin interfaceIBasicBlock<InsnType extends IInstruction>- Returns:
-
getLastAddress
public long getLastAddress()Description copied from interface:IBasicBlockAddress of last instruction in the block.- Specified by:
getLastAddressin interfaceIBasicBlock<InsnType extends IInstruction>- Returns:
-
getEndAddress
public long getEndAddress()Description copied from interface:IBasicBlockAddress following the last instruction of the block (ie, last exclusive address).- Specified by:
getEndAddressin interfaceIBasicBlock<InsnType extends IInstruction>- Returns:
-
getAddressOfInstruction
public long getAddressOfInstruction(int index) - Specified by:
getAddressOfInstructionin interfaceIBasicBlock<InsnType extends IInstruction>
-
getAddresses
public long[] getAddresses()Get a list of the addresses of each instruction in the block.- Returns:
-
getIndexOfInstruction
public int getIndexOfInstruction(long address) - Specified by:
getIndexOfInstructionin interfaceIBasicBlock<InsnType extends IInstruction>- Parameters:
address- instruction address- Returns:
- -1 if there is no instruction starting at the provided address
-
getIndexOfInstruction
Locate an instruction in the block. Comparison is done by identity.- Parameters:
insn-- Returns:
- the instruction index, -1 if not found
-
canThrow
public boolean canThrow()- Specified by:
canThrowin interfaceIBasicBlock<InsnType extends IInstruction>
-
size
public int size()Description copied from interface:IBasicBlockGet the number of instructions in the block.- Specified by:
sizein interfaceIBasicBlock<InsnType extends IInstruction>- Returns:
-
isEmpty
public boolean isEmpty()Description copied from interface:IBasicBlockDetermine if the block has 0 instruction.- Specified by:
isEmptyin interfaceIBasicBlock<InsnType extends IInstruction>- Returns:
-
get
Description copied from interface:IBasicBlockGet the instruction at the specified index.- Specified by:
getin interfaceIBasicBlock<InsnType extends IInstruction>- Returns:
-
get2
Get the instruction at the specified index, in an addressable form.- Parameters:
index-- Returns:
-
getLast
Get the last instruction of the block.Keep in mind that a branching instruction may NOT be the last instruction of a basic block if it supports delay-slots.
- Specified by:
getLastin interfaceIBasicBlock<InsnType extends IInstruction>- Returns:
-
getSizeOfInstructions
public int getSizeOfInstructions()- Specified by:
getSizeOfInstructionsin interfaceIBasicBlock<InsnType extends IInstruction>
-
getLast2
Get the last instruction of the block, in an addressable form.Keep in mind that a branching instruction may NOT be the last instruction of a basic block if it supports delay-slots.
- Returns:
-
getInstruction
Description copied from interface:IBasicBlockGet the instruction located at the exact address.- Specified by:
getInstructionin interfaceIBasicBlock<InsnType extends IInstruction>- Returns:
-
getInstructions
Description copied from interface:IBasicBlockGet a copy of the list of instructions that make up this basic block.- Specified by:
getInstructionsin interfaceIBasicBlock<InsnType extends IInstruction>- Returns:
-
getBranchingInstruction2
public AddressableInstruction<InsnType> getBranchingInstruction2(boolean includeBreaking, boolean includeCalling) Retrieve the branching instruction, if any. In the general case, it should not be assumed that the branching instruction must be the last instruction of a block. Example: on delay-slot architectures, a number of instructions may follow the branching instructions. They are included in the block. That means that the branching instruction, when there is one, may be the one/two/Nth-before-last.- Parameters:
includeBreaking-includeCalling-- Returns:
- the branching instruction+address, or null if none
-
getBranchingInstruction2
Same asgetBranchingInstruction2(true, true). -
remove
public boolean remove(int index) Remove an instruction from the block as well as associated chains. Usage is not recommended for public clients.This method may have the nasty side-effect of making the block empty. In that case, it returns true, and it is the caller's responsibility to refresh the CFG at their earliest convenience.
Another issue the client needs to take care of is the removal of the last instruction, which should only happen on very specific conditions, since the trailing instruction typically conditions the out-edges of the block.
- Parameters:
index-- Returns:
- true if the CFG need refreshing
-
add
DANGEROUS METHOD. Append an instruction to the block.The instruction is appended to the block. The edges are not updated.
The caller is responsible for verifying the instruction (no null, no dup., etc.).
The caller is responsible for maintaining the consistency of the block and of the CFG.- Parameters:
insn- the instruction to be appended
-
add
DANGEROUS METHOD. Add an instruction into the block.- Parameters:
index-insn-
-
addAll
DANGEROUS METHOD. Append instructions to the block.The instructions are appended to the block. The edges are not updated.
The caller is responsible for verifying the instructions (no null, no dup., etc.).
The caller is responsible for maintaining the consistency of the block and of the CFG.- Parameters:
coll-
-
addAll
DANGEROUS METHOD. Add instructions into the block.- Parameters:
index-coll-
-
set
DANGEROUS METHOD. Replace an instruction. Sizes must match.Edges are not updated.
The caller is responsible for maintaining the consistency of the block and of the CFG.- Parameters:
index-insn- the instruction- Returns:
- the instruction that was replaced
-
setLast
-
insize
public int insize()Description copied from interface:IBasicBlockGet the number of regular input edges to this block.- Specified by:
insizein interfaceIBasicBlock<InsnType extends IInstruction>- Returns:
-
irrinsize
public int irrinsize()Description copied from interface:IBasicBlockGet the number of irregular input edges to this block.- Specified by:
irrinsizein interfaceIBasicBlock<InsnType extends IInstruction>- Returns:
-
allinsize
public int allinsize()Description copied from interface:IBasicBlockGet the total number of input edges to this block.- Specified by:
allinsizein interfaceIBasicBlock<InsnType extends IInstruction>- Returns:
-
getInputBlock
Description copied from interface:IBasicBlockGet a regular input block.- Specified by:
getInputBlockin interfaceIBasicBlock<InsnType extends IInstruction>- Parameters:
index- block index- Returns:
- a block
-
getInputBlocks
Description copied from interface:IBasicBlockGet the regular input blocks.- Specified by:
getInputBlocksin interfaceIBasicBlock<InsnType extends IInstruction>- Returns:
- a copy of the list of regular input blocks
-
getIrregularInputBlock
Description copied from interface:IBasicBlockGet an irregular input block.- Specified by:
getIrregularInputBlockin interfaceIBasicBlock<InsnType extends IInstruction>- Parameters:
index- block index- Returns:
- a block
-
getIrregularInputBlocks
- Specified by:
getIrregularInputBlocksin interfaceIBasicBlock<InsnType extends IInstruction>
-
getAllInputBlocks
- Specified by:
getAllInputBlocksin interfaceIBasicBlock<InsnType extends IInstruction>
-
outsize
public int outsize()- Specified by:
outsizein interfaceIBasicBlock<InsnType extends IInstruction>
-
irroutsize
public int irroutsize()- Specified by:
irroutsizein interfaceIBasicBlock<InsnType extends IInstruction>
-
alloutsize
public int alloutsize()- Specified by:
alloutsizein interfaceIBasicBlock<InsnType extends IInstruction>
-
getOutputBlock
Description copied from interface:IBasicBlockGet a regular output block.- Specified by:
getOutputBlockin interfaceIBasicBlock<InsnType extends IInstruction>- Returns:
-
getOutputBlocks
Description copied from interface:IBasicBlockGet the regular output blocks.- Specified by:
getOutputBlocksin interfaceIBasicBlock<InsnType extends IInstruction>- Returns:
- a copy of the list of regular output blocks
-
getOutputOffsets
-
getIrregularOutputBlock
Description copied from interface:IBasicBlockGet an irregular output block.- Specified by:
getIrregularOutputBlockin interfaceIBasicBlock<InsnType extends IInstruction>- Returns:
-
getIrregularOutputBlocks
Description copied from interface:IBasicBlockGet irregular output blocks.- Specified by:
getIrregularOutputBlocksin interfaceIBasicBlock<InsnType extends IInstruction>- Returns:
- a copy of the list of irregular output blocks
-
getIrregularOutputOffsets
-
getAllOutputBlocks
Description copied from interface:IBasicBlockGet regular and irregular output blocks.- Specified by:
getAllOutputBlocksin interfaceIBasicBlock<InsnType extends IInstruction>- Returns:
- a copy of the list of all output blocks
-
getInputs
Retrieve a read-only list of input blocks (regular).NOTE: This method is faster than
getInputBlocks()since it does not provide a copy of the list.- Specified by:
getInputsin interfaceIBasicBlock<InsnType extends IInstruction>- Returns:
-
getInputOffsets
-
getIrregularInputs
Retrieve a read-only list of irregular input blocks.NOTE: This method is faster than
getIrregularInputBlocks()since it does not provide a copy of the list.- Specified by:
getIrregularInputsin interfaceIBasicBlock<InsnType extends IInstruction>- Returns:
-
getIrregularInputOffsets
-
getOutputs
Description copied from interface:IBasicBlockRetrieve a read-only list of output blocks (regular).NOTE: This method is faster than
IBasicBlock.getOutputBlocks()since it does not provide a copy of the list.- Specified by:
getOutputsin interfaceIBasicBlock<InsnType extends IInstruction>- Returns:
-
getIrregularOutputs
Description copied from interface:IBasicBlockRetrieve a read-only list of irregular output blocks.NOTE: This method is faster than
IBasicBlock.getIrregularOutputBlocks()since it does not provide a copy of the list.- Specified by:
getIrregularOutputsin interfaceIBasicBlock<InsnType extends IInstruction>- Returns:
-
getAllInputs
Description copied from interface:IBasicBlockRetrieve a read-only iterable of regular and irregular input blocks.NOTE: This method is faster than
IBasicBlock.getAllInputBlocks()since it does not provide a copy of the list.- Specified by:
getAllInputsin interfaceIBasicBlock<InsnType extends IInstruction>- Returns:
-
getAllOutputs
Description copied from interface:IBasicBlockRetrieve a read-only iterable of regular and irregular output blocks.NOTE: This method is faster than
IBasicBlock.getAllOutputBlocks()since it does not provide a copy of the list.- Specified by:
getAllOutputsin interfaceIBasicBlock<InsnType extends IInstruction>- Returns:
-
setUnknownDst
public void setUnknownDst(boolean unknownDst) -
hasUnknownDst
public boolean hasUnknownDst() -
isSelfReferencing
public boolean isSelfReferencing()Check if the block has at least one regular out-edge pointing to itself.- Returns:
-
isInfiniteLoop
public boolean isInfiniteLoop()Check if the block has a single regular out-edge which points to itself.- Returns:
-
toString
-
setData
Custom data is reset when a DFA is invalidated. -
getData
May return null if the custom object does not exist. -
removeData
-
iterator
- Specified by:
iteratorin interfaceIterable<InsnType extends IInstruction>
-
addressableInstructions
-
compareTo
- Specified by:
compareToin interfaceComparable<InsnType extends IInstruction>
-