more robust join_results: join_work needs to be uninterruptible, otherwise the task being dequeued by join_next might be never executed/finished!
--- a/src/Pure/Concurrent/future.ML Thu Jun 23 23:05:38 2011 +0200
+++ b/src/Pure/Concurrent/future.ML Thu Jun 23 23:12:00 2011 +0200
@@ -454,7 +454,8 @@
fun execute_work NONE = ()
| execute_work (SOME (work, deps')) = (worker_joining (fn () => execute work); join_work deps')
and join_work deps =
- execute_work (SYNCHRONIZED "join" (fn () => join_next deps));
+ Multithreading.with_attributes Multithreading.no_interrupts
+ (fn _ => execute_work (SYNCHRONIZED "join" (fn () => join_next deps)));
in