initial version of SQIsign
Co-authored-by: Jorge Chavez-Saab <jorgechavezsaab@gmail.com> Co-authored-by: Maria Corte-Real Santos <36373796+mariascrs@users.noreply.github.com> Co-authored-by: Luca De Feo <github@defeo.lu> Co-authored-by: Jonathan Komada Eriksen <jonathan.eriksen97@gmail.com> Co-authored-by: Basil Hess <bhe@zurich.ibm.com> Co-authored-by: Antonin Leroux <18654258+tonioecto@users.noreply.github.com> Co-authored-by: Patrick Longa <plonga@microsoft.com> Co-authored-by: Lorenz Panny <lorenz@yx7.cc> Co-authored-by: Francisco Rodríguez-Henríquez <francisco.rodriguez@tii.ae> Co-authored-by: Sina Schaeffler <108983332+syndrakon@users.noreply.github.com> Co-authored-by: Benjamin Wesolowski <19474926+Calodeon@users.noreply.github.com>
This commit is contained in:
92
scripts/precompute_sizes.sage
Executable file
92
scripts/precompute_sizes.sage
Executable file
@@ -0,0 +1,92 @@
|
||||
#!/usr/bin/env sage
|
||||
proof.all(False) # faster
|
||||
|
||||
from sage.misc.banner import require_version
|
||||
if not require_version(9, 8, print_message=True):
|
||||
exit('')
|
||||
|
||||
################################################################
|
||||
|
||||
from parameters import lvl, f, p
|
||||
|
||||
################################################################
|
||||
|
||||
logp = ceil(log(p, 2))
|
||||
tors2part = (p+1).p_primary_part(2)
|
||||
tors3part = (p+1).p_primary_part(3)
|
||||
|
||||
#XXX first load the constants from klpt_constants.h
|
||||
import re
|
||||
klpt_consts = dict()
|
||||
for l in open('include/klpt_constants.h'):
|
||||
m = re.search(r'#define *([^ ]+) *([x0-9]+)$', l)
|
||||
if m:
|
||||
k,v = m.groups()
|
||||
klpt_consts[k] = int(v, 0)
|
||||
|
||||
defs = dict()
|
||||
|
||||
fp2sz = (logp + 63)//64*8 * 2
|
||||
defs['FP2_ENCODED_BYTES'] = fp2sz
|
||||
defs['EC_CURVE_ENCODED_BYTES'] = fp2sz # just the A
|
||||
defs['EC_POINT_ENCODED_BYTES'] = fp2sz # just the x
|
||||
defs['EC_BASIS_ENCODED_BYTES'] = 3 * defs['EC_POINT_ENCODED_BYTES']
|
||||
|
||||
defs['CHAIN_LENGTH'] = klpt_consts['SQISIGN_keygen_length']
|
||||
|
||||
defs['QUAT_ALG_ELEM_ENCODED_BITS'] = ceil(((logp/4) + klpt_consts['KLPT_keygen_length'])/2 +55) #TODO FIXME figure this out XXX XXX
|
||||
defs['QUAT_ALG_ELEM_ENCODED_BYTES'] = (defs['QUAT_ALG_ELEM_ENCODED_BITS'] + 7)//8
|
||||
defs['ID2ISO_LONG_TWO_ISOG_ENCODED_BYTES'] = defs['CHAIN_LENGTH'] * (defs['EC_CURVE_ENCODED_BYTES'] + defs['EC_POINT_ENCODED_BYTES'] + 2)
|
||||
|
||||
defs['ZIP_CHAIN_LEN'] = klpt_consts['SQISIGN_signing_length']
|
||||
defs['ID2ISO_COMPRESSED_LONG_TWO_ISOG_ZIP_CHAIN_BYTES'] = (f + 7) // 8
|
||||
defs['ID2ISO_COMPRESSED_LONG_TWO_ISOG_BYTES'] = defs['ZIP_CHAIN_LEN'] * defs['ID2ISO_COMPRESSED_LONG_TWO_ISOG_ZIP_CHAIN_BYTES'] + 1
|
||||
|
||||
defs['SIGNATURE_LEN'] = defs['ID2ISO_COMPRESSED_LONG_TWO_ISOG_BYTES'] + ((tors2part*tors3part).bit_length()+7)//8 + 1 + (tors2part.bit_length()+7)//8 + (tors3part.bit_length()+7)//8
|
||||
defs['PUBLICKEY_BYTES'] = defs['EC_CURVE_ENCODED_BYTES']
|
||||
defs['SECRETKEY_BYTES'] = defs['EC_CURVE_ENCODED_BYTES'] + 5*defs['QUAT_ALG_ELEM_ENCODED_BYTES'] + defs['EC_POINT_ENCODED_BYTES'] + defs['EC_BASIS_ENCODED_BYTES'] + defs['EC_BASIS_ENCODED_BYTES']
|
||||
|
||||
size_privkey = defs['SECRETKEY_BYTES']
|
||||
size_pubkey = defs['PUBLICKEY_BYTES']
|
||||
size_signature = defs['SIGNATURE_LEN']
|
||||
|
||||
algname = f'lvl{lvl}'
|
||||
|
||||
################################################################
|
||||
|
||||
with open('include/encoded_sizes.h','w') as hfile:
|
||||
for k,v in defs.items():
|
||||
v = ZZ(v)
|
||||
print(f'#define {k} {v}', file=hfile)
|
||||
|
||||
api = f'''
|
||||
// SPDX-License-Identifier: Apache-2.0
|
||||
|
||||
#ifndef api_h
|
||||
#define api_h
|
||||
|
||||
#define CRYPTO_SECRETKEYBYTES {size_privkey:4}
|
||||
#define CRYPTO_PUBLICKEYBYTES {size_pubkey:4}
|
||||
#define CRYPTO_BYTES {size_signature:4}
|
||||
|
||||
#define CRYPTO_ALGNAME "{algname}"
|
||||
|
||||
int
|
||||
crypto_sign_keypair(unsigned char *pk, unsigned char *sk);
|
||||
|
||||
int
|
||||
crypto_sign(unsigned char *sm, unsigned long long *smlen,
|
||||
const unsigned char *m, unsigned long long mlen,
|
||||
const unsigned char *sk);
|
||||
|
||||
int
|
||||
crypto_sign_open(unsigned char *m, unsigned long long *mlen,
|
||||
const unsigned char *sm, unsigned long long smlen,
|
||||
const unsigned char *pk);
|
||||
|
||||
#endif /* api_h */
|
||||
'''.strip()
|
||||
|
||||
with open(f'../../../nistapi/lvl{lvl}/api.h', 'w') as f:
|
||||
print(api, file=f)
|
||||
|
||||
Reference in New Issue
Block a user