pub struct SyscallEnumerator<'a> { /* private fields */ }Expand description
enumerates syscalls from ntdll exports
Implementations§
Source§impl<'a> SyscallEnumerator<'a>
impl<'a> SyscallEnumerator<'a>
Sourcepub fn enumerate(&self) -> Result<Vec<EnumeratedSyscall>>
pub fn enumerate(&self) -> Result<Vec<EnumeratedSyscall>>
enumerate all syscalls and their SSNs
Sourcepub fn resolve_hooked_ssn(&self, target_addr: usize) -> Option<u16>
pub fn resolve_hooked_ssn(&self, target_addr: usize) -> Option<u16>
resolve SSN using “Halo’s Gate” technique
if a syscall is hooked, look at neighboring syscalls (SSNs are sequential, so Nt* functions nearby have SSN +/- N)
Auto Trait Implementations§
impl<'a> Freeze for SyscallEnumerator<'a>
impl<'a> RefUnwindSafe for SyscallEnumerator<'a>
impl<'a> !Send for SyscallEnumerator<'a>
impl<'a> !Sync for SyscallEnumerator<'a>
impl<'a> Unpin for SyscallEnumerator<'a>
impl<'a> UnwindSafe for SyscallEnumerator<'a>
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
Mutably borrows from an owned value. Read more