Package ghidra.program.model.block
Class PartitionCodeSubModel
java.lang.Object
ghidra.program.model.block.PartitionCodeSubModel
- All Implemented Interfaces:
- CodeBlockModel,- SubroutineBlockModel
PartitionCodeSubModel (Model-P) defines subroutines which do not share code with
 other subroutines and may have one or more entry points.
 Entry points represent anyone of a variety of flow entries, including a source, called, jump or
 fall-through entry point.
 MODEL-P is the answer to those who always want to be able to know what subroutine a given instruction is in, but also do not want the subroutine to have multiple entry points. When a model-M subroutine has multiple entry points, that set of code will necessarily consist of several model-P subroutines. When a model-M subroutine has a single entry point, it will consist of a single model-P subroutine which has the same address set and entry point.
- See Also:
- 
Field SummaryFieldsFields inherited from interface ghidra.program.model.block.CodeBlockModelemptyBlockArray
- 
Constructor SummaryConstructorsConstructorDescriptionPartitionCodeSubModel(Program program) Construct a Model-P subroutine on a program.PartitionCodeSubModel(Program program, boolean includeExternals) Construct a Model-P subroutine on a program.
- 
Method SummaryModifier and TypeMethodDescriptionbooleanReturn true if this model allows overlapping of address sets for the blocks it returns.booleanReturns true if externals are handled by the model, false if externals are ignored.Get the underlying base subroutine model.Get the basic block model used by this model.getCodeBlockAt(Address addr, TaskMonitor monitor) Get the code block with a starting address (i.e., entry-point) of addr.getCodeBlocks(TaskMonitor monitor) Get an iterator over the code blocks in the entire program.getCodeBlocksContaining(Address addr, TaskMonitor monitor) Get all the Code Blocks containing the address.getCodeBlocksContaining(AddressSetView addrSet, TaskMonitor monitor) Get an iterator over CodeBlocks which overlap the specified address set.getDestinations(CodeBlock block, TaskMonitor monitor) Get an iterator over destination blocks flowing from this block.getFirstCodeBlockContaining(Address addr, TaskMonitor monitor) Get the (first) Model-P subroutine that contains the address.getFlowType(CodeBlock block) Return in general how things flow out of this node.Returns the listing associated with this block model.getName()Returns the model name.Get a name for this block.intgetNumDestinations(CodeBlock block, TaskMonitor monitor) Get number of destination references flowing out of this subroutine (block).intgetNumSources(CodeBlock block, TaskMonitor monitor) Get number of block source references flowing into this block.Returns the program object associated with this CodeBlockModel instance.getSources(CodeBlock block, TaskMonitor monitor) Get an iterator over source blocks flowing into this block.
- 
Field Details- 
NAME- See Also:
 
 
- 
- 
Constructor Details- 
PartitionCodeSubModelConstruct a Model-P subroutine on a program.- Parameters:
- program- program to create blocks from.
 
- 
PartitionCodeSubModelConstruct a Model-P subroutine on a program.- Parameters:
- program- program to create blocks from.
- includeExternals- externals included if true
 
 
- 
- 
Method Details- 
getCodeBlockAtDescription copied from interface:CodeBlockModelGet the code block with a starting address (i.e., entry-point) of addr.- Specified by:
- getCodeBlockAtin interface- CodeBlockModel
- Parameters:
- addr- starting address of a codeblock.
- monitor- task monitor which allows user to cancel operation.
- Returns:
- null if there is no codeblock starting at the address.
- Throws:
- CancelledException- if the monitor cancels the operation.
- See Also:
 
- 
getCodeBlocksContainingpublic CodeBlock[] getCodeBlocksContaining(Address addr, TaskMonitor monitor) throws CancelledException Get all the Code Blocks containing the address. For model-P, there is only one.- Specified by:
- getCodeBlocksContainingin interface- CodeBlockModel
- Parameters:
- addr- Address to find a containing block.
- monitor- task monitor which allows user to cancel operation.
- Returns:
- A CodeBlock array with one entry containing the subroutine that contains the address null otherwise.
- Throws:
- CancelledException- if the monitor cancels the operation.
 
- 
getFirstCodeBlockContainingpublic CodeBlock getFirstCodeBlockContaining(Address addr, TaskMonitor monitor) throws CancelledException Get the (first) Model-P subroutine that contains the address. This is equivalent to getCodeBlocksContaining(addr) except that it doesn't return an array since model-P subroutines don't share code.- Specified by:
- getFirstCodeBlockContainingin interface- CodeBlockModel
- Parameters:
- addr- Address to find a containing block.
- monitor- task monitor which allows user to cancel operation.
- Returns:
- A CodeBlock if any block contains the address. empty array otherwise.
- Throws:
- CancelledException- if the monitor cancels the operation.
 
- 
getCodeBlocksDescription copied from interface:CodeBlockModelGet an iterator over the code blocks in the entire program.- Specified by:
- getCodeBlocksin interface- CodeBlockModel
- Parameters:
- monitor- task monitor which allows user to cancel operation.
- See Also:
 
- 
getCodeBlocksContainingGet an iterator over CodeBlocks which overlap the specified address set.- Specified by:
- getCodeBlocksContainingin interface- CodeBlockModel
- Parameters:
- addrSet- an address set within program
- monitor- task monitor which allows user to cancel operation.
 
- 
getProgramDescription copied from interface:CodeBlockModelReturns the program object associated with this CodeBlockModel instance.- Specified by:
- getProgramin interface- CodeBlockModel
- Returns:
- program associated with this CodeBlockModel.
- See Also:
 
- 
getListingReturns the listing associated with this block model.- Returns:
- the listing associated with this block model
 
- 
getNameDescription copied from interface:CodeBlockModelGet a name for this block.- Specified by:
- getNamein interface- CodeBlockModel
- Returns:
- usually the label at the start address of the block however the model can choose any name it wants for its blocks.
- See Also:
 
- 
getFlowTypeReturn in general how things flow out of this node. This method exists for the SIMPLEBLOCK model.Since it doesn't make a great deal of sense to ask for this method in the case of subroutines, we return FlowType.UNKNOWN as long as the block exists. If this block has no valid instructions, it can't flow, so FlowType.INVALID is returned. - Specified by:
- getFlowTypein interface- CodeBlockModel
- Returns:
- flow type of this node
 
- 
getSourcespublic CodeBlockReferenceIterator getSources(CodeBlock block, TaskMonitor monitor) throws CancelledException Get an iterator over source blocks flowing into this block.- Specified by:
- getSourcesin interface- CodeBlockModel
- Parameters:
- block- code block to get the source iterator for.
- monitor- task monitor which allows user to cancel operation.
- Throws:
- CancelledException- if the monitor cancels the operation.
 
- 
getNumSourcesGet number of block source references flowing into this block.- Specified by:
- getNumSourcesin interface- CodeBlockModel
- Parameters:
- block- code block to get the source iterator for.
- monitor- task monitor which allows user to cancel operation.
- Throws:
- CancelledException- if the monitor cancels the operation.
 
- 
getDestinationspublic CodeBlockReferenceIterator getDestinations(CodeBlock block, TaskMonitor monitor) throws CancelledException Get an iterator over destination blocks flowing from this block.- Specified by:
- getDestinationsin interface- CodeBlockModel
- Parameters:
- block- code block to get the destination block iterator for.
- monitor- task monitor which allows user to cancel operation.
- Throws:
- CancelledException- if the monitor cancels the operation.
 
- 
getNumDestinationsGet number of destination references flowing out of this subroutine (block). All Calls from this block, and all external FlowType block references from this block are counted.- Specified by:
- getNumDestinationsin interface- CodeBlockModel
- Parameters:
- block- code block to get the number of destination references from.
- monitor- task monitor which allows user to cancel operation.
- Throws:
- CancelledException- if the monitor cancels the operation.
 
- 
getBasicBlockModelDescription copied from interface:CodeBlockModelGet the basic block model used by this model.- Specified by:
- getBasicBlockModelin interface- CodeBlockModel
- See Also:
 
- 
getNameDescription copied from interface:CodeBlockModelReturns the model name.- Specified by:
- getNamein interface- CodeBlockModel
- Returns:
- the model name
- See Also:
 
- 
getBaseSubroutineModelDescription copied from interface:SubroutineBlockModelGet the underlying base subroutine model. This is generally the MultEntSubModel (M-Model).- Specified by:
- getBaseSubroutineModelin interface- SubroutineBlockModel
- Returns:
- base subroutine model. If there is no base model, this subroutine model is returned.
- See Also:
 
- 
allowsBlockOverlappublic boolean allowsBlockOverlap()Description copied from interface:CodeBlockModelReturn true if this model allows overlapping of address sets for the blocks it returns.- Specified by:
- allowsBlockOverlapin interface- CodeBlockModel
- Returns:
- true if this model allows overlapping of address sets for the blocks it returns. This implies that getBlocksContaining() can return more than one block. false implies that getBlocksContaining() will return at most one block.
- See Also:
 
- 
externalsIncludedpublic boolean externalsIncluded()Description copied from interface:CodeBlockModelReturns true if externals are handled by the model, false if externals are ignored. When handled, externals are represented by an ExtCodeBlockImpl.- Specified by:
- externalsIncludedin interface- CodeBlockModel
- See Also:
 
 
-