Browse Source

reduce required curve data

master
Michael Hamburg 9 years ago
parent
commit
6aea0961ac
1 changed files with 17 additions and 10 deletions
  1. +17
    -10
      src/gen_headers/curve_data.py

+ 17
- 10
src/gen_headers/curve_data.py View File

@@ -1,14 +1,12 @@
field_data = { field_data = {
"p25519" : { "p25519" : {
"gf_desc" : "2^255 - 19", "gf_desc" : "2^255 - 19",
"modulus" : 2**255 - 19,
"gf_shortname" : "25519", "gf_shortname" : "25519",
"gf_impl_bits" : 320, "gf_impl_bits" : 320,
"gf_lit_limb_bits" : 51 "gf_lit_limb_bits" : 51
}, },
"p448" : { "p448" : {
"gf_desc" : "2^448 - 2^224 - 1", "gf_desc" : "2^448 - 2^224 - 1",
"modulus" : 2**448 - 2**224 - 1,
"gf_shortname" : "448", "gf_shortname" : "448",
"gf_impl_bits" : 512, "gf_impl_bits" : 512,
"gf_lit_limb_bits" : 56 "gf_lit_limb_bits" : 56
@@ -18,20 +16,13 @@ field_data = {
curve_data = { curve_data = {
"Curve25519" : { "Curve25519" : {
"iso_to" : "Curve25519", "iso_to" : "Curve25519",
"name" : "IsoEd25519",
"cxx_ns" : "IsoEd25519",
"shortname" : "255",
"c_ns" : "decaf_255",
"name" : "Iso-Ed25519",
"cofactor" : 8, "cofactor" : 8,
"field" : "p25519", "field" : "p25519",
"scalar_bits" : 253 "scalar_bits" : 253
}, },
"Ed448" : { "Ed448" : {
"iso_to" : "Ed448-Goldilocks",
"name" : "Ed448-Goldilocks", "name" : "Ed448-Goldilocks",
"cxx_ns" : "Ed448Goldilocks",
"shortname" : "448",
"c_ns" : "decaf_448",
"cofactor" : 4, "cofactor" : 4,
"field" : "p448", "field" : "p448",
"scalar_bits" : 446 "scalar_bits" : 446
@@ -47,6 +38,10 @@ def ceil_log2(x):
return out return out


for field,data in field_data.iteritems(): for field,data in field_data.iteritems():
if "modulus" not in data:
data["modulus"] = eval(data["gf_desc"].replace("^","**"))
if "gf_bits" not in data: if "gf_bits" not in data:
data["gf_bits"] = ceil_log2(data["modulus"]) data["gf_bits"] = ceil_log2(data["modulus"])
@@ -64,6 +59,12 @@ for curve,data in curve_data.iteritems():
if key not in data: if key not in data:
data[key] = field_data[data["field"]][key] data[key] = field_data[data["field"]][key]
if "iso_to" not in data:
data["iso_to"] = data["name"]
if "cxx_ns" not in data:
data["cxx_ns"] = data["name"].replace("-","")
if "modulus_type" not in data: if "modulus_type" not in data:
mod = data["modulus"] mod = data["modulus"]
ptwo = 2 ptwo = 2
@@ -73,6 +74,12 @@ for curve,data in curve_data.iteritems():
if "bits" not in data: if "bits" not in data:
data["bits"] = ceil_log2(data["modulus"]) data["bits"] = ceil_log2(data["modulus"])
if "shortname" not in data:
data["shortname"] = str(data["bits"])
if "c_ns" not in data:
data["c_ns"] = "decaf_" + data["shortname"]
if "ser_bytes" not in data: if "ser_bytes" not in data:
data["ser_bytes"] = (data["bits"]-2)//8 + 1 data["ser_bytes"] = (data["bits"]-2)//8 + 1


Loading…
Cancel
Save