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: PhysicalMemory, D: VirtualTranslate3> VirtualDma<T, DirectTranslate, D>

source

pub fn new(phys_mem: T, arch: impl Into<ArchitectureObj>, translator: D) -> Self

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: PhysicalMemory, V: VirtualTranslate2, D: VirtualTranslate3> VirtualDma<T, V, D>

source

pub fn with_vat( phys_mem: T, arch: impl Into<ArchitectureObj>, translator: D, vat: V ) -> Self

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) -> ArchitectureObj

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

source

pub fn proc_arch(&self) -> ArchitectureObj

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: ArchitectureObj) -> ArchitectureObj

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) -> PartialResult<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) -> Self

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<T: PhysicalMemory, V: VirtualTranslate2, D: VirtualTranslate3> MemoryView for VirtualDma<T, V, D>

source§

fn read_raw_iter<'a>(&mut self, _: ReadRawMemOps<'_, '_, '_, '_>) -> Result<()>

source§

fn write_raw_iter(&mut self, _: WriteRawMemOps<'_, '_, '_, '_>) -> Result<()>

source§

fn metadata(&self) -> MemoryViewMetadata

source§

fn read_iter<'a, 'b>( &mut self, inp: impl Iterator<Item = ReadData<'a>>, out: Option<&mut ReadCallback<'b, 'a>>, out_fail: Option<&mut ReadCallback<'b, 'a>> ) -> Result<()>

Read arbitrary amount of data. Read more
source§

fn read_raw_list(&mut self, data: &mut [ReadData<'_>]) -> PartialResult<()>

source§

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

source§

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

source§

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

source§

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

source§

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

source§

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

source§

fn read_addr64_rip(&mut self, addr: Address) -> PartialResult<Address>
where Self: Sized,

Reads the specified address as a rip-relative address.
source§

fn read_addr_arch( &mut self, arch: ArchitectureObj, addr: Address ) -> PartialResult<Address>
where Self: Sized,

source§

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

source§

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

source§

fn write_iter<'a, 'b>( &mut self, inp: impl Iterator<Item = WriteData<'a>>, out: Option<&mut WriteCallback<'b, 'a>>, out_fail: Option<&mut WriteCallback<'b, 'a>> ) -> Result<()>

Write arbitrary amount of data. Read more
source§

fn write_raw_list(&mut self, data: &[WriteData<'_>]) -> PartialResult<()>

source§

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

source§

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

source§

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

source§

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

Reads a fixed length string from the target. Read more
source§

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

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) -> PartialResult<String>

Reads a variable length string with up to 4kb length from the target. Read more
source§

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

source§

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

source§

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

source§

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

source§

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

source§

fn into_overlay_arch(self, arch: ArchitectureObj) -> ArchOverlayView<Self>
where Self: Sized,

source§

fn overlay_arch( &mut self, arch: ArchitectureObj ) -> 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, umem)>) -> RemapView<Self>
where Self: Sized,

source§

fn remap_view( &mut self, mem_map: MemoryMap<(Address, umem)> ) -> 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: PhysicalMemory, V: VirtualTranslate2, D: VirtualTranslate3> VirtualTranslate for VirtualDma<T, V, D>

source§

fn virt_to_phys_list( &mut self, addrs: &[VtopRange], out: VirtualTranslationCallback<'_>, out_fail: VirtualTranslationFailCallback<'_> )

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: VirtualTranslationCallback<'_> )

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: VirtualTranslationCallback<'_> )

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: imem, start: Address, end: Address, out: MemoryRangeCallback<'_> )

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

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

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

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

Retrieve page information at virtual address. Read more
source§

fn virt_page_map_range_vec( &mut self, gap_size: imem, start: Address, end: Address ) -> Vec<MemoryRange>

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

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

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: imem, out: MemoryRangeCallback<'_>)

Retrieves all mapped virtual pages. Read more
source§

fn virt_page_map_vec(&mut self, gap_size: imem) -> Vec<MemoryRange>

Returns a Vec of all mapped virtual pages. Read more

Auto Trait Implementations§

§

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

§

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

§

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

§

impl<T, V, D> Unpin for VirtualDma<T, V, D>
where D: Unpin, T: Unpin, V: 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,

§

type ROwned = T

The owned type, stored in RCow::Owned
§

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

§

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.

§

impl<S> ROExtAcc for S

§

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

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

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
§

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
§

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
§

impl<S> ROExtOps<Aligned> for S

§

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
§

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
§

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
§

impl<S> ROExtOps<Unaligned> for S

§

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
§

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
§

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
§

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

§

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

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

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
§

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
§

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

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
§

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
§

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

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

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
§

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
§

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,

§

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

§

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

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

§

type Type = T

This is always Self.
§

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

Converts a value back to the original type.
§

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

Converts a reference back to the original type.
§

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

Converts a mutable reference back to the original type.
§

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

Converts a box back to the original type.
§

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

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

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

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

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

Converts a value back to the original type.
§

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

Converts a reference back to the original type.
§

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

Converts a mutable reference back to the original type.
§

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

Converts a box back to the original type.
§

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

Converts an Arc back to the original type.
§

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

Converts an Rc back to the original type.