summaryrefslogtreecommitdiff
path: root/crates/windows-kernel-sys/src/ntoskrnl.rs
diff options
context:
space:
mode:
authorFuwn <[email protected]>2022-01-03 03:20:12 -0800
committerFuwn <[email protected]>2022-01-03 03:20:12 -0800
commit85db2b507f3f69b32811c54a89d9ac7bbbc46121 (patch)
tree2efd66da452f8a6a2cc6c91584c925f237506ddf /crates/windows-kernel-sys/src/ntoskrnl.rs
downloaddriver-85db2b507f3f69b32811c54a89d9ac7bbbc46121.tar.xz
driver-85db2b507f3f69b32811c54a89d9ac7bbbc46121.zip
feat(driver): commit primer
Diffstat (limited to 'crates/windows-kernel-sys/src/ntoskrnl.rs')
-rw-r--r--crates/windows-kernel-sys/src/ntoskrnl.rs50
1 files changed, 50 insertions, 0 deletions
diff --git a/crates/windows-kernel-sys/src/ntoskrnl.rs b/crates/windows-kernel-sys/src/ntoskrnl.rs
new file mode 100644
index 0000000..f1daa4e
--- /dev/null
+++ b/crates/windows-kernel-sys/src/ntoskrnl.rs
@@ -0,0 +1,50 @@
+#![allow(non_upper_case_globals)]
+#![allow(non_camel_case_types)]
+#![allow(non_snake_case)]
+
+use crate::base::*;
+
+#[link(name = "wrapper_ntoskrnl")]
+extern "C" {
+ pub fn _ExInitializeFastMutex(mutex: PFAST_MUTEX);
+ pub fn _ExAcquirePushLockExclusive(push_lock: PEX_PUSH_LOCK);
+ pub fn _ExReleasePushLockExclusive(push_lock: PEX_PUSH_LOCK);
+ pub fn _ExAcquirePushLockShared(push_lock: PEX_PUSH_LOCK);
+ pub fn _ExReleasePushLockShared(push_lock: PEX_PUSH_LOCK);
+ pub fn _IoGetCurrentIrpStackLocation(irp: PIRP) -> PIO_STACK_LOCATION;
+ pub fn _IoGetNextIrpStackLocation(irp: PIRP) -> PIO_STACK_LOCATION;
+ pub fn _IoSetCompletionRoutine(
+ irp: PIRP,
+ completion_routine: PIO_COMPLETION_ROUTINE,
+ context: PVOID,
+ invoke_on_success: BOOLEAN,
+ invoke_on_error: BOOLEAN,
+ invoke_on_cancel: BOOLEAN,
+ );
+ pub fn _IoCompleteRequest(irp: PIRP, priority_boost: CCHAR);
+ pub fn _MmGetMdlByteCount(mdl: PMDL) -> ULONG;
+ pub fn _MmGetMdlByteOffset(mdl: PMDL) -> ULONG;
+ pub fn _MmGetSystemAddressForMdlSafe(mdl: PMDL, priority: ULONG) -> PVOID;
+ pub fn _ObDereferenceObject(p: *mut cty::c_void);
+ pub fn _ObReferenceObject(p: *mut cty::c_void);
+}
+
+pub use self::{
+ IoGetCurrentProcess as PsGetCurrentProcess,
+ _ExAcquirePushLockExclusive as ExAcquirePushLockExclusive,
+ _ExAcquirePushLockShared as ExAcquirePushLockShared,
+ _ExInitializeFastMutex as ExInitializeFastMutex,
+ _ExReleasePushLockExclusive as ExReleasePushLockExclusive,
+ _ExReleasePushLockShared as ExReleasePushLockShared,
+ _IoCompleteRequest as IoCompleteRequest,
+ _IoGetCurrentIrpStackLocation as IoGetCurrentIrpStackLocation,
+ _IoGetNextIrpStackLocation as IoGetNextIrpStackLocation,
+ _IoSetCompletionRoutine as IoSetCompletionRoutine,
+ _MmGetMdlByteCount as MmGetMdlByteCount,
+ _MmGetMdlByteOffset as MmGetMdlByteOffset,
+ _MmGetSystemAddressForMdlSafe as MmGetSystemAddressForMdlSafe,
+ _ObDereferenceObject as ObDereferenceObject,
+ _ObReferenceObject as ObReferenceObject,
+};
+
+include!(concat!(env!("OUT_DIR"), "/ntoskrnl.rs"));