ViewVC Help
View File | Revision Log | Show Annotations | Download File
/cvs/Coro/Changes
Revision: 1.437
Committed: Wed Nov 19 05:52:42 2008 UTC (15 years, 6 months ago) by root
Branch: MAIN
Changes since 1.436: +1 -0 lines
Log Message:
*** empty log message ***

File Contents

# User Rev Content
1 root 1.1 Revision history for Perl extension Coro.
2 root 1.113
3 root 1.382 TODO: should explore PerlIO::coroaio (perl leaks like hell).
4 root 1.328 TODO: maybe implement a default message channel, very much like Erlang's
5     actor model (which is cool in a lot of important aspects (failures!),
6 root 1.247 but very lacking in others (higher level ipc)).
7 root 1.173
8 root 1.419 TODO: testcancel
9 root 1.428 TODO: guard as SLF - to avoid deadlocks.
10     - avoid deadlock in Coro::Channel if maxsize == 1 (Richard Hundt).
11    
12 root 1.408 5.0
13 root 1.424 - NEW ARCHITECTURE: use the latest 4.x version if you experience
14     stability issues.
15 root 1.411 - bump API version to 7 - all dependents must be recompiled.
16 root 1.430 - removed timed_* functions - they were not being used anyways
17     and should be replaced by a more generic mechanism -
18 root 1.429 and were annoying to support anyways :)
19     - removed SemaphoreSet's waiter method - use sem instead.
20 root 1.415 - Coro::Semaphore->adjust didn't correctly wake up enough waiters.
21 root 1.416 - async_pool did free a scalar value twice
22     ("Attempt to unreference...").
23 root 1.420 - fix a longstanding bug where calling terminate on a coro that
24     was waiting for a semaphore that was just becoming available
25     would cause a deadlock (semaphore would get into a state where
26 root 1.433 it was available but waiters were still blocked).
27 root 1.432 - calling throw on a coroutine that is waiting for a semaphore will
28     no longer make it acquire the semaphore (and thus leak a count).
29 root 1.412 - perl's process emulation is now not even theoretically supported
30     anymore.
31 root 1.437 - new functions Coro::rouse_cb and Coro::rouse_wait.
32 root 1.433 - new function Coro::Semaphore::wait.
33 root 1.428 - use named constants in Coro::Channel (Richard Hundt).
34 root 1.412 - directly patch the entersub opcode calling SLF functions (cede,
35     transfer and so on). this does speed up context switching, but
36     more importanly, it frees us from the hardcoded behaviour of
37     entersub, so we might actually be able to return something from
38     those functions and atcually create new ones.
39     - take advantage of __builtin_frame_address on gcc.
40     - expose THX in coroapi (not sure whether this was a wise decision,
41     as "threaded" perls are running at half speed anyways).
42     - implement execute_slf (schedule-like-function) interface that makes
43     it possible to implement schedule-like-functions in XS.
44 root 1.424 - use new SLF interface to massively speed up Coro::EV by roughly a
45     factor of two.
46     - used new SLF interface to massively speed up Coro::Semaphore by a
47     factor of three.
48 root 1.426 - used new SLF interface to speed up Coro::AIO by roughly a factor of
49     four and reduce its memory usage considerably.
50 root 1.429 - implement Coro::SemaphoreSet purely in terms of Coro::Semaphore,
51     for a nice speedup and vastly more correct behaviour. Also implement
52     a new method "sem" to get at the underlying semaphore object.
53 root 1.430 - implement Coro::Channel in terms of Coro::Semaphore, for a moderate
54     (in comparison) 20-40% speedup.
55 root 1.435 - used new SLF interface to reimplement Coro::Signal gaining
56     some unknown (because I was too lazy), but certain, speedup, and also
57     making signals reliable for the first time.
58 root 1.417 - forgot to include Coro/libcoro/README in the dist for all these years.
59 root 1.418 - work around a freebsd pthreads bug (manual testcancel is required as
60     pthread_cond_wait isn't a cancellation point on freebsd).
61 root 1.436 - (libcoro) lots of minor cleanups and portability improvements.
62 root 1.416
63     4.913 Sat Nov 15 07:58:28 CET 2008
64     - async_pool did free a scalar value twice
65     ("Attempt to unreference...").
66 root 1.408
67 root 1.407 4.912 Thu Nov 13 18:31:23 CET 2008
68 root 1.404 - minor cleanups.
69 root 1.405 - use much larger stacks on linux and perl < 5.8.8.
70 root 1.406 - Coro::Debug::new_unix_server did not unlink the socket
71     when destroyed.
72 root 1.404
73 root 1.403 4.911 Tue Nov 11 04:26:17 CET 2008
74 root 1.401 - "port" to threaded perls.
75    
76 root 1.400 4.91 Mon Nov 10 05:36:38 CET 2008
77     - the ->throw exception object no longer leaks.
78     - creating a new cctx leaked a scopestack entry (memleak).
79     - new coroutines didn't get created with a zero flags field
80     (unknown impact).
81 root 1.399 - calling ->throw on a not-yet-started coroutine should now work
82     instead of being ignored.
83 root 1.400 - ->throw is now supported on Coro::State objects.
84 root 1.398 - clean up cctx creation code a bit.
85 root 1.400 - entersub is actually a UNOP, not a LOGOP (not a bugfix).
86 root 1.398
87 root 1.397 4.9 Sat Nov 8 17:45:27 CET 2008
88 root 1.392 - (libcoro) did not preserve rbp with CORO_ASM (we are getting there).
89     - (libcoro) no longer leak threads in the experimental pthread backend,
90     also speed it up considerably.
91 root 1.394 - (libcoro) do not rely on makecontext passing void *'s unscathed.
92 root 1.392 - fix compiletime dependencies on libcoro in the Makefile.
93     - cctx_count wasn't always updated properly.
94 root 1.393 - Coro::State::cctx_stacksize wasn't applied correctly.
95     - new function Coro::State::cctx_max_idle.
96     - the default max number of idle C contexts is now 4.
97 root 1.394 - (libcoro) try harder to get _setjmp/_longjmp.
98     - (libcoro) cleanup and extend the libcoro API to officially
99     allow the creation of empty source contexts.
100 root 1.395 - very experimental workaround for the totally broken netbsd platform.
101 root 1.396 - tried to hack around openbsd bugs.
102 root 1.391
103 root 1.390 4.804 Wed Nov 5 16:36:00 CET 2008
104 root 1.389 - Coro::Debug::new_unix_server would not create a non-blocking listening
105 root 1.390 socket, sometimes causing freezes.
106 root 1.392 - (libcoro) fix misaligned stack points for setjmp and assembly
107     methods, which can cause crashes on x86/x86_64 with a sufficiently
108     aggressive compiler.
109 root 1.389 - new function: Coro::Debug::new_tcp_server.
110 root 1.388 - move ->throw into the Coro class because it only works on coro objects.
111    
112 root 1.387 4.803 Mon Nov 3 17:16:12 CET 2008
113 root 1.392 - (libcoro) use a global asm statement to become independent of gcc
114     otpimisations for CORO_ASM (thanks to pippijn for the idea).
115 root 1.387 - try to workaround yet another broken bsd, this time dragonfly.
116 root 1.386
117 root 1.385 4.802 Thu Oct 30 10:56:12 CET 2008
118     - support -fno-omit-frame-pointer on x86 with the assembly method.
119 root 1.383 - tune 01_unblock.t tests a bit.
120    
121 root 1.382 4.801 Wed Oct 22 18:33:37 CEST 2008
122 root 1.381 - improve readline speed for very long "lines".
123 root 1.382 - backport to 5.8.8.
124 root 1.381
125 root 1.380 4.8 Thu Oct 2 13:34:40 CEST 2008
126 root 1.378 - new function Coro::AIO::aio_wait.
127     - Coro.:AIO and Coro::BDB now "use Coro::AnyEvent".
128     - greatly speed up and reduce memory usage of Coro::AIO requests.
129 root 1.379 - implement some other ยต-optimisations.
130 root 1.378
131 root 1.377 4.749 Mon Sep 29 14:40:12 CEST 2008
132     - port to slow and broken pseudo-threaded perls. (courtesy pippijn).
133    
134 root 1.376 4.748 Sat Sep 27 14:03:19 CEST 2008
135 root 1.374 - implement, but do not document, PerlIO::cede(granularity).
136 root 1.372 - Coro::Storable forgot to wrap Storable::pstore.
137 root 1.374 - work around the multitude of leaks and memory corruption
138 root 1.375 bugs in PerlIO::via by using our own C-level perliol. As a side
139     effect, Coro::Storable is now much, much, much faster.
140 root 1.372
141 root 1.371 4.747 Tue Sep 23 01:59:41 CEST 2008
142 root 1.369 - fix a per-cv memleak (one empty array was leaked per
143     code reference).
144 root 1.370 - avoid a crash in coro->call|rss when the coroutine was already
145     destroyed (most noticably when using Coro::Debug::ps :)
146     - also protect *Storable::FILE.
147 root 1.371 - push up default storable granularity to 20ms.
148 root 1.369
149 root 1.368 4.746 Sun Sep 21 03:22:20 CEST 2008
150     - be more insistent on locking Storable against reentrancy
151     in Coro::Storable.
152 root 1.366 - move swap_def?v and throw to Coro::State, as documented.
153    
154 root 1.365 4.745 Thu Jul 24 00:14:38 CEST 2008
155 root 1.364 - remove debugging code related to MgPV_nolen_const, also try to
156     make it compile with perl 5.8.6 (yes, apple apparently loves
157     outdated software). Reported by John S.
158 root 1.363
159 root 1.362 4.744 Tue Jul 8 22:06:35 CEST 2008
160 root 1.361 - correctly provide default DIE/WARN handlers as documented.
161     - also overwrite PL_vtbl_sigelem.svt_clear, even though current
162     implementations inside perl work fine for us.
163    
164 root 1.360 4.743 Mon Jun 16 00:21:57 CEST 2008
165     - when using Coro::EV without running EV::loop it could
166     result in busy-waiting for events, this has been fixed.
167     - reduce codesize and improve performance by using EV_DEFAULT_UC.
168    
169 root 1.359 4.742 Sat May 31 14:10:21 CEST 2008
170     - implement a workaround for (some) perl <5.8.8 versions.
171     - require EV 3.3+.
172    
173 root 1.358 4.741 Fri May 30 23:33:09 CEST 2008
174     - tell netbsd how utterly broken their imitation of an OS is
175     and refuse to build by default if pthreads are in use.
176     - switch to "s" method on all bsd's by default, as their ucontext
177     stuff seems just too broken.
178     - fix a bug in Coro::Select.
179    
180 root 1.357 4.74 Thu May 29 20:05:31 CEST 2008
181     - do not test Coro::LWP for lack of dependencies.
182     - do not test Coro::Select for lack of working perls.
183    
184     4.73 Thu May 29 2008
185 root 1.356 - fix a bug in Coro::EV which would cause it to block despite
186     there being runnable coroutines.
187 root 1.354 - sprinkle "no warnings" freely over everything, also suppress
188     warnings for some other modules.
189 root 1.355 - fix typo in WSAEWOULDBLOCK.
190 root 1.354
191 root 1.353 4.72 Sun May 25 05:14:36 CEST 2008
192 root 1.351 - tweak META.yaml a bit, unfortunately, there is no documented way
193     to have optional dependencies with CPAN. doh :(
194 root 1.350 - avoid running some tests on windows because they would fail due to
195 root 1.351 perl bug (broken fork, broken pipes...).
196     - work around perl on windows bugs where perl returns undocumented
197     error codes for sysread, syswrite etc. by taking advantage
198     of AnyEvent's workaround for that problem.
199 root 1.350 - use AnyEvent::Util::fh_nonblocking in Coro::Handle to work around
200     a common perl implementation bug on windows.
201     - use unix domain sockets in testsuite to work around
202 root 1.351 common perl implementation bugs on widows (they are emulated by
203     tcp sockets on windows. ugh.)
204 root 1.350
205 root 1.349 4.71 Sat May 24 20:01:27 CEST 2008
206 root 1.348 - fix a bug in Coro::AnyEvent ("Usage: Coro::AnyEvent::_schedule()").
207 root 1.347 - take advantage of async name resolution of AnyEvent::Util.
208     - work around brutal inet_aton override in Coro::LWP.
209 root 1.348 - take advantage of the readyhook in Coro::EV, for smoother
210     scheduling.
211 root 1.347
212 root 1.346 4.7 Sun May 11 00:32:19 CEST 2008
213 root 1.342 - completely reworked the Coro manpage.
214     - added Coro::AnyEvent, generic event loop integration.
215 root 1.341 - implement cancel, ready and kill commands in Coro::Debug.
216     - document find_coro in Coro::Debug.
217 root 1.343 - incompatible change: rename has_stack to has_cctx.
218 root 1.346 - Coro::AIO and Coro::BDB no longer force event model detection,
219     use AnyEvent::AIO and AnyEvent::BDB.
220 root 1.341
221 root 1.340 4.6 Sat Apr 26 10:05:14 CEST 2008
222 root 1.336 - INCOMPATIBLE CHANGE: sub/code attributes are no longer supported
223 root 1.339 by the Coro module. It was a mistake to have it in the first place.
224     - (experimental) support for activestate perl 5.10 (method "w").
225     - (experimental) support for strawberry perl (method "a").
226 root 1.337 - coro_sigelem_set did not return a value although it had to,
227     actual impact unknown.
228 root 1.336
229 root 1.335 4.51 Mon Apr 14 13:28:27 CEST 2008
230     - make it compile again on 5.8.
231    
232 root 1.334 4.50 Thu Apr 10 09:43:17 CEST 2008
233     - I did it twice! (see 4.49).
234    
235 root 1.333 4.49 Sun Apr 6 21:23:31 CEST 2008
236     - grr, instead of compiling the recent changes on 5.10 only they
237     were compiled on 5.8 only.
238    
239 root 1.332 4.48 Sun Apr 6 20:36:46 CEST 2008
240 root 1.331 - allow coroutine switches during eval's under 5.10.x, as it seems
241     the parser is a per-interpreter option now, so this is safe
242     (this might fix the odd crashing bug).
243 root 1.332 - drop support for 5.9.x versions: they are dead, jim.
244 root 1.331
245 root 1.330 4.47 Sun Apr 6 00:37:52 CEST 2008
246 root 1.329 - force cctx allocation on API calls: we know we need to force one
247     and gcc actually manages to confuse our heuristic nowadays,
248     leading to crashes and worse.
249 root 1.330 - document force_cctx.
250 root 1.329
251 root 1.328 4.46 Fri Apr 4 22:05:43 CEST 2008
252     - upgrade libcoro, resulting in pthread-backend (which was only created
253     to fulfill the rules of the programming languages shootout).
254    
255 root 1.327 4.45 Thu Mar 13 11:55:36 CET 2008
256 root 1.322 - fix a file leaking bug in eg/mhyttpd that would allow
257     downloading of any file (reported by oesi).
258 root 1.325 - fix deadlock bug in Coro::Channel (reported by Richard Hundt)
259     (also add testcase).
260 root 1.323 - support Broadcast option in Coro::Socket (patch by Richard Hundt,
261     apparently having loads of fun with that).
262 root 1.324 - implement $state->swap_defsv, ->swap_defav and document ->throw.
263 root 1.322
264 root 1.321 4.4 Wed Feb 13 16:44:29 CET 2008
265 root 1.319 - only assume .cfi pseudo isns exist on GNU/Linux.
266 root 1.320 - add get_timed method to Coro::Channels.
267 root 1.321 - fixed Coro::Debug manpage.
268     - perl 5.11 compatbility improvement based on patch by
269     Andreas Kรถnig.
270 root 1.319
271 root 1.318 4.37 Sun Jan 20 11:25:23 CET 2008
272 root 1.317 - soften the check for an active parser for perl 5.10 (avoiding
273     "Coro::State::transfer called while parsing" in many cases).
274 root 1.316
275 root 1.315 4.36 Sun Jan 13 10:53:56 CET 2008
276 root 1.314 - reset diehook when terminating from an async_pool as to not
277     trigger any __DIE__ handlers.
278    
279 root 1.313 4.35 Sun Jan 13 04:14:13 CET 2008
280 root 1.308 - "bt" debug command now displays any exceptions
281 root 1.311 from longmess and also skips the innermost
282     stackframes, giving more useufl output.
283 root 1.309 - allow backtraces in coroutines blocked in Coro::EV,
284 root 1.310 at a <1% speed hit.
285 root 1.312 - handle localising of $SIG{__WARN__} and __DIE__
286 root 1.314 properly (with a proper amount of dirty hacking).
287 root 1.308
288 root 1.307 4.34 Sat Dec 22 17:49:53 CET 2007
289 root 1.306 - upgrade to EV version 2.0 API.
290    
291 root 1.305 4.33 Mon Dec 17 08:36:12 CET 2007
292     - make Coro::AIO etc. loadable in the absence of EV.
293    
294 root 1.304 4.32 Mon Dec 17 07:46:02 CET 2007
295 root 1.301 - majorly improved Coro::Handle's performance with Coro::EV.
296 root 1.302 - implemented the until now mythical Coro::BDB module.
297 root 1.304 - specialcase EV in Coro::AIO and Coro::BDB for extra speed.
298 root 1.301
299 root 1.300 4.31 Wed Dec 5 12:32:39 CET 2007
300     - remove warn statement form Coro::Util.
301    
302 root 1.299 4.3 Tue Dec 4 20:33:14 CET 2007
303     - calls to the idle function could cause stack corruption
304     when the stack changed.
305 root 1.295 - do no longer rely on the presence of EV::DNS if EV is used
306     (because it is gone), but instead take avdantage of EV::ADNS
307     if available.
308 root 1.296 - add ($) prototypes to all functions in Coro::Storable.
309 root 1.297 - use a conventional (safer) idle callback in Coro::EV.
310 root 1.298 - do accept quickly in Coro::Debug to avoid endless loops.
311 root 1.295
312 root 1.294 4.22 Fri Nov 30 16:04:04 CET 2007
313 root 1.293 - really use optimised versions for Event and EV in Coro::Util
314     and Coro::Handle.
315    
316 root 1.292 4.21 Sun Nov 25 10:48:59 CET 2007
317 root 1.290 - fix a spurious memory read.
318 root 1.291 - Coro::EV no longer keeps the eventloop "alive".
319 root 1.290
320 root 1.289 4.2 Fri Nov 9 20:47:05 CET 2007
321 root 1.282 - enable/disable tracing from a new coroutine, not a pooled one.
322 root 1.283 - fix a memleak in Coro::Event.
323 root 1.284 - removed killall call from fork_eval.
324     - made sure store_fd is already loaded so that fork_eval
325     does not have to parse autoload in each subprocess.
326 root 1.288 - only use assembly method if -O switch is in $Config{optimize}.
327 root 1.289 - add (optional) Coro::EV module, so far the best event loop module
328     directly supported by Coro.
329     - if the event model is EV, use EV::DNS to resolve
330     stuff in Coro::Util.
331 root 1.286 - don't get confused by multiple event notifications in Coro::Handle.
332 root 1.287 - initial support for EV (libevent interface).
333 root 1.289 - require Event and EV using configure_requires, to force their existance.
334 root 1.282
335 root 1.281 4.13 Wed Oct 24 07:26:45 CEST 2007
336 root 1.277 - add Coro::Storable::blocking_thaw.
337 root 1.278 - use a vastly more complicated technique to localise
338     $SIG{__WARN/DIE__} that also works on perls <= 5.8.8.
339 root 1.279 - use a coroutine for the idle callback Coro::Event,
340     instead of running Event in the current coroutine context.
341     This also catches recursive invocations.
342 root 1.280 - actually report fork errors in gethostbyname and inet_aton.
343 root 1.277
344 root 1.276 4.11 Thu Oct 11 02:40:24 CEST 2007
345     - port to threaded perls.
346    
347 root 1.275 4.1 Thu Oct 11 02:38:16 CEST 2007
348 root 1.264 - incompatible change: $SIG{__DIE__} and $SIG{__WARN__} will now
349     be local to each coro (see Coro::State).
350 root 1.274 - incompatible change: for very deep reasons, cede and cede_notself
351     cannot return anything, so nothing will be returned.
352 root 1.264 - possibly bring back 5.10 compatibility (untested).
353     - work around stupid (and wrong) warning on 5.10 :(.
354     - overlay the saved state over the context stack. This saves
355     a few hundred bytes per coroutine on average and also
356     speeds up context switching a bit.
357 root 1.265 - further tune default stack sizes.
358 root 1.264 - (more) correctly calculate stack usage in coro_rss.
359 root 1.267 - Coro::Storable::blocking_* did not properly lock
360     resulting in races between coroutines.
361     - added Coro::Storable::guard.
362 root 1.268 - stopping to trace a coroutine could destroy the cctx of
363     an unrelated coroutine.
364 root 1.269 - explain the relationship between Perl and C coroutines in
365     more detail in Coro::State.
366 root 1.270 - Coro::Util::inet_aton did not short-circuit dotted quad forms,
367     causing a fork per resolve. This also affected Coro::Socket.
368 root 1.272 - switch to a separate stack in $coro->call/eval to avoid
369     invalidating pointers.
370 root 1.264
371 root 1.263 4.03 Sat Oct 6 21:24:00 CEST 2007
372 root 1.262 - added Coro::throw method.
373     - minor code cleanups.
374    
375 root 1.261 4.02 Sat Oct 6 02:36:47 CEST 2007
376 root 1.258 - fix a very minor per-coroutine memleak (a single codereference).
377 root 1.259 - fixed a bug where the currently in-use c context would be freed
378     prematurely (can happen only when programs change the stacksize
379     or use tracing).
380     - tracing can no longer keep a coro alive after it terminated.
381 root 1.260 - do static branch prediction in the common path for gcc. gives
382     about 2-5% speed improvement here.
383 root 1.258
384 root 1.256 4.01 Fri Oct 5 22:10:49 CEST 2007
385 root 1.257 - instead of recreating *a* standard output handle we simply
386     use STDOUT, which is faster and hopefully more robust.
387 root 1.255
388 root 1.254 4.0 Fri Oct 5 12:56:00 CEST 2007
389 root 1.238 - incompatibly changed Coro::Storable::freeze.
390 root 1.244 - major new feature: added Coro::Debug, for interactive coroutine
391     debugging, tracing and much more.
392 root 1.252 - major bug fix: unbelievable, but true: $_, $/ and many other
393     "saved" variables actually weren't being saved. This has been fixed,
394     of course, while increasing performance while losing all the save
395     flags.
396 root 1.251 - save flags are gone, and all the api functions dealing with them.
397 root 1.232 - added Coro::Semaphore::adjust.
398 root 1.233 - added Coro::Util::fork_eval.
399     - added Coro::Storable::{nfreeze,blocking_{freeze,nfreeze}}.
400 root 1.248 - added Coro::killall.
401 root 1.236 - reduce initial stack sizes to allow for "micro-coroutines".
402 root 1.239 - better async_pool resource management, moved parts of async_pool
403 root 1.240 handling to XS (major speed improvement).
404 root 1.245 - actually croak before modifying important data structures.
405     - refuse to transfer while compiling.
406     - possibly support eval EXPR better now.
407 root 1.249 - enable assembly per default on linux+bsd x86+amd64.
408 root 1.253 - all internal members were renamed _something for easier subclassing.
409 root 1.237 - many minor tweaks.
410 root 1.232
411 root 1.231 3.63 Wed May 16 14:10:06 CEST 2007
412 root 1.230 - implement handcoded assembly for x86/amd64 SVR ABI.
413    
414 root 1.229 3.62 Fri Apr 27 21:36:06 CEST 2007
415     - upgrade libcoro (which might set unwind info correctly).
416 root 1.228 - change default on linux to setjmp/longjmp.
417 root 1.227
418 root 1.226 3.61 Thu Apr 19 12:36:18 CEST 2007
419 root 1.225 - Coro::Storable caused an endless loop when thawing invalid
420     pst's sometimes.
421 root 1.223 - use a Semaphore in Coro::Storable, as Storable doesn't
422 root 1.224 seem to be reentrant (although it is documented to
423     be threadsafe...).
424     - fix Coro::Signal to bring back the original unreliable
425     but stateful semantics.
426 root 1.226 - fixed a lot of typos in Coro.pm (patch submitted by David
427     Steinbrunner, which applied flawlessly).
428 root 1.223
429     3.6 Sat Apr 14 17:13:31 CEST 2007
430 root 1.217 - added some bugfixes to get eg/myhttpd working again.
431 root 1.218 - added Coro::Storable for often-cede'ing freeze/thaw.
432 root 1.219 - try to do a clean exit when a coroutine calls exit
433     (EXPERIMENTAL).
434 root 1.220 - got rid of indirect call through _coro_init.
435     - updated the partly antique examples in eg/ to
436     work again and be a bit less magic, too.
437     - fixed Coro::Signal semantics to work as documented again.
438 root 1.217
439 root 1.216 3.55 Sun Mar 25 01:20:47 CET 2007
440 root 1.215 - add SAVE_DEFFH to save the default filehandle and enable
441     it by default.
442     - finally move socket-operations from Coro::Socket to Coro::Handle
443     to be able to unblock foreign sockets.
444     - add Coro::State::save_also and guarded_save.
445 root 1.211 - add count accessor to Coro::Semaphore.
446 root 1.212 - add Coro::State::cctx_stacksize.
447 root 1.213 - just for the fun of it, do not rely on implicit context,
448     which can dramatically improve performance, but people
449     using windows-process-emulation perls do not care much about
450     performance.
451 root 1.211
452 root 1.210 3.51 Sun Mar 4 14:18:04 CET 2007
453 root 1.209 - fixed a problem when you weakened references to Coro::State's
454     (patch by Yuval Kogman).
455    
456 root 1.208 3.501 Wed Feb 28 12:44:07 CET 2007
457     - rename some global symbols as macosx from hell redefines
458     them without asking.
459    
460 root 1.207 3.5 Tue Feb 13 20:22:53 CET 2007
461 root 1.204 - do AnyEvent model detection earlier, avoiding problems
462     caused by first using AnyEvent and later Coro::Event.
463 root 1.205 - implement and document Coro::Event event objects.
464     - fix a potential problem in Coro::Event causing crashes.
465 root 1.206 - initialise PL_comppad when creating a new coroutine,
466     avoids crashes on early coro destruction.
467 root 1.204
468 root 1.203 3.41 Mon Jan 22 19:19:49 CET 2007
469 root 1.202 - readline on Coro::Handle did not support undefined $/,
470     nor did it deliver partial lines on EOF or error.
471 root 1.203 - implement malloc fallback for stack allocation because
472     stupid broken idiotic OSX has a stupid broken
473     idiotic fits-the-whole-os mmap "implementation" and
474     my dick feels longer if Coro is portable even to
475     obsolete platforms.
476 root 1.202
477 root 1.201 3.4 Fri Jan 19 21:52:54 CET 2007
478 root 1.197 - remove t/09_timer.t, as it isn't really testing much
479     but was rather flaky in practise.
480 root 1.198 - async_pool coro would keep arguments and callback alive until
481     it was reused.
482 root 1.199 - cancellation of a coroutine could cause spurious idle calls
483     in cede_notself.
484 root 1.197
485 root 1.196 3.3 Sat Jan 6 03:45:00 CET 2007
486 root 1.187 - implement $coro->on_destroy.
487 root 1.188 - Coro::Event blocking semantics have been changed,
488     documented and - hopefully - improved.
489 root 1.184 - fix nice adding, not subtracting, from priority.
490 root 1.185 - fix ->prio and api_is_ready (patch by Mark Hinds).
491 root 1.190 - fixed an assert ("... == prev__cctx->idle_te")
492     that could errronously trigger.
493 root 1.192 - fix various large and small memleaks.
494 root 1.191 - use a (hopefully) more stable cancel implementation
495     that immediately frees the coroutine data.
496 root 1.194 - cede/cede_notself return a status now.
497 root 1.191 - added Coro::guard function.
498 root 1.193 - added a global coroutine pool for jobs (on my machine,
499     I can create and execute 48k simple coros/s with async,
500     and 128k coros with async_pool).
501 root 1.195 - Coro::AIO now uses the coroutine priority as io priority.
502 root 1.184
503 root 1.183 3.2 Fri Dec 22 05:07:09 CET 2006
504 root 1.179 - improve portability to slightly older perls.
505 root 1.180 - use cleaner coroutine destruction.
506 root 1.182 - simplify configuration for users.
507     - optionally (unrecommended) prefer perl functions over
508     their coro replacements.
509 root 1.179
510 root 1.178 3.11 Tue Dec 5 13:11:24 CET 2006
511     - fixed some bogus assert's, but as perl.h disables assert even
512     without NDEBUG (thank you very much), not too many people should
513     notice (that did include myself). Andreas Kรถnig noticed, though :)
514     - do not save/restore PL_sortcxix on >= 5.9.x, it doesn't seem to have
515     it. Also noticed by Andreas Kรถnig :)
516     - save/restore tainted status.
517     - verified to pass the testsuite on my 5.9.5.
518    
519 root 1.177 3.1 Mon Dec 4 23:03:40 CET 2006
520     - INCOMPATIBLE CHANGE: $/ is now per-coroutine (but slow).
521 root 1.175 - incompatible change: transfer flags are now per-state.
522 root 1.173 - give a better error message on deadlock.
523 root 1.175 - document Coro::nready.
524 root 1.174 - enhanced testsuite.
525 root 1.169
526 root 1.172 3.01 Sun Dec 3 23:47:42 CET 2006
527     - forgot to include Coro::Timer.
528    
529 root 1.171 3.0 Sun Dec 3 22:57:25 CET 2006
530 root 1.163 - the "FINALLY COMPLETELY STABLE" release (coming soon:
531     the "FAMOUS LAST WORDS" release).
532 root 1.166 - implement a new stack sharing algorithm, which uses a stack
533     pool (size currently hardcoded).
534 root 1.155 - make stack sharing mandatory (it no longer uses a heuristic).
535 root 1.157 - eval/die no longer cause weird problems under heavy use.
536 root 1.152 - Coro::Event could cause livelocks if it was used but
537 root 1.161 no Coro::Event watchers were used.
538 root 1.167 - Coro::Event now uses asynccheck as prepare does not
539     check for changed watchers.
540 root 1.170 - Coro::Event allows multiple waiting coros and will wake up one
541     per event.
542 root 1.152 - Coro::Event should be cleaner and more efficient now.
543 root 1.165 - new utility function Coro::unblock_sub.
544 root 1.164 - document the sad fact that Event is no longer reentrant.
545 root 1.163 - putting a coroutine into the ready queue twice could under
546     some circumstances lead to stack corruption.
547 root 1.161 - minor incompatibility: subclassing Coro::State is supported
548     directly now without going through a _coro_state member.
549 root 1.156 - state/coro switching is much faster now.
550 root 1.154 - very minor optimisations and code/documentation cleanup.
551 root 1.153 - avoid problems due to compiler inlining.
552 root 1.154 - removed timers from Coro::Timer -> use AnyEvent instead.
553     - replaced Coro::idle coroutine by (cleaner) idle handler.
554 root 1.156 - updated to newest libcoro.
555 root 1.159 - implement enhanced support for valgrind.
556 root 1.162 - implement is_ready and return value for ready.
557 root 1.168 - removed Coro::Cont, it was a misnomer (it's generators),
558     and it was somewhat annoying to get it right. Will come back
559     if somebody asks for it :)
560 root 1.163 - many ->wait methods and Coro::Event could return
561     spuriously without the event having happened.
562 root 1.146
563 root 1.145 2.5 Tue Nov 7 12:22:33 CET 2006
564 root 1.143 - made Coro::Util, Coro::Select, Coro::Handle and Coro::Socket
565     use AnyEvent, moved them to Coro/.
566 root 1.140 - added Coro::LWP which contains all the uglyness required to
567     make LWP non-blocking.
568     - should work with perl 5.9.x now (Andreas Kรถnig made me do it).
569 root 1.141 - fixed another bug in Coro::Select when the timeout was undef.
570 root 1.136 - reuse PL_start_env for all coros, saves some memory per coroutine.
571     - manage PL_top_env differently, hopefully to avoid panic: top_env.
572 root 1.137 - timeout argument was not properly used in Coro::Socket.
573     - allow limited forms of subclassing in Coro::Handle/Coro::Socket.
574 root 1.138 - emulate undocumented(!) functionality of IO::Socket required
575     by LWP(!!).
576     - updated eg/lwp to work with newer lwp's.
577 root 1.140 - remove "FATAL: uncaught exception" prefix. Coroutines that die
578     kill the whole process, just as exceptions in the main "coroutine"
579     did already.
580 root 1.135
581 root 1.134 2.1 Wed Nov 1 23:01:13 CET 2006
582     - fix a long-standing bug in Coro::Select where select with
583     zero timeout would instead change the current default filehandle.
584 root 1.132 - use a simpler and hopefully more robust way to clone padlists
585     (uses less memory and a perl function instead of our own).
586     - coro can now create a stack guard area on many architectures.
587 root 1.134 - Coro::AIO properly reexports additional functions from IO::AIO.
588 root 1.132 - updated libcoro with a workaround for OS X,
589 root 1.134 pach and testing by Michael Schwern.
590 root 1.130
591 root 1.129 2.0 Tue Oct 24 05:47:17 CEST 2006
592 root 1.128 - support additional aio requests in Coro::AIO.
593    
594 root 1.129 1.9 (never properly released due to a glitch)
595    
596 root 1.127 1.8 Thu Feb 2 00:59:06 CET 2006
597 root 1.125 - applied suggested patch by SAMV to avoid problems during stupid
598     mark & sweep gc run.
599 root 1.126 - applied patch by Scott Walters for 5.9.3 compatibility.
600 root 1.125
601 root 1.124 1.7 Tue Dec 27 01:41:58 CET 2005
602 root 1.123 - added Coro::AIO, a thin wrapper around IO::AIO.
603 root 1.122 - improved Makefile.PL explanations.
604    
605 root 1.119 1.6 Mon Dec 12 21:30:05 CET 2005
606 root 1.117 - additionally save PM_curpm might fix as-of-yet
607 root 1.121 unseen problems with regex matches being attributed to the
608 root 1.117 wrong package.
609 root 1.118 - add t/10_bugs.t, which currently checks against imho broken
610     perls that use 0.26MB of stack space per Perl_magic_get
611 root 1.121 invocation (newer linuxes) as opposed to the 0.0002MB perl
612     normally uses.
613 root 1.120 - make stacksize configurable for the ultimate debian experience.
614 root 1.117
615 root 1.116 1.51 Mon Dec 12 18:48:36 CET 2005
616     - remove debugging warn() accidentally left in Coro::Select.
617    
618 root 1.115 1.5 Tue Nov 29 13:32:44 CET 2005
619 root 1.114 - use Coro::Event inside Coro::Select to avoid spurious deadlocks.
620 root 1.115 - fix Coro::Select 'select'.
621     - strict'ify some modules.
622 root 1.112 - libcoro errornously restored the SIGUSR2 handler to SIGUSR1.
623 root 1.115 - use XSLoader in selected modules.
624     - remove some 5.6 compatibility cruft.
625 root 1.112
626 root 1.111 1.4 Tue Sep 6 00:11:05 CEST 2005
627     - libcoro did not take into account the trampoline on amd64,
628     when 'l'inux method was used.
629    
630 root 1.110 1.31 Tue Aug 30 23:31:33 CEST 2005
631     - some portability fixes/workarounds.
632    
633 root 1.107 1.3 Sat Aug 20 03:08:56 CEST 2005
634 root 1.108 - no code changes. module seems to work fine.
635 root 1.106 - improve Coro::State docs, remove reference to nonexisting
636     Coro::State::flush method.
637 root 1.107 - no longer autodetect windows, present it as an option instead.
638 root 1.106
639 root 1.105 1.2 Mon May 16 02:00:55 CEST 2005
640 root 1.100 - included libcoro.c earlier in State.xs, might improve portability.
641 root 1.101 - use a faster and possibly more stable Coro::Cont implementation.
642 root 1.102 - accept x86_64 in addition to amd64 for optimized linux-amd64 support.
643 root 1.104 - fix bugs Coro::SemaphoreSet that could cause locks never to be freed.
644 root 1.105 - fix bugs in CoroAPI.h and document it in Coro::MakeMaker.
645 root 1.100
646 root 1.99 1.11 Thu Mar 3 18:00:52 CET 2005
647     - change of contact address.
648    
649 root 1.98 1.1 Tue Feb 22 20:51:16 CET 2005
650 root 1.97 - support [l]inux method on amd64.
651 root 1.109 - allow some context switches while compiling/eval'ing.
652 root 1.97
653 root 1.96 1.0 Tue Aug 10 03:47:27 CEST 2004
654 root 1.95 - Event 0.89 fixes the bug again.
655 root 1.96 - fix the remaining(??) memleak. I didn't free the cache-AV for
656     padlists, so one AV per created anon-sub leaked.
657 root 1.95
658 pcg 1.94 0.97 Fri May 14 15:23:32 CEST 2004
659     - remove stupid gcc extension that was an experiment only anyway.
660    
661 pcg 1.93 0.96 Thu May 13 18:09:29 CEST 2004
662 root 1.103 - tell people if they have yet another broken Event variant.
663 pcg 1.91 - made Coro to work _better_ with threads (it seems that, as long
664     as you use Coros in one thread only everything will work fine.
665     Looking at the perl source the problem might be missing locking
666     between Coro and some perl internal routines. That's not easily
667     fixable).
668 pcg 1.92 - (hopefully) got rid of the static xnext inside transfer.
669 pcg 1.91
670 pcg 1.90 0.95 Sun Feb 15 03:20:28 CET 2004
671 pcg 1.86 - removed Coro::State::flush, implemented a new and much
672     faster caching mechanism by attaching magic to the CV.
673 pcg 1.87 - a memleak with (real) closures remains.
674 pcg 1.88 - dramatically reduced size of stacks to 65536 (linux/x86), after
675     observing that even myhttpd never had more than a kilobyte
676     of stack in use (stack is still only physically allocated in
677     pagesize increments for systems suporting mmap).
678 pcg 1.89 - fix for a "cygwin-64" architecture added, proposed by Stefan Traby.
679 pcg 1.90 - fix for threaded perl.
680 pcg 1.86
681 pcg 1.85 0.9 Sun Nov 23 04:32:39 CET 2003
682 pcg 1.84 - fix a few very hard to track down but (of course) stupid
683     memory leaks.
684     - stringify version number to avoid locale problems :(.
685 pcg 1.85 - perl 5.9.0 does not have SvPADBUSY, reported by Scott Walters,
686     hopefully ignoring it "just works".
687 pcg 1.84
688 pcg 1.83 0.8 Wed Nov 5 19:38:40 CET 2003
689     - port to perl5.005_03, but only 5.8.x+ is supported!
690 pcg 1.82 - honor LocalAddr even without LocalPort in Coro::Socket.
691    
692 root 1.81 0.7 Tue May 27 03:12:38 CEST 2003
693     - the version jump indicates some level of testing, not gobs
694     of new features.
695 root 1.80 - uh... I found the prompt function in ExtUtils::MakeMaker.
696     Highly correct stuff, that is...
697 root 1.81 - fixed(?) a bug with die's in coroutines causing "panic: top_env".
698     the fix is not well understood by the author, so beware :(.
699 root 1.80
700 root 1.79 0.652 Thu May 8 02:54:46 CEST 2003
701 root 1.76 - Applied patch by Slaven Rezic to set default to "s" on FreeBSD,
702 root 1.78 cause version 4 doesn't have ucontext.
703 root 1.77 - Benjamin Reed reported that setjmp works fine on darwin,
704     so preselect it.
705 root 1.76
706 root 1.75 0.651 Sat Mar 29 15:00:23 CET 2003
707     - fix a bug in Coro::Handle where some bytes could get lost
708     on reading, reported by jason@nichego.net.
709 root 1.74
710 root 1.73 0.65 Sun Mar 23 00:08:26 CET 2003
711 root 1.72 - added a README.linux-glibc.
712     - new module Coro::Select.
713     - also save/restore PL_comppad, fixes segfaults with 5.8.1.
714     (I never claimed that I know what I am doing ;).
715 root 1.73 - set default to setjmp/longjmp on non-x86-linux.
716 root 1.72
717 root 1.71 0.6 Thu Nov 21 11:09:06 CET 2002
718     - made lazy context switching the default.
719     - fixed the bug where SemaphoreSet::guard
720     was the same as timed_guard and timed_guard was missing.
721     - fix a memleak in Coro::Timer.
722     - reclassified context sharing as not experimental.
723    
724 root 1.70 0.534 Sun Apr 14 03:05:12 CEST 2002
725 root 1.69 - fixed backspace => tab in header parsing (myhttpd).
726 root 1.70 - added eg/readline, for elmex.
727     - Coro::Event now calls ->start on first call instead of
728     ->again, which created wrong timeouts for the first ->next.
729     - fixed a bug where Coro::Socket returned a closed socket instead
730     of nothing on ECONNREFUSED and similar error conditions.
731 root 1.69
732 root 1.68 0.533 Mon Feb 18 18:49:40 CET 2002
733     - adapt to finally working Event-0.85.
734     - fixed buggy event initialization (trapped under windows, but how
735     could it possibly have worked anywhere?)
736    
737 root 1.67 0.532 Wed Jan 16 02:45:32 CET 2002
738 root 1.66 - removed the reference to pp_entersub, might work on
739     (some) win32 perls now (testsuite works under cygwin,
740     without Event, which freezes).
741 root 1.65
742 root 1.64 0.531 Mon Dec 10 22:18:44 CET 2001
743 root 1.63 - Fixed a bug in SemaphoreSet::timed_down.
744    
745 root 1.64 0.53 Tue Nov 27 21:11:13 CET 2001
746 root 1.60 - some tests for Event.
747 root 1.61 - slightly different internal architecture to get refcnt into the object
748     and not the reference. might fix a few bugs, certainly did introduce
749     new ones.
750     - Coro::Timer (independent of Event).
751 root 1.62 - new timed_wait functions for Coro::Signal, Semaphore, SemaphoreSet.
752 root 1.60
753 root 1.64 0.52 Tue Nov 6 21:36:18 CET 2001
754 root 1.58 - ported to cygwin (trivial).
755     patch by Gerrit P. Haase <gp@familiehaase.de>.
756     - small setjmp code fix by Sullivan.DanielJ@epamail.epa.gov.
757    
758 root 1.64 0.51 Thu Nov 1 20:39:01 CET 2001
759 root 1.54 - terminate/cancel now work properly (otherwise termination
760     could cause a "next coroutine is not and contains not..."
761     error.
762 root 1.55 - added Coro::Socket::shutdown.
763 root 1.56 - Coro::Event::loop no is the same as Event::loop.
764     - implemented terminate with args + join.
765 root 1.54
766 root 1.64 0.5 Fri Sep 28 16:15:35 CEST 2001
767 root 1.53 - fixed "print" on a Coro::Handle. The print method worked.
768 root 1.50 - small tweaks (seem to reduce memory consumption a lot)
769     in various modules.
770     - splendid use of "no warnings" scattered throughout.
771 root 1.52 - added Coro::Handle::rbuf, fixed Coro::Handle::fh.
772 root 1.48
773 root 1.47 0.49 Sun Sep 16 02:42:45 CEST 2001
774 root 1.43 - changed some method calls to function calls for speed
775     inside Coro::Handle.
776 root 1.44 - make Coro::Handle use an array instead of a hash for
777     speed reasons.
778     - IRIX mystery solved: it's SGI's NT, after all: "standard, huh?".
779     sjlj and ucontext should now work.
780     - IRIX-specific port for libcoro.
781 root 1.45 - swapped order of accept results to match IO::Socket.
782 root 1.46 - changed getsock/peername to sock/peername to match IO::Socket.
783     - fixed a bug that caused segfault when returning to main task
784     under some circumstances.
785     - other bugfixes.
786 root 1.43
787 root 1.42 0.45 Sun Sep 2 02:54:01 CEST 2001
788 root 1.36 - new method Coro::Handle::timeout.
789     - corrected speling of set...name to get...name in Coro::Socket.
790     - Coro::Socket::accept now returns a Coro::Socket, not a Coro::Handle.
791     - Coro::Handle now supports fileno and FILENO.
792     - added eg/myhttpd, a web server.
793 root 1.37 - Coro::Socket now accepts numeric ports as well as "port(number)"
794     syntax.
795 root 1.38 - moved some scheduling primitives into xs code. more to come.
796 root 1.39 - new simple priority system.
797 root 1.40 - implemented Coro::Event using XS, almost four times faster!
798 root 1.41 - small memory corruption problem fixed (boy that was difficult).
799 root 1.36
800 root 1.35 0.13 Wed Aug 8 16:53:07 CEST 2001
801 root 1.31 - new method Coro::Handle::readline.
802 root 1.34 - added eg/lwp and Coro::Handle::autoflush, to make LWP work.
803     (see eg/lwp on how to make LWP non-blocking).
804 root 1.31 - renamed Coro::Socket::new_inet to new.
805 root 1.32 - added Coro::Util, some utility functions.
806 root 1.33 - die/eval now works better (still get annoying (but true ;)
807     "Callback called exit" messages).
808 root 1.34 - Coro::Handle now supports timeout, and Coro::Socket Timeout.
809     - much better Coro::Socket support.
810 root 1.31
811     0.12 Fri Jul 27 04:19:01 CEST 2001
812 root 1.29 - do not use mmap if neither MAP_ANON nor MAP_ANONYMOUS is defined.
813 root 1.34 - very experimental stack sharing algorithm. not 100% safe but
814 root 1.28 should work well in practise ;)
815 root 1.30 - added Coro::RWLock.
816 root 1.31 - Coro::Specific now works.
817 root 1.28
818     0.11 Tue Jul 24 22:49:21 CEST 2001
819 root 1.27 - added specialized hack for newer and older linux versions (fast).
820     - renamed Coro::Event::IO to Coro::Handle.
821     - new module Coro::Socket.
822    
823 root 1.26 0.1 Tue Jul 24 01:47:53 CEST 2001
824 root 1.23 - release candidate 3. A rather new internal structure :(
825 root 1.24 - the great renaming: Damian Conway gave me a suitable replacement
826     for yield.
827 root 1.23 - added Coro/libcoro, a portable coroutine implementation for C
828 root 1.22 (not even perl-dependent!!!), which can be used by Coro::State.
829 root 1.20 - renamed SAVE_DEFSV (on xs-level only) to avoid symbol clash in
830     perl-5.6.
831 root 1.16 - new function Coro::Event::idle.
832     - the idle process is now overriden
833     by default in Coro::Event.
834 root 1.17 - Coro::Channel now enforces the size.
835 root 1.18 - canceling events now works in all cases.
836 root 1.19 - Coro state now include $_ and $@.
837     - yet another bug workaround that I do not really understand :(
838 root 1.21 - new module Coro::Event::IO (very undocumented) to do
839     non-blocking i/o.
840 root 1.25 - performance tuning.
841 root 1.16
842 root 1.15 0.08 Thu Jul 19 06:13:25 CEST 2001
843 root 1.14 - release candidate 2 (new functionality).
844 root 1.13 - add Coro::State::flush function.
845     - transfer now supports a flags value (mostly for speed ATM).
846     - might compile and work in the presence of threads now.
847 root 1.14 - continuations have a saner syntax.
848 root 1.19 - no more memleaks.
849 root 1.13
850 root 1.12 0.07 Tue Jul 17 17:40:18 CEST 2001
851     - release candidate 1 ;)
852     - slightly nicer code.
853     - fixed a scheduling bug in Coro::Event.
854    
855 root 1.11 0.06 Tue Jul 17 04:23:24 CEST 2001
856     - ok, I found the showstopper - the same sub must not be
857 root 1.9 re-entered in two different coroutines, otherwise => crash. I
858     see no easy solution to this problem, except by walking the call
859     chaing and saving/restoring the cv's, which is what I do now.
860 root 1.11 - memory leaks still latent, especially at thread termination.
861     - Coro::Event now works (haha).
862 root 1.9
863 root 1.8 0.05 Sun Jul 15 17:32:20 CEST 2001
864     - fixed a few issues in Coro::Event.
865     - I forgot to include Coro::Event in 0.04 :(:(:(
866    
867 root 1.7 0.04 Sun Jul 15 05:24:59 CEST 2001
868 root 1.5 - @_ is now properly localized.
869 root 1.4 - Coro::State is now easier subclassable.
870     - Coro::Cont now coroutine-aware.
871     - Coro::Specific is a low-overhead module to create
872     coroutine-specific vars.
873 root 1.6 - Coro::Event provides a simple interface to Event.
874 root 1.4
875 root 1.3 0.03 Fri Jul 13 14:51:52 CEST 2001
876 root 1.4 - transfer() now implemented in XS (beware).
877     - new module Coro::Cont for really faked continuations.
878     - big internal architecture changes: Coro::State is now
879 root 1.3 really low-level and can thus be used to implement other
880 root 1.4 interesting things, While "Coro::" implements a process-like
881     model. Still crude and subject to change.
882 root 1.3 - $_ and $@ are no longer being localized.
883    
884 root 1.2 0.02 Tue Jul 10 01:38:17 CEST 2001
885     - implemented "async" attribute.
886     - $_ and $@ are now localized.
887     - added Coro::Channel.
888     - more testcases, still no docs.
889    
890 root 1.1 0.01 Tue Jul 3 02:18:41 CEST 2001
891     - original version; copied from Convert::Scalar.
892