Commit Graph

96 Commits

Author SHA1 Message Date
147d762ebc
Implemented modified and somewhat faster initialization code.
As this unavoidably breaks compatibility with pre-1.3.x versions, added a new flag to 'slunkparam_t' that enables backwards compatibility mode.
Also extended the self-test code to test the new initialization, in addition to the "legacy" initialization.
2022-10-13 02:26:51 +02:00
d988fd0a56
Added flag to indicate multi-thread support to the public API. 2022-09-23 22:21:01 +02:00
cc4b9c8af3
Enable the "-pedantic" option for GCC + fixed a few warnings. 2022-09-20 21:53:57 +02:00
0c91cac7e4
Clean up includes in "front-end" application. 2022-09-20 21:52:23 +02:00
5e7b6ebb09
Updated Linux build script to better match the officially supported Debian platforms. 2022-06-18 22:30:45 +02:00
f6cd289725
Support for MIPS architecture + small improvement to Linux cross-build script. 2022-05-21 17:32:18 +02:00
3901bd6a1d
Small fix to make error messages in encrypt() and decrypt() more consistent. 2022-05-10 20:36:07 +02:00
69e549aafd
Added support for the Haiku operating system. 2022-04-26 22:03:08 +02:00
afdce47caa
Small code clean-up + improved the Makefile + detect GNU/Hurd operating system. 2022-04-23 20:25:58 +02:00
2cee77b108
Adjust I/O buffer size according to file size + allow slightly bigger maximum buffer size. 2022-04-17 00:43:21 +02:00
50955210ac
Small improvement to platform detection. 2022-04-08 23:10:27 +02:00
70e9d2d3b5
Fixed slunkcrypt_reset() when no thread pool is allocated, e.g. when thread count is 1. 2022-04-07 00:15:07 +02:00
7359ce3673
Enhanced self-test routine + added macro to "safely" free SlunkCrypt instance. 2022-04-02 17:27:48 +02:00
69df385d57
Detect the number of available CPU cores by using either sched_getaffinity(), GetProcessAffinityMask() or sysconf(), depending on the target platform. 2022-04-01 20:33:46 +02:00
fdc1c8b0d8
Refactored progress indicator update + increase file I/O buffer size. 2022-03-29 22:58:47 +02:00
f70ccb6a14
Some code refactoring in the thread pool module. 2022-03-24 21:59:43 +01:00
d0be7ad5a5
Make it possible to set number of threads in the front-end + updated the README file. 2022-03-24 00:06:01 +01:00
c32c85d8c9
Much improved threading support. 2022-03-22 23:01:19 +01:00
c607046831
Implemented improved method for detecting identical files. 2022-03-04 20:56:20 +01:00
ca16052112
Some code refactoring. 2022-03-01 23:34:50 +01:00
b95e578e33
Print the system error message, if the input or output file could not be opened. 2022-02-27 19:38:10 +01:00
65c17e6759
Make sure that input file name and output file name are distinct (to the extent possible). 2022-02-25 00:12:52 +01:00
65f08d43a5
Replaced clock() function by clock_gettime() on Linux and QueryPerformanceFrequency() on Windows. 2022-02-11 21:52:22 +01:00
b39b7cafaa
Small improvement to the password generator. 2022-02-08 22:53:02 +01:00
1c587be39b
Gracefully handle an *empty* argument array (argc < 1), which apparently is possible on Linux and maybe others. 2022-01-27 00:21:28 +01:00
61fa41c888
GUI: Added button to generate a random password to the "Encrypt" tab. 2021-05-08 19:53:15 +02:00
502e92ee09
Added a simple GUI front-end for Windows platform. 2021-05-04 21:35:30 +02:00
7f643ad566
Do not request more than 256 bytes of random data from getentropy() at once. 2021-04-21 16:02:25 +02:00
b7e32f5f0a
Refactored passphrase generator into a separate file. 2021-04-18 22:19:17 +02:00
46dc28f3ca
Refactored encryption/decryption routines as well as the self-test routine into separate files. 2021-04-18 15:32:37 +02:00
102233a237
Fold the hash at the very end of the keygen loop (effectively), instead of already in the hash function. 2021-04-15 22:51:35 +02:00
ff48e473a9
Print a warning when ignoring excess command-line arguments. 2021-04-11 20:55:39 +02:00
a9e1974149
Improved test cases to also verify the checksum of the ciphertext. 2021-04-10 16:37:09 +02:00
3cdfc9d9ab
Small tweak to self-test routine. 2021-04-08 02:38:01 +02:00
0e75e05fda
Small code simplification in open_files() function. 2021-04-07 02:28:26 +02:00
4ce6e5b828
Remove an incomplete (or corrupted) output file by default. 2021-04-03 19:26:15 +02:00
06f57ca483
Clean up function names. 2021-04-02 16:37:19 +02:00
471e08737b
Replaced separate encrypt() and decrypt() functions with a single process() function + added 'mode' parameter to alloc() and reset() functions. 2021-04-01 01:58:39 +02:00
163dee5e9d
Only check current clock() on every 32-th cycle, in order to limit the overhead. 2021-03-28 16:17:06 +02:00
73f2e71342
Revamped the stepping algorithm. 2021-03-27 22:41:31 +01:00
bdab06cd80
Don't require environment variable to start with "pass:" prefix + some code clean-up. 2021-03-26 01:48:30 +01:00
7fb9a517fe
Silenced some compiler warnings, found by Clang. 2021-03-24 20:23:14 +01:00
ded1220a13
Improved command-line syntax for passing the passphrase + Updated README file. 2021-03-22 22:52:00 +01:00
0b7777fc3e
More thorough cleaning of encryption/decryption state and buffers. 2021-03-21 16:46:22 +01:00
d8f446832b
Replaced some more byte-order-specific code with a byte-order-agnostic implementation. 2021-03-20 21:19:13 +01:00
2e74accf36
Don't set 'stdout' to _O_BINARY mode on Windows, because it can have some weird effect when printing text to the terminal. Also, we currently don't output any "binary" data to 'stdout' anyway. 2021-03-20 21:19:10 +01:00
21cab67912
Small fix to BLAKE2s initialization code. 2021-03-20 21:19:09 +01:00
fe1398fdcb
Implemented checksum based on BLAKE2s hash function. 2021-03-20 21:19:07 +01:00
b998dc5947
Obfuscate nonce in output file, by XOR'ing with the first digits of PI. 2021-03-20 21:19:01 +01:00
f250143f8b
Slightly improved cleansing of the command-line on Win32. 2021-03-20 21:18:59 +01:00