1
0
mirror of https://github.com/trezor/trezor-firmware.git synced 2024-11-22 23:48:12 +00:00
trezor-firmware/crypto
Christian Reitter 525bbab165 tests(crypto): update wycheproof testcase source and parsing
The JSON schema of the test cases has slightly changed.
The "curve" field has moved to the "testGroups" level and the X25519 algorithm has been renamed,
which requires adjustments in the parsing code.

A duplicate definition of "ecdh_vectors" has also been removed.
2022-01-07 16:55:24 +01:00
..
aes fix(crypto): fix build on clang/arm64 2020-12-17 00:09:47 +01:00
chacha20poly1305 feat(core): make chacha_drbg more robust 2021-05-21 13:42:53 +02:00
ed25519-donna fix(crypto): Clean up stack in ed25519.c. 2021-11-01 16:39:53 +01:00
fuzzer crypto: new iteration of fuzz testing code, improved dictionary script, minor documentation changes 2021-08-05 17:03:04 +02:00
gui
monero fix(crypto): clarify incorrect base58.c code comment 2021-12-01 18:09:52 +01:00
tests tests(crypto): update wycheproof testcase source and parsing 2022-01-07 16:55:24 +01:00
tools fix(crypto): fix wrong input handling in mktable 2021-11-19 23:10:34 +01:00
.gitignore
.gitmodules
.gitrepo
address.c feat(core,legacy): add support for Ethereum 64-bit chain_id 2021-09-10 15:09:03 +02:00
address.h feat(core,legacy): add support for Ethereum 64-bit chain_id 2021-09-10 15:09:03 +02:00
AUTHORS
base32.c
base32.h
base58.c
base58.h
bignum.c fix(crypto): revert to bitwise OR operator and silence warning 2021-12-09 14:31:52 +01:00
bignum.h style(crypto): cleanup unused functions 2021-03-09 13:21:34 +01:00
bip32.c feat(crypto/cardano): implement Cardano Ledger derivation 2021-11-10 13:57:57 +01:00
bip32.h refactor(crypto): extract Cardano derivations to separate file 2021-11-10 13:57:57 +01:00
bip39_english.h
bip39.c feat(crypto): support all bip39 lengths in mnemonic_to_bits 2021-11-10 13:57:57 +01:00
bip39.h Refactor mnemonic_to_entropy to not (misleadingly) return checksum 2020-12-19 20:17:16 +01:00
blake2_common.h feat(crypto): add big endian support 2021-11-04 20:38:52 +01:00
blake2b.c
blake2b.h
blake2s.c
blake2s.h
blake256.c fix(crypto): Fix incorrect handling of empty input in blake256_Update(). 2021-06-11 20:22:42 +02:00
blake256.h
byte_order.h feat(crypto): add big endian support 2021-11-04 20:38:52 +01:00
cardano.c feat(crypto/cardano): implement Cardano Ledger derivation 2021-11-10 13:57:57 +01:00
cardano.h refactor(crypto): extract Cardano derivations to separate file 2021-11-10 13:57:57 +01:00
cash_addr.c
cash_addr.h
chacha_drbg.c feat(core): make chacha_drbg more robust 2021-05-21 13:42:53 +02:00
chacha_drbg.h feat(core): make chacha_drbg more robust 2021-05-21 13:42:53 +02:00
check_mem.h
CONTRIBUTORS
curves.c feat(crypto/cardano): implement Cardano Ledger derivation 2021-11-10 13:57:57 +01:00
curves.h feat(crypto/cardano): implement Cardano Ledger derivation 2021-11-10 13:57:57 +01:00
ecdsa.c fix(crypto): Treat point at infinity as an invalid public key in ecdsa_recover_pub_from_sig(). 2022-01-07 14:37:40 +01:00
ecdsa.h refactor(core,crypto): make public key derivation functions return 2021-10-25 14:41:28 +02:00
groestl_internal.h fix(crypto): fix build on clang/arm64 2020-12-17 00:09:47 +01:00
groestl.c
groestl.h ci: enable editorconfig checks, fix whitespace issues 2020-11-11 14:43:50 +01:00
hasher.c feat(crypto): Add TapSigHash to Hasher. 2021-11-18 22:39:32 +01:00
hasher.h feat(crypto): Add TapSigHash to Hasher. 2021-11-18 22:39:32 +01:00
hmac_drbg.c
hmac_drbg.h
hmac.c
hmac.h
LICENSE
Makefile build(crypto): make valgrind flag compatible with secp256k1-zkp (#2027) 2021-12-20 15:19:14 +01:00
memzero.c fix(crypto): update case of windows.h (#1560) 2021-04-08 14:16:23 +02:00
memzero.h
nem.c
nem.h
nist256p1.c
nist256p1.h
nist256p1.table
options.h
pbkdf2.c
pbkdf2.h
rand.c
rand.h
rc4.c
rc4.h
README.md Add support for Schnorr crypto (BCH variant) 2021-03-09 14:22:56 +01:00
rfc6979.c
rfc6979.h
ripemd160.c
ripemd160.h
schnorr.c fix(crypto,core,legacy): Check private key validity when deriving public key. 2021-11-01 16:39:53 +01:00
schnorr.h Add support for Schnorr crypto (BCH variant) 2021-03-09 14:22:56 +01:00
script.c
script.h
secp256k1.c
secp256k1.h
secp256k1.table
segwit_addr.c feat(crypto): update segwit_addr to support Bech32m 2021-10-18 13:36:05 +02:00
segwit_addr.h feat(crypto): update segwit_addr to support Bech32m 2021-10-18 13:36:05 +02:00
setup.py
sha2.c feat(crypto): Add key tweaking functions to zkp_bip340.c. 2021-11-13 13:33:46 +01:00
sha2.h feat(crypto): Add key tweaking functions to zkp_bip340.c. 2021-11-13 13:33:46 +01:00
sha3.c fix(crypto): fix undefined behaviour of IS_ALIGNED_64 macro 2021-11-08 17:38:51 +01:00
sha3.h
shamir.c
shamir.h
slip39_wordlist.h chore(crypto): Rework SLIP-39 word lookup. 2020-12-15 13:41:42 +01:00
slip39.c chore(crypto): Rework SLIP-39 word lookup. 2020-12-15 13:41:42 +01:00
slip39.h fix(crypto): Improve naming and robustness of SLIP39's T9 mask lookup. 2020-12-15 13:41:42 +01:00
zkp_bip340.c refactor(crypto): make secp256k1_context_writable_randomize() return status 2021-11-18 19:05:40 +01:00
zkp_bip340.h feat(crypto): Add key tweaking functions to zkp_bip340.c. 2021-11-13 13:33:46 +01:00
zkp_context.c fix(crypto): assign NULL to zkp_context after is is destroyed 2021-11-29 14:16:42 +01:00
zkp_context.h refactor(crypto): expose zkp_context_is_initialized 2021-11-29 14:16:42 +01:00
zkp_ecdsa.c refactor(crypto): make secp256k1_context_writable_randomize() return status 2021-11-18 19:05:40 +01:00
zkp_ecdsa.h refactor(core,crypto): make public key derivation functions return 2021-10-25 14:41:28 +02:00

trezor-crypto

Build Status gitter

Heavily optimized cryptography algorithms for embedded devices.

These include:

  • AES/Rijndael encryption/decryption
  • Big Number (256 bit) Arithmetics
  • BIP32 Hierarchical Deterministic Wallets
  • BIP39 Mnemonic code
  • ECDSA signing/verifying (supports secp256k1 and nist256p1 curves, uses RFC6979 for deterministic signatures)
  • ECDSA public key derivation
  • Schnorr (BCH variant) signing/verifying
  • Base32 (RFC4648 and custom alphabets)
  • Base58 address representation
  • Ed25519 signing/verifying (also SHA3 and Keccak variants)
  • ECDH using secp256k1, nist256p1 and Curve25519
  • HMAC-SHA256 and HMAC-SHA512
  • PBKDF2
  • RIPEMD-160
  • SHA1
  • SHA2-256/SHA2-512
  • SHA3/Keccak
  • BLAKE2s/BLAKE2b
  • Chacha20-Poly1305
  • unit tests (using Check - check.sf.net; in test_check.c)
  • tests against OpenSSL (in test_openssl.c)
  • integrated Wycheproof tests

Distibuted under MIT License.

Some parts of the library come from external sources: