VirtualDma

Struct VirtualDma 

Source
pub struct VirtualDma<T, V, D> { /* private fields */ }
Expand description

The VirtualDma struct provides a default implementation to access virtual memory from user provided PhysicalMemory and VirtualTranslate2 objects.

This struct implements MemoryView and allows the user to access the virtual memory of a process.

Implementations§

Source§

impl<T, D> VirtualDma<T, DirectTranslate, D>

Source

pub fn new( phys_mem: T, arch: impl Into<&'static dyn Architecture>, translator: D, ) -> VirtualDma<T, DirectTranslate, D>

Constructs a VirtualDma object from user supplied architectures and DTB. It creates a default VirtualTranslate2 object using the DirectTranslate struct.

If you want to use a cache for translating virtual to physical memory consider using the VirtualDma::with_vat() function and supply your own VirtualTranslate2 object.

§Examples

Constructing a VirtualDma object with a given dtb and using it to read:

use memflow::types::Address;
use memflow::architecture::x86::x64;
use memflow::mem::{PhysicalMemory, VirtualTranslate2, MemoryView, VirtualDma};
use memflow::cglue::Fwd;

fn read(phys_mem: Fwd<&mut impl PhysicalMemory>, vat: &mut impl VirtualTranslate2, dtb: Address, read_addr: Address) {
    let arch = x64::ARCH;
    let translator = x64::new_translator(dtb);

    let mut virt_mem = VirtualDma::new(phys_mem, arch, translator);

    let mut addr = 0u64;
    virt_mem.read_into(read_addr, &mut addr).unwrap();
    println!("addr: {:x}", addr);
}
Source§

impl<T, V, D> VirtualDma<T, V, D>

Source

pub fn with_vat( phys_mem: T, arch: impl Into<&'static dyn Architecture>, translator: D, vat: V, ) -> VirtualDma<T, V, D>

This function constructs a VirtualDma instance with a user supplied VirtualTranslate2 object. It can be used when working with cached virtual to physical translations such as a Tlb.

§Examples

Constructing a VirtualDma object with VAT and using it to read:

use memflow::types::Address;
use memflow::architecture::x86::x64;
use memflow::mem::{PhysicalMemory, VirtualTranslate2, MemoryView, VirtualDma};
use memflow::cglue::Fwd;

fn read(phys_mem: Fwd<&mut impl PhysicalMemory>, vat: impl VirtualTranslate2, dtb: Address, read_addr: Address) {
    let arch = x64::ARCH;
    let translator = x64::new_translator(dtb);

    let mut virt_mem = VirtualDma::with_vat(phys_mem, arch, translator, vat);

    let mut addr = 0u64;
    virt_mem.read_into(read_addr, &mut addr).unwrap();
    println!("addr: {:x}", addr);
}
Source

pub fn sys_arch(&self) -> &'static dyn Architecture

Returns the architecture of the system. The system architecture is used for virtual to physical translations.

Source

pub fn proc_arch(&self) -> &'static dyn Architecture

Returns the architecture of the process for this context. The process architecture is mainly used to determine pointer sizes.

Source

pub fn set_proc_arch( &mut self, new_arch: &'static dyn Architecture, ) -> &'static dyn Architecture

Replaces current process architecture with a new one.

Source

pub fn translator(&self) -> &D

Returns the Directory Table Base of this process..

Source

pub fn set_translator(&mut self, new_translator: D) -> D

Replace current translator with a new one.

Source

pub fn read_addr( &mut self, addr: Address, ) -> Result<Address, PartialError<Address>>

A wrapper around read_addr64 and read_addr32 that will use the pointer size of this context’s process. TODO: do this in virt mem

Source

pub fn into_inner(self) -> (T, V)

Consumes this VirtualDma object, returning the underlying memory and vat objects

Source

pub fn mem_vat_pair(&mut self) -> (&mut T, &mut V)

Source

pub fn phys_mem(&mut self) -> &mut T

Source

pub fn phys_mem_ref(&self) -> &T

Source

pub fn vat(&mut self) -> &mut V

Trait Implementations§

Source§

impl<T, V, D> Clone for VirtualDma<T, V, D>
where T: Clone, V: Clone, D: Clone,

Source§

fn clone(&self) -> VirtualDma<T, V, D>

Returns a duplicate 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<T, V, D> MemoryView for VirtualDma<T, V, D>

Source§

fn read_raw_iter<'a>( &mut self, _: MemOps<'_, '_, '_, CTup3<Address, Address, CSliceMut<'_, u8>>, CTup2<Address, CSliceMut<'_, u8>>>, ) -> Result<(), Error>

Source§

fn write_raw_iter( &mut self, _: MemOps<'_, '_, '_, CTup3<Address, Address, CSliceRef<'_, u8>>, CTup2<Address, CSliceRef<'_, u8>>>, ) -> Result<(), Error>

Source§

fn metadata(&self) -> MemoryViewMetadata

Source§

fn read_iter<'a, 'b>( &mut self, inp: impl Iterator<Item = CTup2<Address, CSliceMut<'a, u8>>>, out: Option<&mut OpaqueCallback<'b, CTup2<Address, CSliceMut<'a, u8>>>>, out_fail: Option<&mut OpaqueCallback<'b, CTup2<Address, CSliceMut<'a, u8>>>>, ) -> Result<(), Error>

Read arbitrary amount of data. Read more
Source§

fn read_raw_list( &mut self, data: &mut [CTup2<Address, CSliceMut<'_, u8>>], ) -> Result<(), PartialError<()>>

Source§

fn read_raw_into( &mut self, addr: Address, out: &mut [u8], ) -> Result<(), PartialError<()>>

Source§

fn read_raw( &mut self, addr: Address, len: usize, ) -> Result<Vec<u8>, PartialError<Vec<u8>>>

Source§

fn read_into<T>( &mut self, addr: Address, out: &mut T, ) -> Result<(), PartialError<()>>
where T: Pod + ?Sized, Self: Sized,

Source§

fn read<T>(&mut self, addr: Address) -> Result<T, PartialError<T>>
where T: Pod, Self: Sized,

Source§

fn read_addr32( &mut self, addr: Address, ) -> Result<Address, PartialError<Address>>
where Self: Sized,

Source§

fn read_addr64( &mut self, addr: Address, ) -> Result<Address, PartialError<Address>>
where Self: Sized,

Source§

fn read_addr_arch( &mut self, arch: &'static dyn Architecture, addr: Address, ) -> Result<Address, PartialError<Address>>
where Self: Sized,

Source§

fn read_ptr_into<U, T>( &mut self, ptr: Pointer<U, T>, out: &mut T, ) -> Result<(), PartialError<()>>
where U: PrimitiveAddress, T: Pod + ?Sized, Self: Sized,

Source§

fn read_ptr<U, T>(&mut self, ptr: Pointer<U, T>) -> Result<T, PartialError<T>>
where U: PrimitiveAddress, T: Pod, Self: Sized,

Source§

fn write_iter<'a, 'b>( &mut self, inp: impl Iterator<Item = CTup2<Address, CSliceRef<'a, u8>>>, out: Option<&mut OpaqueCallback<'b, CTup2<Address, CSliceRef<'a, u8>>>>, out_fail: Option<&mut OpaqueCallback<'b, CTup2<Address, CSliceRef<'a, u8>>>>, ) -> Result<(), Error>

Write arbitrary amount of data. Read more
Source§

fn write_raw_list( &mut self, data: &[CTup2<Address, CSliceRef<'_, u8>>], ) -> Result<(), PartialError<()>>

Source§

fn write_raw( &mut self, addr: Address, data: &[u8], ) -> Result<(), PartialError<()>>

Source§

fn write<T>(&mut self, addr: Address, data: &T) -> Result<(), PartialError<()>>
where T: Pod + ?Sized, Self: Sized,

Source§

fn write_ptr<U, T>( &mut self, ptr: Pointer<U, T>, data: &T, ) -> Result<(), PartialError<()>>
where U: PrimitiveAddress, T: Pod + ?Sized, Self: Sized,

Source§

fn read_char_array( &mut self, addr: Address, len: usize, ) -> Result<String, PartialError<String>>

👎Deprecated: please use read_utf8 or read_utf8_lossy instead
Reads a fixed length string from the target. Read more
Source§

fn read_char_string_n( &mut self, addr: Address, n: usize, ) -> Result<String, PartialError<String>>

👎Deprecated: please use read_utf8 or read_utf8_lossy instead
Reads a variable length string with a length of up to specified amount from the target. Read more
Source§

fn read_char_string( &mut self, addr: Address, ) -> Result<String, PartialError<String>>

👎Deprecated: please use read_utf8 or read_utf8_lossy instead
Reads a variable length string with up to 4kb length from the target. Read more
Source§

fn read_utf8( &mut self, addr: Address, max_length: usize, ) -> Result<String, PartialError<String>>

Reads a string at the given position with a length of up to max_length characters. Read more
Source§

fn read_utf8_lossy( &mut self, addr: Address, max_length: usize, ) -> Result<String, PartialError<String>>

Reads a string at the given position with a length of up to max_length characters. Read more
Source§

fn cursor(&mut self) -> MemoryCursor<Fwd<&mut Self>>
where Self: Sized,

Returns a cursor over this memory view. See MemoryCursor for more details.
Source§

fn into_cursor(self) -> MemoryCursor<Self>
where Self: Sized,

Converts this memory view into a cursor. See MemoryCursor for more details.
Source§

fn cursor_at(&mut self, address: Address) -> MemoryCursor<Fwd<&mut Self>>
where Self: Sized,

Returns a cursor over this memory view at the specified address. See MemoryCursor for more details.
Source§

fn into_cursor_at(self, address: Address) -> MemoryCursor<Self>
where Self: Sized,

Converts this memory view into a cursor at the specified address. See MemoryCursor for more details.
Source§

fn batcher(&mut self) -> MemoryViewBatcher<'_, Self>
where Self: Sized,

Source§

fn into_overlay_arch( self, arch: &'static dyn Architecture, ) -> ArchOverlayView<Self>
where Self: Sized,

Source§

fn overlay_arch( &mut self, arch: &'static dyn Architecture, ) -> ArchOverlayView<Fwd<&mut Self>>
where Self: Sized,

Source§

fn into_overlay_arch_parts( self, arch_bits: u8, little_endian: bool, ) -> ArchOverlayView<Self>
where Self: Sized,

Source§

fn overlay_arch_parts( &mut self, arch_bits: u8, little_endian: bool, ) -> ArchOverlayView<Fwd<&mut Self>>
where Self: Sized,

Source§

fn into_remap_view(self, mem_map: MemoryMap<(Address, u64)>) -> RemapView<Self>
where Self: Sized,

Source§

fn remap_view( &mut self, mem_map: MemoryMap<(Address, u64)>, ) -> RemapView<Fwd<&mut Self>>
where Self: Sized,

Source§

fn into_phys_mem(self) -> PhysicalMemoryOnView<Self>
where Self: Sized,

Source§

fn phys_mem(&mut self) -> PhysicalMemoryOnView<Fwd<&mut Self>>
where Self: Sized,

Source§

impl<T, V, D> VirtualTranslate for VirtualDma<T, V, D>

Source§

fn virt_to_phys_list( &mut self, addrs: &[CTup2<Address, u64>], out: OpaqueCallback<'_, VirtualTranslation>, out_fail: OpaqueCallback<'_, VirtualTranslationFail>, )

Translate a list of address ranges into physical address space. Read more
Source§

fn virt_to_phys_range( &mut self, start: Address, end: Address, out: OpaqueCallback<'_, VirtualTranslation>, )

Translate a single virtual address range into physical address space. Read more
Source§

fn virt_translation_map_range( &mut self, start: Address, end: Address, out: OpaqueCallback<'_, VirtualTranslation>, )

Translate a single virtual address range into physical address space and coalesce nearby regions. Read more
Source§

fn virt_page_map_range( &mut self, gap_size: i64, start: Address, end: Address, out: OpaqueCallback<'_, CTup3<Address, u64, PageType>>, )

Retrieves mapped virtual pages in the specified range. Read more
Source§

fn virt_to_phys(&mut self, address: Address) -> Result<PhysicalAddress, Error>

Translate a single virtual address into a single physical address. Read more
Source§

fn virt_page_info(&mut self, addr: Address) -> Result<Page, Error>

Retrieve page information at virtual address. Read more
Source§

fn virt_page_map_range_vec( &mut self, gap_size: i64, start: Address, end: Address, ) -> Vec<CTup3<Address, u64, PageType>>

Retrieve a vector of physical pages within given range. Read more
Source§

fn virt_translation_map(&mut self, out: OpaqueCallback<'_, VirtualTranslation>)

Get virtual translation map over entire address space. Read more
Source§

fn virt_translation_map_vec(&mut self) -> Vec<VirtualTranslation>

Get virtual translation map over entire address space and return it as a vector. Read more
Source§

fn phys_to_virt(&mut self, phys: Address) -> Option<Address>

Attempt to translate a physical address into a virtual one. Read more
Source§

fn phys_to_virt_vec(&mut self, phys: Address) -> Vec<Address>

Retrieve all virtual address that map into a given physical address. Read more
Source§

fn virt_page_map( &mut self, gap_size: i64, out: OpaqueCallback<'_, CTup3<Address, u64, PageType>>, )

Retrieves all mapped virtual pages. Read more
Source§

fn virt_page_map_vec( &mut self, gap_size: i64, ) -> Vec<CTup3<Address, u64, PageType>>

Returns a Vec of all mapped virtual pages. Read more

Auto Trait Implementations§

§

impl<T, V, D> !Freeze for VirtualDma<T, V, D>

§

impl<T, V, D> !RefUnwindSafe for VirtualDma<T, V, D>

§

impl<T, V, D> Send for VirtualDma<T, V, D>
where T: Send, V: Send, D: Send,

§

impl<T, V, D> !Sync for VirtualDma<T, V, D>

§

impl<T, V, D> Unpin for VirtualDma<T, V, D>
where T: Unpin, V: Unpin, D: Unpin,

§

impl<T, V, D> !UnwindSafe for VirtualDma<T, V, D>

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
Source§

impl<'a, T> BorrowOwned<'a> for T
where T: 'a + Clone,

Source§

type ROwned = T

The owned type, stored in RCow::Owned
Source§

type RBorrowed = &'a T

The borrowed type, stored in RCow::Borrowed
Source§

fn r_borrow( this: &'a <T as BorrowOwned<'a>>::ROwned, ) -> <T as BorrowOwned<'a>>::RBorrowed

Source§

fn r_to_owned( this: <T as BorrowOwned<'a>>::RBorrowed, ) -> <T as BorrowOwned<'a>>::ROwned

Source§

fn deref_borrowed(this: &<T as BorrowOwned<'a>>::RBorrowed) -> &T

Source§

fn deref_owned(this: &<T as BorrowOwned<'a>>::ROwned) -> &T

Source§

fn from_cow_borrow(this: &'a T) -> <T as BorrowOwned<'a>>::RBorrowed

Source§

fn from_cow_owned(this: <T as ToOwned>::Owned) -> <T as BorrowOwned<'a>>::ROwned

Source§

fn into_cow_borrow(this: <T as BorrowOwned<'a>>::RBorrowed) -> &'a T

Source§

fn into_cow_owned(this: <T as BorrowOwned<'a>>::ROwned) -> <T as ToOwned>::Owned

Source§

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

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, F> From2<T> for F
where T: Into<F>,

Source§

fn from2(other: T) -> F

Source§

impl<T> GetWithMetadata for T

Source§

type ForSelf = WithMetadata_<T, T>

This is always WithMetadata_<Self, Self>
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> IntoEither for T

Source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts self into a Left variant of Either<Self, Self> if into_left is true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts self into a Left variant of Either<Self, Self> if into_left(&self) returns true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

impl<S> ROExtAcc for S

Source§

fn f_get<F>(&self, offset: FieldOffset<S, F, Aligned>) -> &F

Gets a reference to a field, determined by offset. Read more
Source§

fn f_get_mut<F>(&mut self, offset: FieldOffset<S, F, Aligned>) -> &mut F

Gets a muatble reference to a field, determined by offset. Read more
Source§

fn f_get_ptr<F, A>(&self, offset: FieldOffset<S, F, A>) -> *const F

Gets a const pointer to a field, the field is determined by offset. Read more
Source§

fn f_get_mut_ptr<F, A>(&mut self, offset: FieldOffset<S, F, A>) -> *mut F

Gets a mutable pointer to a field, determined by offset. Read more
Source§

impl<S> ROExtOps<Aligned> for S

Source§

fn f_replace<F>(&mut self, offset: FieldOffset<S, F, Aligned>, value: F) -> F

Replaces a field (determined by offset) with value, returning the previous value of the field. Read more
Source§

fn f_swap<F>(&mut self, offset: FieldOffset<S, F, Aligned>, right: &mut S)

Swaps a field (determined by offset) with the same field in right. Read more
Source§

fn f_get_copy<F>(&self, offset: FieldOffset<S, F, Aligned>) -> F
where F: Copy,

Gets a copy of a field (determined by offset). The field is determined by offset. Read more
Source§

impl<S> ROExtOps<Unaligned> for S

Source§

fn f_replace<F>(&mut self, offset: FieldOffset<S, F, Unaligned>, value: F) -> F

Replaces a field (determined by offset) with value, returning the previous value of the field. Read more
Source§

fn f_swap<F>(&mut self, offset: FieldOffset<S, F, Unaligned>, right: &mut S)

Swaps a field (determined by offset) with the same field in right. Read more
Source§

fn f_get_copy<F>(&self, offset: FieldOffset<S, F, Unaligned>) -> F
where F: Copy,

Gets a copy of a field (determined by offset). The field is determined by offset. Read more
Source§

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

Source§

fn eq_id(&self, other: &Self) -> bool

Compares the address of self with the address of other. Read more
Source§

fn piped<F, U>(self, f: F) -> U
where F: FnOnce(Self) -> U, Self: Sized,

Emulates the pipeline operator, allowing method syntax in more places. Read more
Source§

fn piped_ref<'a, F, U>(&'a self, f: F) -> U
where F: FnOnce(&'a Self) -> U,

The same as piped except that the function takes &Self Useful for functions that take &Self instead of Self. Read more
Source§

fn piped_mut<'a, F, U>(&'a mut self, f: F) -> U
where F: FnOnce(&'a mut Self) -> U,

The same as piped, except that the function takes &mut Self. Useful for functions that take &mut Self instead of Self.
Source§

fn mutated<F>(self, f: F) -> Self
where F: FnOnce(&mut Self), Self: Sized,

Mutates self using a closure taking self by mutable reference, passing it along the method chain. Read more
Source§

fn observe<F>(self, f: F) -> Self
where F: FnOnce(&Self), Self: Sized,

Observes the value of self, passing it along unmodified. Useful in long method chains. Read more
Source§

fn into_<T>(self) -> T
where Self: Into<T>,

Performs a conversion with Into. using the turbofish .into_::<_>() syntax. Read more
Source§

fn as_ref_<T>(&self) -> &T
where Self: AsRef<T>, T: ?Sized,

Performs a reference to reference conversion with AsRef, using the turbofish .as_ref_::<_>() syntax. Read more
Source§

fn as_mut_<T>(&mut self) -> &mut T
where Self: AsMut<T>, T: ?Sized,

Performs a mutable reference to mutable reference conversion with AsMut, using the turbofish .as_mut_::<_>() syntax. Read more
Source§

fn drop_(self)
where Self: Sized,

Drops self using method notation. Alternative to std::mem::drop. Read more
Source§

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

Source§

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<This> TransmuteElement for This
where This: ?Sized,

Source§

unsafe fn transmute_element<T>(self) -> Self::TransmutedPtr
where Self: CanTransmuteElement<T>,

Transmutes the element type of this pointer.. Read more
Source§

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

Source§

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>,

Source§

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> TypeIdentity for T
where T: ?Sized,

Source§

type Type = T

This is always Self.
Source§

fn into_type(self) -> Self::Type
where Self: Sized, Self::Type: Sized,

Converts a value back to the original type.
Source§

fn as_type(&self) -> &Self::Type

Converts a reference back to the original type.
Source§

fn as_type_mut(&mut self) -> &mut Self::Type

Converts a mutable reference back to the original type.
Source§

fn into_type_box(self: Box<Self>) -> Box<Self::Type>

Converts a box back to the original type.
Source§

fn into_type_arc(this: Arc<Self>) -> Arc<Self::Type>

Converts an Arc back to the original type. Read more
Source§

fn into_type_rc(this: Rc<Self>) -> Rc<Self::Type>

Converts an Rc back to the original type. Read more
Source§

fn from_type(this: Self::Type) -> Self
where Self: Sized, Self::Type: Sized,

Converts a value back to the original type.
Source§

fn from_type_ref(this: &Self::Type) -> &Self

Converts a reference back to the original type.
Source§

fn from_type_mut(this: &mut Self::Type) -> &mut Self

Converts a mutable reference back to the original type.
Source§

fn from_type_box(this: Box<Self::Type>) -> Box<Self>

Converts a box back to the original type.
Source§

fn from_type_arc(this: Arc<Self::Type>) -> Arc<Self>

Converts an Arc back to the original type.
Source§

fn from_type_rc(this: Rc<Self::Type>) -> Rc<Self>

Converts an Rc back to the original type.