mirror of
				https://github.com/torvalds/linux.git
				synced 2025-11-04 02:30:34 +02:00 
			
		
		
		
	rust: sync: introduce LockClassKey
				
					
				
			It is a wrapper around C's `lock_class_key`, which is used by the synchronisation primitives that are checked with lockdep. This is in preparation for introducing Rust abstractions for these primitives. Cc: Peter Zijlstra <peterz@infradead.org> Cc: Ingo Molnar <mingo@redhat.com> Cc: Will Deacon <will@kernel.org> Cc: Waiman Long <longman@redhat.com> Reviewed-by: Martin Rodriguez Reboredo <yakoyoku@gmail.com> Co-developed-by: Boqun Feng <boqun.feng@gmail.com> Signed-off-by: Boqun Feng <boqun.feng@gmail.com> Signed-off-by: Wedson Almeida Filho <walmeida@microsoft.com> Reviewed-by: Gary Guo <gary@garyguo.net> Reviewed-by: Benno Lossin <benno.lossin@proton.me> Link: https://lore.kernel.org/r/20230411054543.21278-1-wedsonaf@gmail.com Signed-off-by: Miguel Ojeda <ojeda@kernel.org>
This commit is contained in:
		
							parent
							
								
									b0cf5d5021
								
							
						
					
					
						commit
						6ea5aa0885
					
				
					 1 changed files with 45 additions and 0 deletions
				
			
		| 
						 | 
					@ -5,6 +5,51 @@
 | 
				
			||||||
//! This module contains the kernel APIs related to synchronisation that have been ported or
 | 
					//! This module contains the kernel APIs related to synchronisation that have been ported or
 | 
				
			||||||
//! wrapped for usage by Rust code in the kernel.
 | 
					//! wrapped for usage by Rust code in the kernel.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					use crate::types::Opaque;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
mod arc;
 | 
					mod arc;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
pub use arc::{Arc, ArcBorrow, UniqueArc};
 | 
					pub use arc::{Arc, ArcBorrow, UniqueArc};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/// Represents a lockdep class. It's a wrapper around C's `lock_class_key`.
 | 
				
			||||||
 | 
					#[repr(transparent)]
 | 
				
			||||||
 | 
					pub struct LockClassKey(Opaque<bindings::lock_class_key>);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// SAFETY: `bindings::lock_class_key` is designed to be used concurrently from multiple threads and
 | 
				
			||||||
 | 
					// provides its own synchronization.
 | 
				
			||||||
 | 
					unsafe impl Sync for LockClassKey {}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					impl LockClassKey {
 | 
				
			||||||
 | 
					    /// Creates a new lock class key.
 | 
				
			||||||
 | 
					    pub const fn new() -> Self {
 | 
				
			||||||
 | 
					        Self(Opaque::uninit())
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    #[allow(dead_code)]
 | 
				
			||||||
 | 
					    pub(crate) fn as_ptr(&self) -> *mut bindings::lock_class_key {
 | 
				
			||||||
 | 
					        self.0.get()
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/// Defines a new static lock class and returns a pointer to it.
 | 
				
			||||||
 | 
					#[doc(hidden)]
 | 
				
			||||||
 | 
					#[macro_export]
 | 
				
			||||||
 | 
					macro_rules! static_lock_class {
 | 
				
			||||||
 | 
					    () => {{
 | 
				
			||||||
 | 
					        static CLASS: $crate::sync::LockClassKey = $crate::sync::LockClassKey::new();
 | 
				
			||||||
 | 
					        &CLASS
 | 
				
			||||||
 | 
					    }};
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/// Returns the given string, if one is provided, otherwise generates one based on the source code
 | 
				
			||||||
 | 
					/// location.
 | 
				
			||||||
 | 
					#[doc(hidden)]
 | 
				
			||||||
 | 
					#[macro_export]
 | 
				
			||||||
 | 
					macro_rules! optional_name {
 | 
				
			||||||
 | 
					    () => {
 | 
				
			||||||
 | 
					        $crate::c_str!(::core::concat!(::core::file!(), ":", ::core::line!()))
 | 
				
			||||||
 | 
					    };
 | 
				
			||||||
 | 
					    ($name:literal) => {
 | 
				
			||||||
 | 
					        $crate::c_str!($name)
 | 
				
			||||||
 | 
					    };
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
		Loading…
	
		Reference in a new issue