Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

blst Go bindings no longer compile with Go 1.24 #245

Open
mark-rushakoff opened this issue Dec 16, 2024 · 2 comments
Open

blst Go bindings no longer compile with Go 1.24 #245

mark-rushakoff opened this issue Dec 16, 2024 · 2 comments

Comments

@mark-rushakoff
Copy link

I tried building Go code that references blst at the latest release, and with go1.24rc1 the blst bindings fail to build.

This failure can be reproduced from the blst repository, in the bindings/go directory.

Tests run fine with go1.23:

$ go version ; go test
go version go1.23.4 darwin/arm64
PASS
ok  	github.com/supranational/blst/bindings/go	0.715

With go1.24rc1, the bindings fail to build:

$ ~/go/bin/go1.24rc1 version;  ~/go/bin/go1.24rc1 test .
go version go1.24rc1 darwin/arm64
# github.com/supranational/blst/bindings/go [github.com/supranational/blst/bindings/go.test]
./blst.go:237:11: cannot define new methods on non-local type SecretKey
./blst.go:324:15: cannot define new methods on non-local type SecretKey
./blst.go:444:11: cannot define new methods on non-local type Fp12
./blst.go:448:11: cannot define new methods on non-local type Fp12
./blst.go:452:11: cannot define new methods on non-local type Fp12
./blst.go:456:11: cannot define new methods on non-local type Fp12
./blst.go:462:12: cannot define new methods on non-local type Fp12
./blst.go:482:11: cannot define new methods on non-local type P1Affine
./blst.go:487:11: cannot define new methods on non-local type P1Affine
./blst.go:495:12: cannot define new methods on non-local type P2Affine
./blst.go:495:12: too many errors
FAIL	github.com/supranational/blst/bindings/go [build failed]
FAIL

This appears to be a deliberate change in the Go toolchain, according to the draft Go 1.24 release notes:

The compiler already disallowed defining new methods with receiver types that were cgo-generated, but it was possible to circumvent that restriction via an alias type. Go 1.24 now always reports an error if a receiver denotes a cgo-generated type, whether directly or indirectly (through an alias type).

The HTML comments at that paragraph indicate golang/go#60725 and golang/go#57926.

The fix is probably changing this set of types:

blst/bindings/go/blst.go

Lines 171 to 182 in bef14ca

type Scalar = C.blst_scalar
type Fp = C.blst_fp
type Fp2 = C.blst_fp2
type Fp6 = C.blst_fp6
type Fp12 = C.blst_fp12
type P1 = C.blst_p1
type P2 = C.blst_p2
type P1Affine = C.blst_p1_affine
type P2Affine = C.blst_p2_affine
type Message = []byte
type Pairing = []C.blst_pairing
type SecretKey = Scalar

to "normal" type definitions (e.g. type Scalar C.blst_scalar without the = in the middle) and then defining the required methods, including forwarding all the other methods that already exist on the C.blst_scalar type. I think this would avoid breaking any existing usage, but I haven't really used this package yet so it's a bit of a guess on my part.

@dot-asm
Copy link
Collaborator

dot-asm commented Dec 20, 2024

Thanks for the heads-up! Unfortunately getting rid of = in type declaration doesn't cut it. Could you test #247, i.e. go1.24 branch in https://github.com/dot-asm/blst, with whatever you're working on?

@mark-rushakoff
Copy link
Author

I commented on #247 too -- merging #247 will resolve this issue. Thanks for the quick fix.

mark-rushakoff added a commit to gordian-engine/gordian that referenced this issue Jan 8, 2025
This uses the supranational/blst package for an implementation of BLS
signatures. We use the minimized signature form, hence the package name.

The package includes a BLS-backed gcrypto.PubKey implementation and a
CommonMessageSignatureProof implementation. There are likely some
missing details in the BLS setup, at least in adding configurability for
the signatures' salt. I think the domain separation tag is correct.

I cannot find the whitepaper or technical document that introduced me to
the concept, but the model of arranging the validators in a tree for key
and signature aggregation is based on the concept that the leftmost
validators are trustworthy and likely to be online, while the rightmost
validators are the least expected to vote. See further documentation on
the SignatureProof type.

It has not been fully integrated yet, but we have tests around the usage
of both of those types.

Next up are some slight interface changes that will affect the ed25519
implementation too. And I think we may need some special handling such
that the signature committed to chain is a "final aggregation" of keys
that would not normally be aggregated together. For instance, if there
are only four validators, then during consensus gossip, we would pair
0-1 and 2-3, but never 0-2 or 1-3. If the final votes were only from 0,
1, and 3 -- that is to say validator 2 was absent or perhaps voted nil
-- then we would commit with the aggregated signaure 0-1-3, to minimize
space used for signatures.

This also removes the gmerkle package, which was left in for
specifically this use case, but which turned out to be an incorrect fit.

Note that with the introduction of this package, we have a dependency on
supranational/blst, which is a C dependency; and there is currently the
outstanding issue supranational/blst#245 which prevents building blst
with Go 1.24. However, supranational/blst#247 is an open PR that fixes
the build for Go 1.24 and Go tip.
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants