Skip to content

Commit

Permalink
rust: sync: add #[must_use] to Lock::try_lock
Browse files Browse the repository at this point in the history
The `Lock::try_lock` function returns an `Option<Guard<...>>`, but it
currently does not issue a warning if the return value is unused.
To avoid potential bugs, the `#[must_use]` annotation is added to ensure proper usage.

Suggested-by: Alice Ryhl <[email protected]>
Link: Rust-for-Linux#1133
Signed-off-by: Jason Devers <[email protected]>
  • Loading branch information
hz2 authored and intel-lab-lkp committed Dec 8, 2024
1 parent 40384c8 commit 1be392c
Showing 1 changed file with 1 addition and 0 deletions.
1 change: 1 addition & 0 deletions rust/kernel/sync/lock.rs
Original file line number Diff line number Diff line change
Expand Up @@ -147,6 +147,7 @@ impl<T: ?Sized, B: Backend> Lock<T, B> {
/// Tries to acquire the lock.
///
/// Returns a guard that can be used to access the data protected by the lock if successful.
#[must_use = "if unused, leading to an empty critical section"]
pub fn try_lock(&self) -> Option<Guard<'_, T, B>> {
// SAFETY: The constructor of the type calls `init`, so the existence of the object proves
// that `init` was called.
Expand Down

0 comments on commit 1be392c

Please sign in to comment.