|
Ghidra Decompiler Analysis Engine
|
Common core of classes that read or write SLEIGH specification files natively. More...
#include <sleighbase.hh>


Public Member Functions | |
| SleighBase (void) | |
| Construct an uninitialized translator. | |
| virtual void | addRegister (const string &nm, AddrSpace *base, uintb offset, int4 size) |
| Add a named register to the model for this processor. More... | |
| virtual const VarnodeData & | getRegister (const string &nm) const |
| Get a register as VarnodeData given its name. More... | |
| virtual string | getRegisterName (AddrSpace *base, uintb off, int4 size) const |
| Get the name of a register given its location. More... | |
| virtual void | getAllRegisters (map< VarnodeData, string > ®list) const |
| Get a list of all register names and the corresponding location. More... | |
| virtual void | getUserOpNames (vector< string > &res) const |
| Get a list of all user-defined pcode ops. More... | |
| void | saveXml (ostream &s) const |
| Write out the SLEIGH specification as an XML <sleigh> tag. More... | |
Public Member Functions inherited from Translate | |
| Translate (void) | |
| Constructor for the translator. More... | |
| void | setDefaultFloatFormats (void) |
| If no explicit float formats, set up default formats. More... | |
| bool | isBigEndian (void) const |
| Is the processor big endian? More... | |
| const FloatFormat * | getFloatFormat (int4 size) const |
| Get format for a particular floating point encoding. More... | |
| int4 | getAlignment (void) const |
| Get the instruction alignment for the processor. More... | |
| uintm | getUniqueBase (void) const |
| Get the base offset for new temporary registers. More... | |
| virtual void | initialize (DocumentStorage &store)=0 |
| Initialize the translator given XML configuration documents. More... | |
| virtual void | registerContext (const string &name, int4 sbit, int4 ebit) |
| Add a new context variable to the model for this processor. More... | |
| virtual void | setContextDefault (const string &name, uintm val) |
| Set the default value for a particular context variable. More... | |
| virtual void | allowContextSet (bool val) const |
| Toggle whether disassembly is allowed to affect context. More... | |
| virtual int4 | instructionLength (const Address &baseaddr) const =0 |
| Get the length of a machine instruction. More... | |
| virtual int4 | oneInstruction (PcodeEmit &emit, const Address &baseaddr) const =0 |
| Transform a single machine instruction into pcode. More... | |
| virtual int4 | printAssembly (AssemblyEmit &emit, const Address &baseaddr) const =0 |
| Disassemble a single machine instruction. More... | |
Public Member Functions inherited from AddrSpaceManager | |
| AddrSpaceManager (void) | |
| Construct an empty address space manager. More... | |
| virtual | ~AddrSpaceManager (void) |
| Destroy the manager. More... | |
| int4 | getDefaultSize (void) const |
| Get size of addresses for the default space. More... | |
| AddrSpace * | getSpaceByName (const string &nm) const |
| Get address space by name. More... | |
| AddrSpace * | getSpaceByShortcut (char sc) const |
| Get address space from its shortcut. More... | |
| AddrSpace * | getIopSpace (void) const |
| Get the internal pcode op space. More... | |
| AddrSpace * | getFspecSpace (void) const |
| Get the internal callspec space. More... | |
| AddrSpace * | getJoinSpace (void) const |
| Get the joining space. More... | |
| AddrSpace * | getStackSpace (void) const |
| Get the stack space for this processor. More... | |
| AddrSpace * | getUniqueSpace (void) const |
| Get the temporary register space for this processor. More... | |
| AddrSpace * | getDefaultCodeSpace (void) const |
| Get the default address space of this processor. More... | |
| AddrSpace * | getDefaultDataSpace (void) const |
| Get the default address space where data is stored. More... | |
| AddrSpace * | getConstantSpace (void) const |
| Get the constant space. More... | |
| Address | getConstant (uintb val) const |
| Get a constant encoded as an Address. More... | |
| Address | createConstFromSpace (AddrSpace *spc) const |
| Create a constant address encoding an address space. More... | |
| Address | resolveConstant (AddrSpace *spc, uintb val, int4 sz, const Address &point, uintb &fullEncoding) const |
| Resolve a native constant into an Address. More... | |
| int4 | numSpaces (void) const |
| Get the number of address spaces for this processor. More... | |
| AddrSpace * | getSpace (int4 i) const |
| Get an address space via its index. More... | |
| AddrSpace * | getNextSpaceInOrder (AddrSpace *spc) const |
| Get the next contiguous address space. More... | |
| JoinRecord * | findAddJoin (const vector< VarnodeData > &pieces, uint4 logicalsize) |
| Get (or create) JoinRecord for pieces. More... | |
| JoinRecord * | findJoin (uintb offset) const |
| Find JoinRecord for offset in the join space. More... | |
| void | setDeadcodeDelay (AddrSpace *spc, int4 delaydelta) |
| Set the deadcodedelay for a specific space. More... | |
| void | truncateSpace (const TruncationTag &tag) |
| Mark a space as truncated from its original size. More... | |
| Address | constructFloatExtensionAddress (const Address &realaddr, int4 realsize, int4 logicalsize) |
| Build a logically lower precision storage location for a bigger floating point register. More... | |
| Address | constructJoinAddress (const Translate *translate, const Address &hiaddr, int4 hisz, const Address &loaddr, int4 losz) |
| Build a logical whole from register pairs. More... | |
| void | renormalizeJoinAddress (Address &addr, int4 size) |
| Make sure a possibly offset join address has a proper JoinRecord. More... | |
Static Public Attributes | |
| static const uintb | MAX_UNIQUE_SIZE = 128 |
| Maximum size of a varnode in the unique space (should match value in SleighBase.java) | |
Protected Member Functions | |
| void | buildXrefs (vector< string > &errorPairs) |
| Build register map. Collect user-ops and context-fields. More... | |
| void | reregisterContext (void) |
| Reregister context fields for a new executable. More... | |
| void | restoreXml (const Element *el) |
| Read a SLEIGH specification from XML. More... | |
Protected Member Functions inherited from Translate | |
| void | setBigEndian (bool val) |
| Set general endianness to big if val is true. More... | |
| void | setUniqueBase (uintm val) |
| Set the base offset for new temporary registers. More... | |
Protected Member Functions inherited from AddrSpaceManager | |
| AddrSpace * | restoreXmlSpace (const Element *el, const Translate *trans) |
| Add a space to the model based an on XML tag. More... | |
| void | restoreXmlSpaces (const Element *el, const Translate *trans) |
| Restore address spaces in the model from an XML tag. More... | |
| void | setDefaultCodeSpace (int4 index) |
| Set the default address space (for code) More... | |
| void | setDefaultDataSpace (int4 index) |
| Set the default address space for data. More... | |
| void | setReverseJustified (AddrSpace *spc) |
| Set reverse justified property on this space. More... | |
| void | assignShortcut (AddrSpace *spc) |
| Select a shortcut character for a new space. More... | |
| void | markNearPointers (AddrSpace *spc, int4 size) |
| Mark that given space can be accessed with near pointers. More... | |
| void | insertSpace (AddrSpace *spc) |
| Add a new address space to the model. More... | |
| void | copySpaces (const AddrSpaceManager *op2) |
| Copy spaces from another manager. More... | |
| void | addSpacebasePointer (SpacebaseSpace *basespace, const VarnodeData &ptrdata, int4 truncSize, bool stackGrowth) |
| Set the base register of a spacebase space. More... | |
| void | insertResolver (AddrSpace *spc, AddressResolver *rsolv) |
| Override the base resolver for a space. More... | |
| void | setInferPtrBounds (const Range &range) |
| Set the range of addresses that can be inferred as pointers. More... | |
| JoinRecord * | findJoinInternal (uintb offset) const |
| Find JoinRecord for offset in the join space. More... | |
Protected Attributes | |
| SubtableSymbol * | root |
| The root SLEIGH decoding symbol. | |
| SymbolTable | symtab |
| The SLEIGH symbol table. | |
| uint4 | maxdelayslotbytes |
| Maximum number of bytes in a delay-slot directive. | |
| uint4 | unique_allocatemask |
| Bits that are guaranteed to be zero in the unique allocation scheme. | |
| uint4 | numSections |
| Number of named sections. | |
| SourceFileIndexer | indexer |
| source file index used when generating SLEIGH constructor debug info | |
Protected Attributes inherited from Translate | |
| int4 | alignment |
| Byte modulo on which instructions are aligned. | |
| vector< FloatFormat > | floatformats |
| Floating point formats utilized by the processor. | |
Common core of classes that read or write SLEIGH specification files natively.
This class represents what's in common across the SLEIGH infrastructure between:
|
virtual |
Add a named register to the model for this processor.
| nm | is the name of the new register |
| base | is the address space containing the register |
| offset | is the offset of the register |
| size | is the number of bytes in the register |
Implements Translate.
|
protected |
Build register map. Collect user-ops and context-fields.
Assuming the symbol table is populated, iterate through the table collecting registers (for the map), user-op names, and context fields.
|
virtual |
Get a list of all register names and the corresponding location.
Most processors have a list of named registers and possibly other memory locations that are specific to it. This function populates a map from the location information to the name, for every named location known by the translator
| reglist | is the map which will be populated by the call |
Implements Translate.
|
virtual |
Get a register as VarnodeData given its name.
Retrieve the location and size of a register given its name
| nm | is the name of the register |
Implements Translate.
|
virtual |
Get the name of a register given its location.
Generic references to locations in a register space can be translated into the associated register name. If the location doesn't match a register exactly, an empty string is returned.
| base | is the address space containing the location |
| off | is the offset of the location |
| size | is the size of the location |
Implements Translate.
|
virtual |
Get a list of all user-defined pcode ops.
The pcode model allows processors to define new pcode instructions that are specific to that processor. These user-defined instructions are all identified by a name and an index. This method returns a list of these ops in index order.
| res | is the resulting vector of user op names |
Implements Translate.
|
protected |
Reregister context fields for a new executable.
If this SleighBase is being reused with a new program, the context variables need to be registered with the new program's database
|
protected |
Read a SLEIGH specification from XML.
This parses the main <sleigh> tag (from a .sla file), which includes the description of address spaces and the symbol table, with its associated decoding tables
| el | is the root XML element |
| void SleighBase::saveXml | ( | ostream & | s | ) | const |
Write out the SLEIGH specification as an XML <sleigh> tag.
This does the bulk of the work of creating a .sla file
| s | is the output stream |
1.8.17