blob: 4c0af31c8d47ab390e6a3b634db5c91559d1c6ba [file] [log] [blame]
Waiman Long0f8f2aa2013-08-28 18:13:26 -07001#ifndef __LINUX_LOCKREF_H
2#define __LINUX_LOCKREF_H
3
4/*
5 * Locked reference counts.
6 *
7 * These are different from just plain atomic refcounts in that they
8 * are atomic with respect to the spinlock that goes with them. In
9 * particular, there can be implementations that don't actually get
10 * the spinlock for the common decrement/increment operations, but they
11 * still have to check that the operation is done semantically as if
12 * the spinlock had been taken (using a cmpxchg operation that covers
13 * both the lock and the count word, or using memory transactions, for
14 * example).
15 */
16
17#include <linux/spinlock.h>
18
19struct lockref {
20 spinlock_t lock;
21 unsigned int count;
22};
23
Linus Torvalds2f4f12e2013-09-02 11:58:20 -070024extern void lockref_get(struct lockref *);
25extern int lockref_get_not_zero(struct lockref *);
26extern int lockref_get_or_lock(struct lockref *);
27extern int lockref_put_or_lock(struct lockref *);
Waiman Long0f8f2aa2013-08-28 18:13:26 -070028
29#endif /* __LINUX_LOCKREF_H */