mirror of
https://github.com/bitcoin/bitcoin.git
synced 2026-03-30 18:35:54 +02:00
4187a46649 Merge bitcoin-core/secp256k1#1492: tests: Add Wycheproof ECDH vectors e266ba11ae tests: Add Wycheproof ECDH vectors 13906b7154 Merge bitcoin-core/secp256k1#1669: gitignore: Add Python cache files c1bcb03276 gitignore: Add Python cache files 70f149b9a1 Merge bitcoin-core/secp256k1#1662: bench: add ellswift to bench help output 6b3fe51fb6 bench: add ellswift to bench help output d84bb83e26 Merge bitcoin-core/secp256k1#1661: configure: Show exhaustive tests in summary 3f54ed8c1b Merge bitcoin-core/secp256k1#1659: include: remove WARN_UNUSED_RESULT for functions always returning 1 20b05c9d3f configure: Show exhaustive tests in summary e56716a3bc Merge bitcoin-core/secp256k1#1660: ci: Fix exiting from ci.sh on error d87c3bc58f ci: Fix exiting from ci.sh on error 1b6e081538 include: remove WARN_UNUSED_RESULT for functions always returning 1 2abb35b034 Merge bitcoin-core/secp256k1#1657: tests: remove unused uncounting_illegal_callback_fn 51907fa918 tests: remove unused uncounting_illegal_callback_fn a7a5117144 Merge bitcoin-core/secp256k1#1359: Fix symbol visibility issues, add test for it 13ed6f65dc Merge bitcoin-core/secp256k1#1593: Remove deprecated `_ec_privkey_{negate,tweak_add,tweak_mul}` aliases from API d1478763a5 build: Drop no longer needed `-fvisibility=hidden` compiler option 8ed1d83d92 ci: Run `tools/symbol-check.py` 41d32ab2de test: Add `tools/symbol-check.py` 88548058b3 Introduce `SECP256K1_LOCAL_VAR` macro 03bbe8c615 Merge bitcoin-core/secp256k1#1655: gha: Print all *.log files, in a separate action 59860bcc24 gha: Print all *.log files, in a separate action 4ba1ba2af9 Merge bitcoin-core/secp256k1#1647: cmake: Adjust diagnostic flags for `clang-cl` abd25054a1 Merge bitcoin-core/secp256k1#1656: musig: Fix clearing of pubnonces 961ec25a83 musig: Fix clearing of pubnonces 3186082387 Merge bitcoin-core/secp256k1#1614: Add _ge_set_all_gej and use it in musig for own public nonces 6c2a39dafb Merge bitcoin-core/secp256k1#1639: Make static context const 37d2c60bec Remove deprecated _ec_privkey_{negate,tweak_add,tweak_mul} aliases 432ac57705 Make static context const 1b1fc09341 Merge bitcoin-core/secp256k1#1642: Verify `compressed` argument in `secp256k1_eckey_pubkey_serialize` c0d9480fbb Merge bitcoin-core/secp256k1#1654: use `EXIT_` constants over magic numbers for indicating program execution status 13d389629a CONTRIBUTING: mention that `EXIT_` codes should be used c855581728 test, bench, precompute_ecmult: use `EXIT_...` constants for `main` return values 965393fcea examples: use `EXIT_...` constants for `main` return values 2e3bf13653 Merge bitcoin-core/secp256k1#1646: README: add instructions for verifying GPG signatures b682dbcf84 README: add instructions for verifying GPG signatures 00774d0723 Merge bitcoin-core/secp256k1#1650: schnorrsig: clear out masked secret key in BIP-340 nonce function a82287fb85 schnorrsig: clear out masked secret key in BIP-340 nonce function 4c50d73dd9 ci: Add new "Windows (clang-cl)" job 84c0bd1f72 cmake: Adjust diagnostic flags for clang-cl f79f46c703 Merge bitcoin-core/secp256k1#1641: doc: Improve cmake instructions in README 2ac9f558c4 doc: Improve cmake instructions in README 1823594761 Verify `compressed` argument in `secp256k1_eckey_pubkey_serialize` 8deef00b33 Merge bitcoin-core/secp256k1#1634: Fix some misspellings 39705450eb Fix some misspellings ec329c2501 Merge bitcoin-core/secp256k1#1633: release cleanup: bump version after 0.6.0 c97059f594 release cleanup: bump version after 0.6.0 64228a648f musig: Use _ge_set_all_gej for own public nonces 300aab1c05 tests: Improve _ge_set_all_gej(_var) tests 365f274ce3 group: Simplify secp256k1_ge_set_all_gej d3082ddead group: Add constant-time secp256k1_ge_set_all_gej git-subtree-dir: src/secp256k1 git-subtree-split: 4187a4664914dc6f6fb6a619c6b85c854fc33033
112 lines
3.4 KiB
Python
Executable File
112 lines
3.4 KiB
Python
Executable File
#!/usr/bin/env python3
|
|
# Copyright (c) 2023 Random "Randy" Lattice and Sean Andersen
|
|
# Distributed under the MIT software license, see the accompanying
|
|
# file COPYING or https://www.opensource.org/licenses/mit-license.php.
|
|
'''
|
|
Generate a C file with ECDSA testvectors from the Wycheproof project.
|
|
'''
|
|
|
|
import json
|
|
import sys
|
|
|
|
from wycheproof_utils import to_c_array
|
|
|
|
filename_input = sys.argv[1]
|
|
|
|
with open(filename_input) as f:
|
|
doc = json.load(f)
|
|
|
|
num_groups = len(doc['testGroups'])
|
|
|
|
|
|
num_vectors = 0
|
|
offset_msg_running, offset_pk_running, offset_sig = 0, 0, 0
|
|
out = ""
|
|
messages = ""
|
|
signatures = ""
|
|
public_keys = ""
|
|
cache_msgs = {}
|
|
cache_public_keys = {}
|
|
|
|
for i in range(num_groups):
|
|
group = doc['testGroups'][i]
|
|
num_tests = len(group['tests'])
|
|
public_key = group['publicKey']
|
|
for j in range(num_tests):
|
|
test_vector = group['tests'][j]
|
|
# // 2 to convert hex to byte length
|
|
sig_size = len(test_vector['sig']) // 2
|
|
msg_size = len(test_vector['msg']) // 2
|
|
|
|
if test_vector['result'] == "invalid":
|
|
expected_verify = 0
|
|
elif test_vector['result'] == "valid":
|
|
expected_verify = 1
|
|
else:
|
|
raise ValueError("invalid result field")
|
|
|
|
if num_vectors != 0 and sig_size != 0:
|
|
signatures += ",\n "
|
|
|
|
new_msg = False
|
|
msg = to_c_array(test_vector['msg'])
|
|
msg_offset = offset_msg_running
|
|
# check for repeated msg
|
|
if msg not in cache_msgs:
|
|
if num_vectors != 0 and msg_size != 0:
|
|
messages += ",\n "
|
|
cache_msgs[msg] = offset_msg_running
|
|
messages += msg
|
|
new_msg = True
|
|
else:
|
|
msg_offset = cache_msgs[msg]
|
|
|
|
new_pk = False
|
|
pk = to_c_array(public_key['uncompressed'])
|
|
pk_offset = offset_pk_running
|
|
# check for repeated pk
|
|
if pk not in cache_public_keys:
|
|
if num_vectors != 0:
|
|
public_keys += ",\n "
|
|
cache_public_keys[pk] = offset_pk_running
|
|
public_keys += pk
|
|
new_pk = True
|
|
else:
|
|
pk_offset = cache_public_keys[pk]
|
|
|
|
signatures += to_c_array(test_vector['sig'])
|
|
|
|
out += " /" + "* tcId: " + str(test_vector['tcId']) + ". " + test_vector['comment'] + " *" + "/\n"
|
|
out += f" {{{pk_offset}, {msg_offset}, {msg_size}, {offset_sig}, {sig_size}, {expected_verify} }},\n"
|
|
if new_msg:
|
|
offset_msg_running += msg_size
|
|
if new_pk:
|
|
offset_pk_running += 65
|
|
offset_sig += sig_size
|
|
num_vectors += 1
|
|
|
|
struct_definition = """
|
|
typedef struct {
|
|
size_t pk_offset;
|
|
size_t msg_offset;
|
|
size_t msg_len;
|
|
size_t sig_offset;
|
|
size_t sig_len;
|
|
int expected_verify;
|
|
} wycheproof_ecdsa_testvector;
|
|
"""
|
|
|
|
|
|
print("/* Note: this file was autogenerated using tests_wycheproof_generate_ecdsa.py. Do not edit. */")
|
|
print(f"#define SECP256K1_ECDSA_WYCHEPROOF_NUMBER_TESTVECTORS ({num_vectors})")
|
|
|
|
print(struct_definition)
|
|
|
|
print("static const unsigned char wycheproof_ecdsa_messages[] = { " + messages + "};\n")
|
|
print("static const unsigned char wycheproof_ecdsa_public_keys[] = { " + public_keys + "};\n")
|
|
print("static const unsigned char wycheproof_ecdsa_signatures[] = { " + signatures + "};\n")
|
|
|
|
print("static const wycheproof_ecdsa_testvector testvectors[SECP256K1_ECDSA_WYCHEPROOF_NUMBER_TESTVECTORS] = {")
|
|
print(out)
|
|
print("};")
|