Author: kib
Date: Fri Aug 22 18:42:14 2014
New Revision: 270345
URL: http://svnweb.freebsd.org/changeset/base/270345

Log:
  In do_lock_pi(), do not override error from umtxq_sleep_pi() when
  doing suspend check.  This restores the pre-r251684 behaviour, to
  retry once after the signal is detected.
  
  PR:   kern/192918
  Submitted by: Elliott Rabe, Dell Inc., Eric van Gyzen <e...@vangyzen.net>
  Obtained from:        Dell Inc.
  MFC after:    1 week

Modified:
  head/sys/kern/kern_umtx.c

Modified: head/sys/kern/kern_umtx.c
==============================================================================
--- head/sys/kern/kern_umtx.c   Fri Aug 22 18:09:06 2014        (r270344)
+++ head/sys/kern/kern_umtx.c   Fri Aug 22 18:42:14 2014        (r270345)
@@ -1700,10 +1700,12 @@ do_lock_pi(struct thread *td, struct umu
                 * and we need to retry or we lost a race to the thread
                 * unlocking the umtx.
                 */
-               if (old == owner)
+               if (old == owner) {
                        error = umtxq_sleep_pi(uq, pi, owner & 
~UMUTEX_CONTESTED,
                            "umtxpi", timeout == NULL ? NULL : &timo);
-               else {
+                       if (error != 0)
+                               continue;
+               } else {
                        umtxq_unbusy(&uq->uq_key);
                        umtxq_unlock(&uq->uq_key);
                }
_______________________________________________
svn-src-head@freebsd.org mailing list
http://lists.freebsd.org/mailman/listinfo/svn-src-head
To unsubscribe, send any mail to "svn-src-head-unsubscr...@freebsd.org"

Reply via email to