The code as it appears in the tree is considered feature complete. This
means I do not want to introduce any further properties or arguments to the
functions in the MP package and now the priority is shared among these
goals:
* Implement the spinlock-free wait queue in Windows. I believe this is
doable with a simple SleepEx() and our current interrupt signaling
mechanism -- both combined would behave like sigsuspend() in our POSIX
code.
* Further stress testing. I have added three files to src/tests/bugs/,
covering locks, semaphores and mailboxes. Next is condition variables and
trying to enlarge the set of tests to hit corner cases.
* Analyzing "formally" the code for the queue. I have simplified the code
and tried to specify it further in src/threads/queue.d, and it would be
nice if some more knowledgeable people could have a look at this
abstraction to see whether it might hit some ugly corner cases.
* There are some hidden problems with the garbage collector and interrupts.
I have not managed to reproduce it with the current code, but some people
reported it for long lived processes.
* Fix a few other reported bugs which are pending right now
Help is welcome with any of these goals. Other than this, I think we are
close to another release -- ideally before I leave for the ELS in a couple
of weeks. The code seems to work rather fine, it is no longer a CPU hog and
the new abstractions (semaphores, mailboxes) should help simplify existing
code (Slime, for starters).
Best,
Juanjo
--
Instituto de FĂsica Fundamental, CSIC
c/ Serrano, 113b, Madrid 28006 (Spain)
http://juanjose.garciaripoll.googlepages.com
------------------------------------------------------------------------------
For Developers, A Lot Can Happen In A Second.
Boundary is the first to Know...and Tell You.
Monitor Your Applications in Ultra-Fine Resolution. Try it FREE!
http://p.sf.net/sfu/Boundary-d2dvs2
_______________________________________________
Ecls-list mailing list
Ecls-list@lists.sourceforge.net
https://lists.sourceforge.net/lists/listinfo/ecls-list