mirror of
https://github.com/bitcoin/bitcoin.git
synced 2025-01-25 10:43:19 -03:00
Update secp256k1 subtree to latest master
This commit is contained in:
commit
ff54395de4
11 changed files with 35 additions and 21 deletions
4
src/secp256k1/.github/workflows/ci.yml
vendored
4
src/secp256k1/.github/workflows/ci.yml
vendored
|
@ -632,7 +632,7 @@ jobs:
|
||||||
|
|
||||||
- name: Install Homebrew packages
|
- name: Install Homebrew packages
|
||||||
run: |
|
run: |
|
||||||
brew install automake libtool gcc
|
brew install --quiet automake libtool gcc
|
||||||
ln -s $(brew --prefix gcc)/bin/gcc-?? /usr/local/bin/gcc
|
ln -s $(brew --prefix gcc)/bin/gcc-?? /usr/local/bin/gcc
|
||||||
|
|
||||||
- name: Install and cache Valgrind
|
- name: Install and cache Valgrind
|
||||||
|
@ -691,7 +691,7 @@ jobs:
|
||||||
|
|
||||||
- name: Install Homebrew packages
|
- name: Install Homebrew packages
|
||||||
run: |
|
run: |
|
||||||
brew install automake libtool gcc
|
brew install --quiet automake libtool gcc
|
||||||
ln -s $(brew --prefix gcc)/bin/gcc-?? /usr/local/bin/gcc
|
ln -s $(brew --prefix gcc)/bin/gcc-?? /usr/local/bin/gcc
|
||||||
|
|
||||||
- name: CI script
|
- name: CI script
|
||||||
|
|
|
@ -5,6 +5,8 @@ All notable changes to this project will be documented in this file.
|
||||||
The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/),
|
The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/),
|
||||||
and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html).
|
and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html).
|
||||||
|
|
||||||
|
## [Unreleased]
|
||||||
|
|
||||||
## [0.5.1] - 2024-08-01
|
## [0.5.1] - 2024-08-01
|
||||||
|
|
||||||
#### Added
|
#### Added
|
||||||
|
@ -141,6 +143,7 @@ This version was in fact never released.
|
||||||
The number was given by the build system since the introduction of autotools in Jan 2014 (ea0fe5a5bf0c04f9cc955b2966b614f5f378c6f6).
|
The number was given by the build system since the introduction of autotools in Jan 2014 (ea0fe5a5bf0c04f9cc955b2966b614f5f378c6f6).
|
||||||
Therefore, this version number does not uniquely identify a set of source files.
|
Therefore, this version number does not uniquely identify a set of source files.
|
||||||
|
|
||||||
|
[unreleased]: https://github.com/bitcoin-core/secp256k1/compare/v0.5.1...HEAD
|
||||||
[0.5.1]: https://github.com/bitcoin-core/secp256k1/compare/v0.5.0...v0.5.1
|
[0.5.1]: https://github.com/bitcoin-core/secp256k1/compare/v0.5.0...v0.5.1
|
||||||
[0.5.0]: https://github.com/bitcoin-core/secp256k1/compare/v0.4.1...v0.5.0
|
[0.5.0]: https://github.com/bitcoin-core/secp256k1/compare/v0.4.1...v0.5.0
|
||||||
[0.4.1]: https://github.com/bitcoin-core/secp256k1/compare/v0.4.0...v0.4.1
|
[0.4.1]: https://github.com/bitcoin-core/secp256k1/compare/v0.4.0...v0.4.1
|
||||||
|
|
|
@ -4,7 +4,7 @@ project(libsecp256k1
|
||||||
# The package (a.k.a. release) version is based on semantic versioning 2.0.0 of
|
# The package (a.k.a. release) version is based on semantic versioning 2.0.0 of
|
||||||
# the API. All changes in experimental modules are treated as
|
# the API. All changes in experimental modules are treated as
|
||||||
# backwards-compatible and therefore at most increase the minor version.
|
# backwards-compatible and therefore at most increase the minor version.
|
||||||
VERSION 0.5.1
|
VERSION 0.5.2
|
||||||
DESCRIPTION "Optimized C library for ECDSA signatures and secret/public key operations on curve secp256k1."
|
DESCRIPTION "Optimized C library for ECDSA signatures and secret/public key operations on curve secp256k1."
|
||||||
HOMEPAGE_URL "https://github.com/bitcoin-core/secp256k1"
|
HOMEPAGE_URL "https://github.com/bitcoin-core/secp256k1"
|
||||||
LANGUAGES C
|
LANGUAGES C
|
||||||
|
@ -27,7 +27,7 @@ endif()
|
||||||
# All changes in experimental modules are treated as if they don't affect the
|
# All changes in experimental modules are treated as if they don't affect the
|
||||||
# interface and therefore only increase the revision.
|
# interface and therefore only increase the revision.
|
||||||
set(${PROJECT_NAME}_LIB_VERSION_CURRENT 4)
|
set(${PROJECT_NAME}_LIB_VERSION_CURRENT 4)
|
||||||
set(${PROJECT_NAME}_LIB_VERSION_REVISION 1)
|
set(${PROJECT_NAME}_LIB_VERSION_REVISION 2)
|
||||||
set(${PROJECT_NAME}_LIB_VERSION_AGE 2)
|
set(${PROJECT_NAME}_LIB_VERSION_AGE 2)
|
||||||
|
|
||||||
set(CMAKE_C_STANDARD 90)
|
set(CMAKE_C_STANDARD 90)
|
||||||
|
@ -276,6 +276,14 @@ if(SECP256K1_APPEND_CFLAGS)
|
||||||
string(APPEND CMAKE_C_COMPILE_OBJECT " ${SECP256K1_APPEND_CFLAGS}")
|
string(APPEND CMAKE_C_COMPILE_OBJECT " ${SECP256K1_APPEND_CFLAGS}")
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
|
set(SECP256K1_APPEND_LDFLAGS "" CACHE STRING "Linker flags that are appended to the command line after all other flags added by the build system. This variable is intended for debugging and special builds.")
|
||||||
|
if(SECP256K1_APPEND_LDFLAGS)
|
||||||
|
# Appending to this low-level rule variable is the only way to
|
||||||
|
# guarantee that the flags appear at the end of the command line.
|
||||||
|
string(APPEND CMAKE_C_CREATE_SHARED_LIBRARY " ${SECP256K1_APPEND_LDFLAGS}")
|
||||||
|
string(APPEND CMAKE_C_LINK_EXECUTABLE " ${SECP256K1_APPEND_LDFLAGS}")
|
||||||
|
endif()
|
||||||
|
|
||||||
add_subdirectory(src)
|
add_subdirectory(src)
|
||||||
if(SECP256K1_BUILD_EXAMPLES)
|
if(SECP256K1_BUILD_EXAMPLES)
|
||||||
add_subdirectory(examples)
|
add_subdirectory(examples)
|
||||||
|
@ -355,6 +363,9 @@ endif()
|
||||||
if(SECP256K1_APPEND_CFLAGS)
|
if(SECP256K1_APPEND_CFLAGS)
|
||||||
message("SECP256K1_APPEND_CFLAGS ............... ${SECP256K1_APPEND_CFLAGS}")
|
message("SECP256K1_APPEND_CFLAGS ............... ${SECP256K1_APPEND_CFLAGS}")
|
||||||
endif()
|
endif()
|
||||||
|
if(SECP256K1_APPEND_LDFLAGS)
|
||||||
|
message("SECP256K1_APPEND_LDFLAGS .............. ${SECP256K1_APPEND_LDFLAGS}")
|
||||||
|
endif()
|
||||||
message("")
|
message("")
|
||||||
if(print_msan_notice)
|
if(print_msan_notice)
|
||||||
message(
|
message(
|
||||||
|
|
|
@ -40,7 +40,7 @@ RUN apt-get update && apt-get install --no-install-recommends -y \
|
||||||
apt-get clean && rm -rf /var/lib/apt/lists/*
|
apt-get clean && rm -rf /var/lib/apt/lists/*
|
||||||
|
|
||||||
# Build and install gcc snapshot
|
# Build and install gcc snapshot
|
||||||
ARG GCC_SNAPSHOT_MAJOR=14
|
ARG GCC_SNAPSHOT_MAJOR=15
|
||||||
RUN apt-get update && apt-get install --no-install-recommends -y wget libgmp-dev libmpfr-dev libmpc-dev flex && \
|
RUN apt-get update && apt-get install --no-install-recommends -y wget libgmp-dev libmpfr-dev libmpc-dev flex && \
|
||||||
mkdir gcc && cd gcc && \
|
mkdir gcc && cd gcc && \
|
||||||
wget --progress=dot:giga --https-only --recursive --accept '*.tar.xz' --level 1 --no-directories "https://gcc.gnu.org/pub/gcc/snapshots/LATEST-${GCC_SNAPSHOT_MAJOR}" && \
|
wget --progress=dot:giga --https-only --recursive --accept '*.tar.xz' --level 1 --no-directories "https://gcc.gnu.org/pub/gcc/snapshots/LATEST-${GCC_SNAPSHOT_MAJOR}" && \
|
||||||
|
|
|
@ -5,8 +5,8 @@ AC_PREREQ([2.60])
|
||||||
# backwards-compatible and therefore at most increase the minor version.
|
# backwards-compatible and therefore at most increase the minor version.
|
||||||
define(_PKG_VERSION_MAJOR, 0)
|
define(_PKG_VERSION_MAJOR, 0)
|
||||||
define(_PKG_VERSION_MINOR, 5)
|
define(_PKG_VERSION_MINOR, 5)
|
||||||
define(_PKG_VERSION_PATCH, 1)
|
define(_PKG_VERSION_PATCH, 2)
|
||||||
define(_PKG_VERSION_IS_RELEASE, true)
|
define(_PKG_VERSION_IS_RELEASE, false)
|
||||||
|
|
||||||
# The library version is based on libtool versioning of the ABI. The set of
|
# The library version is based on libtool versioning of the ABI. The set of
|
||||||
# rules for updating the version can be found here:
|
# rules for updating the version can be found here:
|
||||||
|
@ -14,7 +14,7 @@ define(_PKG_VERSION_IS_RELEASE, true)
|
||||||
# All changes in experimental modules are treated as if they don't affect the
|
# All changes in experimental modules are treated as if they don't affect the
|
||||||
# interface and therefore only increase the revision.
|
# interface and therefore only increase the revision.
|
||||||
define(_LIB_VERSION_CURRENT, 4)
|
define(_LIB_VERSION_CURRENT, 4)
|
||||||
define(_LIB_VERSION_REVISION, 1)
|
define(_LIB_VERSION_REVISION, 2)
|
||||||
define(_LIB_VERSION_AGE, 2)
|
define(_LIB_VERSION_AGE, 2)
|
||||||
|
|
||||||
AC_INIT([libsecp256k1],m4_join([.], _PKG_VERSION_MAJOR, _PKG_VERSION_MINOR, _PKG_VERSION_PATCH)m4_if(_PKG_VERSION_IS_RELEASE, [true], [], [-dev]),[https://github.com/bitcoin-core/secp256k1/issues],[libsecp256k1],[https://github.com/bitcoin-core/secp256k1])
|
AC_INIT([libsecp256k1],m4_join([.], _PKG_VERSION_MAJOR, _PKG_VERSION_MINOR, _PKG_VERSION_PATCH)m4_if(_PKG_VERSION_IS_RELEASE, [true], [], [-dev]),[https://github.com/bitcoin-core/secp256k1/issues],[libsecp256k1],[https://github.com/bitcoin-core/secp256k1])
|
||||||
|
|
|
@ -18,9 +18,9 @@
|
||||||
#include "examples_util.h"
|
#include "examples_util.h"
|
||||||
|
|
||||||
int main(void) {
|
int main(void) {
|
||||||
unsigned char msg[12] = "Hello World!";
|
unsigned char msg[] = {'H', 'e', 'l', 'l', 'o', ' ', 'W', 'o', 'r', 'l', 'd', '!'};
|
||||||
unsigned char msg_hash[32];
|
unsigned char msg_hash[32];
|
||||||
unsigned char tag[17] = "my_fancy_protocol";
|
unsigned char tag[] = {'m', 'y', '_', 'f', 'a', 'n', 'c', 'y', '_', 'p', 'r', 'o', 't', 'o', 'c', 'o', 'l'};
|
||||||
unsigned char seckey[32];
|
unsigned char seckey[32];
|
||||||
unsigned char randomize[32];
|
unsigned char randomize[32];
|
||||||
unsigned char auxiliary_rand[32];
|
unsigned char auxiliary_rand[32];
|
||||||
|
|
|
@ -35,7 +35,7 @@ extern "C" {
|
||||||
*
|
*
|
||||||
* If the Y coordinate is relevant, it is given the same parity as t.
|
* If the Y coordinate is relevant, it is given the same parity as t.
|
||||||
*
|
*
|
||||||
* Changes w.r.t. the the paper:
|
* Changes w.r.t. the paper:
|
||||||
* - The u=0, t=0, and u^3+t^2+7=0 conditions result in decoding to the point
|
* - The u=0, t=0, and u^3+t^2+7=0 conditions result in decoding to the point
|
||||||
* at infinity in the paper. Here they are remapped to finite points.
|
* at infinity in the paper. Here they are remapped to finite points.
|
||||||
* - The paper uses an additional encoding bit for the parity of y. Here the
|
* - The paper uses an additional encoding bit for the parity of y. Here the
|
||||||
|
|
|
@ -406,9 +406,9 @@ void run_ellswift_tests(void) {
|
||||||
/* Test hash initializers. */
|
/* Test hash initializers. */
|
||||||
{
|
{
|
||||||
secp256k1_sha256 sha, sha_optimized;
|
secp256k1_sha256 sha, sha_optimized;
|
||||||
static const unsigned char encode_tag[25] = "secp256k1_ellswift_encode";
|
static const unsigned char encode_tag[] = {'s', 'e', 'c', 'p', '2', '5', '6', 'k', '1', '_', 'e', 'l', 'l', 's', 'w', 'i', 'f', 't', '_', 'e', 'n', 'c', 'o', 'd', 'e'};
|
||||||
static const unsigned char create_tag[25] = "secp256k1_ellswift_create";
|
static const unsigned char create_tag[] = {'s', 'e', 'c', 'p', '2', '5', '6', 'k', '1', '_', 'e', 'l', 'l', 's', 'w', 'i', 'f', 't', '_', 'c', 'r', 'e', 'a', 't', 'e'};
|
||||||
static const unsigned char bip324_tag[26] = "bip324_ellswift_xonly_ecdh";
|
static const unsigned char bip324_tag[] = {'b', 'i', 'p', '3', '2', '4', '_', 'e', 'l', 'l', 's', 'w', 'i', 'f', 't', '_', 'x', 'o', 'n', 'l', 'y', '_', 'e', 'c', 'd', 'h'};
|
||||||
|
|
||||||
/* Check that hash initialized by
|
/* Check that hash initialized by
|
||||||
* secp256k1_ellswift_sha256_init_encode has the expected
|
* secp256k1_ellswift_sha256_init_encode has the expected
|
||||||
|
|
|
@ -45,7 +45,7 @@ static void secp256k1_nonce_function_bip340_sha256_tagged_aux(secp256k1_sha256 *
|
||||||
|
|
||||||
/* algo argument for nonce_function_bip340 to derive the nonce exactly as stated in BIP-340
|
/* algo argument for nonce_function_bip340 to derive the nonce exactly as stated in BIP-340
|
||||||
* by using the correct tagged hash function. */
|
* by using the correct tagged hash function. */
|
||||||
static const unsigned char bip340_algo[13] = "BIP0340/nonce";
|
static const unsigned char bip340_algo[] = {'B', 'I', 'P', '0', '3', '4', '0', '/', 'n', 'o', 'n', 'c', 'e'};
|
||||||
|
|
||||||
static const unsigned char schnorrsig_extraparams_magic[4] = SECP256K1_SCHNORRSIG_EXTRAPARAMS_MAGIC;
|
static const unsigned char schnorrsig_extraparams_magic[4] = SECP256K1_SCHNORRSIG_EXTRAPARAMS_MAGIC;
|
||||||
|
|
||||||
|
|
|
@ -21,9 +21,9 @@ static void nonce_function_bip340_bitflip(unsigned char **args, size_t n_flip, s
|
||||||
}
|
}
|
||||||
|
|
||||||
static void run_nonce_function_bip340_tests(void) {
|
static void run_nonce_function_bip340_tests(void) {
|
||||||
unsigned char tag[13] = "BIP0340/nonce";
|
unsigned char tag[] = {'B', 'I', 'P', '0', '3', '4', '0', '/', 'n', 'o', 'n', 'c', 'e'};
|
||||||
unsigned char aux_tag[11] = "BIP0340/aux";
|
unsigned char aux_tag[] = {'B', 'I', 'P', '0', '3', '4', '0', '/', 'a', 'u', 'x'};
|
||||||
unsigned char algo[13] = "BIP0340/nonce";
|
unsigned char algo[] = {'B', 'I', 'P', '0', '3', '4', '0', '/', 'n', 'o', 'n', 'c', 'e'};
|
||||||
size_t algolen = sizeof(algo);
|
size_t algolen = sizeof(algo);
|
||||||
secp256k1_sha256 sha;
|
secp256k1_sha256 sha;
|
||||||
secp256k1_sha256 sha_optimized;
|
secp256k1_sha256 sha_optimized;
|
||||||
|
@ -158,7 +158,7 @@ static void test_schnorrsig_api(void) {
|
||||||
/* Checks that hash initialized by secp256k1_schnorrsig_sha256_tagged has the
|
/* Checks that hash initialized by secp256k1_schnorrsig_sha256_tagged has the
|
||||||
* expected state. */
|
* expected state. */
|
||||||
static void test_schnorrsig_sha256_tagged(void) {
|
static void test_schnorrsig_sha256_tagged(void) {
|
||||||
unsigned char tag[17] = "BIP0340/challenge";
|
unsigned char tag[] = {'B', 'I', 'P', '0', '3', '4', '0', '/', 'c', 'h', 'a', 'l', 'l', 'e', 'n', 'g', 'e'};
|
||||||
secp256k1_sha256 sha;
|
secp256k1_sha256 sha;
|
||||||
secp256k1_sha256 sha_optimized;
|
secp256k1_sha256 sha_optimized;
|
||||||
|
|
||||||
|
@ -806,7 +806,7 @@ static void test_schnorrsig_sign(void) {
|
||||||
unsigned char sk[32];
|
unsigned char sk[32];
|
||||||
secp256k1_xonly_pubkey pk;
|
secp256k1_xonly_pubkey pk;
|
||||||
secp256k1_keypair keypair;
|
secp256k1_keypair keypair;
|
||||||
const unsigned char msg[32] = "this is a msg for a schnorrsig..";
|
const unsigned char msg[] = {'t', 'h', 'i', 's', ' ', 'i', 's', ' ', 'a', ' ', 'm', 's', 'g', ' ', 'f', 'o', 'r', ' ', 'a', ' ', 's', 'c', 'h', 'n', 'o', 'r', 'r', 's', 'i', 'g', '.', '.'};
|
||||||
unsigned char sig[64];
|
unsigned char sig[64];
|
||||||
unsigned char sig2[64];
|
unsigned char sig2[64];
|
||||||
unsigned char zeros64[64] = { 0 };
|
unsigned char zeros64[64] = { 0 };
|
||||||
|
|
|
@ -18,7 +18,7 @@
|
||||||
static uint64_t secp256k1_test_state[4];
|
static uint64_t secp256k1_test_state[4];
|
||||||
|
|
||||||
SECP256K1_INLINE static void testrand_seed(const unsigned char *seed16) {
|
SECP256K1_INLINE static void testrand_seed(const unsigned char *seed16) {
|
||||||
static const unsigned char PREFIX[19] = "secp256k1 test init";
|
static const unsigned char PREFIX[] = {'s', 'e', 'c', 'p', '2', '5', '6', 'k', '1', ' ', 't', 'e', 's', 't', ' ', 'i', 'n', 'i', 't'};
|
||||||
unsigned char out32[32];
|
unsigned char out32[32];
|
||||||
secp256k1_sha256 hash;
|
secp256k1_sha256 hash;
|
||||||
int i;
|
int i;
|
||||||
|
|
Loading…
Add table
Reference in a new issue