@@ -2307,26 +2307,23 @@ static void scalar_test(void) {
2307
2307
2308
2308
{
2309
2309
/* Test multiplicative identity. */
2310
- secp256k1_scalar r1 , v1 ;
2311
- secp256k1_scalar_set_int (& v1 ,1 );
2312
- secp256k1_scalar_mul (& r1 , & s1 , & v1 );
2310
+ secp256k1_scalar r1 ;
2311
+ secp256k1_scalar_mul (& r1 , & s1 , & secp256k1_scalar_one );
2313
2312
CHECK (secp256k1_scalar_eq (& r1 , & s1 ));
2314
2313
}
2315
2314
2316
2315
{
2317
2316
/* Test additive identity. */
2318
- secp256k1_scalar r1 , v0 ;
2319
- secp256k1_scalar_set_int (& v0 ,0 );
2320
- secp256k1_scalar_add (& r1 , & s1 , & v0 );
2317
+ secp256k1_scalar r1 ;
2318
+ secp256k1_scalar_add (& r1 , & s1 , & secp256k1_scalar_zero );
2321
2319
CHECK (secp256k1_scalar_eq (& r1 , & s1 ));
2322
2320
}
2323
2321
2324
2322
{
2325
2323
/* Test zero product property. */
2326
- secp256k1_scalar r1 , v0 ;
2327
- secp256k1_scalar_set_int (& v0 ,0 );
2328
- secp256k1_scalar_mul (& r1 , & s1 , & v0 );
2329
- CHECK (secp256k1_scalar_eq (& r1 , & v0 ));
2324
+ secp256k1_scalar r1 ;
2325
+ secp256k1_scalar_mul (& r1 , & s1 , & secp256k1_scalar_zero );
2326
+ CHECK (secp256k1_scalar_eq (& r1 , & secp256k1_scalar_zero ));
2330
2327
}
2331
2328
2332
2329
}
@@ -2359,11 +2356,9 @@ static void run_scalar_tests(void) {
2359
2356
2360
2357
{
2361
2358
/* (-1)+1 should be zero. */
2362
- secp256k1_scalar s , o ;
2363
- secp256k1_scalar_set_int (& s , 1 );
2364
- CHECK (secp256k1_scalar_is_one (& s ));
2365
- secp256k1_scalar_negate (& o , & s );
2366
- secp256k1_scalar_add (& o , & o , & s );
2359
+ secp256k1_scalar o ;
2360
+ secp256k1_scalar_negate (& o , & secp256k1_scalar_one );
2361
+ secp256k1_scalar_add (& o , & o , & secp256k1_scalar_one );
2367
2362
CHECK (secp256k1_scalar_is_zero (& o ));
2368
2363
secp256k1_scalar_negate (& o , & o );
2369
2364
CHECK (secp256k1_scalar_is_zero (& o ));
@@ -2388,7 +2383,6 @@ static void run_scalar_tests(void) {
2388
2383
secp256k1_scalar y ;
2389
2384
secp256k1_scalar z ;
2390
2385
secp256k1_scalar zz ;
2391
- secp256k1_scalar one ;
2392
2386
secp256k1_scalar r1 ;
2393
2387
secp256k1_scalar r2 ;
2394
2388
secp256k1_scalar zzv ;
@@ -2925,7 +2919,6 @@ static void run_scalar_tests(void) {
2925
2919
0x1e , 0x86 , 0x5d , 0x89 , 0x63 , 0xe6 , 0x0a , 0x46 ,
2926
2920
0x5c , 0x02 , 0x97 , 0x1b , 0x62 , 0x43 , 0x86 , 0xf5 }}
2927
2921
};
2928
- secp256k1_scalar_set_int (& one , 1 );
2929
2922
for (i = 0 ; i < 33 ; i ++ ) {
2930
2923
secp256k1_scalar_set_b32 (& x , chal [i ][0 ], & overflow );
2931
2924
CHECK (!overflow );
@@ -2948,7 +2941,7 @@ static void run_scalar_tests(void) {
2948
2941
CHECK (secp256k1_scalar_eq (& x , & z ));
2949
2942
secp256k1_scalar_mul (& zz , & zz , & y );
2950
2943
CHECK (!secp256k1_scalar_check_overflow (& zz ));
2951
- CHECK (secp256k1_scalar_eq (& one , & zz ));
2944
+ CHECK (secp256k1_scalar_eq (& secp256k1_scalar_one , & zz ));
2952
2945
}
2953
2946
}
2954
2947
}
@@ -4646,7 +4639,6 @@ static int ecmult_multi_false_callback(secp256k1_scalar *sc, secp256k1_ge *pt, s
4646
4639
4647
4640
static void test_ecmult_multi (secp256k1_scratch * scratch , secp256k1_ecmult_multi_func ecmult_multi ) {
4648
4641
int ncount ;
4649
- secp256k1_scalar szero ;
4650
4642
secp256k1_scalar sc [32 ];
4651
4643
secp256k1_ge pt [32 ];
4652
4644
secp256k1_gej r ;
@@ -4655,7 +4647,6 @@ static void test_ecmult_multi(secp256k1_scratch *scratch, secp256k1_ecmult_multi
4655
4647
4656
4648
data .sc = sc ;
4657
4649
data .pt = pt ;
4658
- secp256k1_scalar_set_int (& szero , 0 );
4659
4650
4660
4651
/* No points to multiply */
4661
4652
CHECK (ecmult_multi (& CTX -> error_callback , scratch , & r , NULL , ecmult_multi_callback , & data , 0 ));
@@ -4673,21 +4664,21 @@ static void test_ecmult_multi(secp256k1_scratch *scratch, secp256k1_ecmult_multi
4673
4664
pt [1 ] = secp256k1_ge_const_g ;
4674
4665
4675
4666
/* only G scalar */
4676
- secp256k1_ecmult (& r2 , & ptgj , & szero , & sc [0 ]);
4667
+ secp256k1_ecmult (& r2 , & ptgj , & secp256k1_scalar_zero , & sc [0 ]);
4677
4668
CHECK (ecmult_multi (& CTX -> error_callback , scratch , & r , & sc [0 ], ecmult_multi_callback , & data , 0 ));
4678
4669
CHECK (secp256k1_gej_eq_var (& r , & r2 ));
4679
4670
4680
4671
/* 1-point */
4681
- secp256k1_ecmult (& r2 , & ptgj , & sc [0 ], & szero );
4682
- CHECK (ecmult_multi (& CTX -> error_callback , scratch , & r , & szero , ecmult_multi_callback , & data , 1 ));
4672
+ secp256k1_ecmult (& r2 , & ptgj , & sc [0 ], & secp256k1_scalar_zero );
4673
+ CHECK (ecmult_multi (& CTX -> error_callback , scratch , & r , & secp256k1_scalar_zero , ecmult_multi_callback , & data , 1 ));
4683
4674
CHECK (secp256k1_gej_eq_var (& r , & r2 ));
4684
4675
4685
4676
/* Try to multiply 1 point, but callback returns false */
4686
- CHECK (!ecmult_multi (& CTX -> error_callback , scratch , & r , & szero , ecmult_multi_false_callback , & data , 1 ));
4677
+ CHECK (!ecmult_multi (& CTX -> error_callback , scratch , & r , & secp256k1_scalar_zero , ecmult_multi_false_callback , & data , 1 ));
4687
4678
4688
4679
/* 2-point */
4689
4680
secp256k1_ecmult (& r2 , & ptgj , & sc [0 ], & sc [1 ]);
4690
- CHECK (ecmult_multi (& CTX -> error_callback , scratch , & r , & szero , ecmult_multi_callback , & data , 2 ));
4681
+ CHECK (ecmult_multi (& CTX -> error_callback , scratch , & r , & secp256k1_scalar_zero , ecmult_multi_callback , & data , 2 ));
4691
4682
CHECK (secp256k1_gej_eq_var (& r , & r2 ));
4692
4683
4693
4684
/* 2-point with G scalar */
@@ -4707,7 +4698,7 @@ static void test_ecmult_multi(secp256k1_scratch *scratch, secp256k1_ecmult_multi
4707
4698
random_scalar_order (& sc [i ]);
4708
4699
secp256k1_ge_set_infinity (& pt [i ]);
4709
4700
}
4710
- CHECK (ecmult_multi (& CTX -> error_callback , scratch , & r , & szero , ecmult_multi_callback , & data , sizes [j ]));
4701
+ CHECK (ecmult_multi (& CTX -> error_callback , scratch , & r , & secp256k1_scalar_zero , ecmult_multi_callback , & data , sizes [j ]));
4711
4702
CHECK (secp256k1_gej_is_infinity (& r ));
4712
4703
}
4713
4704
@@ -4717,7 +4708,7 @@ static void test_ecmult_multi(secp256k1_scratch *scratch, secp256k1_ecmult_multi
4717
4708
pt [i ] = ptg ;
4718
4709
secp256k1_scalar_set_int (& sc [i ], 0 );
4719
4710
}
4720
- CHECK (ecmult_multi (& CTX -> error_callback , scratch , & r , & szero , ecmult_multi_callback , & data , sizes [j ]));
4711
+ CHECK (ecmult_multi (& CTX -> error_callback , scratch , & r , & secp256k1_scalar_zero , ecmult_multi_callback , & data , sizes [j ]));
4721
4712
CHECK (secp256k1_gej_is_infinity (& r ));
4722
4713
}
4723
4714
@@ -4730,7 +4721,7 @@ static void test_ecmult_multi(secp256k1_scratch *scratch, secp256k1_ecmult_multi
4730
4721
pt [2 * i + 1 ] = ptg ;
4731
4722
}
4732
4723
4733
- CHECK (ecmult_multi (& CTX -> error_callback , scratch , & r , & szero , ecmult_multi_callback , & data , sizes [j ]));
4724
+ CHECK (ecmult_multi (& CTX -> error_callback , scratch , & r , & secp256k1_scalar_zero , ecmult_multi_callback , & data , sizes [j ]));
4734
4725
CHECK (secp256k1_gej_is_infinity (& r ));
4735
4726
4736
4727
random_scalar_order (& sc [0 ]);
@@ -4743,7 +4734,7 @@ static void test_ecmult_multi(secp256k1_scratch *scratch, secp256k1_ecmult_multi
4743
4734
secp256k1_ge_neg (& pt [2 * i + 1 ], & pt [2 * i ]);
4744
4735
}
4745
4736
4746
- CHECK (ecmult_multi (& CTX -> error_callback , scratch , & r , & szero , ecmult_multi_callback , & data , sizes [j ]));
4737
+ CHECK (ecmult_multi (& CTX -> error_callback , scratch , & r , & secp256k1_scalar_zero , ecmult_multi_callback , & data , sizes [j ]));
4747
4738
CHECK (secp256k1_gej_is_infinity (& r ));
4748
4739
}
4749
4740
@@ -4758,7 +4749,7 @@ static void test_ecmult_multi(secp256k1_scratch *scratch, secp256k1_ecmult_multi
4758
4749
secp256k1_scalar_negate (& sc [i ], & sc [i ]);
4759
4750
}
4760
4751
4761
- CHECK (ecmult_multi (& CTX -> error_callback , scratch , & r , & szero , ecmult_multi_callback , & data , 32 ));
4752
+ CHECK (ecmult_multi (& CTX -> error_callback , scratch , & r , & secp256k1_scalar_zero , ecmult_multi_callback , & data , 32 ));
4762
4753
CHECK (secp256k1_gej_is_infinity (& r ));
4763
4754
}
4764
4755
@@ -4776,8 +4767,8 @@ static void test_ecmult_multi(secp256k1_scratch *scratch, secp256k1_ecmult_multi
4776
4767
secp256k1_gej_add_ge_var (& r , & r , & pt [i ], NULL );
4777
4768
}
4778
4769
4779
- secp256k1_ecmult (& r2 , & r , & sc [0 ], & szero );
4780
- CHECK (ecmult_multi (& CTX -> error_callback , scratch , & r , & szero , ecmult_multi_callback , & data , 20 ));
4770
+ secp256k1_ecmult (& r2 , & r , & sc [0 ], & secp256k1_scalar_zero );
4771
+ CHECK (ecmult_multi (& CTX -> error_callback , scratch , & r , & secp256k1_scalar_zero , ecmult_multi_callback , & data , 20 ));
4781
4772
CHECK (secp256k1_gej_eq_var (& r , & r2 ));
4782
4773
}
4783
4774
@@ -4797,8 +4788,8 @@ static void test_ecmult_multi(secp256k1_scratch *scratch, secp256k1_ecmult_multi
4797
4788
}
4798
4789
4799
4790
secp256k1_gej_set_ge (& p0j , & pt [0 ]);
4800
- secp256k1_ecmult (& r2 , & p0j , & rs , & szero );
4801
- CHECK (ecmult_multi (& CTX -> error_callback , scratch , & r , & szero , ecmult_multi_callback , & data , 20 ));
4791
+ secp256k1_ecmult (& r2 , & p0j , & rs , & secp256k1_scalar_zero );
4792
+ CHECK (ecmult_multi (& CTX -> error_callback , scratch , & r , & secp256k1_scalar_zero , ecmult_multi_callback , & data , 20 ));
4802
4793
CHECK (secp256k1_gej_eq_var (& r , & r2 ));
4803
4794
}
4804
4795
@@ -4809,13 +4800,13 @@ static void test_ecmult_multi(secp256k1_scratch *scratch, secp256k1_ecmult_multi
4809
4800
}
4810
4801
4811
4802
secp256k1_scalar_clear (& sc [0 ]);
4812
- CHECK (ecmult_multi (& CTX -> error_callback , scratch , & r , & szero , ecmult_multi_callback , & data , 20 ));
4803
+ CHECK (ecmult_multi (& CTX -> error_callback , scratch , & r , & secp256k1_scalar_zero , ecmult_multi_callback , & data , 20 ));
4813
4804
secp256k1_scalar_clear (& sc [1 ]);
4814
4805
secp256k1_scalar_clear (& sc [2 ]);
4815
4806
secp256k1_scalar_clear (& sc [3 ]);
4816
4807
secp256k1_scalar_clear (& sc [4 ]);
4817
- CHECK (ecmult_multi (& CTX -> error_callback , scratch , & r , & szero , ecmult_multi_callback , & data , 6 ));
4818
- CHECK (ecmult_multi (& CTX -> error_callback , scratch , & r , & szero , ecmult_multi_callback , & data , 5 ));
4808
+ CHECK (ecmult_multi (& CTX -> error_callback , scratch , & r , & secp256k1_scalar_zero , ecmult_multi_callback , & data , 6 ));
4809
+ CHECK (ecmult_multi (& CTX -> error_callback , scratch , & r , & secp256k1_scalar_zero , ecmult_multi_callback , & data , 5 ));
4819
4810
CHECK (secp256k1_gej_is_infinity (& r ));
4820
4811
4821
4812
/* Run through s0*(t0*P) + s1*(t1*P) exhaustively for many small values of s0, s1, t0, t1 */
@@ -4839,8 +4830,8 @@ static void test_ecmult_multi(secp256k1_scratch *scratch, secp256k1_ecmult_multi
4839
4830
secp256k1_scalar_set_int (& t1 , (t1i + 1 ) / 2 );
4840
4831
secp256k1_scalar_cond_negate (& t1 , t1i & 1 );
4841
4832
4842
- secp256k1_ecmult (& t0p , & ptgj , & t0 , & szero );
4843
- secp256k1_ecmult (& t1p , & ptgj , & t1 , & szero );
4833
+ secp256k1_ecmult (& t0p , & ptgj , & t0 , & secp256k1_scalar_zero );
4834
+ secp256k1_ecmult (& t1p , & ptgj , & t1 , & secp256k1_scalar_zero );
4844
4835
4845
4836
for (s0i = 0 ; s0i < TOP ; s0i ++ ) {
4846
4837
for (s1i = 0 ; s1i < TOP ; s1i ++ ) {
@@ -4859,8 +4850,8 @@ static void test_ecmult_multi(secp256k1_scratch *scratch, secp256k1_ecmult_multi
4859
4850
secp256k1_scalar_mul (& tmp2 , & t1 , & sc [1 ]);
4860
4851
secp256k1_scalar_add (& tmp1 , & tmp1 , & tmp2 );
4861
4852
4862
- secp256k1_ecmult (& expected , & ptgj , & tmp1 , & szero );
4863
- CHECK (ecmult_multi (& CTX -> error_callback , scratch , & actual , & szero , ecmult_multi_callback , & data , 2 ));
4853
+ secp256k1_ecmult (& expected , & ptgj , & tmp1 , & secp256k1_scalar_zero );
4854
+ CHECK (ecmult_multi (& CTX -> error_callback , scratch , & actual , & secp256k1_scalar_zero , ecmult_multi_callback , & data , 2 ));
4864
4855
CHECK (secp256k1_gej_eq_var (& actual , & expected ));
4865
4856
}
4866
4857
}
@@ -5036,7 +5027,6 @@ static int test_ecmult_multi_random(secp256k1_scratch *scratch) {
5036
5027
}
5037
5028
5038
5029
static void test_ecmult_multi_batch_single (secp256k1_ecmult_multi_func ecmult_multi ) {
5039
- secp256k1_scalar szero ;
5040
5030
secp256k1_scalar sc ;
5041
5031
secp256k1_ge pt ;
5042
5032
secp256k1_gej r ;
@@ -5047,11 +5037,10 @@ static void test_ecmult_multi_batch_single(secp256k1_ecmult_multi_func ecmult_mu
5047
5037
random_scalar_order (& sc );
5048
5038
data .sc = & sc ;
5049
5039
data .pt = & pt ;
5050
- secp256k1_scalar_set_int (& szero , 0 );
5051
5040
5052
5041
/* Try to multiply 1 point, but scratch space is empty.*/
5053
5042
scratch_empty = secp256k1_scratch_create (& CTX -> error_callback , 0 );
5054
- CHECK (!ecmult_multi (& CTX -> error_callback , scratch_empty , & r , & szero , ecmult_multi_callback , & data , 1 ));
5043
+ CHECK (!ecmult_multi (& CTX -> error_callback , scratch_empty , & r , & secp256k1_scalar_zero , ecmult_multi_callback , & data , 1 ));
5055
5044
secp256k1_scratch_destroy (& CTX -> error_callback , scratch_empty );
5056
5045
}
5057
5046
@@ -5159,7 +5148,6 @@ static void test_ecmult_multi_batch_size_helper(void) {
5159
5148
static void test_ecmult_multi_batching (void ) {
5160
5149
static const int n_points = 2 * ECMULT_PIPPENGER_THRESHOLD ;
5161
5150
secp256k1_scalar scG ;
5162
- secp256k1_scalar szero ;
5163
5151
secp256k1_scalar * sc = (secp256k1_scalar * )checked_malloc (& CTX -> error_callback , sizeof (secp256k1_scalar ) * n_points );
5164
5152
secp256k1_ge * pt = (secp256k1_ge * )checked_malloc (& CTX -> error_callback , sizeof (secp256k1_ge ) * n_points );
5165
5153
secp256k1_gej r ;
@@ -5169,11 +5157,10 @@ static void test_ecmult_multi_batching(void) {
5169
5157
secp256k1_scratch * scratch ;
5170
5158
5171
5159
secp256k1_gej_set_infinity (& r2 );
5172
- secp256k1_scalar_set_int (& szero , 0 );
5173
5160
5174
5161
/* Get random scalars and group elements and compute result */
5175
5162
random_scalar_order (& scG );
5176
- secp256k1_ecmult (& r2 , & r2 , & szero , & scG );
5163
+ secp256k1_ecmult (& r2 , & r2 , & secp256k1_scalar_zero , & scG );
5177
5164
for (i = 0 ; i < n_points ; i ++ ) {
5178
5165
secp256k1_ge ptg ;
5179
5166
secp256k1_gej ptgj ;
0 commit comments