1 | Revision history for Perl extension Coro. |
1 | Revision history for Perl extension Coro. |
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: __GCC_HAVE_DWARF2_CFI_ASM |
6 | |
6 | |
7 | TODO: tutorial |
7 | 6.29 |
|
|
8 | - when an on_destroy handler destructs the coro currently being |
|
|
9 | destructed a perl scalar could be accessed after being freed, |
|
|
10 | likely causing a crash. |
|
|
11 | |
|
|
12 | 6.28 Wed Mar 6 06:58:02 CET 2013 |
|
|
13 | - clean remnants of existing __DIE__ and __WARN__ handlers so |
|
|
14 | they lose their magic and will not cause segfaults later |
|
|
15 | (testcase by Andrey Sagulin). |
|
|
16 | - improved Coro::State documentation a bit. |
|
|
17 | - Coro::Debug::command now flushes the output. |
|
|
18 | - add hack detection code for x32 abi, because the braindead slugs |
|
|
19 | who designed that made it look exactly like x86_64 without |
|
|
20 | providing proper compile time symbols to test for it. as a result, |
|
|
21 | this detection cannot work reliably. |
|
|
22 | - valgrind stack registering was broken. |
|
|
23 | - do not rely on Time::HiRes anymore in Coro::Debug. |
|
|
24 | |
|
|
25 | 6.23 Fri Dec 7 23:36:37 CET 2012 |
|
|
26 | - use experimental fiber implementation on native windows |
|
|
27 | perls. |
|
|
28 | - use sizeof (void *) as multiplication factor for stack sizes, |
|
|
29 | to accomodate the totally braindamaged microsoft 64 bit "os". |
|
|
30 | - changed verifier host from win2k-ap510-32 to win7-sp516-32/64. |
|
|
31 | activeperl 5.16 crashes when PerlIO_define_layer is called due |
|
|
32 | to some bug in the perl dll, strawberry perl at least passes |
|
|
33 | the testsuite. |
|
|
34 | - implement Coro::Handle->peeraddr/host/port, for slightly |
|
|
35 | improved compatibility with LWP. |
|
|
36 | - implement 5.17 compatibility by almost blindly applying a |
|
|
37 | good-looking patch by Father Chrysostomos. |
|
|
38 | - move stack management functions into libcoro 3. |
|
|
39 | - libcoro version 3 "released". |
|
|
40 | - support magic values as timed_io_once args. |
|
|
41 | - recommend AnyEvent 7+ or EV 4+, also require EV |
|
|
42 | version 4 or newer for Coro::EV. |
|
|
43 | |
|
|
44 | 6.10 Tue Oct 9 01:14:27 CEST 2012 |
|
|
45 | - updated ecb.h, it had a typo that caused it to not compile on many |
|
|
46 | big endian systems (reported by many people). |
|
|
47 | - disable memory fences in ecb.h to improve portability. |
|
|
48 | |
|
|
49 | 6.09 Sat Oct 6 23:25:02 CEST 2012 |
|
|
50 | - Coro::EV I/O watchers were not interruptible by exceptions |
|
|
51 | (Coro::State::throw) (testcase by sten). |
|
|
52 | - ->throw now puts threads into the ready queue, as this seems to |
|
|
53 | be expected by existing code, and code that doesn't cope with spurious |
|
|
54 | wakeups needs fixing anyway. |
|
|
55 | - use fd -1 in mmap. |
|
|
56 | - cast I32 to int in error message printf. |
|
|
57 | - warn about broken so-called "hardened" kernels. |
|
|
58 | |
|
|
59 | 6.08 Fri Apr 13 12:05:47 CEST 2012 |
|
|
60 | - be more aggressive about exiting like perl does - formerly, |
|
|
61 | exiting from the non-main thread would not execute END blocks. |
|
|
62 | |
|
|
63 | 6.07 Fri Nov 11 21:21:48 CET 2011 |
|
|
64 | - work around a bug in PerlIO (setting $SIG{__WARN__} to a PVCV). |
|
|
65 | - update ecb.h. |
|
|
66 | |
|
|
67 | 6.06 Mon Aug 8 23:59:48 CEST 2011 |
|
|
68 | - cygwin unfortunately patches the stack at runtime, so we use the pthreads |
|
|
69 | backend, which is an order of magnitude slower. unfortunately, cygwins |
|
|
70 | pthread implementation isn't very complete either, so allocate the stack |
|
|
71 | twice just to be sure. |
|
|
72 | (note: cygwin also enables mymalloc, which is NOT THREADSAFE ON WINDOWS, |
|
|
73 | in its ithreaded perl - best recompile cygwin and use the 'w'indows |
|
|
74 | backend for much better performance. also disable ithreads for |
|
|
75 | even better performance...). |
|
|
76 | |
|
|
77 | 6.05 Thu Aug 4 21:36:36 CEST 2011 |
|
|
78 | - blush, condvar values would not be propagated from send to recv anymore |
|
|
79 | (reported by Chip Salzenberg). |
|
|
80 | - use exponential increase for the readline buffer length in |
|
|
81 | Coro::Handle. also reduce initial allocation to 1020 from 4096 bytes. |
|
|
82 | |
|
|
83 | 6.04 Wed Aug 3 17:15:45 CEST 2011 |
|
|
84 | - use even more efficient and more compatible condvars for |
|
|
85 | compatibility to AnyEvent 6.x :) |
|
|
86 | - more inconsequential ecb.h updates. |
|
|
87 | |
|
|
88 | 6.03 Wed Aug 3 11:41:30 CEST 2011 |
|
|
89 | - change how Coro patches AnyEvent condvars for compatibility to |
|
|
90 | AnyEvent 6.x. |
|
|
91 | - update ecb.h, to no longer include <pthread.h> in case WinNT.h |
|
|
92 | hasn't been included. |
|
|
93 | |
|
|
94 | 6.02 Wed Jul 13 04:35:19 CEST 2011 |
|
|
95 | - "improve portability to Gentoo" - gentoo manages to put perl variables |
|
|
96 | in memory areas that are farther than 2gb apart, which the jit couldn't |
|
|
97 | handle and barfed. now it's just a bit slower on gentoo and similar |
|
|
98 | systems. |
|
|
99 | |
|
|
100 | 6.01 Sun Jul 3 12:31:14 CEST 2011 |
|
|
101 | - workarounds are good, but the test for whether pthreads are used |
|
|
102 | was not good. thisone should be better. |
|
|
103 | - check differently whether gcc generates cfi instructions itself. |
|
|
104 | |
|
|
105 | 6.0 Wed Jun 29 19:43:35 CEST 2011 |
8 | - INCOMPATIBLE CHANGE: unreferenced coro objects will now be |
106 | - INCOMPATIBLE CHANGE: unreferenced coro objects will now be |
9 | destroyed and cleaned up automatically (e.g. async { schedule }). |
107 | destroyed and cleaned up automatically (e.g. async { schedule }). |
10 | - implement a JIT compiler for part of the thread switch code, |
108 | - implement a JIT compiler for part of the thread switch code, |
11 | which gives a 50% speed improvement on threaded perls, and |
109 | which gives a 50% speed improvement on threaded perls, and |
12 | about 4% on non-thraeded perls (so threaded perls now finally |
110 | about 4% on non-thraeded perls (so threaded perls now finally |