2022-03-08 19:45:41 +00:00
|
|
|
/*****************************************************************************************************
|
|
|
|
* Copyright (c) 2013, 2014, 2017, 2021 Pieter Wuille, Andrew Poelstra, Jonas Nick, Russell O'Connor *
|
|
|
|
* Distributed under the MIT software license, see the accompanying *
|
|
|
|
* file COPYING or https://www.opensource.org/licenses/mit-license.php. *
|
|
|
|
*****************************************************************************************************/
|
|
|
|
|
|
|
|
#ifndef SECP256K1_PRECOMPUTED_ECMULT_H
|
|
|
|
#define SECP256K1_PRECOMPUTED_ECMULT_H
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#include "group.h"
|
|
|
|
#if defined(EXHAUSTIVE_TEST_ORDER)
|
|
|
|
#if EXHAUSTIVE_TEST_ORDER == 13
|
|
|
|
# define WINDOW_G 4
|
|
|
|
# elif EXHAUSTIVE_TEST_ORDER == 199
|
|
|
|
# define WINDOW_G 8
|
|
|
|
# else
|
|
|
|
# error No known generator for the specified exhaustive test group order.
|
|
|
|
# endif
|
2022-10-08 15:43:43 +00:00
|
|
|
static rustsecp256k1_v0_6_1_ge_storage rustsecp256k1_v0_6_1_pre_g[ECMULT_TABLE_SIZE(WINDOW_G)];
|
|
|
|
static rustsecp256k1_v0_6_1_ge_storage rustsecp256k1_v0_6_1_pre_g_128[ECMULT_TABLE_SIZE(WINDOW_G)];
|
2022-03-08 19:45:41 +00:00
|
|
|
#else /* !defined(EXHAUSTIVE_TEST_ORDER) */
|
|
|
|
# define WINDOW_G ECMULT_WINDOW_SIZE
|
2022-10-08 15:43:43 +00:00
|
|
|
extern const rustsecp256k1_v0_6_1_ge_storage rustsecp256k1_v0_6_1_pre_g[ECMULT_TABLE_SIZE(WINDOW_G)];
|
|
|
|
extern const rustsecp256k1_v0_6_1_ge_storage rustsecp256k1_v0_6_1_pre_g_128[ECMULT_TABLE_SIZE(WINDOW_G)];
|
2022-03-08 19:45:41 +00:00
|
|
|
#endif /* defined(EXHAUSTIVE_TEST_ORDER) */
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif /* SECP256K1_PRECOMPUTED_ECMULT_H */
|