sysfs: use atomic_inc_unless_negative in sysfs_get_active
It seems that sysfs has an interesting way of doing the same thing. This removes the cpu_relax unfortunately, but if it's really needed, it would be better to add this to include/linux/atomic.h to benefit all atomic ops users. Signed-off-by: Maarten Lankhorst <maarten.lankhorst@canonical.com> Acked-by: Tejun Heo <tj@kernel.org> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
parent
91721197de
commit
3db3c62584
1 changed files with 2 additions and 15 deletions
|
@ -165,21 +165,8 @@ struct sysfs_dirent *sysfs_get_active(struct sysfs_dirent *sd)
|
||||||
if (unlikely(!sd))
|
if (unlikely(!sd))
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
while (1) {
|
if (!atomic_inc_unless_negative(&sd->s_active))
|
||||||
int v, t;
|
return NULL;
|
||||||
|
|
||||||
v = atomic_read(&sd->s_active);
|
|
||||||
if (unlikely(v < 0))
|
|
||||||
return NULL;
|
|
||||||
|
|
||||||
t = atomic_cmpxchg(&sd->s_active, v, v + 1);
|
|
||||||
if (likely(t == v))
|
|
||||||
break;
|
|
||||||
if (t < 0)
|
|
||||||
return NULL;
|
|
||||||
|
|
||||||
cpu_relax();
|
|
||||||
}
|
|
||||||
|
|
||||||
if (likely(!ignore_lockdep(sd)))
|
if (likely(!ignore_lockdep(sd)))
|
||||||
rwsem_acquire_read(&sd->dep_map, 0, 1, _RET_IP_);
|
rwsem_acquire_read(&sd->dep_map, 0, 1, _RET_IP_);
|
||||||
|
|
Loading…
Add table
Reference in a new issue