ROSE 0.11.145.192
Classes | Typedefs | Enumerations | Functions | Variables
Rose::BinaryAnalysis::Variables Namespace Reference

Description

Finding and describing source-level variables.

This namespace contains facilities for finding source-level variables in binaries and describing those variables. For instance, it can analyze a function and detect stack locations that are likely to represent variables that appear in the source language from which the binary was compiled.

Binaries generally don't represent source-level variables in a straightforward manner. Some things to watch out for are:

Classes

class  BaseVariable
 Base class describing a source-level variable. More...
 
class  GlobalVariable
 Description of a global variable. More...
 
class  InstructionAccess
 Information about how an instruction accesses a variable. More...
 
class  StackFrame
 Information about a stack frame. More...
 
class  StackVariable
 Description of a local stack variable within a function. More...
 
class  VariableFinder
 Analysis to find variable locations. More...
 

Typedefs

using OffsetToAddress = std::map< int64_t, AddressSet >
 Mapping from stack offsets to address sets.
 
using AddressToAddresses = std::map< Address, AddressSet >
 Mapping from addresses to address sets.
 
using OffsetInterval = Sawyer::Container::Interval< int64_t >
 Interval of signed offsets.
 
using AccessFlags = Sawyer::BitFlags< Access, uint64_t >
 Whether a variable is read and/or written by an instruction.
 
using GlobalVariables = Sawyer::Container::IntervalMap< AddressInterval, GlobalVariable >
 Maps virtual addresses to global variables.
 
using StackVariables = Sawyer::Container::IntervalMap< OffsetInterval, StackVariable >
 Collection of local variables organized by stack offsets.
 
using VariableFinderPtr = std::shared_ptr< VariableFinder >
 Shared ownership pointer to VariableFinder.
 
using VariableFinderConstPtr = std::shared_ptr< const VariableFinder >
 Shared ownership pointer to VariableFinder.
 

Enumerations

enum class  Access {
  READ = 0x0001 ,
  WRITE = 0x0002
}
 Whether a variable is read or written. More...
 

Functions

void initDiagnostics ()
 Initialize diagnostic output.
 
void initNamespace ()
 Initialize the namespace.
 
std::string offsetStr (int64_t offset)
 Format a stack offset as a string.
 
std::string sizeStr (uint64_t size)
 Format size as a string.
 
void erase (GlobalVariables &, const AddressInterval &toErase)
 Erase some global variables.
 
void print (const GlobalVariables &, const Partitioner2::PartitionerConstPtr &, std::ostream &out, const std::string &prefix="")
 Print info about multiple global variables.
 
AddressInterval isInconsistent (const GlobalVariables &, Sawyer::Message::Stream &)
 Check that the map is consistent.
 
std::ostream & operator<< (std::ostream &, const InstructionAccess &)
 
void print (const StackVariables &, const Partitioner2::PartitionerConstPtr &, std::ostream &out, const std::string &prefix="")
 Print info about multiple local variables.
 

Variables

Sawyer::Message::Facility mlog
 Diagnostic facility for variables.
 
Sawyer::Attribute::Id ATTR_FRAME_SIZE
 
Sawyer::Attribute::Id ATTR_LOCAL_VARS
 
Sawyer::Attribute::Id ATTR_GLOBAL_VARS
 

Typedef Documentation

◆ VariableFinderPtr

Shared ownership pointer to VariableFinder.

Definition at line 33 of file Rose/BinaryAnalysis/Variables/BasicTypes.h.

◆ VariableFinderConstPtr

Shared ownership pointer to VariableFinder.

Definition at line 34 of file Rose/BinaryAnalysis/Variables/BasicTypes.h.

◆ OffsetToAddress

using Rose::BinaryAnalysis::Variables::OffsetToAddress = typedef std::map<int64_t , AddressSet>

Mapping from stack offsets to address sets.

Definition at line 38 of file Rose/BinaryAnalysis/Variables/BasicTypes.h.

◆ AddressToAddresses

Mapping from addresses to address sets.

Definition at line 41 of file Rose/BinaryAnalysis/Variables/BasicTypes.h.

◆ OffsetInterval

Interval of signed offsets.

Definition at line 44 of file Rose/BinaryAnalysis/Variables/BasicTypes.h.

◆ AccessFlags

Whether a variable is read and/or written by an instruction.

Definition at line 53 of file Rose/BinaryAnalysis/Variables/BasicTypes.h.

◆ GlobalVariables

Maps virtual addresses to global variables.

The global variable will be represented in the map at all addresses that the global variable could occupy. E.g., if global variable "g1" starts at 0x4000 and can be up to 1k 4-byte integers, then a record will exist in the map at all addresses from 0x4000 (inclusive) to 0x4100 (exclusive).

Definition at line 105 of file GlobalVariable.h.

◆ StackVariables

Collection of local variables organized by stack offsets.

Definition at line 166 of file StackVariable.h.

Enumeration Type Documentation

◆ Access

Whether a variable is read or written.

Enumerator
READ 

Variable is read.


WRITE 

Variable is written.

Definition at line 47 of file Rose/BinaryAnalysis/Variables/BasicTypes.h.

Function Documentation

◆ initDiagnostics()

void Rose::BinaryAnalysis::Variables::initDiagnostics ( )

Initialize diagnostic output.

This is called automatically when ROSE is initialized.

◆ initNamespace()

void Rose::BinaryAnalysis::Variables::initNamespace ( )

Initialize the namespace.

This is called automatically when ROSE is initialized.

◆ erase()

void Rose::BinaryAnalysis::Variables::erase ( GlobalVariables ,
const AddressInterval toErase 
)

Erase some global variables.

Erases global variables from the specified memory region. It is not sufficient to only remove addresses from the map; the addresses stored in the variables themselves (values in the map) may need to be adjusted so they don't overlap with the erased range.

◆ print() [1/2]

void Rose::BinaryAnalysis::Variables::print ( const GlobalVariables ,
const Partitioner2::PartitionerConstPtr ,
std::ostream &  out,
const std::string &  prefix = "" 
)

Print info about multiple global variables.

This output includes such things as their addresses, sizes, and the defining instructions. The output is multi-line, intended for debugging.

◆ isInconsistent()

AddressInterval Rose::BinaryAnalysis::Variables::isInconsistent ( const GlobalVariables ,
Sawyer::Message::Stream  
)

Check that the map is consistent.

Test that the keys of the map match up with the variables contained therein. If a map node is found where the interval key for the node doesn't match the addresses of the global variable stored in that node, then the map contains an inconsistency. When an inconsistency is found, and the output stream is enabled then the map is printed and all inconsistencies are highlighted.

Returns the first address interval (key) where an inconsistency is detected, or an empty interval if there are no inconsistencies.

◆ print() [2/2]

void Rose::BinaryAnalysis::Variables::print ( const StackVariables ,
const Partitioner2::PartitionerConstPtr ,
std::ostream &  out,
const std::string &  prefix = "" 
)

Print info about multiple local variables.

This output includes such things as the function to which they belong and the defining instructions. The output is multi-line, intended for debugging.