// Copyright 2016 The Go Authors. All rights reserved. // Use of this source code is governed by a BSD-style // license that can be found in the LICENSE file. // +build go1.7,amd64,!gccgo,!appengine package chacha20poly1305 import "encoding/binary" //go:noescape func chacha20Poly1305Open(dst []byte, key []uint32, src, ad []byte) bool //go:noescape func chacha20Poly1305Seal(dst []byte, key []uint32, src, ad []byte) // cpuid is implemented in chacha20poly1305_amd64.s. func cpuid(eaxArg, ecxArg uint32) (eax, ebx, ecx, edx uint32) // xgetbv with ecx = 0 is implemented in chacha20poly1305_amd64.s. func xgetbv() (eax, edx uint32) var ( useASM bool useAVX2 bool ) func init() { detectCpuFeatures() } // detectCpuFeatures is used to detect if cpu instructions // used by the functions implemented in assembler in // chacha20poly1305_amd64.s are supported. func detectCpuFeatures() { maxId, _, _, _ := cpuid(0, 0) if maxId < 1 { return } _, _, ecx1, _ := cpuid(1, 0) haveSSSE3 := isSet(9, ecx1) useASM = haveSSSE3 haveOSXSAVE := isSet(27, ecx1) osSupportsAVX := false // For XGETBV, OSXSAVE bit is required and sufficient. if haveOSXSAVE { eax, _ := xgetbv() // Check if XMM and YMM registers have OS support. osSupportsAVX = isSet(1, eax) && isSet(2, eax) } haveAVX := isSet(28, ecx1) && osSupportsAVX if maxId < 7 { return } _, ebx7, _, _ := cpuid(7, 0) haveAVX2 := isSet(5, ebx7) && haveAVX haveBMI2 := isSet(8, ebx7) useAVX2 = haveAVX2 && haveBMI2 } // isSet checks if bit at bitpos is set in value. func isSet(bitpos uint, value uint32) bool { return value&(1<