pub struct WindowsPeb<'a, Driver>{ /* private fields */ }Expand description
PEB accessor with a runtime pointer width.
The PEB is a user-mode structure that stores process-wide information, such as loaded modules, heap data, and environment settings.
§Implementation Details
Corresponds to _PEB.
Implementations§
Source§impl<'a, Driver> WindowsPeb<'a, Driver>
impl<'a, Driver> WindowsPeb<'a, Driver>
Sourcepub fn with_kind(
vmi: VmiState<'a, WindowsOs<Driver>>,
va: Va,
root: Pa,
kind: WindowsWow64Kind,
) -> Self
pub fn with_kind( vmi: VmiState<'a, WindowsOs<Driver>>, va: Va, root: Pa, kind: WindowsWow64Kind, ) -> Self
Creates a new PEB accessor with an explicit address space root and pointer width.
Sourcepub fn ldr(&self) -> Result<WindowsPebLdrData<'a, Driver>, VmiError>
pub fn ldr(&self) -> Result<WindowsPebLdrData<'a, Driver>, VmiError>
Returns the PEB loader data.
The loader data contains the three module lists maintained by the Windows loader.
§Implementation Details
Corresponds to _PEB.Ldr.
Sourcepub fn process_parameters(
&self,
) -> Result<WindowsProcessParameters<'a, Driver>, VmiError>
pub fn process_parameters( &self, ) -> Result<WindowsProcessParameters<'a, Driver>, VmiError>
Returns the process parameters of the process.
§Implementation Details
Corresponds to _PEB.ProcessParameters.
Sourcepub fn current_directory(&self) -> Result<String, VmiError>
pub fn current_directory(&self) -> Result<String, VmiError>
Returns the current directory.
Shortcut for self.process_parameters()?.current_directory().
Sourcepub fn dll_path(&self) -> Result<String, VmiError>
pub fn dll_path(&self) -> Result<String, VmiError>
Returns the DLL search path.
Shortcut for self.process_parameters()?.dll_path().
Sourcepub fn image_path_name(&self) -> Result<String, VmiError>
pub fn image_path_name(&self) -> Result<String, VmiError>
Returns the full path of the executable image.
Shortcut for self.process_parameters()?.image_path_name().
Sourcepub fn command_line(&self) -> Result<String, VmiError>
pub fn command_line(&self) -> Result<String, VmiError>
Returns the command line used to launch the process.
Shortcut for self.process_parameters()?.command_line().
Trait Implementations§
Source§impl<Driver> Debug for WindowsPeb<'_, Driver>
impl<Driver> Debug for WindowsPeb<'_, Driver>
Source§impl<'a, Driver> From<WindowsPebBase<'a, Driver, StructLayout32>> for WindowsPeb<'a, Driver>
impl<'a, Driver> From<WindowsPebBase<'a, Driver, StructLayout32>> for WindowsPeb<'a, Driver>
Source§fn from(value: WindowsPebBase<'a, Driver, StructLayout32>) -> Self
fn from(value: WindowsPebBase<'a, Driver, StructLayout32>) -> Self
Source§impl<'a, Driver> From<WindowsPebBase<'a, Driver, StructLayout64>> for WindowsPeb<'a, Driver>
impl<'a, Driver> From<WindowsPebBase<'a, Driver, StructLayout64>> for WindowsPeb<'a, Driver>
Source§fn from(value: WindowsPebBase<'a, Driver, StructLayout64>) -> Self
fn from(value: WindowsPebBase<'a, Driver, StructLayout64>) -> Self
Source§impl<Driver> VmiVa for WindowsPeb<'_, Driver>
impl<Driver> VmiVa for WindowsPeb<'_, Driver>
Auto Trait Implementations§
impl<'a, Driver> Freeze for WindowsPeb<'a, Driver>
impl<'a, Driver> !RefUnwindSafe for WindowsPeb<'a, Driver>
impl<'a, Driver> !Send for WindowsPeb<'a, Driver>
impl<'a, Driver> !Sync for WindowsPeb<'a, Driver>
impl<'a, Driver> Unpin for WindowsPeb<'a, Driver>
impl<'a, Driver> UnsafeUnpin for WindowsPeb<'a, Driver>
impl<'a, Driver> !UnwindSafe for WindowsPeb<'a, Driver>
Blanket Implementations§
Source§impl<T> ArchivePointee for T
impl<T> ArchivePointee for T
Source§type ArchivedMetadata = ()
type ArchivedMetadata = ()
Source§fn pointer_metadata(
_: &<T as ArchivePointee>::ArchivedMetadata,
) -> <T as Pointee>::Metadata
fn pointer_metadata( _: &<T as ArchivePointee>::ArchivedMetadata, ) -> <T as Pointee>::Metadata
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<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> LayoutRaw for T
impl<T> LayoutRaw for T
Source§fn layout_raw(_: <T as Pointee>::Metadata) -> Result<Layout, LayoutError>
fn layout_raw(_: <T as Pointee>::Metadata) -> Result<Layout, LayoutError>
Source§impl<T, N1, N2> Niching<NichedOption<T, N1>> for N2
impl<T, N1, N2> Niching<NichedOption<T, N1>> for N2
Source§unsafe fn is_niched(niched: *const NichedOption<T, N1>) -> bool
unsafe fn is_niched(niched: *const NichedOption<T, N1>) -> bool
Source§fn resolve_niched(out: Place<NichedOption<T, N1>>)
fn resolve_niched(out: Place<NichedOption<T, N1>>)
out indicating that a T is niched.