Skip to content

Commit 44d7b39

Browse files
committed
cpu: support darwin/arm64 CPU feature detection
Support ARM64 features detection. The CPU features which are supported by Apple Silicon M1 are assumed as the minimal set of features for Go programs running on darwin/arm64. The ARM64 supporting features are referred to https://en.wikichip.org/wiki/arm/armv8#ARMv8_Extensions_and_Processor_Features
1 parent d48e67d commit 44d7b39

File tree

4 files changed

+87
-3
lines changed

4 files changed

+87
-3
lines changed

cpu/cpu_arm64.go

+1-1
Original file line numberDiff line numberDiff line change
@@ -44,7 +44,7 @@ func archInit() {
4444
switch runtime.GOOS {
4545
case "freebsd":
4646
readARM64Registers()
47-
case "linux", "netbsd", "openbsd":
47+
case "linux", "netbsd", "openbsd", "darwin":
4848
doinit()
4949
default:
5050
// Many platforms don't seem to allow reading these registers.

cpu/cpu_darwin_arm64.go

+55
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,55 @@
1+
// Copyright 2021 The Go Authors. All rights reserved.
2+
// Use of this source code is governed by a BSD-style
3+
// license that can be found in the LICENSE file.
4+
5+
//go:build darwin && arm64 && !ios
6+
// +build darwin,arm64,!ios
7+
8+
package cpu
9+
10+
const (
11+
commpageHasNeonFP16 = 0x00000008 // ARM v8.2 NEON FP16 supported
12+
commpageHasNeon = 0x00000100 // Advanced SIMD is supported
13+
commpageHasNeonHPFP = 0x00000200 // Advanced SIMD half-precision
14+
commpageHasVfp = 0x00000400 // VFP is supported
15+
commpageHasEvent = 0x00001000 // WFE/SVE and period event wakeup
16+
commpageHasARMv82FHM = 0x00004000 // Optional ARMv8.2 FMLAL/FMLSL instructions (required in ARMv8.4)
17+
commpageHasARMv8Crypto = 0x01000000 // Optional ARMv8 Crypto extensions
18+
commpageHasARMv81Atomics = 0x02000000 // ARMv8.1 Atomic instructions supported
19+
commpageHasARMv8Crc32 = 0x04000000 // Optional ARMv8 crc32 instructions (required in ARMv8.1)
20+
commpageHasARMv82SHA512 = 0x80000000 // Optional ARMv8.2 SHA512 instructions
21+
commpageHasARMv82SHA3 = 0x0000000100000000 // Optional ARMv8.2 SHA3 instructions
22+
)
23+
24+
func doinit() {
25+
ARM64.HasFP = darwinCheckFeatureEnabled(commpageHasVfp)
26+
ARM64.HasASIMD = darwinCheckFeatureEnabled(commpageHasNeon)
27+
ARM64.HasCRC32 = darwinCheckFeatureEnabled(commpageHasARMv8Crc32)
28+
ARM64.HasATOMICS = darwinCheckFeatureEnabled(commpageHasARMv81Atomics)
29+
ARM64.HasFPHP = darwinCheckFeatureEnabled(commpageHasNeonFP16)
30+
ARM64.HasASIMDHP = darwinCheckFeatureEnabled(commpageHasNeonHPFP)
31+
ARM64.HasSHA3 = darwinCheckFeatureEnabled(commpageHasARMv82SHA3)
32+
ARM64.HasSHA512 = darwinCheckFeatureEnabled(commpageHasARMv82SHA512)
33+
ARM64.HasASIMDFHM = darwinCheckFeatureEnabled(commpageHasARMv82FHM)
34+
ARM64.HasSVE = darwinCheckFeatureEnabled(commpageHasEvent)
35+
36+
// There are no hw.optional sysctl values for the below features on Mac OS 11.0
37+
// to detect their supported state dynamically. Assume the CPU features that
38+
// Apple Silicon M1 supports to be available as a minimal set of features
39+
// to all Go programs running on darwin/arm64.
40+
ARM64.HasEVTSTRM = true
41+
ARM64.HasAES = true
42+
ARM64.HasPMULL = true
43+
ARM64.HasSHA1 = true
44+
ARM64.HasSHA2 = true
45+
ARM64.HasCPUID = true
46+
ARM64.HasASIMDRDM = true
47+
ARM64.HasJSCVT = true
48+
ARM64.HasLRCPC = true
49+
ARM64.HasDCPOP = true
50+
ARM64.HasSM3 = true
51+
ARM64.HasSM4 = true
52+
ARM64.HasASIMDDP = true
53+
}
54+
55+
func darwinCheckFeatureEnabled(feature_vec uint64) bool

cpu/cpu_darwin_arm64.s

+29
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,29 @@
1+
//go:build arm64 && gc
2+
// +build arm64
3+
// +build gc
4+
5+
#include "textflag.h"
6+
7+
// func darwinCheckFeatureEnabled(feature_vec uint64) bool
8+
TEXT ·darwinCheckFeatureEnabled(SB), NOSPLIT, $0-8
9+
MOVD feature_vec+0(FP), R0
10+
MOVD $0, ret+0(FP) // default to false
11+
MOVD $1, R2 // set R2 as true boolean constan
12+
13+
#ifdef GOOS_darwin // return if not darwin
14+
#ifdef GOARCH_arm64 // return if not arm64
15+
// These values from:
16+
// https://github.com/apple/darwin-xnu/blob/main/osfmk/arm/cpu_capabilities.h
17+
#define arm_commpage64_base_address 0x0000000fffffc000
18+
#define arm_commpage64_cpu_capabilities64 (arm_commpage64_base_address+0x010)
19+
MOVD $0xffffc000, R1
20+
MOVK $(0xf<<32), R1
21+
MOVD (R1), R1
22+
AND R1, R0
23+
CBZ R0, no_feature
24+
MOVD R2, ret+8(FP)
25+
26+
no_feature:
27+
#endif
28+
#endif
29+
RET

cpu/cpu_other_arm64.go

+2-2
Original file line numberDiff line numberDiff line change
@@ -2,8 +2,8 @@
22
// Use of this source code is governed by a BSD-style
33
// license that can be found in the LICENSE file.
44

5-
//go:build !linux && !netbsd && !openbsd && arm64
6-
// +build !linux,!netbsd,!openbsd,arm64
5+
//go:build !linux && !netbsd && !openbsd && arm64 && !darwin
6+
// +build !linux,!netbsd,!openbsd,arm64,!darwin
77

88
package cpu
99

0 commit comments

Comments
 (0)