ROSE 0.11.145.192
Public Types | Public Member Functions | Static Public Member Functions | Public Attributes | Protected Member Functions | List of all members
Rose::BinaryAnalysis::InstructionSemantics::PartialSymbolicSemantics::SValue Class Reference

Description

Type of values manipulated by the PartialSymbolicSemantics domain.

A value is either known or unknown. Unknown values have a base name (unique ID number), offset, and sign.

Definition at line 61 of file PartialSymbolicSemantics.h.

#include <Rose/BinaryAnalysis/InstructionSemantics/PartialSymbolicSemantics.h>

Inheritance diagram for Rose::BinaryAnalysis::InstructionSemantics::PartialSymbolicSemantics::SValue:
Inheritance graph
[legend]
Collaboration diagram for Rose::BinaryAnalysis::InstructionSemantics::PartialSymbolicSemantics::SValue:
Collaboration graph
[legend]

Public Types

using Super = BaseSemantics::SValue
 Base type.
 
using Ptr = SValuePtr
 Shared-ownership pointer.
 
- Public Types inherited from Rose::BinaryAnalysis::InstructionSemantics::BaseSemantics::SValue
using Ptr = SValuePtr
 Shared-ownership pointer.
 

Public Member Functions

virtual BaseSemantics::SValuePtr bottom_ (size_t nbits) const override
 Data-flow bottom value.
 
virtual BaseSemantics::SValuePtr undefined_ (size_t nbits) const override
 Create a new undefined semantic value.
 
virtual BaseSemantics::SValuePtr unspecified_ (size_t nbits) const override
 Create a new unspecified semantic value.
 
virtual BaseSemantics::SValuePtr number_ (size_t nbits, uint64_t value) const override
 Create a new concrete semantic value.
 
virtual BaseSemantics::SValuePtr copy (size_t new_width=0) const override
 Create a new value from an existing value, changing the width if new_width is non-zero.
 
virtual Sawyer::Optional< BaseSemantics::SValuePtrcreateOptionalMerge (const BaseSemantics::SValuePtr &other, const BaseSemantics::MergerPtr &, const SmtSolverPtr &) const override
 Possibly create a new value by merging two existing values.
 
virtual BaseSemantics::SValuePtr create (size_t nbits, uint64_t name, uint64_t offset, bool negate) const
 Virtual allocating constructor.
 
virtual void hash (Combinatorics::Hasher &) const override
 Hash this semantic value.
 
virtual void print (std::ostream &, BaseSemantics::Formatter &) const override
 Print a value to a stream using default format.
 
virtual bool isBottom () const override
 Determines whether a value is a data-flow bottom.
 
virtual void set_width (size_t nbits) override
 Virtual API.
 
virtual bool may_equal (const BaseSemantics::SValuePtr &other, const SmtSolverPtr &solver=SmtSolverPtr()) const override
 Virtual API.
 
virtual bool must_equal (const BaseSemantics::SValuePtr &other, const SmtSolverPtr &solver=SmtSolverPtr()) const override
 Virtual API.
 
virtual bool is_number () const override
 Virtual API.
 
virtual uint64_t get_number () const override
 Virtual API.
 
- Public Member Functions inherited from Rose::BinaryAnalysis::InstructionSemantics::BaseSemantics::SValue
virtual SValuePtr boolean_ (bool value) const
 Create a new, Boolean value.
 
SValuePtr createMerged (const SValuePtr &other, const MergerPtr &, const SmtSolverPtr &) const
 Create a new value by merging two existing values.
 
size_t nBits () const
 Property: value width.
 
bool isConcrete () const
 Determines if the value is a concrete number.
 
Sawyer::Optional< uint64_t > toUnsigned () const
 Converts a concrete value to a native unsigned integer.
 
Sawyer::Optional< int64_t > toSigned () const
 Converts a concrete value to a native signed integer.
 
bool mustEqual (const SValuePtr &other, const SmtSolverPtr &solver=SmtSolverPtr()) const
 Tests two values for equality.
 
bool mayEqual (const SValuePtr &other, const SmtSolverPtr &solver=SmtSolverPtr()) const
 Tests two values for possible equality.
 
bool isTrue () const
 Returns true if concrete non-zero.
 
bool isFalse () const
 Returns true if concrete zero.
 
std::string toString () const
 Render this symbolic expression as a string.
 
std::string comment () const
 Property: Comment.
 
void comment (const std::string &) const
 Property: Comment.
 
void print (std::ostream &) const
 Print a value to a stream using default format.
 
WithFormatter with_format (Formatter &)
 Used for printing values with formatting.
 
WithFormatter operator+ (Formatter &)
 Used for printing values with formatting.
 
WithFormatter operator+ (const std::string &linePrefix)
 Used for printing values with formatting.
 
virtual size_t get_width () const
 Virtual API.
 
virtual std::string get_comment () const
 Some subclasses support the ability to add comments to values.
 
virtual void set_comment (const std::string &) const
 Some subclasses support the ability to add comments to values.
 
- Public Member Functions inherited from Sawyer::SharedObject
 SharedObject ()
 Default constructor.
 
 SharedObject (const SharedObject &)
 Copy constructor.
 
virtual ~SharedObject ()
 Virtual destructor.
 
SharedObjectoperator= (const SharedObject &)
 Assignment.
 
- Public Member Functions inherited from Sawyer::SharedFromThis< SValue >
SharedPointer< SValue > sharedFromThis ()
 Create a shared pointer from this.
 
SharedPointer< const SValue > sharedFromThis () const
 Create a shared pointer from this.
 

Static Public Member Functions

static uint64_t nextName ()
 Returns the next available name.
 
static SValuePtr instance ()
 Instantiate a new prototypical value.
 
static SValuePtr instance (size_t nbits)
 Instantiate a new undefined value of specified width.
 
static SValuePtr instance (size_t nbits, uint64_t value)
 Instantiate a new concrete value.
 
static SValuePtr instance (size_t nbits, uint64_t name, uint64_t offset, bool negate)
 Insantiate a new value with all the necessary parts.
 
static SValuePtr promote (const BaseSemantics::SValuePtr &)
 Promote a base value to a PartialSymbolicSemantics value.
 
- Static Public Member Functions inherited from Rose::BinaryAnalysis::InstructionSemantics::BaseSemantics::SValue
static SValuePtr promote (const SValuePtr &)
 
- Static Public Member Functions inherited from Sawyer::SmallObject
static SynchronizedPoolAllocatorpoolAllocator ()
 Return the pool allocator for this class.
 
static void * operator new (size_t size)
 
static void operator delete (void *ptr, size_t size)
 

Public Attributes

uint64_t name
 Zero for constants; non-zero ID number for everything else.
 
uint64_t offset
 The constant (if name==0) or an offset w.r.t.
 
bool negate
 Switch between name+offset and (-name)+offset; should be false for constants.
 

Protected Member Functions

 SValue (size_t nbits)
 
 SValue (size_t nbits, uint64_t number)
 
 SValue (size_t nbits, uint64_t name, uint64_t offset, bool negate)
 
- Protected Member Functions inherited from Rose::BinaryAnalysis::InstructionSemantics::BaseSemantics::SValue
 SValue (size_t nbits)
 
 SValue (const SValue &other)
 

Additional Inherited Members

- Protected Attributes inherited from Rose::BinaryAnalysis::InstructionSemantics::BaseSemantics::SValue
size_t width
 

Member Typedef Documentation

◆ Super

Base type.

Definition at line 64 of file PartialSymbolicSemantics.h.

◆ Ptr

Shared-ownership pointer.

Definition at line 67 of file PartialSymbolicSemantics.h.

Member Function Documentation

◆ nextName()

static uint64_t Rose::BinaryAnalysis::InstructionSemantics::PartialSymbolicSemantics::SValue::nextName ( )
static

Returns the next available name.

Returns the next available name and increments it.

Thread safety: This function is thread safe.

◆ instance()

static SValuePtr Rose::BinaryAnalysis::InstructionSemantics::PartialSymbolicSemantics::SValue::instance ( )
static

Instantiate a new prototypical value.

Prototypical values are only used for their virtual constructors.

◆ bottom_()

virtual BaseSemantics::SValuePtr Rose::BinaryAnalysis::InstructionSemantics::PartialSymbolicSemantics::SValue::bottom_ ( size_t  nBits) const
overridevirtual

Data-flow bottom value.

Returns a new value that represents bottom in a data-flow analysis. If a semantic domain can represent a bottom value then the isBottom predicate is true when invoked on this method's return value. If a semantic domain cannot support a bottom value, then it may return some other value.

Implements Rose::BinaryAnalysis::InstructionSemantics::BaseSemantics::SValue.

◆ undefined_()

virtual BaseSemantics::SValuePtr Rose::BinaryAnalysis::InstructionSemantics::PartialSymbolicSemantics::SValue::undefined_ ( size_t  nbits) const
overridevirtual

Create a new undefined semantic value.

The new semantic value will have the same dynamic type as the value on which this virtual method is called. This is the most common way that a new value is created. The unspecified_ method is closely related.

See also
unspecified_

Implements Rose::BinaryAnalysis::InstructionSemantics::BaseSemantics::SValue.

◆ unspecified_()

virtual BaseSemantics::SValuePtr Rose::BinaryAnalysis::InstructionSemantics::PartialSymbolicSemantics::SValue::unspecified_ ( size_t  nbits) const
overridevirtual

Create a new unspecified semantic value.

The new semantic value will have the same dynamic type as the value on which this virtual method is called. Undefined (undefined_) and unspecified are closely related. Unspecified values are the same as undefined values except they're instantiated as the result of some machine instruction where the ISA documentation indicates that the value is unspecified (e.g., status flags for x86 shift and rotate instructions).

Most semantic domains make no distinction between undefined and unspecified.

See also
undefined_

Implements Rose::BinaryAnalysis::InstructionSemantics::BaseSemantics::SValue.

◆ number_()

virtual BaseSemantics::SValuePtr Rose::BinaryAnalysis::InstructionSemantics::PartialSymbolicSemantics::SValue::number_ ( size_t  nbits,
uint64_t  number 
) const
overridevirtual

Create a new concrete semantic value.

The new value will represent the specified concrete value and have the same dynamic type as the value on which this virtual method is called. This is the most common way that a new constant is created. The number is truncated to contain nbits bits (higher order bits are cleared).

Implements Rose::BinaryAnalysis::InstructionSemantics::BaseSemantics::SValue.

◆ copy()

virtual BaseSemantics::SValuePtr Rose::BinaryAnalysis::InstructionSemantics::PartialSymbolicSemantics::SValue::copy ( size_t  new_width = 0) const
overridevirtual

Create a new value from an existing value, changing the width if new_width is non-zero.

Increasing the width logically adds zero bits to the most significant side of the value; decreasing the width logically removes bits from the most significant side of the value.

Implements Rose::BinaryAnalysis::InstructionSemantics::BaseSemantics::SValue.

◆ createOptionalMerge()

virtual Sawyer::Optional< BaseSemantics::SValuePtr > Rose::BinaryAnalysis::InstructionSemantics::PartialSymbolicSemantics::SValue::createOptionalMerge ( const BaseSemantics::SValuePtr other,
const BaseSemantics::MergerPtr merger,
const SmtSolverPtr solver 
) const
overridevirtual

Possibly create a new value by merging two existing values.

This method optionally returns a new semantic value as the data-flow merge of this and other. If the two inputs are "equal" in some sense of the dataflow implementation then nothing is returned, otherwise a new value is returned. Typical usage is like this:

if (SValuePtr merged = v1->createOptionalMerge(v2).orDefault()) {
std::cout <<"v1 and v2 were merged to " <<*merged <<"\n";
} else {
std::cout <<"no merge is necessary\n";
}
or
@code
SValuePtr merge;
if (v1->createOptionalMerge(v2).assignTo(merged)) {
std::cout <<"v1 and v2 were merged to " <<*merged <<"\n";
} else {
std::cout <<"v1 and v2 are equal in some sense (no merge necessary)\n";
}
Reference-counting intrusive smart pointer.
Sawyer::SharedPointer< class SValue > SValuePtr
Shared-ownership pointer to a partial-symbolic semantic value.

If you always want a copy regardless of whether the merge is necessary, then use the createMerged convenience function instead.

Implements Rose::BinaryAnalysis::InstructionSemantics::BaseSemantics::SValue.

◆ create()

virtual BaseSemantics::SValuePtr Rose::BinaryAnalysis::InstructionSemantics::PartialSymbolicSemantics::SValue::create ( size_t  nbits,
uint64_t  name,
uint64_t  offset,
bool  negate 
) const
virtual

Virtual allocating constructor.

Creates a new semantic value with full control over all aspects of the value.

◆ promote()

static SValuePtr Rose::BinaryAnalysis::InstructionSemantics::PartialSymbolicSemantics::SValue::promote ( const BaseSemantics::SValuePtr )
static

Promote a base value to a PartialSymbolicSemantics value.

The value v must have a PartialSymbolicSemantics::SValue dynamic type.

◆ hash()

virtual void Rose::BinaryAnalysis::InstructionSemantics::PartialSymbolicSemantics::SValue::hash ( Combinatorics::Hasher ) const
overridevirtual

Hash this semantic value.

Hashes the value by appending it to the specified hasher.

Implements Rose::BinaryAnalysis::InstructionSemantics::BaseSemantics::SValue.

◆ print()

virtual void Rose::BinaryAnalysis::InstructionSemantics::PartialSymbolicSemantics::SValue::print ( std::ostream &  ,
BaseSemantics::Formatter  
) const
overridevirtual

Print a value to a stream using default format.

The value will normally occupy a single line and not contain leading space or line termination. See also, with_format().

Implements Rose::BinaryAnalysis::InstructionSemantics::BaseSemantics::SValue.

◆ isBottom()

virtual bool Rose::BinaryAnalysis::InstructionSemantics::PartialSymbolicSemantics::SValue::isBottom ( ) const
inlineoverridevirtual

Determines whether a value is a data-flow bottom.

Returns true if this value represents a bottom value for data-flow analysis. Any RiscOperation performed on an operand whose isBottom predicate returns true will itself return a bottom value. This includes operations like "xor x x" which would normally return zero.

Implements Rose::BinaryAnalysis::InstructionSemantics::BaseSemantics::SValue.

Definition at line 133 of file PartialSymbolicSemantics.h.

◆ set_width()

virtual void Rose::BinaryAnalysis::InstructionSemantics::PartialSymbolicSemantics::SValue::set_width ( size_t  nbits)
overridevirtual

◆ may_equal()

virtual bool Rose::BinaryAnalysis::InstructionSemantics::PartialSymbolicSemantics::SValue::may_equal ( const BaseSemantics::SValuePtr other,
const SmtSolverPtr solver = SmtSolverPtr() 
) const
overridevirtual

◆ must_equal()

virtual bool Rose::BinaryAnalysis::InstructionSemantics::PartialSymbolicSemantics::SValue::must_equal ( const BaseSemantics::SValuePtr other,
const SmtSolverPtr solver = SmtSolverPtr() 
) const
overridevirtual

◆ is_number()

virtual bool Rose::BinaryAnalysis::InstructionSemantics::PartialSymbolicSemantics::SValue::is_number ( ) const
inlineoverridevirtual

Virtual API.

See isConcrete.

Implements Rose::BinaryAnalysis::InstructionSemantics::BaseSemantics::SValue.

Definition at line 154 of file PartialSymbolicSemantics.h.

References name.

Referenced by get_number().

◆ get_number()

virtual uint64_t Rose::BinaryAnalysis::InstructionSemantics::PartialSymbolicSemantics::SValue::get_number ( ) const
inlineoverridevirtual

Virtual API.

See toUnsigned and toSigned.

Implements Rose::BinaryAnalysis::InstructionSemantics::BaseSemantics::SValue.

Definition at line 159 of file PartialSymbolicSemantics.h.

References is_number(), and offset.

Member Data Documentation

◆ name

uint64_t Rose::BinaryAnalysis::InstructionSemantics::PartialSymbolicSemantics::SValue::name

Zero for constants; non-zero ID number for everything else.

Definition at line 70 of file PartialSymbolicSemantics.h.

Referenced by is_number().

◆ offset

uint64_t Rose::BinaryAnalysis::InstructionSemantics::PartialSymbolicSemantics::SValue::offset

The constant (if name==0) or an offset w.r.t.

an unknown (named) base value.

Definition at line 71 of file PartialSymbolicSemantics.h.

Referenced by get_number().

◆ negate

bool Rose::BinaryAnalysis::InstructionSemantics::PartialSymbolicSemantics::SValue::negate

Switch between name+offset and (-name)+offset; should be false for constants.

Definition at line 72 of file PartialSymbolicSemantics.h.


The documentation for this class was generated from the following file: