X-Git-Url: http://git.rot13.org/?a=blobdiff_plain;f=kernel%2Ffutex_compat.c;h=d1d92b441fb7d7a327f229def2db99d4359063ee;hb=b5a1a9abe1a54ba40a9612001920f98bbdd0c56f;hp=54274fc853216d7448762c78e37ac0cd30d5e8f6;hpb=bac30d1a78d0f11c613968fc8b351a91ed465386;p=powerpc.git diff --git a/kernel/futex_compat.c b/kernel/futex_compat.c index 54274fc853..d1d92b441f 100644 --- a/kernel/futex_compat.c +++ b/kernel/futex_compat.c @@ -129,14 +129,20 @@ asmlinkage long compat_sys_futex(u32 __user *uaddr, int op, u32 val, unsigned long timeout = MAX_SCHEDULE_TIMEOUT; int val2 = 0; - if ((op == FUTEX_WAIT) && utime) { + if (utime && (op == FUTEX_WAIT || op == FUTEX_LOCK_PI)) { if (get_compat_timespec(&t, utime)) return -EFAULT; - timeout = timespec_to_jiffies(&t) + 1; + if (!timespec_valid(&t)) + return -EINVAL; + if (op == FUTEX_WAIT) + timeout = timespec_to_jiffies(&t) + 1; + else { + timeout = t.tv_sec; + val2 = t.tv_nsec; + } } - if (op >= FUTEX_REQUEUE) + if (op == FUTEX_REQUEUE || op == FUTEX_CMP_REQUEUE) val2 = (int) (unsigned long) utime; - return do_futex((unsigned long)uaddr, op, val, timeout, - (unsigned long)uaddr2, val2, val3); + return do_futex(uaddr, op, val, timeout, uaddr2, val2, val3); }