Ghidra 11.4.2
Ghidra internal decompiler documentation.
|
A collection of parameter descriptions backed by Symbol information. More...
#include <fspec.hh>
Public Member Functions | |
ProtoStoreSymbol (Scope *sc, const Address &usepoint) | |
Constructor. | |
virtual ProtoParameter * | setInput (int4 i, const string &nm, const ParameterPieces &pieces) |
Establish name, data-type, storage of a specific input parameter. | |
virtual void | clearInput (int4 i) |
Clear the input parameter at the specified slot. | |
virtual void | clearAllInputs (void) |
Clear all input parameters (and any backing symbols) | |
virtual int4 | getNumInputs (void) const |
Get the number of input parameters for this prototype. | |
virtual ProtoParameter * | getInput (int4 i) |
Get the i-th input parameter (or NULL if it doesn't exist) | |
virtual ProtoParameter * | setOutput (const ParameterPieces &piece) |
Establish the data-type and storage of the return value. | |
virtual void | clearOutput (void) |
Clear the return value to TYPE_VOID. | |
virtual ProtoParameter * | getOutput (void) |
Get the return-value description. | |
virtual ProtoStore * | clone (void) const |
Clone the entire collection of parameter descriptions. | |
virtual void | encode (Encoder &encoder) const |
Encode any parameters that are not backed by symbols to a stream. | |
virtual void | decode (Decoder &decoder, ProtoModel *model) |
Restore any internal parameter descriptions from a stream. | |
![]() | |
virtual | ~ProtoStore (void) |
Constructor. | |
Private Member Functions | |
ParameterSymbol * | getSymbolBacked (int4 i) |
Fetch or allocate the parameter for the indicated slot. | |
Private Attributes | |
Scope * | scope |
Backing Scope for input parameters. | |
Address | restricted_usepoint |
A usepoint reference for storage locations (usually function entry -1) | |
vector< ProtoParameter * > | inparam |
Cache of allocated input parameters. | |
ProtoParameter * | outparam |
The return-value parameter. | |
A collection of parameter descriptions backed by Symbol information.
Input parameters are determined by symbols a function Scope (category 0). Information about the return-value is stored internally. ProtoParameter objects are constructed on the fly as requested and cached.
sc | is the function Scope that will back this store |
usepoint | is the starting address of the function (-1) |
References ghidra::ParameterPieces::flags, ghidra::Scope::getArch(), ghidra::TypeFactory::getTypeVoid(), outparam, restricted_usepoint, scope, setOutput(), ghidra::ParameterPieces::type, and ghidra::Architecture::types.
|
virtual |
Clear all input parameters (and any backing symbols)
Implements ghidra::ProtoStore.
References ghidra::Scope::clearCategory(), and scope.
|
virtual |
Clear the input parameter at the specified slot.
The parameter is excised, any following parameters are shifted to fill its spot. If there is a backing Symbol, it is removed from the SymbolTable
i | is the specified parameter slot to remove |
Implements ghidra::ProtoStore.
References ghidra::Symbol::function_parameter, ghidra::Scope::getCategorySize(), ghidra::Scope::getCategorySymbol(), ghidra::Symbol::no_category, ghidra::Scope::removeSymbol(), scope, and ghidra::Scope::setCategory().
|
virtual |
Clear the return value to TYPE_VOID.
Implements ghidra::ProtoStore.
References ghidra::ParameterPieces::flags, ghidra::Scope::getArch(), ghidra::TypeFactory::getTypeVoid(), scope, setOutput(), ghidra::ParameterPieces::type, and ghidra::Architecture::types.
|
virtual |
Clone the entire collection of parameter descriptions.
Implements ghidra::ProtoStore.
References ghidra::ProtoParameter::clone(), outparam, restricted_usepoint, and scope.
|
virtual |
Restore any internal parameter descriptions from a stream.
Parse an <internallist> element containing <param> and <retparam> child elements.
decoder | is the stream decoder |
model | is prototype model for determining storage for unassigned parameters |
Implements ghidra::ProtoStore.
|
virtual |
Encode any parameters that are not backed by symbols to a stream.
Symbols are stored elsewhere, so symbol backed parameters are not serialized. If there are any internal parameters an <internallist> element is emitted.
encoder | is the stream encoder |
Implements ghidra::ProtoStore.
|
virtual |
Get the i-th input parameter (or NULL if it doesn't exist)
Implements ghidra::ProtoStore.
References ghidra::Symbol::function_parameter, ghidra::Scope::getCategorySymbol(), getSymbolBacked(), scope, and ghidra::ParameterSymbol::sym.
|
virtual |
Get the number of input parameters for this prototype.
Implements ghidra::ProtoStore.
References ghidra::Symbol::function_parameter, ghidra::Scope::getCategorySize(), and scope.
|
virtual |
|
private |
Fetch or allocate the parameter for the indicated slot.
Retrieve the specified ProtoParameter object, making sure it is a ParameterSymbol. If it doesn't exist, or if the object in the specific slot is not a ParameterSymbol, allocate an (uninitialized) parameter.
i | is the specified input slot |
References inparam.
Referenced by getInput(), and setInput().
|
virtual |
Establish name, data-type, storage of a specific input parameter.
This either allocates a new parameter or replaces the existing one at the specified input slot. If there is a backing symbol table, a Symbol is created or modified.
i | is the specified input slot |
nm | is the (optional) name of the parameter |
pieces | holds the raw storage address and data-type to set |
Implements ghidra::ProtoStore.
References ghidra::ParameterPieces::addr, ghidra::Scope::addSymbol(), ghidra::Scope::clearAttribute(), ghidra::Scope::discoverScope(), ghidra::ParameterPieces::flags, ghidra::Symbol::function_parameter, ghidra::SymbolEntry::getAddr(), ghidra::Scope::getCategorySymbol(), ghidra::Symbol::getFirstWholeMap(), ghidra::Symbol::getName(), ghidra::SymbolEntry::getSize(), ghidra::Datatype::getSize(), ghidra::SymbolEntry::getSymbol(), getSymbolBacked(), ghidra::Symbol::getType(), ghidra::ParameterPieces::hiddenretparm, ghidra::Varnode::hiddenretparm, ghidra::ParameterPieces::indirectstorage, ghidra::Varnode::indirectstorage, ghidra::Symbol::isHiddenReturn(), ghidra::Symbol::isIndirectStorage(), ghidra::Symbol::isNameLocked(), ghidra::Symbol::isTypeLocked(), ghidra::ParameterPieces::namelock, ghidra::Varnode::namelock, ghidra::Scope::removeSymbol(), ghidra::Scope::renameSymbol(), restricted_usepoint, ghidra::Scope::retypeSymbol(), scope, ghidra::Scope::setAttribute(), ghidra::Scope::setCategory(), ghidra::ParameterSymbol::sym, ghidra::ParameterPieces::type, ghidra::ParameterPieces::typelock, and ghidra::Varnode::typelock.
|
virtual |
Establish the data-type and storage of the return value.
This either allocates a new parameter or replaces the existing one. A void return value can be specified with an invalid address and TYPE_VOID data-type.
piece | holds the raw storage address and data-type to set |
Implements ghidra::ProtoStore.
References ghidra::ParameterPieces::addr, ghidra::ParameterPieces::flags, outparam, and ghidra::ParameterPieces::type.
Referenced by clearOutput(), and ProtoStoreSymbol().