diff --git a/badlinkname.go b/badlinkname.go index 97350e4..4eef04d 100644 --- a/badlinkname.go +++ b/badlinkname.go @@ -14,9 +14,6 @@ import _ "unsafe" //go:linkname aeadAESGCMTLS13 //go:linkname cipherSuiteTLS13ByID -//go:linkname cipherSuitesTLS13 -//go:linkname defaultCipherSuitesTLS13 -//go:linkname defaultCipherSuitesTLS13NoAES //go:linkname errShutdown // The compiler doesn't allow linknames on methods, for good reasons. diff --git a/cipher_suites.go b/cipher_suites.go index 83301f3..5f37bf6 100644 --- a/cipher_suites.go +++ b/cipher_suites.go @@ -18,6 +18,7 @@ import ( "hash" "internal/cpu" "runtime" + _ "unsafe" // for linkname "golang.org/x/crypto/chacha20poly1305" ) @@ -197,6 +198,15 @@ type cipherSuiteTLS13 struct { hash crypto.Hash } +// cipherSuitesTLS13 should be an internal detail, +// but widely used packages access it using linkname. +// Notable members of the hall of shame include: +// - github.com/quic-go/quic-go +// +// Do not remove or change the type signature. +// See go.dev/issue/67401. +// +//go:linkname cipherSuitesTLS13 var cipherSuitesTLS13 = []*cipherSuiteTLS13{ // TODO: replace with a map. {TLS_AES_128_GCM_SHA256, 16, aeadAESGCMTLS13, crypto.SHA256}, {TLS_CHACHA20_POLY1305_SHA256, 32, aeadChaCha20Poly1305, crypto.SHA256},