mirror of
				https://github.com/torvalds/linux.git
				synced 2025-11-04 02:30:34 +02:00 
			
		
		
		
	Since we've exposed Lock::from_raw() and Guard::new() publically, we
want to be able to make sure that we assert that a lock is actually held
when constructing a Guard for it to handle instances of unsafe
Guard::new() calls outside of our lock module.
Hence add a new method assert_is_held() to Backend, which uses lockdep
to check whether or not a lock has been acquired. When lockdep is
disabled, this has no overhead.
[Boqun: Resolve the conflicts with exposing Guard::new(), reword the
 commit log a bit and format "unsafe { <statement>; }" into "unsafe {
 <statement> }" for the consistency. ]
Signed-off-by: Lyude Paul <lyude@redhat.com>
Signed-off-by: Boqun Feng <boqun.feng@gmail.com>
Link: https://lore.kernel.org/r/20241125204139.656801-1-lyude@redhat.com
		
	
			
		
			
				
	
	
		
			19 lines
		
	
	
	
		
			371 B
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			19 lines
		
	
	
	
		
			371 B
		
	
	
	
		
			C
		
	
	
	
	
	
// SPDX-License-Identifier: GPL-2.0
 | 
						|
 | 
						|
#include <linux/mutex.h>
 | 
						|
 | 
						|
void rust_helper_mutex_lock(struct mutex *lock)
 | 
						|
{
 | 
						|
	mutex_lock(lock);
 | 
						|
}
 | 
						|
 | 
						|
void rust_helper___mutex_init(struct mutex *mutex, const char *name,
 | 
						|
			      struct lock_class_key *key)
 | 
						|
{
 | 
						|
	__mutex_init(mutex, name, key);
 | 
						|
}
 | 
						|
 | 
						|
void rust_helper_mutex_assert_is_held(struct mutex *mutex)
 | 
						|
{
 | 
						|
	lockdep_assert_held(mutex);
 | 
						|
}
 |