Merge branch 'core-fixes-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/linux-2.6-tip
* 'core-fixes-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/linux-2.6-tip: futex: Fix spurious wakeup for requeue_pi really
This commit is contained in:
commit
3fe866ca6c
|
@ -2127,7 +2127,7 @@ int handle_early_requeue_pi_wakeup(struct futex_hash_bucket *hb,
|
||||||
plist_del(&q->list, &q->list.plist);
|
plist_del(&q->list, &q->list.plist);
|
||||||
|
|
||||||
/* Handle spurious wakeups gracefully */
|
/* Handle spurious wakeups gracefully */
|
||||||
ret = -EAGAIN;
|
ret = -EWOULDBLOCK;
|
||||||
if (timeout && !timeout->task)
|
if (timeout && !timeout->task)
|
||||||
ret = -ETIMEDOUT;
|
ret = -ETIMEDOUT;
|
||||||
else if (signal_pending(current))
|
else if (signal_pending(current))
|
||||||
|
@ -2208,7 +2208,6 @@ static int futex_wait_requeue_pi(u32 __user *uaddr, int fshared,
|
||||||
debug_rt_mutex_init_waiter(&rt_waiter);
|
debug_rt_mutex_init_waiter(&rt_waiter);
|
||||||
rt_waiter.task = NULL;
|
rt_waiter.task = NULL;
|
||||||
|
|
||||||
retry:
|
|
||||||
key2 = FUTEX_KEY_INIT;
|
key2 = FUTEX_KEY_INIT;
|
||||||
ret = get_futex_key(uaddr2, fshared, &key2, VERIFY_WRITE);
|
ret = get_futex_key(uaddr2, fshared, &key2, VERIFY_WRITE);
|
||||||
if (unlikely(ret != 0))
|
if (unlikely(ret != 0))
|
||||||
|
@ -2303,9 +2302,6 @@ out_put_keys:
|
||||||
out_key2:
|
out_key2:
|
||||||
put_futex_key(fshared, &key2);
|
put_futex_key(fshared, &key2);
|
||||||
|
|
||||||
/* Spurious wakeup ? */
|
|
||||||
if (ret == -EAGAIN)
|
|
||||||
goto retry;
|
|
||||||
out:
|
out:
|
||||||
if (to) {
|
if (to) {
|
||||||
hrtimer_cancel(&to->timer);
|
hrtimer_cancel(&to->timer);
|
||||||
|
|
Loading…
Reference in New Issue