ViewVC Help
View File | Revision Log | Show Annotations | Download File | Root Listing
root/jsr166/jsr166/src/jsr166y/ForkJoinPool.java
(Generate patch)

Comparing jsr166/src/jsr166y/ForkJoinPool.java (file contents):
Revision 1.88 by dl, Tue Nov 23 01:06:00 2010 UTC vs.
Revision 1.89 by dl, Wed Nov 24 10:50:38 2010 UTC

# Line 728 | Line 728 | public class ForkJoinPool extends Abstra
728       * Releases workers blocked on a count not equal to current count.
729       * Normally called after precheck that eventWaiters isn't zero to
730       * avoid wasted array checks. Gives up upon a change in count or
731 <     * upon releasing two workers, letting others take over.
731 >     * upon releasing four workers, letting others take over.
732       */
733      private void releaseEventWaiters() {
734          ForkJoinWorkerThread[] ws = workers;
735          int n = ws.length;
736          long h = eventWaiters;
737          int ec = eventCount;
738 <        boolean releasedOne = false;
738 >        int releases = 4;
739          ForkJoinWorkerThread w; int id;
740          while ((id = (((int)h) & WAITER_ID_MASK) - 1) >= 0 &&
741                 (int)(h >>> EVENT_COUNT_SHIFT) != ec &&
# Line 743 | Line 743 | public class ForkJoinPool extends Abstra
743              if (UNSAFE.compareAndSwapLong(this, eventWaitersOffset,
744                                            h,  w.nextWaiter)) {
745                  LockSupport.unpark(w);
746 <                if (releasedOne) // exit on second release
746 >                if (--releases == 0)
747                      break;
748                releasedOne = true;
748              }
749              if (eventCount != ec)
750                  break;

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines