Frank Denis
4a15ab7cd0
fe25519_{abs,cneg} require a single argument
...
They were always used with the same input and output pointers,
so their definition can be simplified.
Fixes #1376
2024-05-30 16:06:56 +02:00
Frank Denis
704e97fdf5
Proper zeroization in hkdf
...
Fixes #1375
2024-05-30 15:56:54 +02:00
Iñigo Querejeta Azurmendi
7978205916
RFC9381 ECVRF implementation ( #1188 )
...
* Version 12 of ECVRF
* Incorrect ordering of function inputs
* Identation and notation
* single multiscalar multiplication function
Also changed the style of tests, where the expected output is in vrf.exp rather than in test data (following the style of the hashing).
* declarations inside the if code block
* identation of test_data
* Rename to RFC9381
* Move declarations to top of block
* Check small order over deserialised PK
* Include from_string functions in ed25519_ref10
* Update quirks.h
---------
Co-authored-by: Frank Denis <124872+jedisct1@users.noreply.github.com>
2024-05-25 18:55:14 +02:00
Frank Denis
a67325c42c
AEGIS: improve performance of AD absorption on x86_64
...
No apparent regression on other platforms.
Adapted from libaegis.
2024-05-25 00:41:08 +02:00
Frank Denis
4ad956470f
Explicitly enabling evex512 is now required with LLVM 18
2024-05-09 22:27:45 +02:00
Frank Denis
da0ce565d2
Use clang pragmas to enable features rather than depend on compiler settings
2024-04-27 23:05:38 +02:00
Frank Denis
edb94a99a6
Remove redundant definition
2024-04-26 13:50:40 +02:00
Andrzej Fiedukowicz
b564794edd
Move includes in crypto_onetimeauth_poly1305.h outside of extern C ( #1345 )
...
Includes being outside of `extern "C"` are de-facto standard in all other include files of libsodium.
At the same time, having inside the `extern "C"` is causing problem with C++ vs. C toolchain being confused about which libraries should be linked. This was especially painful while working on `swift-sodium` integration with windows.
2024-01-17 15:06:11 +01:00
Frank Denis
4c56848dcc
When using MSVC on aarch64, __ARM_ARCH is not defined
...
Reported by RADDI.net -- Thanks!
2024-01-07 16:14:21 +01:00
Frank Denis
44b99c5a23
Add forgotten crypto_kdf_hkdf_sha512_statebytes()
2023-11-29 22:02:37 +01:00
Frank Denis
39184b5b96
Include argon2id in crypto_pwhash_primitive()
...
Fixes #1331
2023-11-10 12:12:02 +01:00
Frank Denis
b5eaa810c8
Revert "Include argon2id in crypto_pwhash_primitive()"
...
This reverts commit a2b12dfcc0
.
2023-11-10 12:10:10 +01:00
Frank Denis
a2b12dfcc0
Include argon2id in crypto_pwhash_primitive()
...
Fixes #1331
2023-11-10 11:30:47 +01:00
Frank Denis
6ee5a73452
Add a comment where coordinates are expected to be normalized
2023-11-08 07:37:12 +01:00
Frank Denis
51126865d0
_M_AMD64 is the same as _M_X64
2023-11-02 06:40:17 +01:00
Frank Denis
1d03ea77fb
Make aegis_mac() fallible
...
So that we can include additional checks, especially for weak states.
Ideally, weak states should be checked after every update, but they
would be especially bad when the cipher is used as a stream cipher.
And in that case, checking for a weak state only at the end is
sufficient.
2023-11-01 19:12:15 +01:00
Frank Denis
8f453f41f8
aarch64: set compiler attributes *after* including <arm_neon.h>
...
Fixes #1321
2023-10-20 13:47:57 +02:00
Ørjan Malde
0bbfe33ba9
midipix support ( #1315 )
2023-09-14 18:00:27 +02:00
Frank Denis
f26b9f72eb
Use ANDROID_CPU_ARM64_FEATURE_AES for AES detection on Android/aarch64
2023-09-13 08:59:14 +02:00
Frank Denis
45aa3adb96
Handle SIGPROT, CHERI's in-address space security exception
2023-09-12 21:02:18 +02:00
Frank Denis
38ada39711
Forgotten attribute pop
2023-09-12 16:02:49 +02:00
Frank Denis
8b1f568cb1
aarch64: try harder when checking for the crypto extensions
2023-09-12 15:57:03 +02:00
Frank Denis
1074191f87
Don't hardcode type sizes
2023-09-12 12:51:53 +02:00
Frank Denis
605382399b
Promote HKDF to minimal builds
2023-09-11 19:31:38 +02:00
Frank Denis
1ef7b43ae9
Switch AEGIS to 256-bit tags by default
2023-09-11 18:02:24 +02:00
Frank Denis
b7ac85b5b7
Don't hardcode the AEGIS tag length
2023-09-11 17:38:29 +02:00
Frank Denis
9db77385d0
Visual Studio: define __ARM_NEON on Windows/ARM
2023-09-11 00:58:53 +02:00
Frank Denis
08070591be
Define additional capabilities when using Visual Studio
2023-09-11 00:52:12 +02:00
Frank Denis
3567436865
Replace the aegis256 implementation with the libaegis implementation
2023-09-09 20:20:54 +02:00
Frank Denis
e494ce3e69
Move sodium implementations out of their dedicated directory
2023-09-09 17:24:49 +02:00
Frank Denis
3acf050566
Replace aegis128l implementation with libaegis' implementation
2023-09-09 17:24:46 +02:00
Frank Denis
94c650ae80
Proper casts for C++
2023-09-08 23:35:24 +02:00
Frank Denis
c3692bbe0f
Revert "C++ compat"
...
This reverts commit 48a679650e
.
2023-09-08 23:31:27 +02:00
Frank Denis
4776f392ab
Simplify how non-deterministic ed25519 nonces are computed
2023-09-08 23:30:25 +02:00
Frank Denis
48a679650e
C++ compat
2023-09-08 20:59:33 +02:00
Scr3amer
18fad78494
Add missing undef in _mm_roti_epi64 definition for blake2b-ssse3 ( #1306 )
2023-09-02 22:16:15 +02:00
Frank Denis
503a1ef2c3
Simplify _mm_roti_epi64 definition
2023-09-02 15:23:53 +02:00
Scr3amer
4ebe29b2e3
Do not redefine _mm_roti_epi64 if xop target feature is enabled. ( #1305 )
...
Undefine compiler macro if present and XOP not enable to avoid preprocessor warnings due to macro redefinition
2023-09-02 15:22:20 +02:00
Frank Denis
8ad54cb636
Fallback to _Thread_local on C11 regardless of the platform
2023-09-01 23:43:21 +02:00
Scr3amer
a04c8687ac
Define TLS as _Thread_local is compiler supports C11 ( #1304 )
...
This avoids having warnings when compiling with Clang-MinGW on windows.
2023-09-01 23:37:36 +02:00
Frank Denis
baa75cd1b8
Indent
2023-09-01 16:32:45 +02:00
Frank Denis
0ea62015f2
scrypt_nosse: Remove the 64-bit version of blkxor()
...
It broke strict aliasing.
Also remove ARCH_BITS that is not required any longer.
Fixes #1301
2023-08-31 23:23:30 +02:00
Frank Denis
b828df51dd
scrypt_integerify_sse: be consistent with the no_sse version
2023-08-31 23:18:09 +02:00
Frank Denis
30212c0952
scrypt_nosse: no need to use void * in integerify()
2023-08-31 23:08:56 +02:00
Frank Denis
a3f200abe6
Manually define __ARM_FEATURE_AES (necessary for CheriOS)
2023-08-23 22:18:11 +02:00
Frank Denis
4dc02ce841
Assume all CPUs supported by ARM Windows have the crypto extensions
...
RADDI.net said:
"All supported AArch64 CPUs on desktop Windows 10 and 11 have
both AES (crypto) and NEON, no feature testing needed."
2023-08-05 23:15:33 +02:00
Frank Denis
e698b1b000
Check _M_ARM64 in addition to __aarch64__
2023-08-05 23:04:35 +02:00
Frank Denis
02368730f0
Compile libaesni with CFLAGS_AVX
2023-08-05 09:40:02 +02:00
Frank Denis
6668dc8008
Require/enable AVX for AES-based ciphers
2023-08-05 09:33:04 +02:00
Frank Denis
50c2f39b38
Move lut to the data section
2023-07-30 01:02:54 +02:00