@@ -210,7 +210,6 @@ static int secp256k1_ecmult_wnaf(int *wnaf, int len, const secp256k1_scalar *a,
210210}
211211
212212struct secp256k1_strauss_point_state {
213- secp256k1_scalar na_1 , na_lam ;
214213 int wnaf_na_1 [129 ];
215214 int wnaf_na_lam [129 ];
216215 int bits_na_1 ;
@@ -240,16 +239,17 @@ static void secp256k1_ecmult_strauss_wnaf(const struct secp256k1_strauss_state *
240239 size_t no = 0 ;
241240
242241 for (np = 0 ; np < num ; ++ np ) {
242+ secp256k1_scalar na_1 , na_lam ;
243243 if (secp256k1_scalar_is_zero (& na [np ]) || secp256k1_gej_is_infinity (& a [np ])) {
244244 continue ;
245245 }
246246 state -> ps [no ].input_pos = np ;
247247 /* split na into na_1 and na_lam (where na = na_1 + na_lam*lambda, and na_1 and na_lam are ~128 bit) */
248- secp256k1_scalar_split_lambda (& state -> ps [ no ]. na_1 , & state -> ps [ no ]. na_lam , & na [np ]);
248+ secp256k1_scalar_split_lambda (& na_1 , & na_lam , & na [np ]);
249249
250250 /* build wnaf representation for na_1 and na_lam. */
251- state -> ps [no ].bits_na_1 = secp256k1_ecmult_wnaf (state -> ps [no ].wnaf_na_1 , 129 , & state -> ps [ no ]. na_1 , WINDOW_A );
252- state -> ps [no ].bits_na_lam = secp256k1_ecmult_wnaf (state -> ps [no ].wnaf_na_lam , 129 , & state -> ps [ no ]. na_lam , WINDOW_A );
251+ state -> ps [no ].bits_na_1 = secp256k1_ecmult_wnaf (state -> ps [no ].wnaf_na_1 , 129 , & na_1 , WINDOW_A );
252+ state -> ps [no ].bits_na_lam = secp256k1_ecmult_wnaf (state -> ps [no ].wnaf_na_lam , 129 , & na_lam , WINDOW_A );
253253 VERIFY_CHECK (state -> ps [no ].bits_na_1 <= 129 );
254254 VERIFY_CHECK (state -> ps [no ].bits_na_lam <= 129 );
255255 if (state -> ps [no ].bits_na_1 > bits ) {
0 commit comments