… | |
… | |
2 | |
2 | |
3 | TODO: should explore PerlIO::coroaio (perl leaks like hell). |
3 | TODO: should explore PerlIO::coroaio (perl leaks like hell). |
4 | TODO: channel->maxsize(newsize)? |
4 | TODO: channel->maxsize(newsize)? |
5 | TODO: http://www.microsoft.com/msj/archive/s2ce.aspx |
5 | TODO: http://www.microsoft.com/msj/archive/s2ce.aspx |
6 | |
6 | |
7 | - croak when a coro being cancelled tries to block (e.g. while |
7 | TODO: tutorial |
8 | executing a guard block). |
8 | - INCOMPATIBLE CHANGE: unreferenced coro objects will now be |
|
|
9 | destroyed and cleaned up automatically (e.g. async { schedule }). |
|
|
10 | - implement a JIT compiler for part of the thread switch code, |
|
|
11 | which gives a 50% speed improvement on threaded perls, and |
|
|
12 | about 4% on non-thraeded perls (so threaded perls now finally |
|
|
13 | reach about half the speed of non-threaded perls). |
|
|
14 | - avoid DEFSV and ERRSV, giving another 10% improvement |
|
|
15 | in thread switching. |
|
|
16 | - Coro::State->is_destroyed is now called is_zombie. |
9 | - implement a Coro::State->safe_cancel method that might fail, but |
17 | - implement a Coro->safe_cancel method that might fail, but |
10 | cancels in a "safer" way. |
18 | cancels in a "safer" way if it succeeds. |
|
|
19 | - add preliminary support for DEBUGGING perls. |
|
|
20 | - get rid of two hash-accesses when initialising a new Coro - this |
|
|
21 | speeds up coro creation by almost a factor of two. |
|
|
22 | - croak when a coro that is being cancelled tries to block |
|
|
23 | (e.g. while executing a guard block), instead of crashing or |
|
|
24 | deadlocking. |
|
|
25 | - use a more robust and also faster method to identify Coro::State |
|
|
26 | objects - speeds up everything a bit. |
11 | - implement Coro->cancel in XS for a 20% speed improvement, and to |
27 | - implement Coro->cancel in XS for a 20% speed improvement, and to |
12 | be able to implement mutual cancellation. |
28 | be able to implement mutual cancellation. |
|
|
29 | - speed up context switches by a percent or two by more efficiently |
|
|
30 | allocating context stack entries. |
|
|
31 | - implement Coro->join and Coro->on_destroy in XS for a speedup and |
|
|
32 | a reduction in memory use. |
13 | - cancelling a coro while it itself is cancelling another coro is |
33 | - cancelling a coro while it itself is cancelling another coro is |
14 | now supported and working, instead of triggering an assertion. |
34 | now supported and working, instead of triggering an assertion. |
15 | - be a bit more crash-resistant when calling (buggy) on_destroy |
35 | - be a bit more crash-resistant when calling (buggy) on_destroy |
16 | callbacks (best effort). |
36 | callbacks (best effort). |
17 | - move on_destroy into the slf_frame, to allow extension slf |
37 | - move on_destroy into the slf_frame, to allow extension slf |
18 | functions to have destructors. |
38 | functions to have destructors. |
|
|
39 | - get rid if coro refcounting - simply crash in other interpreter |
|
|
40 | threads by nulling the pointers on clone. |
|
|
41 | - simplify warn/die hook handling when loading Coro - the convoluted |
|
|
42 | logic seems to be no longer neccessary. |
|
|
43 | - use libecb instead of our own home-grown gcc hacks. |
|
|
44 | - document alternatives to Coro::LWP. Please use them :) |
|
|
45 | - work around another mindless idiotic NEEDLESS bug in openbsd/mirbsds |
|
|
46 | sigaltstack. Really. wine suffers from it, erlang suffers from it, |
|
|
47 | and it's known since at least 2006. |
19 | |
48 | |
20 | 5.372 Wed Feb 23 06:14:30 CET 2011 |
49 | 5.372 Wed Feb 23 06:14:30 CET 2011 |
21 | - apparently mingw doesn't provide a working gettimeofday, try to |
50 | - apparently mingw doesn't provide a working gettimeofday, try to |
22 | work around that by relying on Time::HiRes (indirectly brought to |
51 | work around that by relying on Time::HiRes (indirectly brought to |
23 | my attention by Max Maischein). |
52 | my attention by Max Maischein). |