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>where
T: PhysicalMemory,
D: VirtualTranslate3,
impl<T, D> VirtualDma<T, DirectTranslate, D>where
T: PhysicalMemory,
D: VirtualTranslate3,
Sourcepub fn new(
phys_mem: T,
arch: impl Into<&'static dyn Architecture>,
translator: D,
) -> VirtualDma<T, DirectTranslate, D>
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>
impl<T, V, D> VirtualDma<T, V, D>
Sourcepub fn with_vat(
phys_mem: T,
arch: impl Into<&'static dyn Architecture>,
translator: D,
vat: V,
) -> VirtualDma<T, V, D>
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);
}Sourcepub fn sys_arch(&self) -> &'static dyn Architecture
pub fn sys_arch(&self) -> &'static dyn Architecture
Returns the architecture of the system. The system architecture is used for virtual to physical translations.
Sourcepub fn proc_arch(&self) -> &'static dyn Architecture
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.
Sourcepub fn set_proc_arch(
&mut self,
new_arch: &'static dyn Architecture,
) -> &'static dyn Architecture
pub fn set_proc_arch( &mut self, new_arch: &'static dyn Architecture, ) -> &'static dyn Architecture
Replaces current process architecture with a new one.
Sourcepub fn translator(&self) -> &D
pub fn translator(&self) -> &D
Returns the Directory Table Base of this process..
Sourcepub fn set_translator(&mut self, new_translator: D) -> D
pub fn set_translator(&mut self, new_translator: D) -> D
Replace current translator with a new one.
Sourcepub fn read_addr(
&mut self,
addr: Address,
) -> Result<Address, PartialError<Address>>
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
Sourcepub fn into_inner(self) -> (T, V)
pub fn into_inner(self) -> (T, V)
Consumes this VirtualDma object, returning the underlying memory and vat objects
pub fn mem_vat_pair(&mut self) -> (&mut T, &mut V)
pub fn phys_mem(&mut self) -> &mut T
pub fn phys_mem_ref(&self) -> &T
pub fn vat(&mut self) -> &mut V
Trait Implementations§
Source§impl<T, V, D> Clone for VirtualDma<T, V, D>
impl<T, V, D> Clone for VirtualDma<T, V, D>
Source§fn clone(&self) -> VirtualDma<T, V, D>
fn clone(&self) -> VirtualDma<T, V, D>
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source. Read moreSource§impl<T, V, D> MemoryView for VirtualDma<T, V, D>
impl<T, V, D> MemoryView for VirtualDma<T, V, D>
fn read_raw_iter<'a>( &mut self, _: MemOps<'_, '_, '_, CTup3<Address, Address, CSliceMut<'_, u8>>, CTup2<Address, CSliceMut<'_, u8>>>, ) -> Result<(), Error>
fn write_raw_iter( &mut self, _: MemOps<'_, '_, '_, CTup3<Address, Address, CSliceRef<'_, u8>>, CTup2<Address, CSliceRef<'_, u8>>>, ) -> Result<(), Error>
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>
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>
fn read_raw_list( &mut self, data: &mut [CTup2<Address, CSliceMut<'_, u8>>], ) -> Result<(), PartialError<()>>
fn read_raw_into( &mut self, addr: Address, out: &mut [u8], ) -> Result<(), PartialError<()>>
fn read_raw( &mut self, addr: Address, len: usize, ) -> Result<Vec<u8>, PartialError<Vec<u8>>>
fn read_into<T>( &mut self, addr: Address, out: &mut T, ) -> Result<(), PartialError<()>>
fn read<T>(&mut self, addr: Address) -> Result<T, PartialError<T>>
fn read_addr32(
&mut self,
addr: Address,
) -> Result<Address, PartialError<Address>>where
Self: Sized,
fn read_addr64(
&mut self,
addr: Address,
) -> Result<Address, PartialError<Address>>where
Self: Sized,
fn read_addr_arch(
&mut self,
arch: &'static dyn Architecture,
addr: Address,
) -> Result<Address, PartialError<Address>>where
Self: Sized,
fn read_ptr_into<U, T>( &mut self, ptr: Pointer<U, T>, out: &mut T, ) -> Result<(), PartialError<()>>
fn read_ptr<U, T>(&mut self, ptr: Pointer<U, T>) -> Result<T, PartialError<T>>
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>
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>
fn write_raw_list( &mut self, data: &[CTup2<Address, CSliceRef<'_, u8>>], ) -> Result<(), PartialError<()>>
fn write_raw( &mut self, addr: Address, data: &[u8], ) -> Result<(), PartialError<()>>
fn write<T>(&mut self, addr: Address, data: &T) -> Result<(), PartialError<()>>
fn write_ptr<U, T>( &mut self, ptr: Pointer<U, T>, data: &T, ) -> Result<(), PartialError<()>>
Source§fn read_char_array(
&mut self,
addr: Address,
len: usize,
) -> Result<String, PartialError<String>>
fn read_char_array( &mut self, addr: Address, len: usize, ) -> Result<String, PartialError<String>>
Source§fn read_char_string_n(
&mut self,
addr: Address,
n: usize,
) -> Result<String, PartialError<String>>
fn read_char_string_n( &mut self, addr: Address, n: usize, ) -> Result<String, PartialError<String>>
Source§fn read_char_string(
&mut self,
addr: Address,
) -> Result<String, PartialError<String>>
fn read_char_string( &mut self, addr: Address, ) -> Result<String, PartialError<String>>
Source§fn read_utf8(
&mut self,
addr: Address,
max_length: usize,
) -> Result<String, PartialError<String>>
fn read_utf8( &mut self, addr: Address, max_length: usize, ) -> Result<String, PartialError<String>>
max_length characters. Read moreSource§fn read_utf8_lossy(
&mut self,
addr: Address,
max_length: usize,
) -> Result<String, PartialError<String>>
fn read_utf8_lossy( &mut self, addr: Address, max_length: usize, ) -> Result<String, PartialError<String>>
max_length characters. Read moreSource§fn cursor(&mut self) -> MemoryCursor<Fwd<&mut Self>>where
Self: Sized,
fn cursor(&mut self) -> MemoryCursor<Fwd<&mut Self>>where
Self: Sized,
MemoryCursor for more details.Source§fn into_cursor(self) -> MemoryCursor<Self>where
Self: Sized,
fn into_cursor(self) -> MemoryCursor<Self>where
Self: Sized,
MemoryCursor for more details.Source§fn cursor_at(&mut self, address: Address) -> MemoryCursor<Fwd<&mut Self>>where
Self: Sized,
fn cursor_at(&mut self, address: Address) -> MemoryCursor<Fwd<&mut Self>>where
Self: Sized,
MemoryCursor for more details.Source§fn into_cursor_at(self, address: Address) -> MemoryCursor<Self>where
Self: Sized,
fn into_cursor_at(self, address: Address) -> MemoryCursor<Self>where
Self: Sized,
MemoryCursor for more details.fn batcher(&mut self) -> MemoryViewBatcher<'_, Self>where
Self: Sized,
fn into_overlay_arch(
self,
arch: &'static dyn Architecture,
) -> ArchOverlayView<Self>where
Self: Sized,
fn overlay_arch(
&mut self,
arch: &'static dyn Architecture,
) -> ArchOverlayView<Fwd<&mut Self>>where
Self: Sized,
fn into_overlay_arch_parts(
self,
arch_bits: u8,
little_endian: bool,
) -> ArchOverlayView<Self>where
Self: Sized,
fn overlay_arch_parts(
&mut self,
arch_bits: u8,
little_endian: bool,
) -> ArchOverlayView<Fwd<&mut Self>>where
Self: Sized,
fn into_remap_view(self, mem_map: MemoryMap<(Address, u64)>) -> RemapView<Self>where
Self: Sized,
fn remap_view(
&mut self,
mem_map: MemoryMap<(Address, u64)>,
) -> RemapView<Fwd<&mut Self>>where
Self: Sized,
fn into_phys_mem(self) -> PhysicalMemoryOnView<Self>where
Self: Sized,
fn phys_mem(&mut self) -> PhysicalMemoryOnView<Fwd<&mut Self>>where
Self: Sized,
Source§impl<T, V, D> VirtualTranslate for VirtualDma<T, V, D>
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>,
)
fn virt_to_phys_list( &mut self, addrs: &[CTup2<Address, u64>], out: OpaqueCallback<'_, VirtualTranslation>, out_fail: OpaqueCallback<'_, VirtualTranslationFail>, )
Source§fn virt_to_phys_range(
&mut self,
start: Address,
end: Address,
out: OpaqueCallback<'_, VirtualTranslation>,
)
fn virt_to_phys_range( &mut self, start: Address, end: Address, out: OpaqueCallback<'_, VirtualTranslation>, )
Source§fn virt_translation_map_range(
&mut self,
start: Address,
end: Address,
out: OpaqueCallback<'_, VirtualTranslation>,
)
fn virt_translation_map_range( &mut self, start: Address, end: Address, out: OpaqueCallback<'_, VirtualTranslation>, )
Source§fn virt_page_map_range(
&mut self,
gap_size: i64,
start: Address,
end: Address,
out: OpaqueCallback<'_, CTup3<Address, u64, PageType>>,
)
fn virt_page_map_range( &mut self, gap_size: i64, start: Address, end: Address, out: OpaqueCallback<'_, CTup3<Address, u64, PageType>>, )
Source§fn virt_to_phys(&mut self, address: Address) -> Result<PhysicalAddress, Error>
fn virt_to_phys(&mut self, address: Address) -> Result<PhysicalAddress, Error>
Source§fn virt_page_info(&mut self, addr: Address) -> Result<Page, Error>
fn virt_page_info(&mut self, addr: Address) -> Result<Page, Error>
Source§fn virt_page_map_range_vec(
&mut self,
gap_size: i64,
start: Address,
end: Address,
) -> Vec<CTup3<Address, u64, PageType>>
fn virt_page_map_range_vec( &mut self, gap_size: i64, start: Address, end: Address, ) -> Vec<CTup3<Address, u64, PageType>>
Source§fn virt_translation_map(&mut self, out: OpaqueCallback<'_, VirtualTranslation>)
fn virt_translation_map(&mut self, out: OpaqueCallback<'_, VirtualTranslation>)
Source§fn virt_translation_map_vec(&mut self) -> Vec<VirtualTranslation>
fn virt_translation_map_vec(&mut self) -> Vec<VirtualTranslation>
Source§fn phys_to_virt(&mut self, phys: Address) -> Option<Address>
fn phys_to_virt(&mut self, phys: Address) -> Option<Address>
Source§fn phys_to_virt_vec(&mut self, phys: Address) -> Vec<Address>
fn phys_to_virt_vec(&mut self, phys: Address) -> Vec<Address>
Source§fn virt_page_map(
&mut self,
gap_size: i64,
out: OpaqueCallback<'_, CTup3<Address, u64, PageType>>,
)
fn virt_page_map( &mut self, gap_size: i64, out: OpaqueCallback<'_, CTup3<Address, u64, PageType>>, )
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>
impl<T, V, D> !Sync for VirtualDma<T, V, D>
impl<T, V, D> Unpin for VirtualDma<T, V, D>
impl<T, V, D> !UnwindSafe for VirtualDma<T, V, D>
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Source§impl<'a, T> BorrowOwned<'a> for Twhere
T: 'a + Clone,
impl<'a, T> BorrowOwned<'a> for Twhere
T: 'a + Clone,
fn r_borrow( this: &'a <T as BorrowOwned<'a>>::ROwned, ) -> <T as BorrowOwned<'a>>::RBorrowed
fn r_to_owned( this: <T as BorrowOwned<'a>>::RBorrowed, ) -> <T as BorrowOwned<'a>>::ROwned
fn deref_borrowed(this: &<T as BorrowOwned<'a>>::RBorrowed) -> &T
fn deref_owned(this: &<T as BorrowOwned<'a>>::ROwned) -> &T
fn from_cow_borrow(this: &'a T) -> <T as BorrowOwned<'a>>::RBorrowed
fn from_cow_owned(this: <T as ToOwned>::Owned) -> <T as BorrowOwned<'a>>::ROwned
fn into_cow_borrow(this: <T as BorrowOwned<'a>>::RBorrowed) -> &'a T
fn into_cow_owned(this: <T as BorrowOwned<'a>>::ROwned) -> <T as ToOwned>::Owned
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<T> GetWithMetadata for T
impl<T> GetWithMetadata for T
Source§type ForSelf = WithMetadata_<T, T>
type ForSelf = WithMetadata_<T, T>
WithMetadata_<Self, Self>Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
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 moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
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 moreSource§impl<S> ROExtAcc for S
impl<S> ROExtAcc for S
Source§fn f_get<F>(&self, offset: FieldOffset<S, F, Aligned>) -> &F
fn f_get<F>(&self, offset: FieldOffset<S, F, Aligned>) -> &F
offset. Read moreSource§fn f_get_mut<F>(&mut self, offset: FieldOffset<S, F, Aligned>) -> &mut F
fn f_get_mut<F>(&mut self, offset: FieldOffset<S, F, Aligned>) -> &mut F
offset. Read moreSource§fn f_get_ptr<F, A>(&self, offset: FieldOffset<S, F, A>) -> *const F
fn f_get_ptr<F, A>(&self, offset: FieldOffset<S, F, A>) -> *const F
offset. Read moreSource§fn f_get_mut_ptr<F, A>(&mut self, offset: FieldOffset<S, F, A>) -> *mut F
fn f_get_mut_ptr<F, A>(&mut self, offset: FieldOffset<S, F, A>) -> *mut F
offset. Read moreSource§impl<S> ROExtOps<Aligned> for S
impl<S> ROExtOps<Aligned> for S
Source§fn f_replace<F>(&mut self, offset: FieldOffset<S, F, Aligned>, value: F) -> F
fn f_replace<F>(&mut self, offset: FieldOffset<S, F, Aligned>, value: F) -> F
offset) with value,
returning the previous value of the field. Read moreSource§fn f_get_copy<F>(&self, offset: FieldOffset<S, F, Aligned>) -> Fwhere
F: Copy,
fn f_get_copy<F>(&self, offset: FieldOffset<S, F, Aligned>) -> Fwhere
F: Copy,
Source§impl<S> ROExtOps<Unaligned> for S
impl<S> ROExtOps<Unaligned> for S
Source§fn f_replace<F>(&mut self, offset: FieldOffset<S, F, Unaligned>, value: F) -> F
fn f_replace<F>(&mut self, offset: FieldOffset<S, F, Unaligned>, value: F) -> F
offset) with value,
returning the previous value of the field. Read moreSource§fn f_get_copy<F>(&self, offset: FieldOffset<S, F, Unaligned>) -> Fwhere
F: Copy,
fn f_get_copy<F>(&self, offset: FieldOffset<S, F, Unaligned>) -> Fwhere
F: Copy,
Source§impl<T> SelfOps for Twhere
T: ?Sized,
impl<T> SelfOps for Twhere
T: ?Sized,
Source§fn piped<F, U>(self, f: F) -> U
fn piped<F, U>(self, f: F) -> U
Source§fn piped_ref<'a, F, U>(&'a self, f: F) -> Uwhere
F: FnOnce(&'a Self) -> U,
fn piped_ref<'a, F, U>(&'a self, f: F) -> Uwhere
F: FnOnce(&'a Self) -> U,
piped except that the function takes &Self
Useful for functions that take &Self instead of Self. Read moreSource§fn piped_mut<'a, F, U>(&'a mut self, f: F) -> Uwhere
F: FnOnce(&'a mut Self) -> U,
fn piped_mut<'a, F, U>(&'a mut self, f: F) -> Uwhere
F: FnOnce(&'a mut Self) -> U,
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
fn mutated<F>(self, f: F) -> Self
Source§fn observe<F>(self, f: F) -> Self
fn observe<F>(self, f: F) -> Self
Source§fn as_ref_<T>(&self) -> &T
fn as_ref_<T>(&self) -> &T
AsRef,
using the turbofish .as_ref_::<_>() syntax. Read more