From 100e6b1dd7b147ba29c8b9a36becaed646b1f626 Mon Sep 17 00:00:00 2001 From: Melvin Wang Date: Fri, 3 Nov 2023 14:21:57 -0700 Subject: [PATCH] fix: remove dependency on lazystatic in wdk-alloc rust tag (#21) Signed-off-by: Melvin Wang --- Cargo.lock | 1 - crates/wdk-alloc/Cargo.toml | 1 - crates/wdk-alloc/src/lib.rs | 18 ++++-------------- 3 files changed, 4 insertions(+), 16 deletions(-) diff --git a/Cargo.lock b/Cargo.lock index a9937e61..0983b7a4 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -569,7 +569,6 @@ dependencies = [ name = "wdk-alloc" version = "0.1.0" dependencies = [ - "lazy_static", "wdk-sys", ] diff --git a/crates/wdk-alloc/Cargo.toml b/crates/wdk-alloc/Cargo.toml index ec1a9ad7..9572d8d0 100644 --- a/crates/wdk-alloc/Cargo.toml +++ b/crates/wdk-alloc/Cargo.toml @@ -11,7 +11,6 @@ categories = ["memory-management", "no-std", "hardware-support"] [dependencies] wdk-sys.workspace = true -lazy_static = { version = "1.4.0", features = ["spin_no_std"] } [dev-dependencies] wdk-sys = { workspace = true, features = ["test-stubs"] } diff --git a/crates/wdk-alloc/src/lib.rs b/crates/wdk-alloc/src/lib.rs index 6b8f930c..8dea1391 100644 --- a/crates/wdk-alloc/src/lib.rs +++ b/crates/wdk-alloc/src/lib.rs @@ -35,7 +35,6 @@ use core::alloc::{GlobalAlloc, Layout}; -use lazy_static::lazy_static; use wdk_sys::{ ntddk::{ExAllocatePool2, ExFreePool}, POOL_FLAG_NON_PAGED, @@ -47,18 +46,9 @@ use wdk_sys::{ /// [`core::alloc`]. pub struct WDKAllocator; -// The value of memory tags are stored in little-endian order, so it is -// convenient to reverse the order for readability in tooling(ie. Windbg) -// FIXME: replace lazy_static with std::Lazy once available: https://github.com/rust-lang/rust/issues/109736 -lazy_static! { - static ref RUST_TAG: ULONG = u32::from_ne_bytes( - #[allow(clippy::string_lit_as_bytes)] // A u8 slice is required here - "rust" - .as_bytes() - .try_into() - .expect("tag string.as_bytes() should be able to convert into [u8; 4]"), - ); -} +// The value of memory tags are stored in little-endian order, so it is +// convenient to reverse the order for readability in tooling (ie. Windbg) +const RUST_TAG: ULONG = u32::from_ne_bytes(*b"rust"); // SAFETY: This is safe because the WDK allocator: // 1. can never unwind since it can never panic @@ -67,7 +57,7 @@ lazy_static! { // supported) unsafe impl GlobalAlloc for WDKAllocator { unsafe fn alloc(&self, layout: Layout) -> *mut u8 { - let ptr = ExAllocatePool2(POOL_FLAG_NON_PAGED, layout.size() as SIZE_T, *RUST_TAG); + let ptr = ExAllocatePool2(POOL_FLAG_NON_PAGED, layout.size() as SIZE_T, RUST_TAG); if ptr.is_null() { return core::ptr::null_mut(); }