Squashed 'src/secp256k1/' changes from c545fdc374..199d27cea3
199d27cea3 Merge bitcoin-core/secp256k1#1415: release: Prepare for 0.4.0
16339804c9 release: Prepare for 0.4.0
d9a85065a9 changelog: Catch up in preparation of release
0b4640aedd Merge bitcoin-core/secp256k1#1413: ci: Add `release` job
8659a01714 ci: Add `release` job
f9b38894ba ci: Update `actions/checkout` version
727bec5bc2 Merge bitcoin-core/secp256k1#1414: ci/gha: Add ARM64 QEMU jobs for clang and clang-snapshot
2635068abf ci/gha: Let MSan continue checking after errors in all jobs
e78c7b68eb ci/Dockerfile: Reduce size of Docker image further
2f0d3bbffb ci/Dockerfile: Warn if `ulimit -n` is too high when running Docker
4b8a647ad3 ci/gha: Add ARM64 QEMU jobs for clang and clang-snapshot
6ebe7d2bb3 ci/Dockerfile: Always use versioned clang packages
65c79fe2d0 Merge bitcoin-core/secp256k1#1412: ci: Switch macOS from Ventura to Monterey and add Valgrind
c223d7e33d ci: Switch macOS from Ventura to Monterey and add Valgrind
ea26b71c3a Merge bitcoin-core/secp256k1#1411: ci: Make repetitive command the default one
cce0456304 ci: Make repetitive command the default one
317a4c48f0 ci: Move `git config ...` to `run-in-docker-action`
4d7fe60905 Merge bitcoin-core/secp256k1#1409: ci: Move remained task from Cirrus to GitHub Actions
676ed8f9cf ci: Move "C++ (public headers)" from Cirrus to GitHub Actions
61fc3a2dc8 ci: Move "C++ -fpermissive..." from Cirrus to GitHub Actions
d51fb0a533 ci: Move "MSan" from Cirrus to GitHub Actions
c22ac27529 ci: Move sanitizers task from Cirrus to GitHub Actions
26a989924b Merge bitcoin-core/secp256k1#1410: ci: Use concurrency for pull requests only
ee1be62d84 ci: Use concurrency for pull requests only
6ee14550c8 Merge bitcoin-core/secp256k1#1406: ci, gha: Move more non-x86_64 tasks from Cirrus CI to GitHub Actions
fc3dea29ea ci: Move "ppc64le: Linux..." from Cirrus to GitHub Actions
7782dc8276 ci: Move "ARM64: Linux..." from Cirrus to GitHub Actions
0a16de671c ci: Move "ARM32: Linux..." from Cirrus to GitHub Actions
ea33914e00 ci: Move "s390x (big-endian): Linux..." from Cirrus to GitHub Actions
880be8af99 ci: Move "i686: Linux (Debian stable)" from Cirrus to GiHub Actions
2e6cf9bae5 Merge bitcoin-core/secp256k1#1396: ci, gha: Add "x86_64: Linux (Debian stable)" GitHub Actions job
5373693e45 Merge bitcoin-core/secp256k1#1405: ci: Drop no longer needed workaround
ef9fe959de ci: Drop no longer needed workaround
e10878f58e ci, gha: Drop `driver-opts.network` input for `setup-buildx-action`
4ad4914bd1 ci, gha: Add `retry_builder` Docker image builder
6617a620d9 ci: Remove "x86_64: Linux (Debian stable)" task from Cirrus CI
03c9e6508c ci, gha: Add "x86_64: Linux (Debian stable)" GitHub Actions job
ad3e65d9fe ci: Remove GCC build files and sage to reduce size of Docker image
6b9507adf6 Merge bitcoin-core/secp256k1#1398: ci, gha: Add Windows jobs based on Linux image
87d35f30c0 ci: Rename `cirrus.sh` to more general `ci.sh`
d6281dd008 ci: Remove Windows tasks from Cirrus CI
2b6f9cd546 ci, gha: Add Windows jobs based on Linux image
48b1d939b5 Merge bitcoin-core/secp256k1#1403: ci, gha: Ensure only a single workflow processes `github.ref` at a time
0ba2b94551 Merge bitcoin-core/secp256k1#1373: Add invariant checking for scalars
060e32cb60 Merge bitcoin-core/secp256k1#1401: ci, gha: Run all MSVC tests on Windows natively
de657c2044 Merge bitcoin-core/secp256k1#1062: Removes `_fe_equal_var`, and unwanted `_fe_normalize_weak` calls (in tests)
bcffeb14bc Merge bitcoin-core/secp256k1#1404: ci: Remove "arm64: macOS Ventura" task from Cirrus CI
c2f6435802 ci: Add comment about switching macOS to M1 on GHA later
4a24fae0bc ci: Remove "arm64: macOS Ventura" task from Cirrus CI
b0886fd35c ci, gha: Ensure only a single workflow processes `github.ref` at a time
3d05c86d63 Merge bitcoin-core/secp256k1#1394: ci, gha: Run "x86_64: macOS Ventura" job on GitHub Actions
d78bec7001 ci: Remove Windows MSVC tasks from Cirrus CI
3545dc2b9b ci, gha: Run all MSVC tests on Windows natively
5d8fa825e2 Merge bitcoin-core/secp256k1#1274: test: Silent noisy clang warnings about Valgrind code on macOS x86_64
8e54a346d2 ci, gha: Run "x86_64: macOS Ventura" job on GitHub Actions
b327abfcea Merge bitcoin-core/secp256k1#1402: ci: Use Homebrew's gcc in native macOS task
d62db57427 ci: Use Homebrew's gcc in native macOS task
54058d16fe field: remove `secp256k1_fe_equal_var`
bb4efd6404 tests: remove unwanted `secp256k1_fe_normalize_weak` call
eedd781085 Merge bitcoin-core/secp256k1#1348: tighten group magnitude limits, save normalize_weak calls in group add methods (revival of #1032)
b2f6712dd3 Merge bitcoin-core/secp256k1#1400: ctimetests: Use new SECP256K1_CHECKMEM macros also for ellswift
9c91ea41b1 ci: Enable ellswift module where it's missing
db32a24761 ctimetests: Use new SECP256K1_CHECKMEM macros also for ellswift
ce765a5b8e Merge bitcoin-core/secp256k1#1399: ci, gha: Run "SageMath prover" job on GitHub Actions
8408dfdc4c Revert "ci: Run sage prover on CI"
c8d9914fb1 ci, gha: Run "SageMath prover" job on GitHub Actions
8d2960c8e2 Merge bitcoin-core/secp256k1#1397: ci: Remove "Windows (VS 2022)" task from Cirrus CI
f1774e5ec4 ci, gha: Make MSVC job presentation more explicit
5ee039bb58 ci: Remove "Windows (VS 2022)" task from Cirrus CI
96294c00fb Merge bitcoin-core/secp256k1#1389: ci: Run "Windows (VS 2022)" job on GitHub Actions
a2f7ccdecc ci: Run "Windows (VS 2022)" job on GitHub Actions
374e2b54e2 Merge bitcoin-core/secp256k1#1290: cmake: Set `ENVIRONMENT` property for examples on Windows
1b13415df9 Merge bitcoin-core/secp256k1#1391: refactor: take use of `secp256k1_scalar_{zero,one}` constants (part 2)
a1bd4971d6 refactor: take use of `secp256k1_scalar_{zero,one}` constants (part 2)
b7c685e74a Save _normalize_weak calls in group add methods
c83afa66e0 Tighten group magnitude limits
26392da2fb Merge bitcoin-core/secp256k1#1386: ci: print $ELLSWIFT in cirrus.sh
d23da6d557 use secp256k1_scalar_verify checks
4692478853 ci: print $ELLSWIFT in cirrus.sh
c7d0454932 add verification for scalars
c734c64278 Merge bitcoin-core/secp256k1#1384: build: enable ellswift module via SECP_CONFIG_DEFINES
ad152151b0 update max scalar in scalar_cmov_test and fix schnorrsig_verify exhaustive test
78ca880788 build: enable ellswift module via SECP_CONFIG_DEFINES
0e00fc7d10 Merge bitcoin-core/secp256k1#1383: util: remove unused checked_realloc
b097a466c1 util: remove unused checked_realloc
2bd5f3e618 Merge bitcoin-core/secp256k1#1382: refactor: Drop unused cast
4f8c5bd761 refactor: Drop unused cast
173e8d061a Implement current magnitude assumptions
49afd2f5d8 Take use of _fe_verify_magnitude in field_impl.h
4e9661fc42 Add _fe_verify_magnitude (no-op unless VERIFY is enabled)
690b0fc05a add missing group element invariant checks
175db31149 ci: Drop no longer needed `PATH` variable update on Windows
116d2ab3df cmake: Set `ENVIRONMENT` property for examples on Windows
cef373997c cmake, refactor: Use helper function instead of interface library
747ada3587 test: Silent noisy clang warnings about Valgrind code on macOS x86_64
git-subtree-dir: src/secp256k1
git-subtree-split: 199d27cea32203b224b208627533c2e813cd3b21
2023-09-04 12:51:20 -04:00
|
|
|
name: CI
|
|
|
|
on:
|
|
|
|
pull_request:
|
|
|
|
push:
|
|
|
|
branches:
|
|
|
|
- '**'
|
|
|
|
tags-ignore:
|
|
|
|
- '**'
|
|
|
|
|
|
|
|
concurrency:
|
|
|
|
group: ${{ github.event_name != 'pull_request' && github.run_id || github.ref }}
|
|
|
|
cancel-in-progress: true
|
|
|
|
|
|
|
|
env:
|
|
|
|
### compiler options
|
|
|
|
HOST:
|
|
|
|
WRAPPER_CMD:
|
|
|
|
# Specific warnings can be disabled with -Wno-error=foo.
|
|
|
|
# -pedantic-errors is not equivalent to -Werror=pedantic and thus not implied by -Werror according to the GCC manual.
|
|
|
|
WERROR_CFLAGS: '-Werror -pedantic-errors'
|
|
|
|
MAKEFLAGS: '-j4'
|
|
|
|
BUILD: 'check'
|
|
|
|
### secp256k1 config
|
|
|
|
ECMULTWINDOW: 'auto'
|
|
|
|
ECMULTGENPRECISION: 'auto'
|
|
|
|
ASM: 'no'
|
|
|
|
WIDEMUL: 'auto'
|
|
|
|
WITH_VALGRIND: 'yes'
|
|
|
|
EXTRAFLAGS:
|
|
|
|
### secp256k1 modules
|
|
|
|
EXPERIMENTAL: 'no'
|
|
|
|
ECDH: 'no'
|
|
|
|
RECOVERY: 'no'
|
|
|
|
SCHNORRSIG: 'no'
|
|
|
|
ELLSWIFT: 'no'
|
|
|
|
### test options
|
|
|
|
SECP256K1_TEST_ITERS:
|
|
|
|
BENCH: 'yes'
|
|
|
|
SECP256K1_BENCH_ITERS: 2
|
|
|
|
CTIMETESTS: 'yes'
|
|
|
|
# Compile and run the examples.
|
|
|
|
EXAMPLES: 'yes'
|
|
|
|
|
|
|
|
jobs:
|
|
|
|
docker_cache:
|
|
|
|
name: "Build Docker image"
|
|
|
|
runs-on: ubuntu-latest
|
|
|
|
steps:
|
|
|
|
- name: Set up Docker Buildx
|
2024-01-04 14:40:28 +00:00
|
|
|
uses: docker/setup-buildx-action@v3
|
Squashed 'src/secp256k1/' changes from c545fdc374..199d27cea3
199d27cea3 Merge bitcoin-core/secp256k1#1415: release: Prepare for 0.4.0
16339804c9 release: Prepare for 0.4.0
d9a85065a9 changelog: Catch up in preparation of release
0b4640aedd Merge bitcoin-core/secp256k1#1413: ci: Add `release` job
8659a01714 ci: Add `release` job
f9b38894ba ci: Update `actions/checkout` version
727bec5bc2 Merge bitcoin-core/secp256k1#1414: ci/gha: Add ARM64 QEMU jobs for clang and clang-snapshot
2635068abf ci/gha: Let MSan continue checking after errors in all jobs
e78c7b68eb ci/Dockerfile: Reduce size of Docker image further
2f0d3bbffb ci/Dockerfile: Warn if `ulimit -n` is too high when running Docker
4b8a647ad3 ci/gha: Add ARM64 QEMU jobs for clang and clang-snapshot
6ebe7d2bb3 ci/Dockerfile: Always use versioned clang packages
65c79fe2d0 Merge bitcoin-core/secp256k1#1412: ci: Switch macOS from Ventura to Monterey and add Valgrind
c223d7e33d ci: Switch macOS from Ventura to Monterey and add Valgrind
ea26b71c3a Merge bitcoin-core/secp256k1#1411: ci: Make repetitive command the default one
cce0456304 ci: Make repetitive command the default one
317a4c48f0 ci: Move `git config ...` to `run-in-docker-action`
4d7fe60905 Merge bitcoin-core/secp256k1#1409: ci: Move remained task from Cirrus to GitHub Actions
676ed8f9cf ci: Move "C++ (public headers)" from Cirrus to GitHub Actions
61fc3a2dc8 ci: Move "C++ -fpermissive..." from Cirrus to GitHub Actions
d51fb0a533 ci: Move "MSan" from Cirrus to GitHub Actions
c22ac27529 ci: Move sanitizers task from Cirrus to GitHub Actions
26a989924b Merge bitcoin-core/secp256k1#1410: ci: Use concurrency for pull requests only
ee1be62d84 ci: Use concurrency for pull requests only
6ee14550c8 Merge bitcoin-core/secp256k1#1406: ci, gha: Move more non-x86_64 tasks from Cirrus CI to GitHub Actions
fc3dea29ea ci: Move "ppc64le: Linux..." from Cirrus to GitHub Actions
7782dc8276 ci: Move "ARM64: Linux..." from Cirrus to GitHub Actions
0a16de671c ci: Move "ARM32: Linux..." from Cirrus to GitHub Actions
ea33914e00 ci: Move "s390x (big-endian): Linux..." from Cirrus to GitHub Actions
880be8af99 ci: Move "i686: Linux (Debian stable)" from Cirrus to GiHub Actions
2e6cf9bae5 Merge bitcoin-core/secp256k1#1396: ci, gha: Add "x86_64: Linux (Debian stable)" GitHub Actions job
5373693e45 Merge bitcoin-core/secp256k1#1405: ci: Drop no longer needed workaround
ef9fe959de ci: Drop no longer needed workaround
e10878f58e ci, gha: Drop `driver-opts.network` input for `setup-buildx-action`
4ad4914bd1 ci, gha: Add `retry_builder` Docker image builder
6617a620d9 ci: Remove "x86_64: Linux (Debian stable)" task from Cirrus CI
03c9e6508c ci, gha: Add "x86_64: Linux (Debian stable)" GitHub Actions job
ad3e65d9fe ci: Remove GCC build files and sage to reduce size of Docker image
6b9507adf6 Merge bitcoin-core/secp256k1#1398: ci, gha: Add Windows jobs based on Linux image
87d35f30c0 ci: Rename `cirrus.sh` to more general `ci.sh`
d6281dd008 ci: Remove Windows tasks from Cirrus CI
2b6f9cd546 ci, gha: Add Windows jobs based on Linux image
48b1d939b5 Merge bitcoin-core/secp256k1#1403: ci, gha: Ensure only a single workflow processes `github.ref` at a time
0ba2b94551 Merge bitcoin-core/secp256k1#1373: Add invariant checking for scalars
060e32cb60 Merge bitcoin-core/secp256k1#1401: ci, gha: Run all MSVC tests on Windows natively
de657c2044 Merge bitcoin-core/secp256k1#1062: Removes `_fe_equal_var`, and unwanted `_fe_normalize_weak` calls (in tests)
bcffeb14bc Merge bitcoin-core/secp256k1#1404: ci: Remove "arm64: macOS Ventura" task from Cirrus CI
c2f6435802 ci: Add comment about switching macOS to M1 on GHA later
4a24fae0bc ci: Remove "arm64: macOS Ventura" task from Cirrus CI
b0886fd35c ci, gha: Ensure only a single workflow processes `github.ref` at a time
3d05c86d63 Merge bitcoin-core/secp256k1#1394: ci, gha: Run "x86_64: macOS Ventura" job on GitHub Actions
d78bec7001 ci: Remove Windows MSVC tasks from Cirrus CI
3545dc2b9b ci, gha: Run all MSVC tests on Windows natively
5d8fa825e2 Merge bitcoin-core/secp256k1#1274: test: Silent noisy clang warnings about Valgrind code on macOS x86_64
8e54a346d2 ci, gha: Run "x86_64: macOS Ventura" job on GitHub Actions
b327abfcea Merge bitcoin-core/secp256k1#1402: ci: Use Homebrew's gcc in native macOS task
d62db57427 ci: Use Homebrew's gcc in native macOS task
54058d16fe field: remove `secp256k1_fe_equal_var`
bb4efd6404 tests: remove unwanted `secp256k1_fe_normalize_weak` call
eedd781085 Merge bitcoin-core/secp256k1#1348: tighten group magnitude limits, save normalize_weak calls in group add methods (revival of #1032)
b2f6712dd3 Merge bitcoin-core/secp256k1#1400: ctimetests: Use new SECP256K1_CHECKMEM macros also for ellswift
9c91ea41b1 ci: Enable ellswift module where it's missing
db32a24761 ctimetests: Use new SECP256K1_CHECKMEM macros also for ellswift
ce765a5b8e Merge bitcoin-core/secp256k1#1399: ci, gha: Run "SageMath prover" job on GitHub Actions
8408dfdc4c Revert "ci: Run sage prover on CI"
c8d9914fb1 ci, gha: Run "SageMath prover" job on GitHub Actions
8d2960c8e2 Merge bitcoin-core/secp256k1#1397: ci: Remove "Windows (VS 2022)" task from Cirrus CI
f1774e5ec4 ci, gha: Make MSVC job presentation more explicit
5ee039bb58 ci: Remove "Windows (VS 2022)" task from Cirrus CI
96294c00fb Merge bitcoin-core/secp256k1#1389: ci: Run "Windows (VS 2022)" job on GitHub Actions
a2f7ccdecc ci: Run "Windows (VS 2022)" job on GitHub Actions
374e2b54e2 Merge bitcoin-core/secp256k1#1290: cmake: Set `ENVIRONMENT` property for examples on Windows
1b13415df9 Merge bitcoin-core/secp256k1#1391: refactor: take use of `secp256k1_scalar_{zero,one}` constants (part 2)
a1bd4971d6 refactor: take use of `secp256k1_scalar_{zero,one}` constants (part 2)
b7c685e74a Save _normalize_weak calls in group add methods
c83afa66e0 Tighten group magnitude limits
26392da2fb Merge bitcoin-core/secp256k1#1386: ci: print $ELLSWIFT in cirrus.sh
d23da6d557 use secp256k1_scalar_verify checks
4692478853 ci: print $ELLSWIFT in cirrus.sh
c7d0454932 add verification for scalars
c734c64278 Merge bitcoin-core/secp256k1#1384: build: enable ellswift module via SECP_CONFIG_DEFINES
ad152151b0 update max scalar in scalar_cmov_test and fix schnorrsig_verify exhaustive test
78ca880788 build: enable ellswift module via SECP_CONFIG_DEFINES
0e00fc7d10 Merge bitcoin-core/secp256k1#1383: util: remove unused checked_realloc
b097a466c1 util: remove unused checked_realloc
2bd5f3e618 Merge bitcoin-core/secp256k1#1382: refactor: Drop unused cast
4f8c5bd761 refactor: Drop unused cast
173e8d061a Implement current magnitude assumptions
49afd2f5d8 Take use of _fe_verify_magnitude in field_impl.h
4e9661fc42 Add _fe_verify_magnitude (no-op unless VERIFY is enabled)
690b0fc05a add missing group element invariant checks
175db31149 ci: Drop no longer needed `PATH` variable update on Windows
116d2ab3df cmake: Set `ENVIRONMENT` property for examples on Windows
cef373997c cmake, refactor: Use helper function instead of interface library
747ada3587 test: Silent noisy clang warnings about Valgrind code on macOS x86_64
git-subtree-dir: src/secp256k1
git-subtree-split: 199d27cea32203b224b208627533c2e813cd3b21
2023-09-04 12:51:20 -04:00
|
|
|
with:
|
|
|
|
# See: https://github.com/moby/buildkit/issues/3969.
|
|
|
|
driver-opts: |
|
|
|
|
network=host
|
|
|
|
|
|
|
|
- name: Build container
|
2024-01-04 14:40:28 +00:00
|
|
|
uses: docker/build-push-action@v5
|
Squashed 'src/secp256k1/' changes from c545fdc374..199d27cea3
199d27cea3 Merge bitcoin-core/secp256k1#1415: release: Prepare for 0.4.0
16339804c9 release: Prepare for 0.4.0
d9a85065a9 changelog: Catch up in preparation of release
0b4640aedd Merge bitcoin-core/secp256k1#1413: ci: Add `release` job
8659a01714 ci: Add `release` job
f9b38894ba ci: Update `actions/checkout` version
727bec5bc2 Merge bitcoin-core/secp256k1#1414: ci/gha: Add ARM64 QEMU jobs for clang and clang-snapshot
2635068abf ci/gha: Let MSan continue checking after errors in all jobs
e78c7b68eb ci/Dockerfile: Reduce size of Docker image further
2f0d3bbffb ci/Dockerfile: Warn if `ulimit -n` is too high when running Docker
4b8a647ad3 ci/gha: Add ARM64 QEMU jobs for clang and clang-snapshot
6ebe7d2bb3 ci/Dockerfile: Always use versioned clang packages
65c79fe2d0 Merge bitcoin-core/secp256k1#1412: ci: Switch macOS from Ventura to Monterey and add Valgrind
c223d7e33d ci: Switch macOS from Ventura to Monterey and add Valgrind
ea26b71c3a Merge bitcoin-core/secp256k1#1411: ci: Make repetitive command the default one
cce0456304 ci: Make repetitive command the default one
317a4c48f0 ci: Move `git config ...` to `run-in-docker-action`
4d7fe60905 Merge bitcoin-core/secp256k1#1409: ci: Move remained task from Cirrus to GitHub Actions
676ed8f9cf ci: Move "C++ (public headers)" from Cirrus to GitHub Actions
61fc3a2dc8 ci: Move "C++ -fpermissive..." from Cirrus to GitHub Actions
d51fb0a533 ci: Move "MSan" from Cirrus to GitHub Actions
c22ac27529 ci: Move sanitizers task from Cirrus to GitHub Actions
26a989924b Merge bitcoin-core/secp256k1#1410: ci: Use concurrency for pull requests only
ee1be62d84 ci: Use concurrency for pull requests only
6ee14550c8 Merge bitcoin-core/secp256k1#1406: ci, gha: Move more non-x86_64 tasks from Cirrus CI to GitHub Actions
fc3dea29ea ci: Move "ppc64le: Linux..." from Cirrus to GitHub Actions
7782dc8276 ci: Move "ARM64: Linux..." from Cirrus to GitHub Actions
0a16de671c ci: Move "ARM32: Linux..." from Cirrus to GitHub Actions
ea33914e00 ci: Move "s390x (big-endian): Linux..." from Cirrus to GitHub Actions
880be8af99 ci: Move "i686: Linux (Debian stable)" from Cirrus to GiHub Actions
2e6cf9bae5 Merge bitcoin-core/secp256k1#1396: ci, gha: Add "x86_64: Linux (Debian stable)" GitHub Actions job
5373693e45 Merge bitcoin-core/secp256k1#1405: ci: Drop no longer needed workaround
ef9fe959de ci: Drop no longer needed workaround
e10878f58e ci, gha: Drop `driver-opts.network` input for `setup-buildx-action`
4ad4914bd1 ci, gha: Add `retry_builder` Docker image builder
6617a620d9 ci: Remove "x86_64: Linux (Debian stable)" task from Cirrus CI
03c9e6508c ci, gha: Add "x86_64: Linux (Debian stable)" GitHub Actions job
ad3e65d9fe ci: Remove GCC build files and sage to reduce size of Docker image
6b9507adf6 Merge bitcoin-core/secp256k1#1398: ci, gha: Add Windows jobs based on Linux image
87d35f30c0 ci: Rename `cirrus.sh` to more general `ci.sh`
d6281dd008 ci: Remove Windows tasks from Cirrus CI
2b6f9cd546 ci, gha: Add Windows jobs based on Linux image
48b1d939b5 Merge bitcoin-core/secp256k1#1403: ci, gha: Ensure only a single workflow processes `github.ref` at a time
0ba2b94551 Merge bitcoin-core/secp256k1#1373: Add invariant checking for scalars
060e32cb60 Merge bitcoin-core/secp256k1#1401: ci, gha: Run all MSVC tests on Windows natively
de657c2044 Merge bitcoin-core/secp256k1#1062: Removes `_fe_equal_var`, and unwanted `_fe_normalize_weak` calls (in tests)
bcffeb14bc Merge bitcoin-core/secp256k1#1404: ci: Remove "arm64: macOS Ventura" task from Cirrus CI
c2f6435802 ci: Add comment about switching macOS to M1 on GHA later
4a24fae0bc ci: Remove "arm64: macOS Ventura" task from Cirrus CI
b0886fd35c ci, gha: Ensure only a single workflow processes `github.ref` at a time
3d05c86d63 Merge bitcoin-core/secp256k1#1394: ci, gha: Run "x86_64: macOS Ventura" job on GitHub Actions
d78bec7001 ci: Remove Windows MSVC tasks from Cirrus CI
3545dc2b9b ci, gha: Run all MSVC tests on Windows natively
5d8fa825e2 Merge bitcoin-core/secp256k1#1274: test: Silent noisy clang warnings about Valgrind code on macOS x86_64
8e54a346d2 ci, gha: Run "x86_64: macOS Ventura" job on GitHub Actions
b327abfcea Merge bitcoin-core/secp256k1#1402: ci: Use Homebrew's gcc in native macOS task
d62db57427 ci: Use Homebrew's gcc in native macOS task
54058d16fe field: remove `secp256k1_fe_equal_var`
bb4efd6404 tests: remove unwanted `secp256k1_fe_normalize_weak` call
eedd781085 Merge bitcoin-core/secp256k1#1348: tighten group magnitude limits, save normalize_weak calls in group add methods (revival of #1032)
b2f6712dd3 Merge bitcoin-core/secp256k1#1400: ctimetests: Use new SECP256K1_CHECKMEM macros also for ellswift
9c91ea41b1 ci: Enable ellswift module where it's missing
db32a24761 ctimetests: Use new SECP256K1_CHECKMEM macros also for ellswift
ce765a5b8e Merge bitcoin-core/secp256k1#1399: ci, gha: Run "SageMath prover" job on GitHub Actions
8408dfdc4c Revert "ci: Run sage prover on CI"
c8d9914fb1 ci, gha: Run "SageMath prover" job on GitHub Actions
8d2960c8e2 Merge bitcoin-core/secp256k1#1397: ci: Remove "Windows (VS 2022)" task from Cirrus CI
f1774e5ec4 ci, gha: Make MSVC job presentation more explicit
5ee039bb58 ci: Remove "Windows (VS 2022)" task from Cirrus CI
96294c00fb Merge bitcoin-core/secp256k1#1389: ci: Run "Windows (VS 2022)" job on GitHub Actions
a2f7ccdecc ci: Run "Windows (VS 2022)" job on GitHub Actions
374e2b54e2 Merge bitcoin-core/secp256k1#1290: cmake: Set `ENVIRONMENT` property for examples on Windows
1b13415df9 Merge bitcoin-core/secp256k1#1391: refactor: take use of `secp256k1_scalar_{zero,one}` constants (part 2)
a1bd4971d6 refactor: take use of `secp256k1_scalar_{zero,one}` constants (part 2)
b7c685e74a Save _normalize_weak calls in group add methods
c83afa66e0 Tighten group magnitude limits
26392da2fb Merge bitcoin-core/secp256k1#1386: ci: print $ELLSWIFT in cirrus.sh
d23da6d557 use secp256k1_scalar_verify checks
4692478853 ci: print $ELLSWIFT in cirrus.sh
c7d0454932 add verification for scalars
c734c64278 Merge bitcoin-core/secp256k1#1384: build: enable ellswift module via SECP_CONFIG_DEFINES
ad152151b0 update max scalar in scalar_cmov_test and fix schnorrsig_verify exhaustive test
78ca880788 build: enable ellswift module via SECP_CONFIG_DEFINES
0e00fc7d10 Merge bitcoin-core/secp256k1#1383: util: remove unused checked_realloc
b097a466c1 util: remove unused checked_realloc
2bd5f3e618 Merge bitcoin-core/secp256k1#1382: refactor: Drop unused cast
4f8c5bd761 refactor: Drop unused cast
173e8d061a Implement current magnitude assumptions
49afd2f5d8 Take use of _fe_verify_magnitude in field_impl.h
4e9661fc42 Add _fe_verify_magnitude (no-op unless VERIFY is enabled)
690b0fc05a add missing group element invariant checks
175db31149 ci: Drop no longer needed `PATH` variable update on Windows
116d2ab3df cmake: Set `ENVIRONMENT` property for examples on Windows
cef373997c cmake, refactor: Use helper function instead of interface library
747ada3587 test: Silent noisy clang warnings about Valgrind code on macOS x86_64
git-subtree-dir: src/secp256k1
git-subtree-split: 199d27cea32203b224b208627533c2e813cd3b21
2023-09-04 12:51:20 -04:00
|
|
|
with:
|
|
|
|
file: ./ci/linux-debian.Dockerfile
|
|
|
|
tags: linux-debian-image
|
|
|
|
cache-from: type=gha
|
|
|
|
cache-to: type=gha,mode=min
|
|
|
|
|
|
|
|
linux_debian:
|
|
|
|
name: "x86_64: Linux (Debian stable)"
|
|
|
|
runs-on: ubuntu-latest
|
|
|
|
needs: docker_cache
|
|
|
|
|
|
|
|
strategy:
|
|
|
|
fail-fast: false
|
|
|
|
matrix:
|
|
|
|
configuration:
|
|
|
|
- env_vars: { WIDEMUL: 'int64', RECOVERY: 'yes' }
|
|
|
|
- env_vars: { WIDEMUL: 'int64', ECDH: 'yes', SCHNORRSIG: 'yes', ELLSWIFT: 'yes' }
|
|
|
|
- env_vars: { WIDEMUL: 'int128' }
|
|
|
|
- env_vars: { WIDEMUL: 'int128_struct', ELLSWIFT: 'yes' }
|
|
|
|
- env_vars: { WIDEMUL: 'int128', RECOVERY: 'yes', SCHNORRSIG: 'yes', ELLSWIFT: 'yes' }
|
|
|
|
- env_vars: { WIDEMUL: 'int128', ECDH: 'yes', SCHNORRSIG: 'yes' }
|
|
|
|
- env_vars: { WIDEMUL: 'int128', ASM: 'x86_64', ELLSWIFT: 'yes' }
|
|
|
|
- env_vars: { RECOVERY: 'yes', SCHNORRSIG: 'yes' }
|
|
|
|
- env_vars: { CTIMETESTS: 'no', RECOVERY: 'yes', ECDH: 'yes', SCHNORRSIG: 'yes', CPPFLAGS: '-DVERIFY' }
|
|
|
|
- env_vars: { BUILD: 'distcheck', WITH_VALGRIND: 'no', CTIMETESTS: 'no', BENCH: 'no' }
|
|
|
|
- env_vars: { CPPFLAGS: '-DDETERMINISTIC' }
|
|
|
|
- env_vars: { CFLAGS: '-O0', CTIMETESTS: 'no' }
|
|
|
|
- env_vars: { CFLAGS: '-O1', RECOVERY: 'yes', ECDH: 'yes', SCHNORRSIG: 'yes', ELLSWIFT: 'yes' }
|
|
|
|
- env_vars: { ECMULTGENPRECISION: 2, ECMULTWINDOW: 2 }
|
|
|
|
- env_vars: { ECMULTGENPRECISION: 8, ECMULTWINDOW: 4 }
|
|
|
|
cc:
|
|
|
|
- 'gcc'
|
|
|
|
- 'clang'
|
|
|
|
- 'gcc-snapshot'
|
|
|
|
- 'clang-snapshot'
|
|
|
|
|
|
|
|
env:
|
|
|
|
CC: ${{ matrix.cc }}
|
|
|
|
|
|
|
|
steps:
|
|
|
|
- name: Checkout
|
|
|
|
uses: actions/checkout@v4
|
|
|
|
|
|
|
|
- name: CI script
|
|
|
|
env: ${{ matrix.configuration.env_vars }}
|
|
|
|
uses: ./.github/actions/run-in-docker-action
|
|
|
|
with:
|
|
|
|
dockerfile: ./ci/linux-debian.Dockerfile
|
|
|
|
tag: linux-debian-image
|
|
|
|
|
|
|
|
- run: cat tests.log || true
|
|
|
|
if: ${{ always() }}
|
|
|
|
- run: cat noverify_tests.log || true
|
|
|
|
if: ${{ always() }}
|
|
|
|
- run: cat exhaustive_tests.log || true
|
|
|
|
if: ${{ always() }}
|
|
|
|
- run: cat ctime_tests.log || true
|
|
|
|
if: ${{ always() }}
|
|
|
|
- run: cat bench.log || true
|
|
|
|
if: ${{ always() }}
|
|
|
|
- run: cat config.log || true
|
|
|
|
if: ${{ always() }}
|
|
|
|
- run: cat test_env.log || true
|
|
|
|
if: ${{ always() }}
|
|
|
|
- name: CI env
|
|
|
|
run: env
|
|
|
|
if: ${{ always() }}
|
|
|
|
|
|
|
|
i686_debian:
|
|
|
|
name: "i686: Linux (Debian stable)"
|
|
|
|
runs-on: ubuntu-latest
|
|
|
|
needs: docker_cache
|
|
|
|
|
|
|
|
strategy:
|
|
|
|
fail-fast: false
|
|
|
|
matrix:
|
|
|
|
cc:
|
|
|
|
- 'i686-linux-gnu-gcc'
|
|
|
|
- 'clang --target=i686-pc-linux-gnu -isystem /usr/i686-linux-gnu/include'
|
|
|
|
|
|
|
|
env:
|
|
|
|
HOST: 'i686-linux-gnu'
|
|
|
|
ECDH: 'yes'
|
|
|
|
RECOVERY: 'yes'
|
|
|
|
SCHNORRSIG: 'yes'
|
|
|
|
ELLSWIFT: 'yes'
|
|
|
|
CC: ${{ matrix.cc }}
|
|
|
|
|
|
|
|
steps:
|
|
|
|
- name: Checkout
|
|
|
|
uses: actions/checkout@v4
|
|
|
|
|
|
|
|
- name: CI script
|
|
|
|
uses: ./.github/actions/run-in-docker-action
|
|
|
|
with:
|
|
|
|
dockerfile: ./ci/linux-debian.Dockerfile
|
|
|
|
tag: linux-debian-image
|
|
|
|
|
|
|
|
- run: cat tests.log || true
|
|
|
|
if: ${{ always() }}
|
|
|
|
- run: cat noverify_tests.log || true
|
|
|
|
if: ${{ always() }}
|
|
|
|
- run: cat exhaustive_tests.log || true
|
|
|
|
if: ${{ always() }}
|
|
|
|
- run: cat ctime_tests.log || true
|
|
|
|
if: ${{ always() }}
|
|
|
|
- run: cat bench.log || true
|
|
|
|
if: ${{ always() }}
|
|
|
|
- run: cat config.log || true
|
|
|
|
if: ${{ always() }}
|
|
|
|
- run: cat test_env.log || true
|
|
|
|
if: ${{ always() }}
|
|
|
|
- name: CI env
|
|
|
|
run: env
|
|
|
|
if: ${{ always() }}
|
|
|
|
|
|
|
|
s390x_debian:
|
|
|
|
name: "s390x (big-endian): Linux (Debian stable, QEMU)"
|
|
|
|
runs-on: ubuntu-latest
|
|
|
|
needs: docker_cache
|
|
|
|
|
|
|
|
env:
|
|
|
|
WRAPPER_CMD: 'qemu-s390x'
|
|
|
|
SECP256K1_TEST_ITERS: 16
|
|
|
|
HOST: 's390x-linux-gnu'
|
|
|
|
WITH_VALGRIND: 'no'
|
|
|
|
ECDH: 'yes'
|
|
|
|
RECOVERY: 'yes'
|
|
|
|
SCHNORRSIG: 'yes'
|
|
|
|
ELLSWIFT: 'yes'
|
|
|
|
CTIMETESTS: 'no'
|
|
|
|
|
|
|
|
steps:
|
|
|
|
- name: Checkout
|
|
|
|
uses: actions/checkout@v4
|
|
|
|
|
|
|
|
- name: CI script
|
|
|
|
uses: ./.github/actions/run-in-docker-action
|
|
|
|
with:
|
|
|
|
dockerfile: ./ci/linux-debian.Dockerfile
|
|
|
|
tag: linux-debian-image
|
|
|
|
|
|
|
|
- run: cat tests.log || true
|
|
|
|
if: ${{ always() }}
|
|
|
|
- run: cat noverify_tests.log || true
|
|
|
|
if: ${{ always() }}
|
|
|
|
- run: cat exhaustive_tests.log || true
|
|
|
|
if: ${{ always() }}
|
|
|
|
- run: cat ctime_tests.log || true
|
|
|
|
if: ${{ always() }}
|
|
|
|
- run: cat bench.log || true
|
|
|
|
if: ${{ always() }}
|
|
|
|
- run: cat config.log || true
|
|
|
|
if: ${{ always() }}
|
|
|
|
- run: cat test_env.log || true
|
|
|
|
if: ${{ always() }}
|
|
|
|
- name: CI env
|
|
|
|
run: env
|
|
|
|
if: ${{ always() }}
|
|
|
|
|
|
|
|
arm32_debian:
|
|
|
|
name: "ARM32: Linux (Debian stable, QEMU)"
|
|
|
|
runs-on: ubuntu-latest
|
|
|
|
needs: docker_cache
|
|
|
|
|
|
|
|
strategy:
|
|
|
|
fail-fast: false
|
|
|
|
matrix:
|
|
|
|
configuration:
|
|
|
|
- env_vars: {}
|
|
|
|
- env_vars: { EXPERIMENTAL: 'yes', ASM: 'arm32' }
|
|
|
|
|
|
|
|
env:
|
|
|
|
WRAPPER_CMD: 'qemu-arm'
|
|
|
|
SECP256K1_TEST_ITERS: 16
|
|
|
|
HOST: 'arm-linux-gnueabihf'
|
|
|
|
WITH_VALGRIND: 'no'
|
|
|
|
ECDH: 'yes'
|
|
|
|
RECOVERY: 'yes'
|
|
|
|
SCHNORRSIG: 'yes'
|
|
|
|
ELLSWIFT: 'yes'
|
|
|
|
CTIMETESTS: 'no'
|
|
|
|
|
|
|
|
steps:
|
|
|
|
- name: Checkout
|
|
|
|
uses: actions/checkout@v4
|
|
|
|
|
|
|
|
- name: CI script
|
|
|
|
env: ${{ matrix.configuration.env_vars }}
|
|
|
|
uses: ./.github/actions/run-in-docker-action
|
|
|
|
with:
|
|
|
|
dockerfile: ./ci/linux-debian.Dockerfile
|
|
|
|
tag: linux-debian-image
|
|
|
|
|
|
|
|
- run: cat tests.log || true
|
|
|
|
if: ${{ always() }}
|
|
|
|
- run: cat noverify_tests.log || true
|
|
|
|
if: ${{ always() }}
|
|
|
|
- run: cat exhaustive_tests.log || true
|
|
|
|
if: ${{ always() }}
|
|
|
|
- run: cat ctime_tests.log || true
|
|
|
|
if: ${{ always() }}
|
|
|
|
- run: cat bench.log || true
|
|
|
|
if: ${{ always() }}
|
|
|
|
- run: cat config.log || true
|
|
|
|
if: ${{ always() }}
|
|
|
|
- run: cat test_env.log || true
|
|
|
|
if: ${{ always() }}
|
|
|
|
- name: CI env
|
|
|
|
run: env
|
|
|
|
if: ${{ always() }}
|
|
|
|
|
|
|
|
arm64_debian:
|
|
|
|
name: "ARM64: Linux (Debian stable, QEMU)"
|
|
|
|
runs-on: ubuntu-latest
|
|
|
|
needs: docker_cache
|
|
|
|
|
|
|
|
env:
|
|
|
|
WRAPPER_CMD: 'qemu-aarch64'
|
|
|
|
SECP256K1_TEST_ITERS: 16
|
|
|
|
HOST: 'aarch64-linux-gnu'
|
|
|
|
WITH_VALGRIND: 'no'
|
|
|
|
ECDH: 'yes'
|
|
|
|
RECOVERY: 'yes'
|
|
|
|
SCHNORRSIG: 'yes'
|
|
|
|
ELLSWIFT: 'yes'
|
|
|
|
CTIMETESTS: 'no'
|
|
|
|
|
|
|
|
strategy:
|
|
|
|
fail-fast: false
|
|
|
|
matrix:
|
|
|
|
configuration:
|
|
|
|
- env_vars: { } # gcc
|
|
|
|
- env_vars: # clang
|
|
|
|
CC: 'clang --target=aarch64-linux-gnu'
|
|
|
|
- env_vars: # clang-snapshot
|
|
|
|
CC: 'clang-snapshot --target=aarch64-linux-gnu'
|
|
|
|
|
|
|
|
steps:
|
|
|
|
- name: Checkout
|
|
|
|
uses: actions/checkout@v4
|
|
|
|
|
|
|
|
- name: CI script
|
|
|
|
env: ${{ matrix.configuration.env_vars }}
|
|
|
|
uses: ./.github/actions/run-in-docker-action
|
|
|
|
with:
|
|
|
|
dockerfile: ./ci/linux-debian.Dockerfile
|
|
|
|
tag: linux-debian-image
|
|
|
|
|
|
|
|
- run: cat tests.log || true
|
|
|
|
if: ${{ always() }}
|
|
|
|
- run: cat noverify_tests.log || true
|
|
|
|
if: ${{ always() }}
|
|
|
|
- run: cat exhaustive_tests.log || true
|
|
|
|
if: ${{ always() }}
|
|
|
|
- run: cat ctime_tests.log || true
|
|
|
|
if: ${{ always() }}
|
|
|
|
- run: cat bench.log || true
|
|
|
|
if: ${{ always() }}
|
|
|
|
- run: cat config.log || true
|
|
|
|
if: ${{ always() }}
|
|
|
|
- run: cat test_env.log || true
|
|
|
|
if: ${{ always() }}
|
|
|
|
- name: CI env
|
|
|
|
run: env
|
|
|
|
if: ${{ always() }}
|
|
|
|
|
|
|
|
ppc64le_debian:
|
|
|
|
name: "ppc64le: Linux (Debian stable, QEMU)"
|
|
|
|
runs-on: ubuntu-latest
|
|
|
|
needs: docker_cache
|
|
|
|
|
|
|
|
env:
|
|
|
|
WRAPPER_CMD: 'qemu-ppc64le'
|
|
|
|
SECP256K1_TEST_ITERS: 16
|
|
|
|
HOST: 'powerpc64le-linux-gnu'
|
|
|
|
WITH_VALGRIND: 'no'
|
|
|
|
ECDH: 'yes'
|
|
|
|
RECOVERY: 'yes'
|
|
|
|
SCHNORRSIG: 'yes'
|
|
|
|
ELLSWIFT: 'yes'
|
|
|
|
CTIMETESTS: 'no'
|
|
|
|
|
|
|
|
steps:
|
|
|
|
- name: Checkout
|
|
|
|
uses: actions/checkout@v4
|
|
|
|
|
|
|
|
- name: CI script
|
|
|
|
uses: ./.github/actions/run-in-docker-action
|
|
|
|
with:
|
|
|
|
dockerfile: ./ci/linux-debian.Dockerfile
|
|
|
|
tag: linux-debian-image
|
|
|
|
|
|
|
|
- run: cat tests.log || true
|
|
|
|
if: ${{ always() }}
|
|
|
|
- run: cat noverify_tests.log || true
|
|
|
|
if: ${{ always() }}
|
|
|
|
- run: cat exhaustive_tests.log || true
|
|
|
|
if: ${{ always() }}
|
|
|
|
- run: cat ctime_tests.log || true
|
|
|
|
if: ${{ always() }}
|
|
|
|
- run: cat bench.log || true
|
|
|
|
if: ${{ always() }}
|
|
|
|
- run: cat config.log || true
|
|
|
|
if: ${{ always() }}
|
|
|
|
- run: cat test_env.log || true
|
|
|
|
if: ${{ always() }}
|
|
|
|
- name: CI env
|
|
|
|
run: env
|
|
|
|
if: ${{ always() }}
|
|
|
|
|
|
|
|
valgrind_debian:
|
|
|
|
name: "Valgrind (memcheck)"
|
|
|
|
runs-on: ubuntu-latest
|
|
|
|
needs: docker_cache
|
|
|
|
|
|
|
|
strategy:
|
|
|
|
fail-fast: false
|
|
|
|
matrix:
|
|
|
|
configuration:
|
|
|
|
- env_vars: { CC: 'clang', ASM: 'auto' }
|
|
|
|
- env_vars: { CC: 'i686-linux-gnu-gcc', HOST: 'i686-linux-gnu', ASM: 'auto' }
|
|
|
|
- env_vars: { CC: 'clang', ASM: 'no', ECMULTGENPRECISION: 2, ECMULTWINDOW: 2 }
|
|
|
|
- env_vars: { CC: 'i686-linux-gnu-gcc', HOST: 'i686-linux-gnu', ASM: 'no', ECMULTGENPRECISION: 2, ECMULTWINDOW: 2 }
|
|
|
|
|
|
|
|
env:
|
|
|
|
# The `--error-exitcode` is required to make the test fail if valgrind found errors,
|
|
|
|
# otherwise it will return 0 (https://www.valgrind.org/docs/manual/manual-core.html).
|
|
|
|
WRAPPER_CMD: 'valgrind --error-exitcode=42'
|
|
|
|
ECDH: 'yes'
|
|
|
|
RECOVERY: 'yes'
|
|
|
|
SCHNORRSIG: 'yes'
|
|
|
|
ELLSWIFT: 'yes'
|
|
|
|
CTIMETESTS: 'no'
|
|
|
|
SECP256K1_TEST_ITERS: 2
|
|
|
|
|
|
|
|
steps:
|
|
|
|
- name: Checkout
|
|
|
|
uses: actions/checkout@v4
|
|
|
|
|
|
|
|
- name: CI script
|
|
|
|
env: ${{ matrix.configuration.env_vars }}
|
|
|
|
uses: ./.github/actions/run-in-docker-action
|
|
|
|
with:
|
|
|
|
dockerfile: ./ci/linux-debian.Dockerfile
|
|
|
|
tag: linux-debian-image
|
|
|
|
|
|
|
|
- run: cat tests.log || true
|
|
|
|
if: ${{ always() }}
|
|
|
|
- run: cat noverify_tests.log || true
|
|
|
|
if: ${{ always() }}
|
|
|
|
- run: cat exhaustive_tests.log || true
|
|
|
|
if: ${{ always() }}
|
|
|
|
- run: cat ctime_tests.log || true
|
|
|
|
if: ${{ always() }}
|
|
|
|
- run: cat bench.log || true
|
|
|
|
if: ${{ always() }}
|
|
|
|
- run: cat config.log || true
|
|
|
|
if: ${{ always() }}
|
|
|
|
- run: cat test_env.log || true
|
|
|
|
if: ${{ always() }}
|
|
|
|
- name: CI env
|
|
|
|
run: env
|
|
|
|
if: ${{ always() }}
|
|
|
|
|
|
|
|
sanitizers_debian:
|
|
|
|
name: "UBSan, ASan, LSan"
|
|
|
|
runs-on: ubuntu-latest
|
|
|
|
needs: docker_cache
|
|
|
|
|
|
|
|
strategy:
|
|
|
|
fail-fast: false
|
|
|
|
matrix:
|
|
|
|
configuration:
|
|
|
|
- env_vars: { CC: 'clang', ASM: 'auto' }
|
|
|
|
- env_vars: { CC: 'i686-linux-gnu-gcc', HOST: 'i686-linux-gnu', ASM: 'auto' }
|
|
|
|
- env_vars: { CC: 'clang', ASM: 'no', ECMULTGENPRECISION: 2, ECMULTWINDOW: 2 }
|
|
|
|
- env_vars: { CC: 'i686-linux-gnu-gcc', HOST: 'i686-linux-gnu', ASM: 'no', ECMULTGENPRECISION: 2, ECMULTWINDOW: 2 }
|
|
|
|
|
|
|
|
env:
|
|
|
|
ECDH: 'yes'
|
|
|
|
RECOVERY: 'yes'
|
|
|
|
SCHNORRSIG: 'yes'
|
|
|
|
ELLSWIFT: 'yes'
|
|
|
|
CTIMETESTS: 'no'
|
|
|
|
CFLAGS: '-fsanitize=undefined,address -g'
|
|
|
|
UBSAN_OPTIONS: 'print_stacktrace=1:halt_on_error=1'
|
|
|
|
ASAN_OPTIONS: 'strict_string_checks=1:detect_stack_use_after_return=1:detect_leaks=1'
|
|
|
|
LSAN_OPTIONS: 'use_unaligned=1'
|
|
|
|
SECP256K1_TEST_ITERS: 32
|
|
|
|
|
|
|
|
steps:
|
|
|
|
- name: Checkout
|
|
|
|
uses: actions/checkout@v4
|
|
|
|
|
|
|
|
- name: CI script
|
|
|
|
env: ${{ matrix.configuration.env_vars }}
|
|
|
|
uses: ./.github/actions/run-in-docker-action
|
|
|
|
with:
|
|
|
|
dockerfile: ./ci/linux-debian.Dockerfile
|
|
|
|
tag: linux-debian-image
|
|
|
|
|
|
|
|
- run: cat tests.log || true
|
|
|
|
if: ${{ always() }}
|
|
|
|
- run: cat noverify_tests.log || true
|
|
|
|
if: ${{ always() }}
|
|
|
|
- run: cat exhaustive_tests.log || true
|
|
|
|
if: ${{ always() }}
|
|
|
|
- run: cat ctime_tests.log || true
|
|
|
|
if: ${{ always() }}
|
|
|
|
- run: cat bench.log || true
|
|
|
|
if: ${{ always() }}
|
|
|
|
- run: cat config.log || true
|
|
|
|
if: ${{ always() }}
|
|
|
|
- run: cat test_env.log || true
|
|
|
|
if: ${{ always() }}
|
|
|
|
- name: CI env
|
|
|
|
run: env
|
|
|
|
if: ${{ always() }}
|
|
|
|
|
|
|
|
msan_debian:
|
|
|
|
name: "MSan"
|
|
|
|
runs-on: ubuntu-latest
|
|
|
|
needs: docker_cache
|
|
|
|
|
|
|
|
strategy:
|
|
|
|
fail-fast: false
|
|
|
|
matrix:
|
|
|
|
configuration:
|
|
|
|
- env_vars:
|
|
|
|
CFLAGS: '-fsanitize=memory -fsanitize-recover=memory -g'
|
|
|
|
- env_vars:
|
|
|
|
ECMULTGENPRECISION: 2
|
|
|
|
ECMULTWINDOW: 2
|
|
|
|
CFLAGS: '-fsanitize=memory -fsanitize-recover=memory -g -O3'
|
|
|
|
|
|
|
|
env:
|
|
|
|
ECDH: 'yes'
|
|
|
|
RECOVERY: 'yes'
|
|
|
|
SCHNORRSIG: 'yes'
|
|
|
|
ELLSWIFT: 'yes'
|
|
|
|
CTIMETESTS: 'yes'
|
|
|
|
CC: 'clang'
|
|
|
|
SECP256K1_TEST_ITERS: 32
|
|
|
|
ASM: 'no'
|
|
|
|
WITH_VALGRIND: 'no'
|
|
|
|
|
|
|
|
steps:
|
|
|
|
- name: Checkout
|
|
|
|
uses: actions/checkout@v4
|
|
|
|
|
|
|
|
- name: CI script
|
|
|
|
env: ${{ matrix.configuration.env_vars }}
|
|
|
|
uses: ./.github/actions/run-in-docker-action
|
|
|
|
with:
|
|
|
|
dockerfile: ./ci/linux-debian.Dockerfile
|
|
|
|
tag: linux-debian-image
|
|
|
|
|
|
|
|
- run: cat tests.log || true
|
|
|
|
if: ${{ always() }}
|
|
|
|
- run: cat noverify_tests.log || true
|
|
|
|
if: ${{ always() }}
|
|
|
|
- run: cat exhaustive_tests.log || true
|
|
|
|
if: ${{ always() }}
|
|
|
|
- run: cat ctime_tests.log || true
|
|
|
|
if: ${{ always() }}
|
|
|
|
- run: cat bench.log || true
|
|
|
|
if: ${{ always() }}
|
|
|
|
- run: cat config.log || true
|
|
|
|
if: ${{ always() }}
|
|
|
|
- run: cat test_env.log || true
|
|
|
|
if: ${{ always() }}
|
|
|
|
- name: CI env
|
|
|
|
run: env
|
|
|
|
if: ${{ always() }}
|
|
|
|
|
|
|
|
mingw_debian:
|
|
|
|
name: ${{ matrix.configuration.job_name }}
|
|
|
|
runs-on: ubuntu-latest
|
|
|
|
needs: docker_cache
|
|
|
|
|
|
|
|
env:
|
|
|
|
WRAPPER_CMD: 'wine'
|
|
|
|
WITH_VALGRIND: 'no'
|
|
|
|
ECDH: 'yes'
|
|
|
|
RECOVERY: 'yes'
|
|
|
|
SCHNORRSIG: 'yes'
|
|
|
|
ELLSWIFT: 'yes'
|
|
|
|
CTIMETESTS: 'no'
|
|
|
|
|
|
|
|
strategy:
|
|
|
|
fail-fast: false
|
|
|
|
matrix:
|
|
|
|
configuration:
|
|
|
|
- job_name: 'x86_64 (mingw32-w64): Windows (Debian stable, Wine)'
|
|
|
|
env_vars:
|
|
|
|
HOST: 'x86_64-w64-mingw32'
|
|
|
|
- job_name: 'i686 (mingw32-w64): Windows (Debian stable, Wine)'
|
|
|
|
env_vars:
|
|
|
|
HOST: 'i686-w64-mingw32'
|
|
|
|
|
|
|
|
steps:
|
|
|
|
- name: Checkout
|
|
|
|
uses: actions/checkout@v4
|
|
|
|
|
|
|
|
- name: CI script
|
|
|
|
env: ${{ matrix.configuration.env_vars }}
|
|
|
|
uses: ./.github/actions/run-in-docker-action
|
|
|
|
with:
|
|
|
|
dockerfile: ./ci/linux-debian.Dockerfile
|
|
|
|
tag: linux-debian-image
|
|
|
|
|
|
|
|
- run: cat tests.log || true
|
|
|
|
if: ${{ always() }}
|
|
|
|
- run: cat noverify_tests.log || true
|
|
|
|
if: ${{ always() }}
|
|
|
|
- run: cat exhaustive_tests.log || true
|
|
|
|
if: ${{ always() }}
|
|
|
|
- run: cat ctime_tests.log || true
|
|
|
|
if: ${{ always() }}
|
|
|
|
- run: cat bench.log || true
|
|
|
|
if: ${{ always() }}
|
|
|
|
- run: cat config.log || true
|
|
|
|
if: ${{ always() }}
|
|
|
|
- run: cat test_env.log || true
|
|
|
|
if: ${{ always() }}
|
|
|
|
- name: CI env
|
|
|
|
run: env
|
|
|
|
if: ${{ always() }}
|
|
|
|
|
|
|
|
macos-native:
|
|
|
|
name: "x86_64: macOS Monterey"
|
|
|
|
# See: https://github.com/actions/runner-images#available-images.
|
|
|
|
runs-on: macos-12 # Use M1 once available https://github.com/github/roadmap/issues/528
|
|
|
|
|
|
|
|
env:
|
|
|
|
CC: 'clang'
|
|
|
|
HOMEBREW_NO_AUTO_UPDATE: 1
|
|
|
|
HOMEBREW_NO_INSTALL_CLEANUP: 1
|
|
|
|
|
|
|
|
strategy:
|
|
|
|
fail-fast: false
|
|
|
|
matrix:
|
|
|
|
env_vars:
|
|
|
|
- { WIDEMUL: 'int64', RECOVERY: 'yes', ECDH: 'yes', SCHNORRSIG: 'yes', ELLSWIFT: 'yes' }
|
|
|
|
- { WIDEMUL: 'int128_struct', ECMULTGENPRECISION: 2, ECMULTWINDOW: 4 }
|
|
|
|
- { WIDEMUL: 'int128', ECDH: 'yes', SCHNORRSIG: 'yes', ELLSWIFT: 'yes' }
|
|
|
|
- { WIDEMUL: 'int128', RECOVERY: 'yes' }
|
|
|
|
- { WIDEMUL: 'int128', RECOVERY: 'yes', ECDH: 'yes', SCHNORRSIG: 'yes', ELLSWIFT: 'yes' }
|
|
|
|
- { WIDEMUL: 'int128', RECOVERY: 'yes', ECDH: 'yes', SCHNORRSIG: 'yes', ELLSWIFT: 'yes', CC: 'gcc' }
|
|
|
|
- { WIDEMUL: 'int128', RECOVERY: 'yes', ECDH: 'yes', SCHNORRSIG: 'yes', ELLSWIFT: 'yes', WRAPPER_CMD: 'valgrind --error-exitcode=42', SECP256K1_TEST_ITERS: 2 }
|
|
|
|
- { WIDEMUL: 'int128', RECOVERY: 'yes', ECDH: 'yes', SCHNORRSIG: 'yes', ELLSWIFT: 'yes', CC: 'gcc', WRAPPER_CMD: 'valgrind --error-exitcode=42', SECP256K1_TEST_ITERS: 2 }
|
|
|
|
- { WIDEMUL: 'int128', RECOVERY: 'yes', ECDH: 'yes', SCHNORRSIG: 'yes', ELLSWIFT: 'yes', CPPFLAGS: '-DVERIFY', CTIMETESTS: 'no' }
|
|
|
|
- BUILD: 'distcheck'
|
|
|
|
|
|
|
|
steps:
|
|
|
|
- name: Checkout
|
|
|
|
uses: actions/checkout@v4
|
|
|
|
|
|
|
|
- name: Install Homebrew packages
|
|
|
|
run: |
|
|
|
|
brew install automake libtool gcc
|
|
|
|
ln -s $(brew --prefix gcc)/bin/gcc-?? /usr/local/bin/gcc
|
|
|
|
|
|
|
|
- name: Install and cache Valgrind
|
|
|
|
uses: ./.github/actions/install-homebrew-valgrind
|
|
|
|
|
|
|
|
- name: CI script
|
|
|
|
env: ${{ matrix.env_vars }}
|
|
|
|
run: ./ci/ci.sh
|
|
|
|
|
|
|
|
- run: cat tests.log || true
|
|
|
|
if: ${{ always() }}
|
|
|
|
- run: cat noverify_tests.log || true
|
|
|
|
if: ${{ always() }}
|
|
|
|
- run: cat exhaustive_tests.log || true
|
|
|
|
if: ${{ always() }}
|
|
|
|
- run: cat ctime_tests.log || true
|
|
|
|
if: ${{ always() }}
|
|
|
|
- run: cat bench.log || true
|
|
|
|
if: ${{ always() }}
|
|
|
|
- run: cat config.log || true
|
|
|
|
if: ${{ always() }}
|
|
|
|
- run: cat test_env.log || true
|
|
|
|
if: ${{ always() }}
|
|
|
|
- name: CI env
|
|
|
|
run: env
|
|
|
|
if: ${{ always() }}
|
|
|
|
|
|
|
|
win64-native:
|
|
|
|
name: ${{ matrix.configuration.job_name }}
|
|
|
|
# See: https://github.com/actions/runner-images#available-images.
|
|
|
|
runs-on: windows-2022
|
|
|
|
|
|
|
|
strategy:
|
|
|
|
fail-fast: false
|
|
|
|
matrix:
|
|
|
|
configuration:
|
|
|
|
- job_name: 'x64 (MSVC): Windows (VS 2022, shared)'
|
|
|
|
cmake_options: '-A x64 -DBUILD_SHARED_LIBS=ON'
|
|
|
|
- job_name: 'x64 (MSVC): Windows (VS 2022, static)'
|
|
|
|
cmake_options: '-A x64 -DBUILD_SHARED_LIBS=OFF'
|
|
|
|
- job_name: 'x64 (MSVC): Windows (VS 2022, int128_struct)'
|
|
|
|
cmake_options: '-A x64 -DSECP256K1_TEST_OVERRIDE_WIDE_MULTIPLY=int128_struct'
|
|
|
|
- job_name: 'x64 (MSVC): Windows (VS 2022, int128_struct with __(u)mulh)'
|
|
|
|
cmake_options: '-A x64 -DSECP256K1_TEST_OVERRIDE_WIDE_MULTIPLY=int128_struct'
|
|
|
|
cpp_flags: '/DSECP256K1_MSVC_MULH_TEST_OVERRIDE'
|
|
|
|
- job_name: 'x86 (MSVC): Windows (VS 2022)'
|
|
|
|
cmake_options: '-A Win32'
|
|
|
|
|
|
|
|
steps:
|
|
|
|
- name: Checkout
|
|
|
|
uses: actions/checkout@v4
|
|
|
|
|
|
|
|
- name: Generate buildsystem
|
|
|
|
run: cmake -E env CFLAGS="/WX ${{ matrix.configuration.cpp_flags }}" cmake -B build -DSECP256K1_ENABLE_MODULE_RECOVERY=ON -DSECP256K1_BUILD_EXAMPLES=ON ${{ matrix.configuration.cmake_options }}
|
|
|
|
|
|
|
|
- name: Build
|
|
|
|
run: cmake --build build --config RelWithDebInfo -- /p:UseMultiToolTask=true /maxCpuCount
|
|
|
|
|
|
|
|
- name: Binaries info
|
|
|
|
# Use the bash shell included with Git for Windows.
|
|
|
|
shell: bash
|
|
|
|
run: |
|
|
|
|
cd build/src/RelWithDebInfo && file *tests.exe bench*.exe libsecp256k1-*.dll || true
|
|
|
|
|
|
|
|
- name: Check
|
|
|
|
run: |
|
|
|
|
ctest -C RelWithDebInfo --test-dir build -j ([int]$env:NUMBER_OF_PROCESSORS + 1)
|
|
|
|
build\src\RelWithDebInfo\bench_ecmult.exe
|
|
|
|
build\src\RelWithDebInfo\bench_internal.exe
|
|
|
|
build\src\RelWithDebInfo\bench.exe
|
|
|
|
|
|
|
|
win64-native-headers:
|
|
|
|
name: "x64 (MSVC): C++ (public headers)"
|
|
|
|
# See: https://github.com/actions/runner-images#available-images.
|
|
|
|
runs-on: windows-2022
|
|
|
|
|
|
|
|
steps:
|
|
|
|
- name: Checkout
|
|
|
|
uses: actions/checkout@v4
|
|
|
|
|
|
|
|
- name: Add cl.exe to PATH
|
|
|
|
uses: ilammy/msvc-dev-cmd@v1
|
|
|
|
|
|
|
|
- name: C++ (public headers)
|
|
|
|
run: |
|
|
|
|
cl.exe -c -WX -TP include/*.h
|
|
|
|
|
|
|
|
cxx_fpermissive_debian:
|
|
|
|
name: "C++ -fpermissive (entire project)"
|
|
|
|
runs-on: ubuntu-latest
|
|
|
|
needs: docker_cache
|
|
|
|
|
|
|
|
env:
|
|
|
|
CC: 'g++'
|
|
|
|
CFLAGS: '-fpermissive -g'
|
|
|
|
CPPFLAGS: '-DSECP256K1_CPLUSPLUS_TEST_OVERRIDE'
|
|
|
|
WERROR_CFLAGS:
|
|
|
|
ECDH: 'yes'
|
|
|
|
RECOVERY: 'yes'
|
|
|
|
SCHNORRSIG: 'yes'
|
|
|
|
ELLSWIFT: 'yes'
|
|
|
|
|
|
|
|
steps:
|
|
|
|
- name: Checkout
|
|
|
|
uses: actions/checkout@v4
|
|
|
|
|
|
|
|
- name: CI script
|
|
|
|
uses: ./.github/actions/run-in-docker-action
|
|
|
|
with:
|
|
|
|
dockerfile: ./ci/linux-debian.Dockerfile
|
|
|
|
tag: linux-debian-image
|
|
|
|
|
|
|
|
- run: cat tests.log || true
|
|
|
|
if: ${{ always() }}
|
|
|
|
- run: cat noverify_tests.log || true
|
|
|
|
if: ${{ always() }}
|
|
|
|
- run: cat exhaustive_tests.log || true
|
|
|
|
if: ${{ always() }}
|
|
|
|
- run: cat ctime_tests.log || true
|
|
|
|
if: ${{ always() }}
|
|
|
|
- run: cat bench.log || true
|
|
|
|
if: ${{ always() }}
|
|
|
|
- run: cat config.log || true
|
|
|
|
if: ${{ always() }}
|
|
|
|
- run: cat test_env.log || true
|
|
|
|
if: ${{ always() }}
|
|
|
|
- name: CI env
|
|
|
|
run: env
|
|
|
|
if: ${{ always() }}
|
|
|
|
|
|
|
|
cxx_headers_debian:
|
|
|
|
name: "C++ (public headers)"
|
|
|
|
runs-on: ubuntu-latest
|
|
|
|
needs: docker_cache
|
|
|
|
|
|
|
|
steps:
|
|
|
|
- name: Checkout
|
|
|
|
uses: actions/checkout@v4
|
|
|
|
|
|
|
|
- name: CI script
|
|
|
|
uses: ./.github/actions/run-in-docker-action
|
|
|
|
with:
|
|
|
|
dockerfile: ./ci/linux-debian.Dockerfile
|
|
|
|
tag: linux-debian-image
|
|
|
|
command: |
|
|
|
|
g++ -Werror include/*.h
|
|
|
|
clang -Werror -x c++-header include/*.h
|
|
|
|
|
|
|
|
sage:
|
|
|
|
name: "SageMath prover"
|
|
|
|
runs-on: ubuntu-latest
|
|
|
|
container:
|
|
|
|
image: sagemath/sagemath:latest
|
|
|
|
options: --user root
|
|
|
|
|
|
|
|
steps:
|
|
|
|
- name: Checkout
|
|
|
|
uses: actions/checkout@v4
|
|
|
|
|
|
|
|
- name: CI script
|
|
|
|
run: |
|
|
|
|
cd sage
|
|
|
|
sage prove_group_implementations.sage
|
|
|
|
|
|
|
|
release:
|
|
|
|
runs-on: ubuntu-latest
|
|
|
|
|
|
|
|
steps:
|
|
|
|
- name: Checkout
|
|
|
|
uses: actions/checkout@v4
|
|
|
|
|
|
|
|
- run: ./autogen.sh && ./configure --enable-dev-mode && make distcheck
|
|
|
|
|
|
|
|
- name: Check installation with Autotools
|
|
|
|
env:
|
2024-01-04 14:40:28 +00:00
|
|
|
CI_INSTALL: ${{ runner.temp }}/${{ github.run_id }}${{ github.action }}/install
|
Squashed 'src/secp256k1/' changes from c545fdc374..199d27cea3
199d27cea3 Merge bitcoin-core/secp256k1#1415: release: Prepare for 0.4.0
16339804c9 release: Prepare for 0.4.0
d9a85065a9 changelog: Catch up in preparation of release
0b4640aedd Merge bitcoin-core/secp256k1#1413: ci: Add `release` job
8659a01714 ci: Add `release` job
f9b38894ba ci: Update `actions/checkout` version
727bec5bc2 Merge bitcoin-core/secp256k1#1414: ci/gha: Add ARM64 QEMU jobs for clang and clang-snapshot
2635068abf ci/gha: Let MSan continue checking after errors in all jobs
e78c7b68eb ci/Dockerfile: Reduce size of Docker image further
2f0d3bbffb ci/Dockerfile: Warn if `ulimit -n` is too high when running Docker
4b8a647ad3 ci/gha: Add ARM64 QEMU jobs for clang and clang-snapshot
6ebe7d2bb3 ci/Dockerfile: Always use versioned clang packages
65c79fe2d0 Merge bitcoin-core/secp256k1#1412: ci: Switch macOS from Ventura to Monterey and add Valgrind
c223d7e33d ci: Switch macOS from Ventura to Monterey and add Valgrind
ea26b71c3a Merge bitcoin-core/secp256k1#1411: ci: Make repetitive command the default one
cce0456304 ci: Make repetitive command the default one
317a4c48f0 ci: Move `git config ...` to `run-in-docker-action`
4d7fe60905 Merge bitcoin-core/secp256k1#1409: ci: Move remained task from Cirrus to GitHub Actions
676ed8f9cf ci: Move "C++ (public headers)" from Cirrus to GitHub Actions
61fc3a2dc8 ci: Move "C++ -fpermissive..." from Cirrus to GitHub Actions
d51fb0a533 ci: Move "MSan" from Cirrus to GitHub Actions
c22ac27529 ci: Move sanitizers task from Cirrus to GitHub Actions
26a989924b Merge bitcoin-core/secp256k1#1410: ci: Use concurrency for pull requests only
ee1be62d84 ci: Use concurrency for pull requests only
6ee14550c8 Merge bitcoin-core/secp256k1#1406: ci, gha: Move more non-x86_64 tasks from Cirrus CI to GitHub Actions
fc3dea29ea ci: Move "ppc64le: Linux..." from Cirrus to GitHub Actions
7782dc8276 ci: Move "ARM64: Linux..." from Cirrus to GitHub Actions
0a16de671c ci: Move "ARM32: Linux..." from Cirrus to GitHub Actions
ea33914e00 ci: Move "s390x (big-endian): Linux..." from Cirrus to GitHub Actions
880be8af99 ci: Move "i686: Linux (Debian stable)" from Cirrus to GiHub Actions
2e6cf9bae5 Merge bitcoin-core/secp256k1#1396: ci, gha: Add "x86_64: Linux (Debian stable)" GitHub Actions job
5373693e45 Merge bitcoin-core/secp256k1#1405: ci: Drop no longer needed workaround
ef9fe959de ci: Drop no longer needed workaround
e10878f58e ci, gha: Drop `driver-opts.network` input for `setup-buildx-action`
4ad4914bd1 ci, gha: Add `retry_builder` Docker image builder
6617a620d9 ci: Remove "x86_64: Linux (Debian stable)" task from Cirrus CI
03c9e6508c ci, gha: Add "x86_64: Linux (Debian stable)" GitHub Actions job
ad3e65d9fe ci: Remove GCC build files and sage to reduce size of Docker image
6b9507adf6 Merge bitcoin-core/secp256k1#1398: ci, gha: Add Windows jobs based on Linux image
87d35f30c0 ci: Rename `cirrus.sh` to more general `ci.sh`
d6281dd008 ci: Remove Windows tasks from Cirrus CI
2b6f9cd546 ci, gha: Add Windows jobs based on Linux image
48b1d939b5 Merge bitcoin-core/secp256k1#1403: ci, gha: Ensure only a single workflow processes `github.ref` at a time
0ba2b94551 Merge bitcoin-core/secp256k1#1373: Add invariant checking for scalars
060e32cb60 Merge bitcoin-core/secp256k1#1401: ci, gha: Run all MSVC tests on Windows natively
de657c2044 Merge bitcoin-core/secp256k1#1062: Removes `_fe_equal_var`, and unwanted `_fe_normalize_weak` calls (in tests)
bcffeb14bc Merge bitcoin-core/secp256k1#1404: ci: Remove "arm64: macOS Ventura" task from Cirrus CI
c2f6435802 ci: Add comment about switching macOS to M1 on GHA later
4a24fae0bc ci: Remove "arm64: macOS Ventura" task from Cirrus CI
b0886fd35c ci, gha: Ensure only a single workflow processes `github.ref` at a time
3d05c86d63 Merge bitcoin-core/secp256k1#1394: ci, gha: Run "x86_64: macOS Ventura" job on GitHub Actions
d78bec7001 ci: Remove Windows MSVC tasks from Cirrus CI
3545dc2b9b ci, gha: Run all MSVC tests on Windows natively
5d8fa825e2 Merge bitcoin-core/secp256k1#1274: test: Silent noisy clang warnings about Valgrind code on macOS x86_64
8e54a346d2 ci, gha: Run "x86_64: macOS Ventura" job on GitHub Actions
b327abfcea Merge bitcoin-core/secp256k1#1402: ci: Use Homebrew's gcc in native macOS task
d62db57427 ci: Use Homebrew's gcc in native macOS task
54058d16fe field: remove `secp256k1_fe_equal_var`
bb4efd6404 tests: remove unwanted `secp256k1_fe_normalize_weak` call
eedd781085 Merge bitcoin-core/secp256k1#1348: tighten group magnitude limits, save normalize_weak calls in group add methods (revival of #1032)
b2f6712dd3 Merge bitcoin-core/secp256k1#1400: ctimetests: Use new SECP256K1_CHECKMEM macros also for ellswift
9c91ea41b1 ci: Enable ellswift module where it's missing
db32a24761 ctimetests: Use new SECP256K1_CHECKMEM macros also for ellswift
ce765a5b8e Merge bitcoin-core/secp256k1#1399: ci, gha: Run "SageMath prover" job on GitHub Actions
8408dfdc4c Revert "ci: Run sage prover on CI"
c8d9914fb1 ci, gha: Run "SageMath prover" job on GitHub Actions
8d2960c8e2 Merge bitcoin-core/secp256k1#1397: ci: Remove "Windows (VS 2022)" task from Cirrus CI
f1774e5ec4 ci, gha: Make MSVC job presentation more explicit
5ee039bb58 ci: Remove "Windows (VS 2022)" task from Cirrus CI
96294c00fb Merge bitcoin-core/secp256k1#1389: ci: Run "Windows (VS 2022)" job on GitHub Actions
a2f7ccdecc ci: Run "Windows (VS 2022)" job on GitHub Actions
374e2b54e2 Merge bitcoin-core/secp256k1#1290: cmake: Set `ENVIRONMENT` property for examples on Windows
1b13415df9 Merge bitcoin-core/secp256k1#1391: refactor: take use of `secp256k1_scalar_{zero,one}` constants (part 2)
a1bd4971d6 refactor: take use of `secp256k1_scalar_{zero,one}` constants (part 2)
b7c685e74a Save _normalize_weak calls in group add methods
c83afa66e0 Tighten group magnitude limits
26392da2fb Merge bitcoin-core/secp256k1#1386: ci: print $ELLSWIFT in cirrus.sh
d23da6d557 use secp256k1_scalar_verify checks
4692478853 ci: print $ELLSWIFT in cirrus.sh
c7d0454932 add verification for scalars
c734c64278 Merge bitcoin-core/secp256k1#1384: build: enable ellswift module via SECP_CONFIG_DEFINES
ad152151b0 update max scalar in scalar_cmov_test and fix schnorrsig_verify exhaustive test
78ca880788 build: enable ellswift module via SECP_CONFIG_DEFINES
0e00fc7d10 Merge bitcoin-core/secp256k1#1383: util: remove unused checked_realloc
b097a466c1 util: remove unused checked_realloc
2bd5f3e618 Merge bitcoin-core/secp256k1#1382: refactor: Drop unused cast
4f8c5bd761 refactor: Drop unused cast
173e8d061a Implement current magnitude assumptions
49afd2f5d8 Take use of _fe_verify_magnitude in field_impl.h
4e9661fc42 Add _fe_verify_magnitude (no-op unless VERIFY is enabled)
690b0fc05a add missing group element invariant checks
175db31149 ci: Drop no longer needed `PATH` variable update on Windows
116d2ab3df cmake: Set `ENVIRONMENT` property for examples on Windows
cef373997c cmake, refactor: Use helper function instead of interface library
747ada3587 test: Silent noisy clang warnings about Valgrind code on macOS x86_64
git-subtree-dir: src/secp256k1
git-subtree-split: 199d27cea32203b224b208627533c2e813cd3b21
2023-09-04 12:51:20 -04:00
|
|
|
run: |
|
|
|
|
./autogen.sh && ./configure --prefix=${{ env.CI_INSTALL }} && make clean && make install && ls -RlAh ${{ env.CI_INSTALL }}
|
|
|
|
gcc -o ecdsa examples/ecdsa.c $(PKG_CONFIG_PATH=${{ env.CI_INSTALL }}/lib/pkgconfig pkg-config --cflags --libs libsecp256k1) -Wl,-rpath,"${{ env.CI_INSTALL }}/lib" && ./ecdsa
|
|
|
|
|
|
|
|
- name: Check installation with CMake
|
|
|
|
env:
|
|
|
|
CI_BUILD: ${{ runner.temp }}/${{ github.run_id }}${{ github.action }}/build
|
|
|
|
CI_INSTALL: ${{ runner.temp }}/${{ github.run_id }}${{ github.action }}/install
|
|
|
|
run: |
|
|
|
|
cmake -B ${{ env.CI_BUILD }} -DCMAKE_INSTALL_PREFIX=${{ env.CI_INSTALL }} && cmake --build ${{ env.CI_BUILD }} --target install && ls -RlAh ${{ env.CI_INSTALL }}
|
|
|
|
gcc -o ecdsa examples/ecdsa.c -I ${{ env.CI_INSTALL }}/include -L ${{ env.CI_INSTALL }}/lib*/ -l secp256k1 -Wl,-rpath,"${{ env.CI_INSTALL }}/lib",-rpath,"${{ env.CI_INSTALL }}/lib64" && ./ecdsa
|