discomfitor
3316dd5505
remove trailing whitespace
2011-08-17 20:59:41 +10:00
discomfitor
63141a1035
add some gross bucketing to implement a queue for freeing stream_info structs after an operation has completed (in library mode ONLY; no changes will occur during regular execution) to fix some leaks
2011-08-17 20:59:41 +10:00
discomfitor
949c6d7a97
another semi-clusterfuck commit: *new logging macros *allow compression to and from any FILE, not just stdin/stdout *update main.c to work with the above
2011-08-17 20:59:41 +10:00
discomfitor
6dd20d735b
giant clusterfuck commit: *add and use alloca/strdupa in some spots *implement return values on almost every function *free() is now a macro which also nulls the freed pointer *when in 'library mode', fatal_exit() will not be called *fatal()/failure() are now macros which add line number and file for logging *all occurrences of fatal/failure in files other than main.c are now wrapped to use a logging callback (if specified) and then return *functions now clean up resources on returning with an error
2011-08-17 20:59:40 +10:00
discomfitor
cbff8faef7
move liblrzip.h contents to lrzip_private.h global variables-----
2011-08-17 20:59:40 +10:00
discomfitor
1c64dcfb31
more initialization stuff out of main(), remove weird coincidentally successful one_g variable
2011-08-17 20:59:40 +10:00
Con Kolivas
1ea75154d6
Silence compiler warnings.
2011-05-08 00:05:46 +10:00
Con Kolivas
55dc9b0095
Fix the arbitrary lower limit of 128 bytes by compressing zeroes beyond the size of the chunk.
...
Put special case management of zero sized files.
Modify the percentage calculation to be able to cope with small numbers and zeroes.
2011-05-07 18:37:25 +10:00
Con Kolivas
7ed977b1c1
Detach threads from the compression side since we don't explicitly join them as they may count towards max thread count otherwise.
2011-04-23 08:15:44 +10:00
ckolivas
6ddd2e8e7e
Correct fix to ensure 64 bit lseek is used on apple in stream.c
2011-04-18 23:13:11 +10:00
Con Kolivas
373cfa25e4
limit must still be clamped to chunk_limit at most.
2011-03-23 08:44:52 +11:00
Con Kolivas
915edb78a2
Remove unused variables and functions.
2011-03-23 08:16:07 +11:00
Con Kolivas
b27e1df879
Revert "Modify the file format to not include rzip chunk size except for STDOUT chunked files thus decreasing the file format size further."
...
This reverts commit 131d4c92c2 .
Breaks STDIN/OUT so revert this change and cope with the slightly extra file size on non-chunked files.
2011-03-23 07:59:04 +11:00
Con Kolivas
8fcedbc43e
Fix big endian decompression from lzma.
2011-03-23 07:42:45 +11:00
Con Kolivas
f7a1c14e28
Put warning about possibly wrong password at appropriate place in stream.c
...
Use char to be consistent in open_stream_in.
Fail to failure() instead of fatal() should open_stream_in fail.
2011-03-23 01:13:15 +11:00
Con Kolivas
70e7866271
Include arpa/inet.h for those OSs that have endian details elsewhere.
2011-03-22 21:47:24 +11:00
ckolivas
eebba614bc
Don't adjust endianness in read_val.
2011-03-22 17:00:37 +11:00
ckolivas
36cc464d2b
Yet more 32 bit clamping.
2011-03-22 14:44:56 +11:00
ckolivas
f56e48c4f2
Modify maxram to mean the most we'll allocate in one chunk and add usable_ram for the most we'll allocate to one task.
...
Limit all maxram on 32bits to 1GB since most don't like mallocing more than this.
Update testing to allow larger total amount based on usable ram while sticking to maxram limit per alloc.
2011-03-22 12:10:21 +11:00
Con Kolivas
131d4c92c2
Modify the file format to not include rzip chunk size except for STDOUT chunked files thus decreasing the file format size further.
2011-03-22 09:04:24 +11:00
Con Kolivas
2736118f82
Check for different endian.h includes and variants of le32toh.
2011-03-22 07:57:32 +11:00
Con Kolivas
a30efcaa55
Portable generic byteswap for BE.
2011-03-22 00:13:29 +11:00
Con Kolivas
25a018fd9d
Update Authors to include Serge Belyshev.
2011-03-21 21:02:05 +11:00
Con Kolivas
95f8b9fd90
Forgot return value.
2011-03-21 20:52:11 +11:00
Con Kolivas
135067a0b4
Yet more #6 BE fixes.
2011-03-21 20:33:43 +11:00
Con Kolivas
279b745cd7
Yet #5 more BE fixes.
2011-03-21 20:31:33 +11:00
Con Kolivas
637b0d5f7c
yet yet yet yet more BE fixes.
2011-03-21 20:29:24 +11:00
Con Kolivas
04d3d6a1f5
Read BE fixes.
2011-03-21 20:23:36 +11:00
Con Kolivas
06a76bc4aa
Revert "More big endian fixes."
...
This reverts commit edbcc797e0 .
Broke regression text. Needs more attention.
2011-03-21 19:01:24 +11:00
Con Kolivas
edbcc797e0
More big endian fixes.
2011-03-21 12:41:36 +11:00
Con Kolivas
280254b8cb
Forgot to remove the initial pos offset.
2011-03-21 12:34:57 +11:00
Con Kolivas
fd9bbfe64a
One last check on limit.
2011-03-21 07:33:35 +11:00
Con Kolivas
f87528d14d
Forgot to include salt length for next head.
2011-03-20 17:01:33 +11:00
Con Kolivas
30b70dc884
Fixes for non little endian machines.
2011-03-20 16:16:38 +11:00
Con Kolivas
0dad7dcc5a
Modify the encrypted version to not write down the rzip chunk size, then keep track of where each block header is written, go back and write 8 bytes of salt before it and encrypt the headers in place.
2011-03-20 15:45:44 +11:00
Con Kolivas
e7d33e82d0
Make read_1g able to read from the tmp outbuf if we decide to read from fd_out.
2011-03-19 14:46:06 +11:00
Con Kolivas
ff5a5ed054
Use separate lrz_encrypt and lrz_decrypt wrappers to lrz_crypt.
2011-03-19 14:04:22 +11:00
Con Kolivas
63fb1bafea
Modify the file format further to make all block header information only encode the number of bytes determined in chunk_bytes instead of 8 full bytes all the time.
2011-03-18 23:18:36 +11:00
ckolivas
b8d8ecfe33
Fix warnings.
...
Patch ~ by Serge Belyshev.
2011-03-18 10:37:09 +11:00
ckolivas
e856d481bf
Discard hash_iv entirely, using passphrase hash and centralise key generation.
...
Patch by Serge Belyshev.
2011-03-18 10:22:58 +11:00
Con Kolivas
a3e80871c2
Add 8 bytes of random data to the start of every encrypted compressed block and use it along with 8 bytes from the stored salt to make a unique key and IV for encryption.
2011-03-18 00:06:11 +11:00
ckolivas
e78069c0d7
Consolidate magic writing to be able to seek to read and encrypt block header data later.
2011-03-17 16:59:27 +11:00
ckolivas
4bc23ee001
Centralise where all encryption/decryption is done, and whether to carry over the IV or not.
2011-03-17 14:10:58 +11:00
ckolivas
660243b8dc
Pad out first block if less than CBC_LEN and encrypting or else encryption will fail.
2011-03-17 11:19:34 +11:00
Con Kolivas
76280ffec5
Mlock ivec for it will hold the injection vector.
2011-03-17 00:25:15 +11:00
Con Kolivas
a7468ce6e4
Fail if block to encrypt ends up being less than one full block for now, and tidy up code.
2011-03-16 23:13:09 +11:00
Con Kolivas
c41cfe9e83
Some decompression code needs more room so simply allocate u_len for s_buf.
2011-03-16 21:48:21 +11:00
Con Kolivas
5fd7c82e1f
Implement ciphertext stealing to not have to pad compressed blocks courtesy of Serge Belyshev who saved me hours of debugging thanks!
2011-03-16 21:24:05 +11:00
Con Kolivas
928a0a098a
Consolidate padded length throughout.
2011-03-16 10:29:16 +11:00
Con Kolivas
bedea4dbec
Consolidate cbc padding into a macro.
2011-03-16 10:17:48 +11:00