pub enum AbstractLocation {
    Register(Variable),
    GlobalAddress {
        address: u64,
        size: ByteSize,
    },
    Pointer(Variable, AbstractMemoryLocation),
    GlobalPointer(u64, AbstractMemoryLocation),
}
Expand description

An abstract location describes how to find the value of a variable in memory at a given time.

It is defined recursively, where the root is either a register or a (constant) global address. This way only locations that the local state knows about are representable. It is also impossible to accidentally describe circular references.

Variants§

§

Register(Variable)

The location is given by a register.

§

GlobalAddress

Fields

§address: u64

The address in global memory.

§size: ByteSize

The byte size of the address (not the pointed-to value!).

The value itself is a constant address to global memory. Note that the size is the size of the pointer and not the size of the value residing at the specific address in global memory.

§

Pointer(Variable, AbstractMemoryLocation)

The location is in memory. One needs to follow the pointer in the given register and then follow the abstract memory location inside the pointed to memory object to find the actual memory location.

§

GlobalPointer(u64, AbstractMemoryLocation)

The location is in memory. One needs to follow the pointer located at the given global address and then follow the abstract memory location inside the pointed to memory object to find the actual memory location.

Implementations§

source§

impl AbstractLocation

source

pub fn from_var(variable: &Variable) -> Result<AbstractLocation, Error>

Create an abstract location from a variable corresponding to a register. This function returns an error if the variable is not a physical register.

source

pub fn from_stack_position( stack_register: &Variable, offset: i64, size: ByteSize ) -> AbstractLocation

Create an abstract location on the stack. The returned location describes the value of the given size at the given offset relative to the memory location that the stack_register is pointing to.

source

pub fn from_global_address(address: &Bitvector) -> AbstractLocation

Create an abstract location representing an address pointing to global memory.

source

pub fn with_offset_addendum(self, addendum: i64) -> AbstractLocation

Add an offset to the abstract location.

source

pub fn dereferenced( self, new_size: ByteSize, generic_pointer_size: ByteSize ) -> AbstractLocation

Return the abstract location that one gets when dereferencing the pointer that self is pointing to.

Panics if self is not pointer-sized.

source

pub fn bytesize(&self) -> ByteSize

Get the bytesize of the value represented by the abstract location.

source

pub fn recursion_depth(&self) -> u64

Get the recursion depth of the abstract location, i.e. how many times one has to dereference a pointer until reaching the actual location.

source

pub fn extend( &mut self, extension: AbstractMemoryLocation, generic_pointer_size: ByteSize )

Extend the location string by adding further derefence operations to it according to the given extension.

source

pub fn get_parent_location( &self, generic_pointer_size: ByteSize ) -> Result<(AbstractLocation, i64), Error>

Get the abstract location representing the pointer pointing to the memory object that contains the location represented by self together with the offset that one has to add to the pointer to get the location of self.

Returns an error if the abstract location contains no dereference operation (e.g. if self represents a register value).

source

pub fn get_all_parent_locations( &self, generic_pointer_size: ByteSize ) -> Vec<AbstractLocation>

Get a list of all (recursive) parent locations. The list is sorted by recursion depth, starting with the root location.

Trait Implementations§

source§

impl Clone for AbstractLocation

source§

fn clone(&self) -> AbstractLocation

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl Debug for AbstractLocation

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl<'de> Deserialize<'de> for AbstractLocation

source§

fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>
where __D: Deserializer<'de>,

Deserialize this value from the given Serde deserializer. Read more
source§

impl Display for AbstractLocation

source§

fn fmt(&self, formatter: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl Hash for AbstractLocation

source§

fn hash<__H: Hasher>(&self, state: &mut __H)

Feeds this value into the given Hasher. Read more
1.3.0 · source§

fn hash_slice<H>(data: &[Self], state: &mut H)
where H: Hasher, Self: Sized,

Feeds a slice of this type into the given Hasher. Read more
source§

impl Ord for AbstractLocation

source§

fn cmp(&self, other: &AbstractLocation) -> Ordering

This method returns an Ordering between self and other. Read more
1.21.0 · source§

fn max(self, other: Self) -> Self
where Self: Sized,

Compares and returns the maximum of two values. Read more
1.21.0 · source§

fn min(self, other: Self) -> Self
where Self: Sized,

Compares and returns the minimum of two values. Read more
1.50.0 · source§

fn clamp(self, min: Self, max: Self) -> Self
where Self: Sized + PartialOrd,

Restrict a value to a certain interval. Read more
source§

impl PartialEq for AbstractLocation

source§

fn eq(&self, other: &AbstractLocation) -> bool

This method tests for self and other values to be equal, and is used by ==.
1.0.0 · source§

fn ne(&self, other: &Rhs) -> bool

This method tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
source§

impl PartialOrd for AbstractLocation

source§

fn partial_cmp(&self, other: &AbstractLocation) -> Option<Ordering>

This method returns an ordering between self and other values if one exists. Read more
1.0.0 · source§

fn lt(&self, other: &Rhs) -> bool

This method tests less than (for self and other) and is used by the < operator. Read more
1.0.0 · source§

fn le(&self, other: &Rhs) -> bool

This method tests less than or equal to (for self and other) and is used by the <= operator. Read more
1.0.0 · source§

fn gt(&self, other: &Rhs) -> bool

This method tests greater than (for self and other) and is used by the > operator. Read more
1.0.0 · source§

fn ge(&self, other: &Rhs) -> bool

This method tests greater than or equal to (for self and other) and is used by the >= operator. Read more
source§

impl Serialize for AbstractLocation

source§

fn serialize<__S>(&self, __serializer: __S) -> Result<__S::Ok, __S::Error>
where __S: Serializer,

Serialize this value into the given Serde serializer. Read more
source§

impl Eq for AbstractLocation

source§

impl StructuralEq for AbstractLocation

source§

impl StructuralPartialEq for AbstractLocation

Auto Trait Implementations§

Blanket Implementations§

source§

impl<T> Any for T
where T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for T
where T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
§

impl<Q, K> Comparable<K> for Q
where Q: Ord + ?Sized, K: Borrow<Q> + ?Sized,

§

fn compare(&self, key: &K) -> Ordering

Compare self to key and return their ordering.
§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

§

fn equivalent(&self, key: &K) -> bool

Checks if this value is equivalent to the given key. Read more
§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

§

fn equivalent(&self, key: &K) -> bool

Compare self to key and return true if they are equal.
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T, U> Into<U> for T
where U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<T> ToOwned for T
where T: Clone,

§

type Owned = T

The resulting type after obtaining ownership.
source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
source§

impl<T> ToString for T
where T: Display + ?Sized,

source§

default fn to_string(&self) -> String

Converts the given value to a String. Read more
source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
source§

impl<T> DeserializeOwned for T
where T: for<'de> Deserialize<'de>,