Squashed 'src/secp256k1/' changes from 84973d393..0b7024185
[bitcoinplatinum.git] / src / gen_context.c
blob1835fd491d16b7d8f4774327f25994a79ea1986a
1 /**********************************************************************
2 * Copyright (c) 2013, 2014, 2015 Thomas Daede, Cory Fields *
3 * Distributed under the MIT software license, see the accompanying *
4 * file COPYING or http://www.opensource.org/licenses/mit-license.php.*
5 **********************************************************************/
7 #define USE_BASIC_CONFIG 1
9 #include "basic-config.h"
10 #include "include/secp256k1.h"
11 #include "field_impl.h"
12 #include "scalar_impl.h"
13 #include "group_impl.h"
14 #include "ecmult_gen_impl.h"
16 static void default_error_callback_fn(const char* str, void* data) {
17 (void)data;
18 fprintf(stderr, "[libsecp256k1] internal consistency check failed: %s\n", str);
19 abort();
22 static const secp256k1_callback default_error_callback = {
23 default_error_callback_fn,
24 NULL
27 int main(int argc, char **argv) {
28 secp256k1_ecmult_gen_context ctx;
29 int inner;
30 int outer;
31 FILE* fp;
33 (void)argc;
34 (void)argv;
36 fp = fopen("src/ecmult_static_context.h","w");
37 if (fp == NULL) {
38 fprintf(stderr, "Could not open src/ecmult_static_context.h for writing!\n");
39 return -1;
42 fprintf(fp, "#ifndef _SECP256K1_ECMULT_STATIC_CONTEXT_\n");
43 fprintf(fp, "#define _SECP256K1_ECMULT_STATIC_CONTEXT_\n");
44 fprintf(fp, "#include \"group.h\"\n");
45 fprintf(fp, "#define SC SECP256K1_GE_STORAGE_CONST\n");
46 fprintf(fp, "static const secp256k1_ge_storage secp256k1_ecmult_static_context[64][16] = {\n");
48 secp256k1_ecmult_gen_context_init(&ctx);
49 secp256k1_ecmult_gen_context_build(&ctx, &default_error_callback);
50 for(outer = 0; outer != 64; outer++) {
51 fprintf(fp,"{\n");
52 for(inner = 0; inner != 16; inner++) {
53 fprintf(fp," SC(%uu, %uu, %uu, %uu, %uu, %uu, %uu, %uu, %uu, %uu, %uu, %uu, %uu, %uu, %uu, %uu)", SECP256K1_GE_STORAGE_CONST_GET((*ctx.prec)[outer][inner]));
54 if (inner != 15) {
55 fprintf(fp,",\n");
56 } else {
57 fprintf(fp,"\n");
60 if (outer != 63) {
61 fprintf(fp,"},\n");
62 } else {
63 fprintf(fp,"}\n");
66 fprintf(fp,"};\n");
67 secp256k1_ecmult_gen_context_clear(&ctx);
69 fprintf(fp, "#undef SC\n");
70 fprintf(fp, "#endif\n");
71 fclose(fp);
73 return 0;