92 Commits

Author SHA1 Message Date
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
a4aec9f3fe
Updated pthreads library for the Windows platform (pthreads4w). 2022-03-24 00:06:01 +01:00
c32c85d8c9
Much improved threading support. 2022-03-22 23:01:19 +01:00
ddefc8c142
Initial thread support. 2022-03-21 21:11:46 +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
9e29561707
Refactored project/solution files. 2021-11-10 19:38:35 +01:00
17d807bbb3
Added runtime CPU detection for SSE2 capability to the GUI front-end. 2021-11-09 23:23:43 +01:00
0e65355d2f
Workaround for bug in older version of the UCRT on Windows XP: Explicitly link UCRT version 10.0.14393.0 and force the minimum required OS version to 5.1. 2021-05-10 21:21:47 +02: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
772c88a387
Workaround for Intel® oneAPI DPC++/C++ Compiler detection. 2021-04-11 18:26:44 +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
13e9420ca1
Added MSVC configurations "Release with SSE2" and "Release with debug information". 2021-04-04 20:22:46 +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
334d828c5b
Slightly improved storage of the padding size. 2021-03-20 21:18:59 +01:00
86af5fa51f
Added new option to generate a random passphrase. 2021-03-20 21:18:58 +01:00
fb4f429493
Ignore excess bytes, if length of input file is *not* an integer multiple of 8. 2021-03-20 21:18:57 +01:00
c530556e94
Implemented a simple padding scheme. 2021-03-20 21:18:56 +01:00
9d5a103201
Fixed a few warnings on Linux. 2021-03-20 21:18:52 +01:00