ViewVC Help
View File | Revision Log | Show Annotations | Download File
/cvs/IO-AIO/Changes
(Generate patch)

Comparing IO-AIO/Changes (file contents):
Revision 1.169 by root, Tue Sep 30 17:23:24 2008 UTC vs.
Revision 1.303 by root, Wed Aug 22 22:28:03 2012 UTC

1Revision history for IO::AIO 1Revision history for IO::AIO
2 2
3TODO: better autoconf.pm that can return LIBS etc.
4TODO: aio_cptree/mvtree 3TODO: aio_cptree/mvtree
5TODO: reduce condvar fairness: schedule hot-cache-threads first? 4TODO: reduce condvar fairness: schedule hot-cache-threads first?
6TODO: splice/tee/vmsplice/sync_file_range? (http://kerneltrap.org/node/6505 http://lwn.net/Articles/178199/) 5TODO: vmsplice? (http://kerneltrap.org/node/6505 http://lwn.net/Articles/178199/)
7TODO: aio_fcntl, at least for file-locking 6TODO: aio_fcntl, at least for file-locking
7TODO: aio_mincore?
8TODO: getxattr etc.?
9TODO: F_DUPFD_CLOEXEC
10TODO: emulation for splice?
11TODO: eio_mmap|mlock|munmap|splice...
8 12
93.1 13 - add list of linux fsid values to aio_statvfs docs.
14
154.16 Tue Aug 14 05:39:03 CEST 2012
16 - aio_statvfs was wromgly marked for wd emulation, causing
17 it to malfunctiobn for paths.
18 - fix a crash in aio_fiemap, when used on ranges without any
19 extents.
20 - work around linux kernel bug (at least in 3.2): kernel might
21 trash fiemap input arguments.
22 - work around linux kernel bug (at least in 3.2): kernel does not
23 set FIEMAP_EXTENT_LAST on last segment.
24 - work around linux kernel bug (at least in 3.2): kernel silently
25 truncates segment count if a file.
26 - make fh argument of IO::AIO::mmap optional, also add mmap/munmap
27 to quick overview.
28 - splice can corrupt data.
29 - (libeio) remove pread/pwrite emulation.
30 - do not grow mmaped scalars in aio_read.
31 - add FALLOC_FL_PUNCH_HOLE and document fallocate.
32 - provide pread/pwrite for win32, making it link again on native win32.
33
344.15 Tue Apr 10 06:59:00 CEST 2012
35 - always include linux/types.h for fiemap, for compatibility to
36 ancient systems (Paul Howarth).
37 - experimental support for IO::AIO::splice and ::tee (no aio_...).
38 - provide SEEK_HOLE and SEEK_DATA, if available.
39 - work around (again!) an immensely stupid bug in RHEL, defining
40 autoconf macros in linux system headers (analysed by Paul Howarth).
41
424.14 Sat Apr 7 02:45:18 CEST 2012
43 - fix stat structure usage on windows, which caused bogus stat results.
44 - (libeio) make readahead emulation behave more like actual readahead by never failing.
45 - new request aio_seek.
46 - new request aio_fiemap.
47 - autogenerate the #ifdef/#define 0 blocks for symbols we export.
48
494.12 Fri Dec 30 08:51:25 CET 2011
50 - realpath would return a random value if the name was too long,
51 instead of -1.
52 - port to c89.
53
544.11 Mon Oct 10 00:24:11 CEST 2011
55 - libeio didn't compile on !linux (Paul Howarth).
56
574.1 Sun Oct 9 10:24:11 CEST 2011
58 - IO::AIO did access uninitialised memory on unsuccessful stats.
59 - (libeio) added syncfs syscall wrapper.
60 - (libeio) set thread name on linux (ps -L/Hcx, top, gdb).
61 - (libeio) support multiple indepenent working directories.
62 - applied speling corrections by Nicholas Bamber.
63 - tune treescan #threads and #outstanding requests a bit.
64 - reduce the number of file descriptors in use at any one time
65 in treescan, to avoid running out of them (and using too much ram).
66 - take advantage of working directoriy abstractions
67 in aio_scandir and treescan.
68 - reduce compiled size by ~10% by not inlining some key functionality.
69 - added --progress switch to treescan.
70
714.0 Mon Jul 18 05:01:10 CEST 2011
72 - INCOMPATIBLE CHANGE: fork is no longer supported (indeed, it never was),
73 see FORK BEHAVIOUR in manpage for details.
74 - passes testsuite on win32 now and may actually work
75 (activestate 5.10.1 / MSVC6, YMMV).
76 - (libeio) fix a deadlock where a wakeup signal could be missed when
77 a timeout occured at the same time.
78 - (libeio) added realpath.
79 - (libeio) added fallocate.
80 - (libeio) disabling sendfile on darwin unfortunately broke the emulation.
81 - (libeio) do not acquire any locks when forking.
82 - (libeio) use fewer time() syscalls when waiting for new requests.
83
843.93 Wed Jun 29 23:44:18 CEST 2011
85 - ECB.H WAS MISSING.
86
873.92 Wed Jun 29 14:45:41 CEST 2011
88 - ecb.h was missing.
89
903.91 Wed Jun 29 13:24:42 CEST 2011
91 - (libeio) work around a Linux (and likely FreeBSD and other
92 kernels) bug where sendfile would not transfer all the requested
93 bytes on large transfers, using a heuristic.
94 - buggy sendfile caused aio_move/copy to sometimes fail for big
95 files (fortunately it checks that the whole file has been
96 transferred...)
97 - use libecb for higher performance and higher portability.
98 - (libeio) disable sendfile on darwin, it's too broken.
99 - disable fork tests on !linux, as only linux supports mixing
100 pthread and fork in perl.
101 - document the fact that fork doesn't work anymore when using
102 this module, on anything !GNU/Linux.
103 - increase timeout in t/04_fork.t, as too many CPAN-tester setups
104 run on a 0.1MHz cpu. Or so.
105
1063.9 Fri May 27 02:43:47 CEST 2011
107 - (libeio) fix memory corruption in aio_readdirx for the flags
108 combination READDIR_STAT_ORDER | READDIR_DIRS_FIRST.
109 - add lots of newer POSIX and GNU/Linux-specific open
110 flags.
111
1123.8 Sun Mar 27 12:25:33 CEST 2011
113 - use nonstandard but maybe-working-on-bsd fork technique.
114 - support a max_idle value of 0.
115 - support setting of idle timeout value (IO::AIO::idle_timeout).
116
1173.72 Fri Feb 11 04:25:38 CET 2011
118 - use _POSIX_MEMLOCK_RANGE to detect mlock/munlock.
119 - aio_mknod always used a dev_t value of 0.
120 - new treescan option: --grep.
121 - add more S_IF macros, and major/minor/makedev "macros".
122
1233.71 Thu Dec 30 08:18:46 CET 2010
124 - the numerical result value passed to callbacks did not stringify
125 correctly, due to internal reuse and failure to reset the sv flags.
126 - actually test for posix_[mf]advise, as at least uClibc defines
127 _POSIX_ADVISORY_INFO without actually having any of the required
128 funcitonality. ugh.
129
1303.7 Mon Nov 1 23:00:34 CET 2010
131 - implement/add madvise, mmap, munmap, aio_mlockall, munlockall,
132 aio_mlock, munlock, msync and mtouch to @EXPORT_OK.
133 - document the sad state of affairs w.r.t. pthread on many bsds.
134 - do not enable mmap on systems without _POSIX_MAPPED_FILES
135 (openbsd 4.8).
136 - do not leak memory in IO::AIO::mmap when the scalar already
137 had string-data.
138 - add O_RDWR, O_APPEND and O_EXCL symbols and semi-document
139 them.
140 - cache the result IV, for a minor speedup in the common case.
141 - croak when an mmapped-scalar changes location, to detect
142 user-errors better.
143 - fix aio_readlink prototype.
144
1453.65 Wed Mar 31 02:45:05 CEST 2010
146 - actually use PATH_MAX instead of NAME_MAX for readlink, as to not
147 cut off long pathnames in aio_readlink (based on patch by
148 Rasmus Andersson).
149 - a double fork partially killed the event pipe (great testcase
150 by dormando). affects IO::AIO, BDB and Async::Interrupt.
151 - suck steve's dick and rename our symbols to avoid colliding
152 with nonstandard identifier spam on the broken os x pseudo-os.
153 affects IO::AIO and BDB.
154
1553.6 Mon Jan 11 00:43:39 CET 2010
156 - (libeio) more fixes for the freebsd/apple sendfile - broken by
157 manpage standards, but apparently correct accoridng to actual
158 kernel sources.
159 - add IO::AIO::mmap/munmap support.
160 - add IO::AIO::m(un)lockall support.
161 - clean up manpage.
162
1633.5 Thu Jan 7 21:25:04 CET 2010
164 - (liebio) fix freebsd sendfile (Vanilla Hsu).
165 - (libeio) also fix darwin sendfile that suffered from a similar bug.
166 - add aio_statvfs as interface to statvfs/fstatvfs.
167 - work around buggy symlink() on cygwin in the testsuite.
168 - wtf. freebsd-8.0 actually passes the testsuite! I knew
169 they could implement fork and semaphores one day! cheers!
170
1713.4 Sat Jan 2 15:13:04 CET 2010
172 - (libeio) max_poll_time was not properly converted to ticks.
173 - clarify cancel_subs description.
174 - IO::AIO::sendfile did not actually return the return value
175 from the sendfile call.
176 - implement aio_msync, aio_mtouch.
177 - (libeio) tentatively support darwin in sendfile.
178
1793.31 Thu Nov 12 02:14:29 CET 2009
180 - fix result status documentation of aio_copy, aio_move.
181 - speed up object creation considerably by avoiding
182 hash lookups.
183
1843.3 Wed Aug 5 13:52:58 CEST 2009
185 - use common::sense.
186 - use common schmorp.h header.
187 - allow integers (file descriptors) in addition to file handles.
188 - take advantage of linux' eventfd (but it seems slower on smp?).
189 - use poll not select on posix platforms.
190
1913.261 Wed Jul 1 10:11:51 CEST 2009
192 - more 0S X workarounds (patch by Tokuhiro Matsuno).
193
1943.26 Tue Jun 30 09:33:26 CEST 2009
195 - 0S X of course claims to be posix 2008 but lacks posix_fadvise.
196 try to work around this horribly broken OS in a somewhat hackish
197 way. might help other os's too.
198
1993.25 Sat Jun 27 05:18:26 CEST 2009
200 - added IO::AIO::fadvise and IO::AIO::sendfile.
201 - (libeio) replaced quicksort+insertion sort by a tuned radix
202 sort + insertion sort, resulting in comparable runtime (usually
203 faster) to the old version, but without any ill side effects on
204 degenerated (for quicksort) data.
205 - (libeio) correctly sort dirs by inodes if we have perfect type
206 knowledge and DIRS_FIRST is used.
207 - (libeio) internally the wrong DT_* constants were used, but no
208 known system has differing EIO_DT_*/DT_* values, so not an issue.
209 - removed a (harmless) assert that was left over on the code
210 but should not have been.
211 - use more correct types (change IO length from IV to VAL64,
212 which makes a difference on systems without 64 bit perls).
213
2143.23 Sat Jun 13 16:57:58 CEST 2009
215 - fix off-by-one bug in aio_readdir that was introduced in the
216 rushed 3.22 release.
217
2183.22 Sat Jun 13 15:32:40 CEST 2009
219 - speed up readdirx sort algorithm slightly.
220 - bin/treescan was missing from distro tarball.
221
2223.21 Fri Jun 12 18:45:53 CEST 2009
223 - new options --dirs and --files for treescan.
224 - install bin/treescan by default.
225 - (libeio) aio_readdir can now be cancelled while executing.
226 - fix a printf format string for 64 bit systems (could lead
227 to problems on big endian 64 bit systems).
228 - do not use qsort() but our own algorithm: glibc initialises
229 the whole locale and I/O subsystem inside qsort, causing
230 a stack overflow on 32 bit machines. The new sort uses much less
231 stack and is more than twice as fast in typical situations.
232
2333.2 Sun Jun 7 20:30:05 CEST 2009
234 - (libeio) pwrite emulation was even more flawed than intended and did
235 not restore the file offset.
236 - add aio_readdirx, which can return inode and filetype and sort
237 the names in various ways.
238 - unfortunately, utime, chmod, chown on an open file that has just
239 been written can easily block, which caused aio_copy to block the
240 process. no more!
241 - no longer rely on dst path in aio_copy when futime is available.
242
2433.19 Tue Apr 21 22:05:21 CEST 2009
244 - more perl 5.10 workarounds for aio_read and write.
245 - aio_write no longer modifies the sv (if possible).
246 - aio_read now works correctly with magic values.
247
2483.18 Sun Apr 19 21:17:32 CEST 2009
249 - better diagnostics when some aio_* functions get passed an illegal fh.
250 - try to avoid crashes due to incompatible 5.10 API changes. grmbl.
251
2523.17 Thu Nov 20 08:45:36 CET 2008
253 - (libeio) added aio_sync_file_range (untested).
254 - add aio_busy to @IO::AIO::AIO_REQ.
255
2563.16 Wed Oct 22 18:28:01 CEST 2008
257 - use SvREFCNT_inc instead of SvREFCNT_inc_NN in a non-speed critical
258 part to improve portability to perl 5.8 (reported by szymon).
259
2603.15 Mon Oct 13 00:39:55 CEST 2008
261 - automatic removal of feeders was broken.
262 - (libeio) use a more robust method to detect whether a feeder
263 has added something to the group or not.
264
2653.1 Thu Oct 2 13:34:40 CEST 2008
10 - pre-deref the passed callback object, for increased speed 266 - pre-deref the passed callback object, for increased speed
11 and decreased memory usage. 267 and decreased memory usage.
12 - call on_next_submit callback even for aio_group - impact unknown, 268 - call on_next_submit callback even for aio_group - impact unknown,
13 but seems more correct. 269 but seems more correct.
14 - $req->cb now returns the original callback. 270 - $req->cb now returns the original callback.

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines