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

Comparing liblzf/Changes (file contents):
Revision 1.17 by root, Tue Mar 14 01:24:37 2006 UTC vs.
Revision 1.57 by root, Fri Mar 30 20:58:09 2012 UTC

1
2TODO: try unaligned copy again in decompressor
3TODO: allow size-optimised binaries by avoiding unrolling
4TODO: implement lzf_c_best in lzf.
5TODO: fix lzf_c_best.
6
7 - switch to a multiplicative hash (developed with Steinar Gunderson),
8 which is faster on modern cpus and compresses a bit better. The old
9 hash function which uses only shifts is still available.
10 - allow user configurable hash table slots, which makes it possible
11 to use e.g. 16 bit offsets for a smaller hashtable (if your data is
12 always < 64kb).
13 - use _WIN32, not WIN32, when testing for windows (fails with bcc),
14 patch by Tamas Tevesz.
15 - try to port to win64+gcc, which is non-posix but doesn't have _int64
16 (reported by Maciej Adamczyk).
17
183.6 Mon Feb 7 17:37:31 CET 2011
19 - fixed hash calculation in C♯ version (Tiago Freitas Leal).
20 - unroll copy for small sizes, use memcpy for larger sizes,
21 greatly speeding up decompression in most cases.
22 - finally disable rep movsb - it's a big loss on modern intel cpus,
23 and only a small win on amd cpus.
24 - improve C++ compatibility of the code.
25 - slightly improve compressor speed.
26 - halved memory requirements for compressor on 64 bit architectures,
27 which can improve the speed quite a bit on older cpus.
28
293.5 Fri May 1 02:28:42 CEST 2009
30 - lzf_compress did sometimes write one octet past the given output
31 buffer (analyzed and nice testcase by Salvatore Sanfilippo).
32
333.4 Tue Sep 2 06:45:00 CEST 2008
34 - the fix from 3.3 introduced a compression bug, which is fixed in
35 this release (which explains the mysterious prerelease...). Thanks
36 once more to Clément Calmels.
37
383.3 Mon Aug 25 03:17:42 CEST 2008
39 - lzf_compress could access memory after the given input buffer
40 when outputting back references. reported with nice testcase
41 by Clément Calmels.
42
433.2 Fri May 9 18:52:23 CEST 2008
44 - include a workaround for failing POSIX and real-world compliance
45 on 64 bit windows (microsoft claims to support POSIX, but is far
46 from it). (bug found and analysed nicely by John Lilley).
47
483.1 Fri Nov 30 11:33:04 CET 2007
49 - IMPORTANT BUGFIX: a too long final literal run would corrupt data
50 in the encoder (this was introduced in 3.0 only, earlier versions
51 are safe).
52
533.0 Tue Nov 13 22:13:09 CET 2007
54 - switched to 2-clause bsd with "GPL v2 or any later version" option.
55 - speed up compression by ~10-15% in common cases
56 by some manual unrolling.
57 - import some compiler tricks from JSON::XS, for further speed-ups.
58 - tune hash functions depending on ULTRA_FAST or VERY_FAST settings.
59 - for typical binary data (e.g. /bin/bash, memory dumps,
60 canterbury corpus etc.), speed is now comparable to fastlz, but
61 with better compression ratio. with ULTRA_FAST, it's typically
62 3-15% faster than fastlz while still maintaining a similar ratio.
63 (amd64 and core 2 duo, ymmv). thanks a lot for the competition :)
64 - undo inline assembly in compressor, it is no longer helpful.
65 - no changes to the decompressor.
66 - use a HLOG of 16 by default now (formerly 15).
67
682.1 Fri Nov 2 13:34:42 CET 2007
69 - switched to a 2-clause bsd license with GPL exception.
70 - get rid of memcpy.
71 - tentatively use rep movsb on x86 and x86_64 (gcc only) for a
72 moderate speed improvement.
73 - applied patch by Kein-Hong Man to maske lzf.c compile under
74 the crippled mingw32 environment.
75
762.0 Fri Feb 16 23:11:18 CET 2007
77 - replaced lzf demo by industrial-strength lzf utility with behaviour
78 similar other compression utilities. Thanks for Stefan Traby for
79 rewriting it!
80 - fix state arg prototype.
81
821.7 Wed Sep 27 17:29:15 CEST 2006
83 - remove bogus "unlzf" patch.
84 note to self: never accept well-meant patches.
85 - make lzf more robust in presence of padding bytes or sudden eof.
86
871.6 Fri Jul 7 17:31:26 CEST 2006
88 - the lzf example utility will now uncompress if invoked
89 as "unlzf" (patch by Scott Feeney).
90 - add CHECK_INPUT option that adds more checks for input
91 data validity.
92 - help applications that do not pass in the correct length
93 (such as php) by returning either EINVAL or E2BIG.
94 - default HLOG size is now 15 (cpu caches have increased).
95 - documentation fixes.
96
11.51 Thu Apr 14 22:15:46 CEST 2005 971.51 Thu Apr 14 22:15:46 CEST 2005
2 - incorporated C♯ implementation of both the en- and decoder, 98 - incorporated C♯ implementation of both the en- and decoder,
3 written by "Oren J. Maurice <oymaurice@hazorea.org.il>". 99 written by "Oren J. Maurice".
4 You can find it in the cs/ subdirectory. 100 You can find it in the cs/ subdirectory.
5 - make FRST, NEXT IDX overridable if lzf_c.c is directly included 101 - make FRST, NEXT IDX overridable if lzf_c.c is directly included
6 in the code. 102 in the code.
7 103
81.5 Tue Mar 8 20:23:23 CET 2005 1041.5 Tue Mar 8 20:23:23 CET 2005

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines