52 lines
		
	
	
	
		
			1.2 KiB
			
		
	
	
	
		
			C
		
	
	
	
	
	
		
		
			
		
	
	
			52 lines
		
	
	
	
		
			1.2 KiB
			
		
	
	
	
		
			C
		
	
	
	
	
	
|   | #ifndef _ASM_IA64_SYNC_BITOPS_H
 | ||
|  | #define _ASM_IA64_SYNC_BITOPS_H
 | ||
|  | 
 | ||
|  | /*
 | ||
|  |  * Copyright (C) 2008 Isaku Yamahata <yamahata at valinux co jp> | ||
|  |  * | ||
|  |  * Based on synch_bitops.h which Dan Magenhaimer wrote. | ||
|  |  * | ||
|  |  * bit operations which provide guaranteed strong synchronisation | ||
|  |  * when communicating with Xen or other guest OSes running on other CPUs. | ||
|  |  */ | ||
|  | 
 | ||
|  | static inline void sync_set_bit(int nr, volatile void *addr) | ||
|  | { | ||
|  | 	set_bit(nr, addr); | ||
|  | } | ||
|  | 
 | ||
|  | static inline void sync_clear_bit(int nr, volatile void *addr) | ||
|  | { | ||
|  | 	clear_bit(nr, addr); | ||
|  | } | ||
|  | 
 | ||
|  | static inline void sync_change_bit(int nr, volatile void *addr) | ||
|  | { | ||
|  | 	change_bit(nr, addr); | ||
|  | } | ||
|  | 
 | ||
|  | static inline int sync_test_and_set_bit(int nr, volatile void *addr) | ||
|  | { | ||
|  | 	return test_and_set_bit(nr, addr); | ||
|  | } | ||
|  | 
 | ||
|  | static inline int sync_test_and_clear_bit(int nr, volatile void *addr) | ||
|  | { | ||
|  | 	return test_and_clear_bit(nr, addr); | ||
|  | } | ||
|  | 
 | ||
|  | static inline int sync_test_and_change_bit(int nr, volatile void *addr) | ||
|  | { | ||
|  | 	return test_and_change_bit(nr, addr); | ||
|  | } | ||
|  | 
 | ||
|  | static inline int sync_test_bit(int nr, const volatile void *addr) | ||
|  | { | ||
|  | 	return test_bit(nr, addr); | ||
|  | } | ||
|  | 
 | ||
|  | #define sync_cmpxchg(ptr, old, new)				\
 | ||
|  | 	((__typeof__(*(ptr)))cmpxchg_acq((ptr), (old), (new))) | ||
|  | 
 | ||
|  | #endif /* _ASM_IA64_SYNC_BITOPS_H */
 |