Commit 2a571248 authored by Antonio Hickey's avatar Antonio Hickey Committed by Miguel Ojeda
Browse files

rust: block: refactor to use `&raw mut`



Replace all occurrences (one) of `addr_of_mut!(place)` with
`&raw mut place`.

This will allow us to reduce macro complexity, and improve consistency
with existing reference syntax as `&raw mut` is similar to `&mut` making
it fit more naturally with other existing code.

Suggested-by: default avatarBenno Lossin <benno.lossin@proton.me>
Link: https://github.com/Rust-for-Linux/linux/issues/1148


Signed-off-by: default avatarAntonio Hickey <contact@antoniohickey.com>
Acked-by: default avatarAndreas Hindborg <a.hindborg@kernel.org>
Reviewed-by: default avatarBenno Lossin <benno.lossin@proton.me>
Reviewed-by: default avatarBoqun Feng <boqun.feng@gmail.com>
Link: https://lore.kernel.org/r/20250320020740.1631171-17-contact@antoniohickey.com


[ Reworded slightly. - Miguel ]
Signed-off-by: default avatarMiguel Ojeda <ojeda@kernel.org>
parent e1dfaa33
Loading
Loading
Loading
Loading
+2 −2
Original line number Diff line number Diff line
@@ -12,7 +12,7 @@
};
use core::{
    marker::PhantomData,
    ptr::{addr_of_mut, NonNull},
    ptr::NonNull,
    sync::atomic::{AtomicU64, Ordering},
};

@@ -187,7 +187,7 @@ pub(crate) fn refcount(&self) -> &AtomicU64 {
    pub(crate) unsafe fn refcount_ptr(this: *mut Self) -> *mut AtomicU64 {
        // SAFETY: Because of the safety requirements of this function, the
        // field projection is safe.
        unsafe { addr_of_mut!((*this).refcount) }
        unsafe { &raw mut (*this).refcount }
    }
}