Skip to content

Commit

Permalink
bindings/go/blst.go: re-generate.py.
Browse files Browse the repository at this point in the history
  • Loading branch information
dot-asm committed Dec 10, 2023
1 parent a166a02 commit 0bed2bd
Showing 1 changed file with 27 additions and 20 deletions.
47 changes: 27 additions & 20 deletions bindings/go/blst.go
Original file line number Diff line number Diff line change
Expand Up @@ -33,10 +33,6 @@ package blst
// }
// #endif
//
// static size_t go_pairing_sizeof(size_t DST_len)
// { return (blst_pairing_sizeof() + DST_len + sizeof(blst_pairing) - 1) /
// sizeof(blst_pairing);
// }
// static void go_pairing_init(blst_pairing *new_ctx, bool hash_or_encode,
// const byte *DST, size_t DST_len)
// { if (DST != NULL) {
Expand Down Expand Up @@ -143,6 +139,16 @@ package blst
// for (i = 2; i < n; i++)
// blst_fp12_mul(dst, dst, &in[i]);
// }
// static bool go_p1_affine_validate(const blst_p1_affine *p, bool infcheck)
// { if (infcheck && blst_p1_affine_is_inf(p))
// return 0;
// return blst_p1_affine_in_g1(p);
// }
// static bool go_p2_affine_validate(const blst_p2_affine *p, bool infcheck)
// { if (infcheck && blst_p2_affine_is_inf(p))
// return 0;
// return blst_p2_affine_in_g2(p);
// }
import "C"

import (
Expand Down Expand Up @@ -204,6 +210,11 @@ func SetMaxProcs(max int) {
maxProcs = max
}

var cgo_pairingSizeOf = C.blst_pairing_sizeof()
var cgo_p1Generator = *C.blst_p1_generator()
var cgo_p2Generator = *C.blst_p2_generator()
var cgo_fp12One = *C.blst_fp12_one()

// Secret key
func (sk *SecretKey) Zeroize() {
var zero SecretKey
Expand Down Expand Up @@ -302,9 +313,13 @@ func (master *SecretKey) DeriveChildEip2333(child_index uint32) *SecretKey {
}

// Pairing
func pairingSizeOf(DST_len C.size_t) int {
return int((cgo_pairingSizeOf + DST_len + 7) / 8)
}

func PairingCtx(hash_or_encode bool, DST []byte) Pairing {
DST_len := C.size_t(len(DST))
ctx := make([]C.blst_pairing, int(C.go_pairing_sizeof(DST_len)))
ctx := make([]C.blst_pairing, pairingSizeOf(DST_len))
C.go_pairing_init(&ctx[0], C.bool(hash_or_encode), ptrOrNil(DST), DST_len)
return ctx
}
Expand Down Expand Up @@ -337,7 +352,7 @@ func PairingAsFp12(ctx Pairing) *Fp12 {
}

func Fp12One() Fp12 {
return *C.blst_fp12_one()
return cgo_fp12One
}

func Fp12FinalVerify(pt1 *Fp12, pt2 *Fp12) bool {
Expand Down Expand Up @@ -452,19 +467,15 @@ func (pk *P1Affine) From(s *Scalar) *P1Affine {
}

func (pk *P1Affine) KeyValidate() bool {
return !bool(C.blst_p1_affine_is_inf(pk)) &&
bool(C.blst_p1_affine_in_g1(pk))
return bool(C.go_p1_affine_validate(pk, true))
}

// sigInfcheck, check for infinity, is a way to avoid going
// into resource-consuming verification. Passing 'false' is
// always cryptographically safe, but application might want
// to guard against obviously bogus individual[!] signatures.
func (sig *P2Affine) SigValidate(sigInfcheck bool) bool {
if sigInfcheck && bool(C.blst_p2_affine_is_inf(sig)) {
return false
}
return bool(C.blst_p2_affine_in_g2(sig))
return bool(C.go_p2_affine_validate(sig, C.bool(sigInfcheck)))
}

//
Expand Down Expand Up @@ -1058,19 +1069,15 @@ func (pk *P2Affine) From(s *Scalar) *P2Affine {
}

func (pk *P2Affine) KeyValidate() bool {
return !bool(C.blst_p2_affine_is_inf(pk)) &&
bool(C.blst_p2_affine_in_g2(pk))
return bool(C.go_p2_affine_validate(pk, true))
}

// sigInfcheck, check for infinity, is a way to avoid going
// into resource-consuming verification. Passing 'false' is
// always cryptographically safe, but application might want
// to guard against obviously bogus individual[!] signatures.
func (sig *P1Affine) SigValidate(sigInfcheck bool) bool {
if sigInfcheck && bool(C.blst_p1_affine_is_inf(sig)) {
return false
}
return bool(C.blst_p1_affine_in_g1(sig))
return bool(C.go_p1_affine_validate(sig, C.bool(sigInfcheck)))
}

//
Expand Down Expand Up @@ -1859,7 +1866,7 @@ func (p1 *P1) Sub(pointIf interface{}) *P1 {
}

func P1Generator() *P1 {
return C.blst_p1_generator()
return &cgo_p1Generator
}

// 'acc += point * scalar', passing 'nil' for 'point' means "use the
Expand Down Expand Up @@ -2521,7 +2528,7 @@ func (p2 *P2) Sub(pointIf interface{}) *P2 {
}

func P2Generator() *P2 {
return C.blst_p2_generator()
return &cgo_p2Generator
}

// 'acc += point * scalar', passing 'nil' for 'point' means "use the
Expand Down

0 comments on commit 0bed2bd

Please sign in to comment.