mirror of
git://git.yoctoproject.org/linux-yocto.git
synced 2025-10-22 15:03:53 +02:00
rust: miscdevice: clarify invariant for MiscDeviceRegistration
Reword and expand the invariant documentation for `MiscDeviceRegistration`
to clarify what it means for the inner device to be "registered".
It expands to explain:
- `inner` points to a `miscdevice` registered via `misc_register`.
- This registration stays valid for the entire lifetime of the object.
- Deregistration is guaranteed on `Drop`, via `misc_deregister`.
Reported-by: Benno Lossin <lossin@kernel.org>
Closes: https://github.com/Rust-for-Linux/linux/issues/1168
Fixes: f893691e74
("rust: miscdevice: add base miscdevice abstraction")
Signed-off-by: Shankari Anand <shankari.ak0208@gmail.com>
Link: https://lore.kernel.org/r/20250626104520.563036-1-shankari.ak0208@gmail.com
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
parent
9b5cdd5f40
commit
b9ff1c2a26
|
@ -45,7 +45,13 @@ impl MiscDeviceOptions {
|
|||
///
|
||||
/// # Invariants
|
||||
///
|
||||
/// `inner` is a registered misc device.
|
||||
/// - `inner` contains a `struct miscdevice` that is registered using
|
||||
/// `misc_register()`.
|
||||
/// - This registration remains valid for the entire lifetime of the
|
||||
/// [`MiscDeviceRegistration`] instance.
|
||||
/// - Deregistration occurs exactly once in [`Drop`] via `misc_deregister()`.
|
||||
/// - `inner` wraps a valid, pinned `miscdevice` created using
|
||||
/// [`MiscDeviceOptions::into_raw`].
|
||||
#[repr(transparent)]
|
||||
#[pin_data(PinnedDrop)]
|
||||
pub struct MiscDeviceRegistration<T> {
|
||||
|
|
Loading…
Reference in New Issue
Block a user