mridulm commented on code in PR #50594:
URL: https://github.com/apache/spark/pull/50594#discussion_r2066611172


##########
core/src/main/scala/org/apache/spark/util/UninterruptibleThread.scala:
##########
@@ -69,10 +75,22 @@ private[spark] class UninterruptibleThread(
     }
 
     uninterruptibleLock.synchronized {
+      uninterruptible = true
+    }
+
+    while (uninterruptibleLock.synchronized {
       // Clear the interrupted status if it's set.
       shouldInterruptThread = Thread.interrupted() || shouldInterruptThread
-      uninterruptible = true
+      // wait for super.interrupt() to be called
+      !shouldInterruptThread && awaitInterruptThread }) {
+      try {
+        Thread.sleep(100)

Review Comment:
   Not sure why that would impact either choices: want to make sure there are 
no corner cases missed - both sleep and await are entered only when there is 
lock contention



-- 
This is an automated message from the Apache Git Service.
To respond to the message, please log on to GitHub and use the
URL above to go to the specific comment.

To unsubscribe, e-mail: [email protected]

For queries about this service, please contact Infrastructure at:
[email protected]


---------------------------------------------------------------------
To unsubscribe, e-mail: [email protected]
For additional commands, e-mail: [email protected]

Reply via email to