… | |
… | |
6 | |
6 | |
7 | TODO: tutorial |
7 | TODO: tutorial |
8 | TODO: in_eval, PL_tained |
8 | TODO: in_eval, PL_tained |
9 | - INCOMPATIBLE CHANGE: unreferenced coro objects will now be |
9 | - INCOMPATIBLE CHANGE: unreferenced coro objects will now be |
10 | destroyed and cleaned up automatically (e.g. async { schedule }). |
10 | destroyed and cleaned up automatically (e.g. async { schedule }). |
|
|
11 | - implement a JIT compiler for part of the thread switch code, |
|
|
12 | which gives a 50% speed improvement on threaded perls, and |
|
|
13 | about 4% on non-thraeded perls (so threaded perls now finally |
|
|
14 | reach about half the speed of non-threaded perls). |
|
|
15 | - avoid DEFSV and ERRSV, giving another 10% improvement |
|
|
16 | in thread switching. |
11 | - Coro::State->is_destroyed is now called is_zombie. |
17 | - Coro::State->is_destroyed is now called is_zombie. |
12 | - implement a Coro->safe_cancel method that might fail, but |
18 | - implement a Coro->safe_cancel method that might fail, but |
13 | cancels in a "safer" way if it succeeds. |
19 | cancels in a "safer" way if it succeeds. |
14 | - get rid of two hash-accesses when initialising a new Coro - this |
20 | - get rid of two hash-accesses when initialising a new Coro - this |
15 | speeds up coro creation by almost a factor of two. |
21 | speeds up coro creation by almost a factor of two. |