mirror of
https://github.com/Fishwaldo/linux-bl808.git
synced 2025-03-15 19:45:26 +00:00
rust: types: add Opaque
type
Add the `Opaque` type, which is meant to be used with FFI objects that are never interpreted by Rust code, e.g.: struct Waiter { completion: Opaque<bindings::completion>, next: *mut Waiter, } It has the advantage that the objects don't have to be zero-initialised before calling their init functions, making the code performance closer to C. Signed-off-by: Wedson Almeida Filho <wedsonaf@gmail.com> [Reworded, adapted for upstream and applied latest changes] Signed-off-by: Miguel Ojeda <ojeda@kernel.org>
This commit is contained in:
parent
ba20915bae
commit
b9ecf9b9ac
1 changed files with 25 additions and 0 deletions
|
@ -2,6 +2,31 @@
|
||||||
|
|
||||||
//! Kernel types.
|
//! Kernel types.
|
||||||
|
|
||||||
|
use core::{cell::UnsafeCell, mem::MaybeUninit};
|
||||||
|
|
||||||
|
/// Stores an opaque value.
|
||||||
|
///
|
||||||
|
/// This is meant to be used with FFI objects that are never interpreted by Rust code.
|
||||||
|
#[repr(transparent)]
|
||||||
|
pub struct Opaque<T>(MaybeUninit<UnsafeCell<T>>);
|
||||||
|
|
||||||
|
impl<T> Opaque<T> {
|
||||||
|
/// Creates a new opaque value.
|
||||||
|
pub const fn new(value: T) -> Self {
|
||||||
|
Self(MaybeUninit::new(UnsafeCell::new(value)))
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Creates an uninitialised value.
|
||||||
|
pub const fn uninit() -> Self {
|
||||||
|
Self(MaybeUninit::uninit())
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Returns a raw pointer to the opaque data.
|
||||||
|
pub fn get(&self) -> *mut T {
|
||||||
|
UnsafeCell::raw_get(self.0.as_ptr())
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/// A sum type that always holds either a value of type `L` or `R`.
|
/// A sum type that always holds either a value of type `L` or `R`.
|
||||||
pub enum Either<L, R> {
|
pub enum Either<L, R> {
|
||||||
/// Constructs an instance of [`Either`] containing a value of type `L`.
|
/// Constructs an instance of [`Either`] containing a value of type `L`.
|
||||||
|
|
Loading…
Add table
Reference in a new issue