mirror of
https://git.proxmox.com/git/mirror_zfs.git
synced 2025-01-28 02:44:30 +03:00
302b88e6ab
These functions didn't exist for all archs prior to 2.6.24. This patch addes an autoconf test to detect this and add them when needed. The autoconf check is needed instead of just an #ifndef because in the most modern kernels atomic64_{cmp}xchg are implemented as in inline function and not a #define.
68 lines
1.2 KiB
C
68 lines
1.2 KiB
C
#ifndef _SPL_ATOMIC_COMPAT_H
|
|
#define _SPL_ATOMIC_COMPAT_H
|
|
|
|
#include <asm/atomic.h>
|
|
#include <spl_config.h>
|
|
|
|
#ifndef HAVE_ATOMIC64_T
|
|
#include <linux/spinlock.h>
|
|
|
|
typedef struct {
|
|
spinlock_t lock;
|
|
__s64 val;
|
|
} atomic64_t;
|
|
|
|
#define ATOMIC64_INIT(i) { .lock = SPIN_LOCK_UNLOCKED, .val = (i) }
|
|
|
|
static inline void atomic64_add(__s64 i, atomic64_t *v)
|
|
{
|
|
unsigned long flags;
|
|
|
|
spin_lock_irqsave(&v->lock, flags);
|
|
v->val += i;
|
|
spin_unlock_irqrestore(&v->lock, flags);
|
|
}
|
|
|
|
static inline void atomic64_sub(__s64 i, atomic64_t *v)
|
|
{
|
|
unsigned long flags;
|
|
|
|
spin_lock_irqsave(&v->lock, flags);
|
|
v->val -= i;
|
|
spin_unlock_irqrestore(&v->lock, flags);
|
|
}
|
|
|
|
static inline __s64 atomic64_read(atomic64_t *v)
|
|
{
|
|
unsigned long flags;
|
|
__s64 r;
|
|
|
|
spin_lock_irqsave(&v->lock, flags);
|
|
r = v->val;
|
|
spin_unlock_irqrestore(&v->lock, flags);
|
|
|
|
return r;
|
|
}
|
|
|
|
static inline void atomic64_set(atomic64_t *v, __s64 i)
|
|
{
|
|
unsigned long flags;
|
|
|
|
spin_lock_irqsave(&v->lock, flags);
|
|
v->val = i;
|
|
spin_unlock_irqrestore(&v->lock, flags);
|
|
}
|
|
|
|
#endif /* HAVE_ATOMIC64_T */
|
|
|
|
#ifndef HAVE_ATOMIC64_CMPXCHG
|
|
#define atomic64_cmpxchg(v, o, n) (cmpxchg(&((v)->counter), (o), (n)))
|
|
#endif
|
|
|
|
#ifndef HAVE_ATOMIC64_XCHG
|
|
#define atomic64_xchg(v, n) (xchg(&((v)->counter), n))
|
|
#endif
|
|
|
|
#endif /* _SPL_ATOMIC_COMPAT_H */
|
|
|