Skip to content

Commit 2a7be67

Browse files
committed
Combine bench_sign and bench_verify into single bench
1 parent 8fa4120 commit 2a7be67

File tree

5 files changed

+51
-71
lines changed

5 files changed

+51
-71
lines changed

.gitignore

+1-3
Original file line numberDiff line numberDiff line change
@@ -1,9 +1,7 @@
1-
bench_inv
1+
bench
22
bench_ecdh
33
bench_ecmult
44
bench_schnorrsig
5-
bench_sign
6-
bench_verify
75
bench_recover
86
bench_internal
97
tests

Makefile.am

+3-5
Original file line numberDiff line numberDiff line change
@@ -81,11 +81,9 @@ endif
8181

8282
noinst_PROGRAMS =
8383
if USE_BENCHMARK
84-
noinst_PROGRAMS += bench_verify bench_sign bench_internal bench_ecmult
85-
bench_verify_SOURCES = src/bench_verify.c
86-
bench_verify_LDADD = libsecp256k1.la $(SECP_LIBS) $(SECP_TEST_LIBS) $(COMMON_LIB)
87-
bench_sign_SOURCES = src/bench_sign.c
88-
bench_sign_LDADD = libsecp256k1.la $(SECP_LIBS) $(SECP_TEST_LIBS) $(COMMON_LIB)
84+
noinst_PROGRAMS += bench bench_internal bench_ecmult
85+
bench_SOURCES = src/bench.c
86+
bench_LDADD = libsecp256k1.la $(SECP_LIBS) $(SECP_TEST_LIBS) $(COMMON_LIB)
8987
bench_internal_SOURCES = src/bench_internal.c
9088
bench_internal_LDADD = $(SECP_LIBS) $(COMMON_LIB)
9189
bench_internal_CPPFLAGS = $(SECP_INCLUDES)

ci/cirrus.sh

+2-3
Original file line numberDiff line numberDiff line change
@@ -26,7 +26,7 @@ make
2626

2727
# Print information about binaries so that we can see that the architecture is correct
2828
file *tests* || true
29-
file bench_* || true
29+
file bench* || true
3030
file .libs/* || true
3131

3232
# This tells `make check` to wrap test invocations.
@@ -49,8 +49,7 @@ then
4949
{
5050
$EXEC ./bench_ecmult
5151
$EXEC ./bench_internal
52-
$EXEC ./bench_sign
53-
$EXEC ./bench_verify
52+
$EXEC ./bench
5453
} >> bench.log 2>&1
5554
if [ "$RECOVERY" = "yes" ]
5655
then

src/bench_verify.c src/bench.c

+45
Original file line numberDiff line numberDiff line change
@@ -40,6 +40,42 @@ static void bench_verify(void* arg, int iters) {
4040
}
4141
}
4242

43+
typedef struct {
44+
secp256k1_context* ctx;
45+
unsigned char msg[32];
46+
unsigned char key[32];
47+
} bench_sign_data;
48+
49+
static void bench_sign_setup(void* arg) {
50+
int i;
51+
bench_sign_data *data = (bench_sign_data*)arg;
52+
53+
for (i = 0; i < 32; i++) {
54+
data->msg[i] = i + 1;
55+
}
56+
for (i = 0; i < 32; i++) {
57+
data->key[i] = i + 65;
58+
}
59+
}
60+
61+
static void bench_sign_run(void* arg, int iters) {
62+
int i;
63+
bench_sign_data *data = (bench_sign_data*)arg;
64+
65+
unsigned char sig[74];
66+
for (i = 0; i < iters; i++) {
67+
size_t siglen = 74;
68+
int j;
69+
secp256k1_ecdsa_signature signature;
70+
CHECK(secp256k1_ecdsa_sign(data->ctx, &signature, data->msg, data->key, NULL, NULL));
71+
CHECK(secp256k1_ecdsa_signature_serialize_der(data->ctx, sig, &siglen, &signature));
72+
for (j = 0; j < 32; j++) {
73+
data->msg[j] = sig[j];
74+
data->key[j] = sig[j + 32];
75+
}
76+
}
77+
}
78+
4379
int main(void) {
4480
int i;
4581
secp256k1_pubkey pubkey;
@@ -48,6 +84,7 @@ int main(void) {
4884

4985
int iters = get_iters(20000);
5086

87+
/* ECDSA verification benchmark */
5188
data.ctx = secp256k1_context_create(SECP256K1_CONTEXT_SIGN | SECP256K1_CONTEXT_VERIFY);
5289

5390
for (i = 0; i < 32; i++) {
@@ -67,5 +104,13 @@ int main(void) {
67104
run_benchmark("ecdsa_verify", bench_verify, NULL, NULL, &data, 10, iters);
68105

69106
secp256k1_context_destroy(data.ctx);
107+
108+
/* ECDSA signing benchmark */
109+
data.ctx = secp256k1_context_create(SECP256K1_CONTEXT_SIGN);
110+
111+
run_benchmark("ecdsa_sign", bench_sign_run, bench_sign_setup, NULL, &data, 10, iters);
112+
113+
secp256k1_context_destroy(data.ctx);
114+
70115
return 0;
71116
}

src/bench_sign.c

-60
This file was deleted.

0 commit comments

Comments
 (0)