2022-08-06 19:05:54 +02:00
|
|
|
# Constantine
|
|
|
|
# Copyright (c) 2018-2019 Status Research & Development GmbH
|
|
|
|
# Copyright (c) 2020-Present Mamy André-Ratsimbazafy
|
|
|
|
# Licensed and distributed under either of
|
|
|
|
# * MIT license (license terms in the root directory or at http://opensource.org/licenses/MIT).
|
|
|
|
# * Apache v2 license (license terms in the root directory or at http://www.apache.org/licenses/LICENSE-2.0).
|
|
|
|
# at your option. This file may not be copied, modified, or distributed except according to those terms.
|
|
|
|
|
|
|
|
import
|
|
|
|
../constantine/math/config/curves,
|
|
|
|
../constantine/curves_primitives
|
|
|
|
|
|
|
|
export curves, curves_primitives
|
|
|
|
|
|
|
|
# Overview
|
|
|
|
# ------------------------------------------------------------
|
|
|
|
#
|
|
|
|
# This files provides template for C bindings generation
|
|
|
|
|
|
|
|
template genBindingsField*(Field: untyped) =
|
2023-04-18 22:02:23 +02:00
|
|
|
when appType == "lib":
|
2023-04-26 06:58:31 +02:00
|
|
|
{.push noconv, dynlib, exportc, raises: [].} # No exceptions allowed
|
2023-04-18 22:02:23 +02:00
|
|
|
else:
|
2023-04-26 06:58:31 +02:00
|
|
|
{.push noconv, exportc, raises: [].} # No exceptions allowed
|
2023-04-18 22:02:23 +02:00
|
|
|
|
2023-08-13 15:08:04 +02:00
|
|
|
func `ctt _ Field _ unmarshalBE`(dst: var Field, src: openarray[byte]): bool =
|
2022-08-06 19:05:54 +02:00
|
|
|
## Deserialize
|
|
|
|
unmarshalBE(dst, src)
|
|
|
|
|
2023-08-13 15:08:04 +02:00
|
|
|
func `ctt _ Field _ marshalBE`(dst: var openarray[byte], src: Field): bool =
|
2022-08-06 19:05:54 +02:00
|
|
|
marshalBE(dst, src)
|
|
|
|
# --------------------------------------------------------------------------------------
|
|
|
|
func `ctt _ Field _ is_eq`(a, b: Field): SecretBool =
|
|
|
|
a == b
|
|
|
|
|
|
|
|
func `ctt _ Field _ is_zero`(a: Field): SecretBool =
|
|
|
|
a.isZero()
|
|
|
|
|
|
|
|
func `ctt _ Field _ is_one`(a: Field): SecretBool =
|
|
|
|
a.isOne()
|
|
|
|
|
|
|
|
func `ctt _ Field _ is_minus_one`(a: Field): SecretBool =
|
|
|
|
a.isMinusOne()
|
|
|
|
# --------------------------------------------------------------------------------------
|
|
|
|
func `ctt _ Field _ set_zero`(a: var Field) =
|
|
|
|
a.setZero()
|
|
|
|
|
|
|
|
func `ctt _ Field _ set_one`(a: var Field) =
|
|
|
|
a.setOne()
|
|
|
|
|
|
|
|
func `ctt _ Field _ set_minus_one`(a: var Field) =
|
|
|
|
a.setMinusOne()
|
|
|
|
# --------------------------------------------------------------------------------------
|
2022-09-15 17:11:57 +02:00
|
|
|
func `ctt _ Field _ neg`(r: var Field, a: Field) =
|
|
|
|
r.neg(a)
|
|
|
|
|
|
|
|
func `ctt _ Field _ neg_in_place`(a: var Field) =
|
2022-08-06 19:05:54 +02:00
|
|
|
a.neg()
|
|
|
|
|
|
|
|
func `ctt _ Field _ sum`(r: var Field, a, b: Field) =
|
|
|
|
r.sum(a,b)
|
|
|
|
|
|
|
|
func `ctt _ Field _ add_in_place`(a: var Field, b: Field) =
|
|
|
|
a += b
|
|
|
|
|
|
|
|
func `ctt _ Field _ diff`(r: var Field, a, b: Field) =
|
|
|
|
r.diff(a,b)
|
|
|
|
|
|
|
|
func `ctt _ Field _ sub_in_place`(a: var Field, b: Field) =
|
|
|
|
a -= b
|
|
|
|
|
|
|
|
func `ctt _ Field _ double`(r: var Field, a: Field) =
|
|
|
|
r.double(a)
|
|
|
|
|
|
|
|
func `ctt _ Field _ double_in_place`(a: var Field) =
|
|
|
|
a.double()
|
|
|
|
# --------------------------------------------------------------------------------------
|
|
|
|
func `ctt _ Field _ prod`(r: var Field, a, b: Field) =
|
|
|
|
r.prod(a,b)
|
|
|
|
|
|
|
|
func `ctt _ Field _ mul_in_place`(a: var Field, b: Field) =
|
|
|
|
a *= b
|
2023-04-18 22:02:23 +02:00
|
|
|
|
2022-08-06 19:05:54 +02:00
|
|
|
func `ctt _ Field _ square`(r: var Field, a: Field) =
|
|
|
|
r.square(a)
|
|
|
|
|
|
|
|
func `ctt _ Field _ square_in_place`(a: var Field) =
|
|
|
|
a.square()
|
|
|
|
# --------------------------------------------------------------------------------------
|
|
|
|
func `ctt _ Field _ div2`(a: var Field) =
|
|
|
|
a.div2()
|
2023-04-18 22:02:23 +02:00
|
|
|
|
2022-08-06 19:05:54 +02:00
|
|
|
func `ctt _ Field _ inv`(r: var Field, a: Field) =
|
|
|
|
r.inv(a)
|
2023-04-18 22:02:23 +02:00
|
|
|
|
2022-08-06 19:05:54 +02:00
|
|
|
func `ctt _ Field _ inv_in_place`(a: var Field) =
|
|
|
|
a.inv()
|
|
|
|
# --------------------------------------------------------------------------------------
|
|
|
|
func `ctt _ Field _ ccopy`(a: var Field, b: Field, ctl: SecretBool) =
|
|
|
|
a.ccopy(b, ctl)
|
|
|
|
|
|
|
|
func `ctt _ Field _ cswap`(a, b: var Field, ctl: SecretBool) =
|
|
|
|
a.cswap(b, ctl)
|
2023-04-18 22:02:23 +02:00
|
|
|
|
2022-08-06 22:11:03 +02:00
|
|
|
func `ctt _ Field _ cset_zero`(a: var Field, ctl: SecretBool) =
|
2022-08-06 19:05:54 +02:00
|
|
|
a.csetZero(ctl)
|
2023-04-18 22:02:23 +02:00
|
|
|
|
2022-08-06 22:11:03 +02:00
|
|
|
func `ctt _ Field _ cset_one`(a: var Field, ctl: SecretBool) =
|
2022-08-06 19:05:54 +02:00
|
|
|
a.csetOne(ctl)
|
|
|
|
|
|
|
|
func `ctt _ Field _ cneg_in_place`(a: var Field, ctl: SecretBool) =
|
|
|
|
a.cneg(ctl)
|
|
|
|
|
|
|
|
func `ctt _ Field _ cadd_in_place`(a: var Field, b: Field, ctl: SecretBool) =
|
|
|
|
a.cadd(b, ctl)
|
|
|
|
|
|
|
|
func `ctt _ Field _ csub_in_place`(a: var Field, b: Field, ctl: SecretBool) =
|
|
|
|
a.csub(b, ctl)
|
|
|
|
|
|
|
|
{.pop.}
|
|
|
|
|
|
|
|
|
|
|
|
template genBindingsFieldSqrt*(Field: untyped) =
|
2023-04-18 22:02:23 +02:00
|
|
|
when appType == "lib":
|
2023-04-26 06:58:31 +02:00
|
|
|
{.push noconv, dynlib, exportc, raises: [].} # No exceptions allowed
|
2023-04-18 22:02:23 +02:00
|
|
|
else:
|
2023-04-26 06:58:31 +02:00
|
|
|
{.push noconv, exportc, raises: [].} # No exceptions allowed
|
2022-08-06 19:05:54 +02:00
|
|
|
|
|
|
|
func `ctt _ Field _ is_square`(a: Field): SecretBool =
|
|
|
|
a.isSquare()
|
|
|
|
|
|
|
|
func `ctt _ Field _ invsqrt`(r: var Field, a: Field) =
|
|
|
|
r.invsqrt(a)
|
|
|
|
|
|
|
|
func `ctt _ Field _ invsqrt_in_place`(r: var Field, a: Field): SecretBool =
|
|
|
|
r.invsqrt_if_square(a)
|
|
|
|
|
|
|
|
func `ctt _ Field _ sqrt_in_place`(a: var Field) =
|
|
|
|
a.sqrt()
|
|
|
|
|
|
|
|
func `ctt _ Field _ sqrt_if_square_in_place`(a: var Field): SecretBool =
|
|
|
|
a.sqrt_if_square()
|
|
|
|
|
|
|
|
func `ctt _ Field _ sqrt_invsqrt`(sqrt, invsqrt: var Field, a: Field) =
|
|
|
|
sqrt_invsqrt(sqrt, invsqrt, a)
|
|
|
|
|
|
|
|
func `ctt _ Field _ sqrt_invsqrt_if_square`(sqrt, invsqrt: var Field, a: Field): SecretBool =
|
|
|
|
sqrt_invsqrt_if_square(sqrt, invsqrt, a)
|
|
|
|
|
|
|
|
func `ctt _ Field _ sqrt_ratio_if_square`(r: var Field, u, v: Field): SecretBool =
|
|
|
|
r.sqrt_ratio_if_square(u, v)
|
|
|
|
|
|
|
|
{.pop.}
|
|
|
|
|
|
|
|
|
|
|
|
template genBindingsExtField*(Field: untyped) =
|
2023-04-18 22:02:23 +02:00
|
|
|
when appType == "lib":
|
2023-04-26 06:58:31 +02:00
|
|
|
{.push noconv, dynlib, exportc, raises: [].} # No exceptions allowed
|
2023-04-18 22:02:23 +02:00
|
|
|
else:
|
2023-04-26 06:58:31 +02:00
|
|
|
{.push noconv, exportc, raises: [].} # No exceptions allowed
|
2022-08-06 19:05:54 +02:00
|
|
|
|
|
|
|
# --------------------------------------------------------------------------------------
|
|
|
|
func `ctt _ Field _ is_eq`(a, b: Field): SecretBool =
|
|
|
|
a == b
|
|
|
|
|
|
|
|
func `ctt _ Field _ is_zero`(a: Field): SecretBool =
|
|
|
|
a.isZero()
|
|
|
|
|
|
|
|
func `ctt _ Field _ is_one`(a: Field): SecretBool =
|
|
|
|
a.isOne()
|
|
|
|
|
|
|
|
func `ctt _ Field _ is_minus_one`(a: Field): SecretBool =
|
|
|
|
a.isMinusOne()
|
|
|
|
# --------------------------------------------------------------------------------------
|
|
|
|
func `ctt _ Field _ set_zero`(a: var Field) =
|
|
|
|
a.setZero()
|
|
|
|
|
|
|
|
func `ctt _ Field _ set_one`(a: var Field) =
|
|
|
|
a.setOne()
|
|
|
|
|
|
|
|
func `ctt _ Field _ set_minus_one`(a: var Field) =
|
|
|
|
a.setMinusOne()
|
|
|
|
# --------------------------------------------------------------------------------------
|
|
|
|
func `ctt _ Field _ neg`(a: var Field) =
|
|
|
|
a.neg()
|
|
|
|
|
|
|
|
func `ctt _ Field _ sum`(r: var Field, a, b: Field) =
|
|
|
|
r.sum(a,b)
|
|
|
|
|
|
|
|
func `ctt _ Field _ add_in_place`(a: var Field, b: Field) =
|
|
|
|
a += b
|
|
|
|
|
|
|
|
func `ctt _ Field _ diff`(r: var Field, a, b: Field) =
|
|
|
|
r.diff(a,b)
|
|
|
|
|
|
|
|
func `ctt _ Field _ sub_in_place`(a: var Field, b: Field) =
|
|
|
|
a -= b
|
|
|
|
|
|
|
|
func `ctt _ Field _ double`(r: var Field, a: Field) =
|
|
|
|
r.double(a)
|
|
|
|
|
|
|
|
func `ctt _ Field _ double_in_place`(a: var Field) =
|
|
|
|
a.double()
|
|
|
|
|
|
|
|
func `ctt _ Field _ conj`(r: var Field, a: Field) =
|
|
|
|
r.conj(a)
|
2023-04-18 22:02:23 +02:00
|
|
|
|
2022-08-06 19:05:54 +02:00
|
|
|
func `ctt _ Field _ conj_in_place`(a: var Field) =
|
|
|
|
a.conj()
|
|
|
|
|
|
|
|
func `ctt _ Field _ conjneg`(r: var Field, a: Field) =
|
|
|
|
r.conjneg(a)
|
2023-04-18 22:02:23 +02:00
|
|
|
|
2022-08-06 19:05:54 +02:00
|
|
|
func `ctt _ Field _ conjneg_in_place`(a: var Field) =
|
|
|
|
a.conjneg()
|
|
|
|
|
|
|
|
# --------------------------------------------------------------------------------------
|
|
|
|
func `ctt _ Field _ prod`(r: var Field, a, b: Field) =
|
|
|
|
r.prod(a,b)
|
|
|
|
|
|
|
|
func `ctt _ Field _ mul_in_place`(a: var Field, b: Field) =
|
|
|
|
a *= b
|
2023-04-18 22:02:23 +02:00
|
|
|
|
2022-08-06 19:05:54 +02:00
|
|
|
func `ctt _ Field _ square`(r: var Field, a: Field) =
|
|
|
|
r.square(a)
|
|
|
|
|
|
|
|
func `ctt _ Field _ square_in_place`(a: var Field) =
|
|
|
|
a.square()
|
|
|
|
# --------------------------------------------------------------------------------------
|
|
|
|
func `ctt _ Field _ div2`(a: var Field) =
|
|
|
|
a.div2()
|
2023-04-18 22:02:23 +02:00
|
|
|
|
2022-08-06 19:05:54 +02:00
|
|
|
func `ctt _ Field _ inv`(r: var Field, a: Field) =
|
|
|
|
r.inv(a)
|
2023-04-18 22:02:23 +02:00
|
|
|
|
2022-08-06 19:05:54 +02:00
|
|
|
func `ctt _ Field _ inv_in_place`(a: var Field) =
|
|
|
|
a.inv()
|
|
|
|
# --------------------------------------------------------------------------------------
|
2022-08-06 22:11:03 +02:00
|
|
|
func `ctt _ Field _ ccopy`(a: var Field, b: Field, ctl: SecretBool) =
|
|
|
|
a.ccopy(b, ctl)
|
|
|
|
|
|
|
|
func `ctt _ Field _ cset_zero`(a: var Field, ctl: SecretBool) =
|
2022-08-06 19:05:54 +02:00
|
|
|
a.csetZero(ctl)
|
2023-04-18 22:02:23 +02:00
|
|
|
|
2022-08-06 22:11:03 +02:00
|
|
|
func `ctt _ Field _ cset_one`(a: var Field, ctl: SecretBool) =
|
2022-08-06 19:05:54 +02:00
|
|
|
a.csetOne(ctl)
|
|
|
|
|
|
|
|
func `ctt _ Field _ cneg_in_place`(a: var Field, ctl: SecretBool) =
|
|
|
|
a.cneg(ctl)
|
|
|
|
|
|
|
|
func `ctt _ Field _ cadd_in_place`(a: var Field, b: Field, ctl: SecretBool) =
|
|
|
|
a.cadd(b, ctl)
|
|
|
|
|
|
|
|
func `ctt _ Field _ csub_in_place`(a: var Field, b: Field, ctl: SecretBool) =
|
|
|
|
a.csub(b, ctl)
|
|
|
|
|
|
|
|
{.pop.}
|
|
|
|
|
|
|
|
template genBindingsExtFieldSqrt*(Field: untyped) =
|
2023-04-18 22:02:23 +02:00
|
|
|
when appType == "lib":
|
2023-04-26 06:58:31 +02:00
|
|
|
{.push noconv, dynlib, exportc, raises: [].} # No exceptions allowed
|
2023-04-18 22:02:23 +02:00
|
|
|
else:
|
2023-04-26 06:58:31 +02:00
|
|
|
{.push noconv, exportc, raises: [].} # No exceptions allowed
|
2022-08-06 19:05:54 +02:00
|
|
|
|
|
|
|
func `ctt _ Field _ is_square`(a: Field): SecretBool =
|
|
|
|
a.isSquare()
|
|
|
|
|
|
|
|
func `ctt _ Field _ sqrt_in_place`(a: var Field) =
|
|
|
|
a.sqrt()
|
|
|
|
|
|
|
|
func `ctt _ Field _ sqrt_if_square_in_place`(a: var Field): SecretBool =
|
|
|
|
a.sqrt_if_square()
|
|
|
|
|
|
|
|
{.pop}
|
|
|
|
|
|
|
|
template genBindings_EC_ShortW_Affine*(ECP, Field: untyped) =
|
2023-04-18 22:02:23 +02:00
|
|
|
when appType == "lib":
|
2023-04-26 06:58:31 +02:00
|
|
|
{.push noconv, dynlib, exportc, raises: [].} # No exceptions allowed
|
2023-04-18 22:02:23 +02:00
|
|
|
else:
|
2023-04-26 06:58:31 +02:00
|
|
|
{.push noconv, exportc, raises: [].} # No exceptions allowed
|
2022-08-06 19:05:54 +02:00
|
|
|
|
|
|
|
# --------------------------------------------------------------------------------------
|
|
|
|
func `ctt _ ECP _ is_eq`(P, Q: ECP): SecretBool =
|
|
|
|
P == Q
|
2023-04-18 22:02:23 +02:00
|
|
|
|
2022-08-06 19:05:54 +02:00
|
|
|
func `ctt _ ECP _ is_inf`(P: ECP): SecretBool =
|
|
|
|
P.isInf()
|
|
|
|
|
|
|
|
func `ctt _ ECP _ set_inf`(P: var ECP) =
|
|
|
|
P.setInf()
|
|
|
|
|
|
|
|
func `ctt _ ECP _ ccopy`(P: var ECP, Q: ECP, ctl: SecretBool) =
|
|
|
|
P.ccopy(Q, ctl)
|
2023-04-18 22:02:23 +02:00
|
|
|
|
2022-08-06 19:05:54 +02:00
|
|
|
func `ctt _ ECP _ is_on_curve`(x, y: Field): SecretBool =
|
|
|
|
isOnCurve(x, y, ECP.G)
|
|
|
|
|
|
|
|
func `ctt _ ECP _ neg`(P: var ECP, Q: ECP) =
|
|
|
|
P.neg(Q)
|
|
|
|
|
|
|
|
func `ctt _ ECP _ neg_in_place`(P: var ECP) =
|
|
|
|
P.neg()
|
|
|
|
|
|
|
|
{.pop.}
|
|
|
|
|
|
|
|
template genBindings_EC_ShortW_NonAffine*(ECP, ECP_Aff, Field: untyped) =
|
2023-04-18 22:02:23 +02:00
|
|
|
when appType == "lib":
|
2023-04-26 06:58:31 +02:00
|
|
|
{.push noconv, dynlib, exportc, raises: [].} # No exceptions allowed
|
2023-04-18 22:02:23 +02:00
|
|
|
else:
|
2023-04-26 06:58:31 +02:00
|
|
|
{.push noconv, exportc, raises: [].} # No exceptions allowed
|
2022-08-06 19:05:54 +02:00
|
|
|
|
|
|
|
# --------------------------------------------------------------------------------------
|
|
|
|
func `ctt _ ECP _ is_eq`(P, Q: ECP): SecretBool =
|
|
|
|
P == Q
|
2023-04-18 22:02:23 +02:00
|
|
|
|
2022-08-06 19:05:54 +02:00
|
|
|
func `ctt _ ECP _ is_inf`(P: ECP): SecretBool =
|
|
|
|
P.isInf()
|
|
|
|
|
|
|
|
func `ctt _ ECP _ set_inf`(P: var ECP) =
|
|
|
|
P.setInf()
|
|
|
|
|
|
|
|
func `ctt _ ECP _ ccopy`(P: var ECP, Q: ECP, ctl: SecretBool) =
|
|
|
|
P.ccopy(Q, ctl)
|
2023-04-18 22:02:23 +02:00
|
|
|
|
2022-08-06 19:05:54 +02:00
|
|
|
func `ctt _ ECP _ neg`(P: var ECP, Q: ECP) =
|
|
|
|
P.neg(Q)
|
|
|
|
|
|
|
|
func `ctt _ ECP _ neg_in_place`(P: var ECP) =
|
|
|
|
P.neg()
|
|
|
|
|
|
|
|
func `ctt _ ECP _ cneg_in_place`(P: var ECP, ctl: SecretBool) =
|
|
|
|
P.neg()
|
|
|
|
|
|
|
|
func `ctt _ ECP _ sum`(r: var ECP, P, Q: ECP) =
|
|
|
|
r.sum(P, Q)
|
|
|
|
|
|
|
|
func `ctt _ ECP _ add_in_place`(P: var ECP, Q: ECP) =
|
|
|
|
P += Q
|
|
|
|
|
|
|
|
func `ctt _ ECP _ diff`(r: var ECP, P, Q: ECP) =
|
|
|
|
r.diff(P, Q)
|
|
|
|
|
|
|
|
func `ctt _ ECP _ double`(r: var ECP, P: ECP) =
|
|
|
|
r.double(P)
|
|
|
|
|
|
|
|
func `ctt _ ECP _ double_in_place`(P: var ECP) =
|
|
|
|
P.double()
|
2023-04-18 22:02:23 +02:00
|
|
|
|
2022-08-06 19:05:54 +02:00
|
|
|
func `ctt _ ECP _ affine`(dst: var ECP_Aff, src: ECP) =
|
|
|
|
dst.affine(src)
|
|
|
|
|
|
|
|
func `ctt _ ECP _ from_affine`(dst: var ECP, src: ECP_Aff) =
|
|
|
|
dst.fromAffine(src)
|
|
|
|
|
|
|
|
{.pop.}
|