diff options
| author | Konrad Rzeszutek Wilk <konrad.wilk@oracle.com> | 2012-10-19 15:19:19 -0400 |
|---|---|---|
| committer | Konrad Rzeszutek Wilk <konrad.wilk@oracle.com> | 2012-10-19 15:19:19 -0400 |
| commit | e05dacd71db0a5da7c1a44bcaab2a8a240b9c233 (patch) | |
| tree | 31382cf1c7d62c03126448affb2fc86e8c4aaa8b /include/linux/atomic.h | |
| parent | 3ab0b83bf6a1e834f4b884150d8012990c75d25d (diff) | |
| parent | ddffeb8c4d0331609ef2581d84de4d763607bd37 (diff) | |
Merge commit 'v3.7-rc1' into stable/for-linus-3.7
* commit 'v3.7-rc1': (10892 commits)
Linux 3.7-rc1
x86, boot: Explicitly include autoconf.h for hostprogs
perf: Fix UAPI fallout
ARM: config: make sure that platforms are ordered by option string
ARM: config: sort select statements alphanumerically
UAPI: (Scripted) Disintegrate include/linux/byteorder
UAPI: (Scripted) Disintegrate include/linux
UAPI: Unexport linux/blk_types.h
UAPI: Unexport part of linux/ppp-comp.h
perf: Handle new rbtree implementation
procfs: don't need a PATH_MAX allocation to hold a string representation of an int
vfs: embed struct filename inside of names_cache allocation if possible
audit: make audit_inode take struct filename
vfs: make path_openat take a struct filename pointer
vfs: turn do_path_lookup into wrapper around struct filename variant
audit: allow audit code to satisfy getname requests from its names_list
vfs: define struct filename and have getname() return it
btrfs: Fix compilation with user namespace support enabled
userns: Fix posix_acl_file_xattr_userns gid conversion
userns: Properly print bluetooth socket uids
...
Diffstat (limited to 'include/linux/atomic.h')
| -rw-r--r-- | include/linux/atomic.h | 25 |
1 files changed, 25 insertions, 0 deletions
diff --git a/include/linux/atomic.h b/include/linux/atomic.h index 70cfcb2d63c4..5b08a8540ecf 100644 --- a/include/linux/atomic.h +++ b/include/linux/atomic.h | |||
| @@ -86,6 +86,31 @@ static inline int atomic_dec_unless_positive(atomic_t *p) | |||
| 86 | } | 86 | } |
| 87 | #endif | 87 | #endif |
| 88 | 88 | ||
| 89 | /* | ||
| 90 | * atomic_dec_if_positive - decrement by 1 if old value positive | ||
| 91 | * @v: pointer of type atomic_t | ||
| 92 | * | ||
| 93 | * The function returns the old value of *v minus 1, even if | ||
| 94 | * the atomic variable, v, was not decremented. | ||
| 95 | */ | ||
| 96 | #ifndef atomic_dec_if_positive | ||
| 97 | static inline int atomic_dec_if_positive(atomic_t *v) | ||
| 98 | { | ||
| 99 | int c, old, dec; | ||
| 100 | c = atomic_read(v); | ||
| 101 | for (;;) { | ||
| 102 | dec = c - 1; | ||
| 103 | if (unlikely(dec < 0)) | ||
| 104 | break; | ||
| 105 | old = atomic_cmpxchg((v), c, dec); | ||
| 106 | if (likely(old == c)) | ||
| 107 | break; | ||
| 108 | c = old; | ||
| 109 | } | ||
| 110 | return dec; | ||
| 111 | } | ||
| 112 | #endif | ||
| 113 | |||
| 89 | #ifndef CONFIG_ARCH_HAS_ATOMIC_OR | 114 | #ifndef CONFIG_ARCH_HAS_ATOMIC_OR |
| 90 | static inline void atomic_or(int i, atomic_t *v) | 115 | static inline void atomic_or(int i, atomic_t *v) |
| 91 | { | 116 | { |
