mirror of
https://github.com/golang/sys.git
synced 2026-02-07 19:26:03 +03:00
Add a RISCV64 variable to cpu that indicates both the presence of RISC-V extensions and performance information about the underlying RISC-V cores. The variable is only populated with non false values on Linux. The detection code first attempts to use the riscv_hwprobe syscall introduced in Linux 6.4, falling back to HWCAP if riscv_hwprobe is not supported. The patch can detect the C, V, Zba, Zbb and Zbs extensions. V, Zba, Zbb and Zbs can only be detected on a 6.5 kernel or later (without backports). Updates golang/go#61416 Change-Id: I40f92724ee3d337c06bdc559ff0b18a8f6bfda9f Reviewed-on: https://go-review.googlesource.com/c/sys/+/605815 Reviewed-by: Cherry Mui <cherryyz@google.com> Reviewed-by: Dmitri Shuralyov <dmitshur@google.com> LUCI-TryBot-Result: Go LUCI <golang-scoped@luci-project-accounts.iam.gserviceaccount.com> Reviewed-by: Joel Sing <joel@sing.id.au> Reviewed-by: Meng Zhuo <mengzhuo1203@gmail.com>
85 lines
2.0 KiB
Go
85 lines
2.0 KiB
Go
// Copyright 2018 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.
|
|
|
|
package cpu_test
|
|
|
|
import (
|
|
"runtime"
|
|
"testing"
|
|
|
|
"golang.org/x/sys/cpu"
|
|
)
|
|
|
|
func TestAMD64minimalFeatures(t *testing.T) {
|
|
if runtime.GOARCH == "amd64" {
|
|
if !cpu.Initialized {
|
|
t.Fatal("Initialized expected true, got false")
|
|
}
|
|
if !cpu.X86.HasSSE2 {
|
|
t.Fatal("HasSSE2 expected true, got false")
|
|
}
|
|
}
|
|
}
|
|
|
|
func TestAVX2hasAVX(t *testing.T) {
|
|
if runtime.GOARCH == "amd64" {
|
|
if cpu.X86.HasAVX2 && !cpu.X86.HasAVX {
|
|
t.Fatal("HasAVX expected true, got false")
|
|
}
|
|
}
|
|
}
|
|
|
|
func TestAVX512HasAVX2AndAVX(t *testing.T) {
|
|
if runtime.GOARCH == "amd64" {
|
|
if cpu.X86.HasAVX512 && !cpu.X86.HasAVX {
|
|
t.Fatal("HasAVX expected true, got false")
|
|
}
|
|
if cpu.X86.HasAVX512 && !cpu.X86.HasAVX2 {
|
|
t.Fatal("HasAVX2 expected true, got false")
|
|
}
|
|
}
|
|
}
|
|
|
|
func TestARM64minimalFeatures(t *testing.T) {
|
|
if runtime.GOARCH != "arm64" || runtime.GOOS == "ios" {
|
|
return
|
|
}
|
|
if !cpu.ARM64.HasASIMD {
|
|
t.Fatal("HasASIMD expected true, got false")
|
|
}
|
|
if !cpu.ARM64.HasFP {
|
|
t.Fatal("HasFP expected true, got false")
|
|
}
|
|
}
|
|
|
|
func TestMIPS64Initialized(t *testing.T) {
|
|
if runtime.GOARCH == "mips64" || runtime.GOARCH == "mips64le" {
|
|
if !cpu.Initialized {
|
|
t.Fatal("Initialized expected true, got false")
|
|
}
|
|
}
|
|
}
|
|
|
|
func TestRISCV64Initialized(t *testing.T) {
|
|
if runtime.GOARCH == "riscv64" {
|
|
if !cpu.Initialized {
|
|
t.Fatal("Initialized expected true, got false")
|
|
}
|
|
}
|
|
}
|
|
|
|
// On ppc64x, the ISA bit for POWER8 should always be set on POWER8 and beyond.
|
|
func TestPPC64minimalFeatures(t *testing.T) {
|
|
// Do not run this with gccgo on ppc64, as it doesn't have POWER8 as a minimum
|
|
// requirement.
|
|
if runtime.Compiler == "gccgo" && runtime.GOARCH == "ppc64" {
|
|
t.Skip("gccgo does not require POWER8 on ppc64; skipping")
|
|
}
|
|
if runtime.GOARCH == "ppc64" || runtime.GOARCH == "ppc64le" {
|
|
if !cpu.PPC64.IsPOWER8 {
|
|
t.Fatal("IsPOWER8 expected true, got false")
|
|
}
|
|
}
|
|
}
|