35 lines
		
	
	
	
		
			1.2 KiB
		
	
	
	
		
			Text
		
	
	
	
	
	
			
		
		
	
	
			35 lines
		
	
	
	
		
			1.2 KiB
		
	
	
	
		
			Text
		
	
	
	
	
	
| ============
 | |
| LITMUS TESTS
 | |
| ============
 | |
| 
 | |
| Each subdirectory contains litmus tests that are typical to describe the
 | |
| semantics of respective kernel APIs.
 | |
| For more information about how to "run" a litmus test or how to generate
 | |
| a kernel test module based on a litmus test, please see
 | |
| tools/memory-model/README.
 | |
| 
 | |
| 
 | |
| atomic (/atomic derectory)
 | |
| --------------------------
 | |
| 
 | |
| Atomic-RMW+mb__after_atomic-is-stronger-than-acquire.litmus
 | |
|     Test that an atomic RMW followed by a smp_mb__after_atomic() is
 | |
|     stronger than a normal acquire: both the read and write parts of
 | |
|     the RMW are ordered before the subsequential memory accesses.
 | |
| 
 | |
| Atomic-RMW-ops-are-atomic-WRT-atomic_set.litmus
 | |
|     Test that atomic_set() cannot break the atomicity of atomic RMWs.
 | |
|     NOTE: Require herd7 7.56 or later which supports "(void)expr".
 | |
| 
 | |
| 
 | |
| RCU (/rcu directory)
 | |
| --------------------
 | |
| 
 | |
| MP+onceassign+derefonce.litmus (under tools/memory-model/litmus-tests/)
 | |
|     Demonstrates the use of rcu_assign_pointer() and rcu_dereference() to
 | |
|     ensure that an RCU reader will not see pre-initialization garbage.
 | |
| 
 | |
| RCU+sync+read.litmus
 | |
| RCU+sync+free.litmus
 | |
|     Both the above litmus tests demonstrate the RCU grace period guarantee
 | |
|     that an RCU read-side critical section can never span a grace period.
 |