diff options
| author | J08nY | 2017-05-07 18:06:53 +0200 |
|---|---|---|
| committer | J08nY | 2017-05-07 18:06:53 +0200 |
| commit | 2c6bfa342ac85cd1ec5265b217d7cb33afd91e69 (patch) | |
| tree | 0b3c371c7c033b713f5c8f57e774b4f56b97e41e /src/invalid/invalid.c | |
| parent | 2fe84534d7cfa5a2aebd8877222871b54e7c80c5 (diff) | |
| download | ecgen-2c6bfa342ac85cd1ec5265b217d7cb33afd91e69.tar.gz ecgen-2c6bfa342ac85cd1ec5265b217d7cb33afd91e69.tar.zst ecgen-2c6bfa342ac85cd1ec5265b217d7cb33afd91e69.zip | |
Fixed unrolls / unique generator curve generaton
- Also added some tests to catch some regressions like this early
- Fixed double free in gens, also some funky stuff with gunclone
and obj_free in curve_free
Diffstat (limited to 'src/invalid/invalid.c')
| -rw-r--r-- | src/invalid/invalid.c | 15 |
1 files changed, 12 insertions, 3 deletions
diff --git a/src/invalid/invalid.c b/src/invalid/invalid.c index 18224e8..122bf4f 100644 --- a/src/invalid/invalid.c +++ b/src/invalid/invalid.c @@ -5,7 +5,6 @@ #include "invalid.h" #include "exhaustive/exhaustive.h" #include "invalid_thread.h" -#include "io/config.h" #include "io/output.h" #include "math/curve.h" #include "math/equation.h" @@ -31,6 +30,7 @@ static void invalid_original_ginit(gen_t *generators, const config_t *cfg) { } static void invalid_invalid_ginit(gen_t *generators, const config_t *cfg) { + generators[OFFSET_SEED] = &gen_skip; generators[OFFSET_FIELD] = &gen_skip; generators[OFFSET_A] = &gen_skip; generators[OFFSET_B] = &b_random; @@ -121,6 +121,14 @@ static size_t invalid_curves(curve_t *curve, config_t *cfg, pari_ulong *primes, } if (total > 0) { + if (!exhaustive_gen_retry(invalid, cfg, invalid_gen, NULL, unrolls, + OFFSET_GENERATORS, OFFSET_POINTS, 1)) { + curve_unroll(invalid, cfg, avma, + btop); // necessary to free the ellinit + avma = btop; + continue; + } + // only pass small primes that divide the curve order and those // where we dont have a curve yet. // this is passed to points_trial which uses trial division to find @@ -142,7 +150,7 @@ static size_t invalid_curves(curve_t *curve, config_t *cfg, pari_ulong *primes, // generate prime order points, this is expensive (order needs to be // factorised, so only do it if we want the curve) exhaustive_gen(invalid, cfg, invalid_gen, invalid_argss, unrolls, - OFFSET_GENERATORS, OFFSET_END); + OFFSET_POINTS, OFFSET_END); size_t count = 0; for (size_t i = nprimes; i-- > 0;) { @@ -184,7 +192,8 @@ static size_t invalid_curves(curve_t *curve, config_t *cfg, pari_ulong *primes, // primes from range divided order. Thus remove it // like it never existed. - obj_free(invalid->curve); // necessary to free the ellinit + curve_unroll(invalid, cfg, avma, + btop); // necessary to free the ellinit avma = btop; } } |
