mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2025-01-25 19:29:46 +07:00
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 */
|