summaryrefslogtreecommitdiff
path: root/vendor/github.com/klauspost/cpuid
diff options
context:
space:
mode:
Diffstat (limited to 'vendor/github.com/klauspost/cpuid')
-rw-r--r--vendor/github.com/klauspost/cpuid/v2/.goreleaser.yml23
-rw-r--r--vendor/github.com/klauspost/cpuid/v2/README.md6
-rw-r--r--vendor/github.com/klauspost/cpuid/v2/cpuid.go10
-rw-r--r--vendor/github.com/klauspost/cpuid/v2/detect_arm64.go14
-rw-r--r--vendor/github.com/klauspost/cpuid/v2/featureid_string.go432
-rw-r--r--vendor/github.com/klauspost/cpuid/v2/os_darwin_arm64.go6
-rw-r--r--vendor/github.com/klauspost/cpuid/v2/os_linux_arm64.go78
7 files changed, 329 insertions, 240 deletions
diff --git a/vendor/github.com/klauspost/cpuid/v2/.goreleaser.yml b/vendor/github.com/klauspost/cpuid/v2/.goreleaser.yml
index 944cc0007..1b695b62c 100644
--- a/vendor/github.com/klauspost/cpuid/v2/.goreleaser.yml
+++ b/vendor/github.com/klauspost/cpuid/v2/.goreleaser.yml
@@ -1,5 +1,4 @@
-# This is an example goreleaser.yaml file with some sane defaults.
-# Make sure to check the documentation at http://goreleaser.com
+version: 2
builds:
-
@@ -27,16 +26,7 @@ builds:
archives:
-
id: cpuid
- name_template: "cpuid-{{ .Os }}_{{ .Arch }}_{{ .Version }}"
- replacements:
- aix: AIX
- darwin: OSX
- linux: Linux
- windows: Windows
- 386: i386
- amd64: x86_64
- freebsd: FreeBSD
- netbsd: NetBSD
+ name_template: "cpuid-{{ .Os }}_{{ .Arch }}{{ if .Arm }}v{{ .Arm }}{{ end }}"
format_overrides:
- goos: windows
format: zip
@@ -44,8 +34,6 @@ archives:
- LICENSE
checksum:
name_template: 'checksums.txt'
-snapshot:
- name_template: "{{ .Tag }}-next"
changelog:
sort: asc
filters:
@@ -58,7 +46,7 @@ changelog:
nfpms:
-
- file_name_template: "cpuid_package_{{ .Version }}_{{ .Os }}_{{ .Arch }}"
+ file_name_template: "cpuid_package_{{ .Os }}_{{ .Arch }}{{ if .Arm }}v{{ .Arm }}{{ end }}"
vendor: Klaus Post
homepage: https://github.com/klauspost/cpuid
maintainer: Klaus Post <klauspost@gmail.com>
@@ -67,8 +55,3 @@ nfpms:
formats:
- deb
- rpm
- replacements:
- darwin: Darwin
- linux: Linux
- freebsd: FreeBSD
- amd64: x86_64
diff --git a/vendor/github.com/klauspost/cpuid/v2/README.md b/vendor/github.com/klauspost/cpuid/v2/README.md
index f06ba51c5..e59d3d0c0 100644
--- a/vendor/github.com/klauspost/cpuid/v2/README.md
+++ b/vendor/github.com/klauspost/cpuid/v2/README.md
@@ -282,7 +282,9 @@ Exit Code 1
| AMXINT8 | Tile computational operations on 8-bit integers |
| AMXFP16 | Tile computational operations on FP16 numbers |
| AMXFP8 | Tile computational operations on FP8 numbers |
+| AMXCOMPLEX | Tile computational operations on complex numbers |
| AMXTILE | Tile architecture |
+| AMXTF32 | Matrix Multiplication of TF32 Tiles into Packed Single Precision Tile |
| APX_F | Intel APX |
| AVX | AVX functions |
| AVX10 | If set the Intel AVX10 Converged Vector ISA is supported |
@@ -480,12 +482,16 @@ Exit Code 1
| DCPOP | Data cache clean to Point of Persistence (DC CVAP) |
| EVTSTRM | Generic timer |
| FCMA | Floatin point complex number addition and multiplication |
+| FHM | FMLAL and FMLSL instructions |
| FP | Single-precision and double-precision floating point |
| FPHP | Half-precision floating point |
| GPA | Generic Pointer Authentication |
| JSCVT | Javascript-style double->int convert (FJCVTZS) |
| LRCPC | Weaker release consistency (LDAPR, etc) |
| PMULL | Polynomial Multiply instructions (PMULL/PMULL2) |
+| RNDR | Random Number instructions |
+| TLB | Outer Shareable and TLB range maintenance instructions |
+| TS | Flag manipulation instructions |
| SHA1 | SHA-1 instructions (SHA1C, etc) |
| SHA2 | SHA-2 instructions (SHA256H, etc) |
| SHA3 | SHA-3 instructions (EOR3, RAXI, XAR, BCAX) |
diff --git a/vendor/github.com/klauspost/cpuid/v2/cpuid.go b/vendor/github.com/klauspost/cpuid/v2/cpuid.go
index db99eb62f..8103fb343 100644
--- a/vendor/github.com/klauspost/cpuid/v2/cpuid.go
+++ b/vendor/github.com/klauspost/cpuid/v2/cpuid.go
@@ -83,6 +83,8 @@ const (
AMXINT8 // Tile computational operations on 8-bit integers
AMXFP8 // Tile computational operations on FP8 numbers
AMXTILE // Tile architecture
+ AMXTF32 // Tile architecture
+ AMXCOMPLEX // Matrix Multiplication of TF32 Tiles into Packed Single Precision Tile
APX_F // Intel APX
AVX // AVX functions
AVX10 // If set the Intel AVX10 Converged Vector ISA is supported
@@ -282,12 +284,16 @@ const (
DCPOP // Data cache clean to Point of Persistence (DC CVAP)
EVTSTRM // Generic timer
FCMA // Floatin point complex number addition and multiplication
+ FHM // FMLAL and FMLSL instructions
FP // Single-precision and double-precision floating point
FPHP // Half-precision floating point
GPA // Generic Pointer Authentication
JSCVT // Javascript-style double->int convert (FJCVTZS)
LRCPC // Weaker release consistency (LDAPR, etc)
PMULL // Polynomial Multiply instructions (PMULL/PMULL2)
+ RNDR // Random Number instructions
+ TLB // Outer Shareable and TLB range maintenance instructions
+ TS // Flag manipulation instructions
SHA1 // SHA-1 instructions (SHA1C, etc)
SHA2 // SHA-2 instructions (SHA256H, etc)
SHA3 // SHA-3 instructions (EOR3, RAXI, XAR, BCAX)
@@ -532,7 +538,7 @@ func (c CPUInfo) Ia32TscAux() uint32 {
return ecx
}
-// SveLengths returns arm SVE vector and predicate lengths.
+// SveLengths returns arm SVE vector and predicate lengths in bits.
// Will return 0, 0 if SVE is not enabled or otherwise unable to detect.
func (c CPUInfo) SveLengths() (vl, pl uint64) {
if !c.Has(SVE) {
@@ -1284,6 +1290,8 @@ func support() flagSet {
// CPUID.(EAX=7, ECX=1).EDX
fs.setIf(edx1&(1<<4) != 0, AVXVNNIINT8)
fs.setIf(edx1&(1<<5) != 0, AVXNECONVERT)
+ fs.setIf(edx1&(1<<7) != 0, AMXTF32)
+ fs.setIf(edx1&(1<<8) != 0, AMXCOMPLEX)
fs.setIf(edx1&(1<<10) != 0, AVXVNNIINT16)
fs.setIf(edx1&(1<<14) != 0, PREFETCHI)
fs.setIf(edx1&(1<<19) != 0, AVX10)
diff --git a/vendor/github.com/klauspost/cpuid/v2/detect_arm64.go b/vendor/github.com/klauspost/cpuid/v2/detect_arm64.go
index 566743d22..9ae32d607 100644
--- a/vendor/github.com/klauspost/cpuid/v2/detect_arm64.go
+++ b/vendor/github.com/klauspost/cpuid/v2/detect_arm64.go
@@ -157,6 +157,10 @@ func addInfo(c *CPUInfo, safe bool) {
// x--------------------------------------------------x
// | Name | bits | visible |
// |--------------------------------------------------|
+ // | RNDR | [63-60] | y |
+ // |--------------------------------------------------|
+ // | TLB | [59-56] | y |
+ // |--------------------------------------------------|
// | TS | [55-52] | y |
// |--------------------------------------------------|
// | FHM | [51-48] | y |
@@ -182,12 +186,10 @@ func addInfo(c *CPUInfo, safe bool) {
// | AES | [7-4] | y |
// x--------------------------------------------------x
- // if instAttrReg0&(0xf<<52) != 0 {
- // fmt.Println("TS")
- // }
- // if instAttrReg0&(0xf<<48) != 0 {
- // fmt.Println("FHM")
- // }
+ f.setIf(instAttrReg0&(0xf<<60) != 0, RNDR)
+ f.setIf(instAttrReg0&(0xf<<56) != 0, TLB)
+ f.setIf(instAttrReg0&(0xf<<52) != 0, TS)
+ f.setIf(instAttrReg0&(0xf<<48) != 0, FHM)
f.setIf(instAttrReg0&(0xf<<44) != 0, ASIMDDP)
f.setIf(instAttrReg0&(0xf<<40) != 0, SM4)
f.setIf(instAttrReg0&(0xf<<36) != 0, SM3)
diff --git a/vendor/github.com/klauspost/cpuid/v2/featureid_string.go b/vendor/github.com/klauspost/cpuid/v2/featureid_string.go
index e7f874a7e..04760c1af 100644
--- a/vendor/github.com/klauspost/cpuid/v2/featureid_string.go
+++ b/vendor/github.com/klauspost/cpuid/v2/featureid_string.go
@@ -17,223 +17,229 @@ func _() {
_ = x[AMXINT8-7]
_ = x[AMXFP8-8]
_ = x[AMXTILE-9]
- _ = x[APX_F-10]
- _ = x[AVX-11]
- _ = x[AVX10-12]
- _ = x[AVX10_128-13]
- _ = x[AVX10_256-14]
- _ = x[AVX10_512-15]
- _ = x[AVX2-16]
- _ = x[AVX512BF16-17]
- _ = x[AVX512BITALG-18]
- _ = x[AVX512BW-19]
- _ = x[AVX512CD-20]
- _ = x[AVX512DQ-21]
- _ = x[AVX512ER-22]
- _ = x[AVX512F-23]
- _ = x[AVX512FP16-24]
- _ = x[AVX512IFMA-25]
- _ = x[AVX512PF-26]
- _ = x[AVX512VBMI-27]
- _ = x[AVX512VBMI2-28]
- _ = x[AVX512VL-29]
- _ = x[AVX512VNNI-30]
- _ = x[AVX512VP2INTERSECT-31]
- _ = x[AVX512VPOPCNTDQ-32]
- _ = x[AVXIFMA-33]
- _ = x[AVXNECONVERT-34]
- _ = x[AVXSLOW-35]
- _ = x[AVXVNNI-36]
- _ = x[AVXVNNIINT8-37]
- _ = x[AVXVNNIINT16-38]
- _ = x[BHI_CTRL-39]
- _ = x[BMI1-40]
- _ = x[BMI2-41]
- _ = x[CETIBT-42]
- _ = x[CETSS-43]
- _ = x[CLDEMOTE-44]
- _ = x[CLMUL-45]
- _ = x[CLZERO-46]
- _ = x[CMOV-47]
- _ = x[CMPCCXADD-48]
- _ = x[CMPSB_SCADBS_SHORT-49]
- _ = x[CMPXCHG8-50]
- _ = x[CPBOOST-51]
- _ = x[CPPC-52]
- _ = x[CX16-53]
- _ = x[EFER_LMSLE_UNS-54]
- _ = x[ENQCMD-55]
- _ = x[ERMS-56]
- _ = x[F16C-57]
- _ = x[FLUSH_L1D-58]
- _ = x[FMA3-59]
- _ = x[FMA4-60]
- _ = x[FP128-61]
- _ = x[FP256-62]
- _ = x[FSRM-63]
- _ = x[FXSR-64]
- _ = x[FXSROPT-65]
- _ = x[GFNI-66]
- _ = x[HLE-67]
- _ = x[HRESET-68]
- _ = x[HTT-69]
- _ = x[HWA-70]
- _ = x[HYBRID_CPU-71]
- _ = x[HYPERVISOR-72]
- _ = x[IA32_ARCH_CAP-73]
- _ = x[IA32_CORE_CAP-74]
- _ = x[IBPB-75]
- _ = x[IBPB_BRTYPE-76]
- _ = x[IBRS-77]
- _ = x[IBRS_PREFERRED-78]
- _ = x[IBRS_PROVIDES_SMP-79]
- _ = x[IBS-80]
- _ = x[IBSBRNTRGT-81]
- _ = x[IBSFETCHSAM-82]
- _ = x[IBSFFV-83]
- _ = x[IBSOPCNT-84]
- _ = x[IBSOPCNTEXT-85]
- _ = x[IBSOPSAM-86]
- _ = x[IBSRDWROPCNT-87]
- _ = x[IBSRIPINVALIDCHK-88]
- _ = x[IBS_FETCH_CTLX-89]
- _ = x[IBS_OPDATA4-90]
- _ = x[IBS_OPFUSE-91]
- _ = x[IBS_PREVENTHOST-92]
- _ = x[IBS_ZEN4-93]
- _ = x[IDPRED_CTRL-94]
- _ = x[INT_WBINVD-95]
- _ = x[INVLPGB-96]
- _ = x[KEYLOCKER-97]
- _ = x[KEYLOCKERW-98]
- _ = x[LAHF-99]
- _ = x[LAM-100]
- _ = x[LBRVIRT-101]
- _ = x[LZCNT-102]
- _ = x[MCAOVERFLOW-103]
- _ = x[MCDT_NO-104]
- _ = x[MCOMMIT-105]
- _ = x[MD_CLEAR-106]
- _ = x[MMX-107]
- _ = x[MMXEXT-108]
- _ = x[MOVBE-109]
- _ = x[MOVDIR64B-110]
- _ = x[MOVDIRI-111]
- _ = x[MOVSB_ZL-112]
- _ = x[MOVU-113]
- _ = x[MPX-114]
- _ = x[MSRIRC-115]
- _ = x[MSRLIST-116]
- _ = x[MSR_PAGEFLUSH-117]
- _ = x[NRIPS-118]
- _ = x[NX-119]
- _ = x[OSXSAVE-120]
- _ = x[PCONFIG-121]
- _ = x[POPCNT-122]
- _ = x[PPIN-123]
- _ = x[PREFETCHI-124]
- _ = x[PSFD-125]
- _ = x[RDPRU-126]
- _ = x[RDRAND-127]
- _ = x[RDSEED-128]
- _ = x[RDTSCP-129]
- _ = x[RRSBA_CTRL-130]
- _ = x[RTM-131]
- _ = x[RTM_ALWAYS_ABORT-132]
- _ = x[SBPB-133]
- _ = x[SERIALIZE-134]
- _ = x[SEV-135]
- _ = x[SEV_64BIT-136]
- _ = x[SEV_ALTERNATIVE-137]
- _ = x[SEV_DEBUGSWAP-138]
- _ = x[SEV_ES-139]
- _ = x[SEV_RESTRICTED-140]
- _ = x[SEV_SNP-141]
- _ = x[SGX-142]
- _ = x[SGXLC-143]
- _ = x[SHA-144]
- _ = x[SME-145]
- _ = x[SME_COHERENT-146]
- _ = x[SPEC_CTRL_SSBD-147]
- _ = x[SRBDS_CTRL-148]
- _ = x[SRSO_MSR_FIX-149]
- _ = x[SRSO_NO-150]
- _ = x[SRSO_USER_KERNEL_NO-151]
- _ = x[SSE-152]
- _ = x[SSE2-153]
- _ = x[SSE3-154]
- _ = x[SSE4-155]
- _ = x[SSE42-156]
- _ = x[SSE4A-157]
- _ = x[SSSE3-158]
- _ = x[STIBP-159]
- _ = x[STIBP_ALWAYSON-160]
- _ = x[STOSB_SHORT-161]
- _ = x[SUCCOR-162]
- _ = x[SVM-163]
- _ = x[SVMDA-164]
- _ = x[SVMFBASID-165]
- _ = x[SVML-166]
- _ = x[SVMNP-167]
- _ = x[SVMPF-168]
- _ = x[SVMPFT-169]
- _ = x[SYSCALL-170]
- _ = x[SYSEE-171]
- _ = x[TBM-172]
- _ = x[TDX_GUEST-173]
- _ = x[TLB_FLUSH_NESTED-174]
- _ = x[TME-175]
- _ = x[TOPEXT-176]
- _ = x[TSCRATEMSR-177]
- _ = x[TSXLDTRK-178]
- _ = x[VAES-179]
- _ = x[VMCBCLEAN-180]
- _ = x[VMPL-181]
- _ = x[VMSA_REGPROT-182]
- _ = x[VMX-183]
- _ = x[VPCLMULQDQ-184]
- _ = x[VTE-185]
- _ = x[WAITPKG-186]
- _ = x[WBNOINVD-187]
- _ = x[WRMSRNS-188]
- _ = x[X87-189]
- _ = x[XGETBV1-190]
- _ = x[XOP-191]
- _ = x[XSAVE-192]
- _ = x[XSAVEC-193]
- _ = x[XSAVEOPT-194]
- _ = x[XSAVES-195]
- _ = x[AESARM-196]
- _ = x[ARMCPUID-197]
- _ = x[ASIMD-198]
- _ = x[ASIMDDP-199]
- _ = x[ASIMDHP-200]
- _ = x[ASIMDRDM-201]
- _ = x[ATOMICS-202]
- _ = x[CRC32-203]
- _ = x[DCPOP-204]
- _ = x[EVTSTRM-205]
- _ = x[FCMA-206]
- _ = x[FP-207]
- _ = x[FPHP-208]
- _ = x[GPA-209]
- _ = x[JSCVT-210]
- _ = x[LRCPC-211]
- _ = x[PMULL-212]
- _ = x[SHA1-213]
- _ = x[SHA2-214]
- _ = x[SHA3-215]
- _ = x[SHA512-216]
- _ = x[SM3-217]
- _ = x[SM4-218]
- _ = x[SVE-219]
- _ = x[lastID-220]
+ _ = x[AMXTF32-10]
+ _ = x[AMXCOMPLEX-11]
+ _ = x[APX_F-12]
+ _ = x[AVX-13]
+ _ = x[AVX10-14]
+ _ = x[AVX10_128-15]
+ _ = x[AVX10_256-16]
+ _ = x[AVX10_512-17]
+ _ = x[AVX2-18]
+ _ = x[AVX512BF16-19]
+ _ = x[AVX512BITALG-20]
+ _ = x[AVX512BW-21]
+ _ = x[AVX512CD-22]
+ _ = x[AVX512DQ-23]
+ _ = x[AVX512ER-24]
+ _ = x[AVX512F-25]
+ _ = x[AVX512FP16-26]
+ _ = x[AVX512IFMA-27]
+ _ = x[AVX512PF-28]
+ _ = x[AVX512VBMI-29]
+ _ = x[AVX512VBMI2-30]
+ _ = x[AVX512VL-31]
+ _ = x[AVX512VNNI-32]
+ _ = x[AVX512VP2INTERSECT-33]
+ _ = x[AVX512VPOPCNTDQ-34]
+ _ = x[AVXIFMA-35]
+ _ = x[AVXNECONVERT-36]
+ _ = x[AVXSLOW-37]
+ _ = x[AVXVNNI-38]
+ _ = x[AVXVNNIINT8-39]
+ _ = x[AVXVNNIINT16-40]
+ _ = x[BHI_CTRL-41]
+ _ = x[BMI1-42]
+ _ = x[BMI2-43]
+ _ = x[CETIBT-44]
+ _ = x[CETSS-45]
+ _ = x[CLDEMOTE-46]
+ _ = x[CLMUL-47]
+ _ = x[CLZERO-48]
+ _ = x[CMOV-49]
+ _ = x[CMPCCXADD-50]
+ _ = x[CMPSB_SCADBS_SHORT-51]
+ _ = x[CMPXCHG8-52]
+ _ = x[CPBOOST-53]
+ _ = x[CPPC-54]
+ _ = x[CX16-55]
+ _ = x[EFER_LMSLE_UNS-56]
+ _ = x[ENQCMD-57]
+ _ = x[ERMS-58]
+ _ = x[F16C-59]
+ _ = x[FLUSH_L1D-60]
+ _ = x[FMA3-61]
+ _ = x[FMA4-62]
+ _ = x[FP128-63]
+ _ = x[FP256-64]
+ _ = x[FSRM-65]
+ _ = x[FXSR-66]
+ _ = x[FXSROPT-67]
+ _ = x[GFNI-68]
+ _ = x[HLE-69]
+ _ = x[HRESET-70]
+ _ = x[HTT-71]
+ _ = x[HWA-72]
+ _ = x[HYBRID_CPU-73]
+ _ = x[HYPERVISOR-74]
+ _ = x[IA32_ARCH_CAP-75]
+ _ = x[IA32_CORE_CAP-76]
+ _ = x[IBPB-77]
+ _ = x[IBPB_BRTYPE-78]
+ _ = x[IBRS-79]
+ _ = x[IBRS_PREFERRED-80]
+ _ = x[IBRS_PROVIDES_SMP-81]
+ _ = x[IBS-82]
+ _ = x[IBSBRNTRGT-83]
+ _ = x[IBSFETCHSAM-84]
+ _ = x[IBSFFV-85]
+ _ = x[IBSOPCNT-86]
+ _ = x[IBSOPCNTEXT-87]
+ _ = x[IBSOPSAM-88]
+ _ = x[IBSRDWROPCNT-89]
+ _ = x[IBSRIPINVALIDCHK-90]
+ _ = x[IBS_FETCH_CTLX-91]
+ _ = x[IBS_OPDATA4-92]
+ _ = x[IBS_OPFUSE-93]
+ _ = x[IBS_PREVENTHOST-94]
+ _ = x[IBS_ZEN4-95]
+ _ = x[IDPRED_CTRL-96]
+ _ = x[INT_WBINVD-97]
+ _ = x[INVLPGB-98]
+ _ = x[KEYLOCKER-99]
+ _ = x[KEYLOCKERW-100]
+ _ = x[LAHF-101]
+ _ = x[LAM-102]
+ _ = x[LBRVIRT-103]
+ _ = x[LZCNT-104]
+ _ = x[MCAOVERFLOW-105]
+ _ = x[MCDT_NO-106]
+ _ = x[MCOMMIT-107]
+ _ = x[MD_CLEAR-108]
+ _ = x[MMX-109]
+ _ = x[MMXEXT-110]
+ _ = x[MOVBE-111]
+ _ = x[MOVDIR64B-112]
+ _ = x[MOVDIRI-113]
+ _ = x[MOVSB_ZL-114]
+ _ = x[MOVU-115]
+ _ = x[MPX-116]
+ _ = x[MSRIRC-117]
+ _ = x[MSRLIST-118]
+ _ = x[MSR_PAGEFLUSH-119]
+ _ = x[NRIPS-120]
+ _ = x[NX-121]
+ _ = x[OSXSAVE-122]
+ _ = x[PCONFIG-123]
+ _ = x[POPCNT-124]
+ _ = x[PPIN-125]
+ _ = x[PREFETCHI-126]
+ _ = x[PSFD-127]
+ _ = x[RDPRU-128]
+ _ = x[RDRAND-129]
+ _ = x[RDSEED-130]
+ _ = x[RDTSCP-131]
+ _ = x[RRSBA_CTRL-132]
+ _ = x[RTM-133]
+ _ = x[RTM_ALWAYS_ABORT-134]
+ _ = x[SBPB-135]
+ _ = x[SERIALIZE-136]
+ _ = x[SEV-137]
+ _ = x[SEV_64BIT-138]
+ _ = x[SEV_ALTERNATIVE-139]
+ _ = x[SEV_DEBUGSWAP-140]
+ _ = x[SEV_ES-141]
+ _ = x[SEV_RESTRICTED-142]
+ _ = x[SEV_SNP-143]
+ _ = x[SGX-144]
+ _ = x[SGXLC-145]
+ _ = x[SHA-146]
+ _ = x[SME-147]
+ _ = x[SME_COHERENT-148]
+ _ = x[SPEC_CTRL_SSBD-149]
+ _ = x[SRBDS_CTRL-150]
+ _ = x[SRSO_MSR_FIX-151]
+ _ = x[SRSO_NO-152]
+ _ = x[SRSO_USER_KERNEL_NO-153]
+ _ = x[SSE-154]
+ _ = x[SSE2-155]
+ _ = x[SSE3-156]
+ _ = x[SSE4-157]
+ _ = x[SSE42-158]
+ _ = x[SSE4A-159]
+ _ = x[SSSE3-160]
+ _ = x[STIBP-161]
+ _ = x[STIBP_ALWAYSON-162]
+ _ = x[STOSB_SHORT-163]
+ _ = x[SUCCOR-164]
+ _ = x[SVM-165]
+ _ = x[SVMDA-166]
+ _ = x[SVMFBASID-167]
+ _ = x[SVML-168]
+ _ = x[SVMNP-169]
+ _ = x[SVMPF-170]
+ _ = x[SVMPFT-171]
+ _ = x[SYSCALL-172]
+ _ = x[SYSEE-173]
+ _ = x[TBM-174]
+ _ = x[TDX_GUEST-175]
+ _ = x[TLB_FLUSH_NESTED-176]
+ _ = x[TME-177]
+ _ = x[TOPEXT-178]
+ _ = x[TSCRATEMSR-179]
+ _ = x[TSXLDTRK-180]
+ _ = x[VAES-181]
+ _ = x[VMCBCLEAN-182]
+ _ = x[VMPL-183]
+ _ = x[VMSA_REGPROT-184]
+ _ = x[VMX-185]
+ _ = x[VPCLMULQDQ-186]
+ _ = x[VTE-187]
+ _ = x[WAITPKG-188]
+ _ = x[WBNOINVD-189]
+ _ = x[WRMSRNS-190]
+ _ = x[X87-191]
+ _ = x[XGETBV1-192]
+ _ = x[XOP-193]
+ _ = x[XSAVE-194]
+ _ = x[XSAVEC-195]
+ _ = x[XSAVEOPT-196]
+ _ = x[XSAVES-197]
+ _ = x[AESARM-198]
+ _ = x[ARMCPUID-199]
+ _ = x[ASIMD-200]
+ _ = x[ASIMDDP-201]
+ _ = x[ASIMDHP-202]
+ _ = x[ASIMDRDM-203]
+ _ = x[ATOMICS-204]
+ _ = x[CRC32-205]
+ _ = x[DCPOP-206]
+ _ = x[EVTSTRM-207]
+ _ = x[FCMA-208]
+ _ = x[FHM-209]
+ _ = x[FP-210]
+ _ = x[FPHP-211]
+ _ = x[GPA-212]
+ _ = x[JSCVT-213]
+ _ = x[LRCPC-214]
+ _ = x[PMULL-215]
+ _ = x[RNDR-216]
+ _ = x[TLB-217]
+ _ = x[TS-218]
+ _ = x[SHA1-219]
+ _ = x[SHA2-220]
+ _ = x[SHA3-221]
+ _ = x[SHA512-222]
+ _ = x[SM3-223]
+ _ = x[SM4-224]
+ _ = x[SVE-225]
+ _ = x[lastID-226]
_ = x[firstID-0]
}
-const _FeatureID_name = "firstIDADXAESNIAMD3DNOWAMD3DNOWEXTAMXBF16AMXFP16AMXINT8AMXFP8AMXTILEAPX_FAVXAVX10AVX10_128AVX10_256AVX10_512AVX2AVX512BF16AVX512BITALGAVX512BWAVX512CDAVX512DQAVX512ERAVX512FAVX512FP16AVX512IFMAAVX512PFAVX512VBMIAVX512VBMI2AVX512VLAVX512VNNIAVX512VP2INTERSECTAVX512VPOPCNTDQAVXIFMAAVXNECONVERTAVXSLOWAVXVNNIAVXVNNIINT8AVXVNNIINT16BHI_CTRLBMI1BMI2CETIBTCETSSCLDEMOTECLMULCLZEROCMOVCMPCCXADDCMPSB_SCADBS_SHORTCMPXCHG8CPBOOSTCPPCCX16EFER_LMSLE_UNSENQCMDERMSF16CFLUSH_L1DFMA3FMA4FP128FP256FSRMFXSRFXSROPTGFNIHLEHRESETHTTHWAHYBRID_CPUHYPERVISORIA32_ARCH_CAPIA32_CORE_CAPIBPBIBPB_BRTYPEIBRSIBRS_PREFERREDIBRS_PROVIDES_SMPIBSIBSBRNTRGTIBSFETCHSAMIBSFFVIBSOPCNTIBSOPCNTEXTIBSOPSAMIBSRDWROPCNTIBSRIPINVALIDCHKIBS_FETCH_CTLXIBS_OPDATA4IBS_OPFUSEIBS_PREVENTHOSTIBS_ZEN4IDPRED_CTRLINT_WBINVDINVLPGBKEYLOCKERKEYLOCKERWLAHFLAMLBRVIRTLZCNTMCAOVERFLOWMCDT_NOMCOMMITMD_CLEARMMXMMXEXTMOVBEMOVDIR64BMOVDIRIMOVSB_ZLMOVUMPXMSRIRCMSRLISTMSR_PAGEFLUSHNRIPSNXOSXSAVEPCONFIGPOPCNTPPINPREFETCHIPSFDRDPRURDRANDRDSEEDRDTSCPRRSBA_CTRLRTMRTM_ALWAYS_ABORTSBPBSERIALIZESEVSEV_64BITSEV_ALTERNATIVESEV_DEBUGSWAPSEV_ESSEV_RESTRICTEDSEV_SNPSGXSGXLCSHASMESME_COHERENTSPEC_CTRL_SSBDSRBDS_CTRLSRSO_MSR_FIXSRSO_NOSRSO_USER_KERNEL_NOSSESSE2SSE3SSE4SSE42SSE4ASSSE3STIBPSTIBP_ALWAYSONSTOSB_SHORTSUCCORSVMSVMDASVMFBASIDSVMLSVMNPSVMPFSVMPFTSYSCALLSYSEETBMTDX_GUESTTLB_FLUSH_NESTEDTMETOPEXTTSCRATEMSRTSXLDTRKVAESVMCBCLEANVMPLVMSA_REGPROTVMXVPCLMULQDQVTEWAITPKGWBNOINVDWRMSRNSX87XGETBV1XOPXSAVEXSAVECXSAVEOPTXSAVESAESARMARMCPUIDASIMDASIMDDPASIMDHPASIMDRDMATOMICSCRC32DCPOPEVTSTRMFCMAFPFPHPGPAJSCVTLRCPCPMULLSHA1SHA2SHA3SHA512SM3SM4SVElastID"
+const _FeatureID_name = "firstIDADXAESNIAMD3DNOWAMD3DNOWEXTAMXBF16AMXFP16AMXINT8AMXFP8AMXTILEAMXTF32AMXCOMPLEXAPX_FAVXAVX10AVX10_128AVX10_256AVX10_512AVX2AVX512BF16AVX512BITALGAVX512BWAVX512CDAVX512DQAVX512ERAVX512FAVX512FP16AVX512IFMAAVX512PFAVX512VBMIAVX512VBMI2AVX512VLAVX512VNNIAVX512VP2INTERSECTAVX512VPOPCNTDQAVXIFMAAVXNECONVERTAVXSLOWAVXVNNIAVXVNNIINT8AVXVNNIINT16BHI_CTRLBMI1BMI2CETIBTCETSSCLDEMOTECLMULCLZEROCMOVCMPCCXADDCMPSB_SCADBS_SHORTCMPXCHG8CPBOOSTCPPCCX16EFER_LMSLE_UNSENQCMDERMSF16CFLUSH_L1DFMA3FMA4FP128FP256FSRMFXSRFXSROPTGFNIHLEHRESETHTTHWAHYBRID_CPUHYPERVISORIA32_ARCH_CAPIA32_CORE_CAPIBPBIBPB_BRTYPEIBRSIBRS_PREFERREDIBRS_PROVIDES_SMPIBSIBSBRNTRGTIBSFETCHSAMIBSFFVIBSOPCNTIBSOPCNTEXTIBSOPSAMIBSRDWROPCNTIBSRIPINVALIDCHKIBS_FETCH_CTLXIBS_OPDATA4IBS_OPFUSEIBS_PREVENTHOSTIBS_ZEN4IDPRED_CTRLINT_WBINVDINVLPGBKEYLOCKERKEYLOCKERWLAHFLAMLBRVIRTLZCNTMCAOVERFLOWMCDT_NOMCOMMITMD_CLEARMMXMMXEXTMOVBEMOVDIR64BMOVDIRIMOVSB_ZLMOVUMPXMSRIRCMSRLISTMSR_PAGEFLUSHNRIPSNXOSXSAVEPCONFIGPOPCNTPPINPREFETCHIPSFDRDPRURDRANDRDSEEDRDTSCPRRSBA_CTRLRTMRTM_ALWAYS_ABORTSBPBSERIALIZESEVSEV_64BITSEV_ALTERNATIVESEV_DEBUGSWAPSEV_ESSEV_RESTRICTEDSEV_SNPSGXSGXLCSHASMESME_COHERENTSPEC_CTRL_SSBDSRBDS_CTRLSRSO_MSR_FIXSRSO_NOSRSO_USER_KERNEL_NOSSESSE2SSE3SSE4SSE42SSE4ASSSE3STIBPSTIBP_ALWAYSONSTOSB_SHORTSUCCORSVMSVMDASVMFBASIDSVMLSVMNPSVMPFSVMPFTSYSCALLSYSEETBMTDX_GUESTTLB_FLUSH_NESTEDTMETOPEXTTSCRATEMSRTSXLDTRKVAESVMCBCLEANVMPLVMSA_REGPROTVMXVPCLMULQDQVTEWAITPKGWBNOINVDWRMSRNSX87XGETBV1XOPXSAVEXSAVECXSAVEOPTXSAVESAESARMARMCPUIDASIMDASIMDDPASIMDHPASIMDRDMATOMICSCRC32DCPOPEVTSTRMFCMAFHMFPFPHPGPAJSCVTLRCPCPMULLRNDRTLBTSSHA1SHA2SHA3SHA512SM3SM4SVElastID"
-var _FeatureID_index = [...]uint16{0, 7, 10, 15, 23, 34, 41, 48, 55, 61, 68, 73, 76, 81, 90, 99, 108, 112, 122, 134, 142, 150, 158, 166, 173, 183, 193, 201, 211, 222, 230, 240, 258, 273, 280, 292, 299, 306, 317, 329, 337, 341, 345, 351, 356, 364, 369, 375, 379, 388, 406, 414, 421, 425, 429, 443, 449, 453, 457, 466, 470, 474, 479, 484, 488, 492, 499, 503, 506, 512, 515, 518, 528, 538, 551, 564, 568, 579, 583, 597, 614, 617, 627, 638, 644, 652, 663, 671, 683, 699, 713, 724, 734, 749, 757, 768, 778, 785, 794, 804, 808, 811, 818, 823, 834, 841, 848, 856, 859, 865, 870, 879, 886, 894, 898, 901, 907, 914, 927, 932, 934, 941, 948, 954, 958, 967, 971, 976, 982, 988, 994, 1004, 1007, 1023, 1027, 1036, 1039, 1048, 1063, 1076, 1082, 1096, 1103, 1106, 1111, 1114, 1117, 1129, 1143, 1153, 1165, 1172, 1191, 1194, 1198, 1202, 1206, 1211, 1216, 1221, 1226, 1240, 1251, 1257, 1260, 1265, 1274, 1278, 1283, 1288, 1294, 1301, 1306, 1309, 1318, 1334, 1337, 1343, 1353, 1361, 1365, 1374, 1378, 1390, 1393, 1403, 1406, 1413, 1421, 1428, 1431, 1438, 1441, 1446, 1452, 1460, 1466, 1472, 1480, 1485, 1492, 1499, 1507, 1514, 1519, 1524, 1531, 1535, 1537, 1541, 1544, 1549, 1554, 1559, 1563, 1567, 1571, 1577, 1580, 1583, 1586, 1592}
+var _FeatureID_index = [...]uint16{0, 7, 10, 15, 23, 34, 41, 48, 55, 61, 68, 75, 85, 90, 93, 98, 107, 116, 125, 129, 139, 151, 159, 167, 175, 183, 190, 200, 210, 218, 228, 239, 247, 257, 275, 290, 297, 309, 316, 323, 334, 346, 354, 358, 362, 368, 373, 381, 386, 392, 396, 405, 423, 431, 438, 442, 446, 460, 466, 470, 474, 483, 487, 491, 496, 501, 505, 509, 516, 520, 523, 529, 532, 535, 545, 555, 568, 581, 585, 596, 600, 614, 631, 634, 644, 655, 661, 669, 680, 688, 700, 716, 730, 741, 751, 766, 774, 785, 795, 802, 811, 821, 825, 828, 835, 840, 851, 858, 865, 873, 876, 882, 887, 896, 903, 911, 915, 918, 924, 931, 944, 949, 951, 958, 965, 971, 975, 984, 988, 993, 999, 1005, 1011, 1021, 1024, 1040, 1044, 1053, 1056, 1065, 1080, 1093, 1099, 1113, 1120, 1123, 1128, 1131, 1134, 1146, 1160, 1170, 1182, 1189, 1208, 1211, 1215, 1219, 1223, 1228, 1233, 1238, 1243, 1257, 1268, 1274, 1277, 1282, 1291, 1295, 1300, 1305, 1311, 1318, 1323, 1326, 1335, 1351, 1354, 1360, 1370, 1378, 1382, 1391, 1395, 1407, 1410, 1420, 1423, 1430, 1438, 1445, 1448, 1455, 1458, 1463, 1469, 1477, 1483, 1489, 1497, 1502, 1509, 1516, 1524, 1531, 1536, 1541, 1548, 1552, 1555, 1557, 1561, 1564, 1569, 1574, 1579, 1583, 1586, 1588, 1592, 1596, 1600, 1606, 1609, 1612, 1615, 1621}
func (i FeatureID) String() string {
if i < 0 || i >= FeatureID(len(_FeatureID_index)-1) {
diff --git a/vendor/github.com/klauspost/cpuid/v2/os_darwin_arm64.go b/vendor/github.com/klauspost/cpuid/v2/os_darwin_arm64.go
index 84b1acd21..6f0b33ca6 100644
--- a/vendor/github.com/klauspost/cpuid/v2/os_darwin_arm64.go
+++ b/vendor/github.com/klauspost/cpuid/v2/os_darwin_arm64.go
@@ -96,9 +96,11 @@ func tryToFillCPUInfoFomSysctl(c *CPUInfo) {
setFeature(c, "hw.optional.arm.FEAT_DPB", DCPOP)
// setFeature(c, "", EVTSTRM)
setFeature(c, "hw.optional.arm.FEAT_FCMA", FCMA)
+ setFeature(c, "hw.optional.arm.FEAT_FHM", FHM)
setFeature(c, "hw.optional.arm.FEAT_FP", FP)
setFeature(c, "hw.optional.arm.FEAT_FP16", FPHP)
setFeature(c, "hw.optional.arm.FEAT_PAuth", GPA)
+ setFeature(c, "hw.optional.arm.FEAT_RNG", RNDR)
setFeature(c, "hw.optional.arm.FEAT_JSCVT", JSCVT)
setFeature(c, "hw.optional.arm.FEAT_LRCPC", LRCPC)
setFeature(c, "hw.optional.arm.FEAT_PMULL", PMULL)
@@ -106,6 +108,10 @@ func tryToFillCPUInfoFomSysctl(c *CPUInfo) {
setFeature(c, "hw.optional.arm.FEAT_SHA256", SHA2)
setFeature(c, "hw.optional.arm.FEAT_SHA3", SHA3)
setFeature(c, "hw.optional.arm.FEAT_SHA512", SHA512)
+ setFeature(c, "hw.optional.arm.FEAT_TLBIOS", TLB)
+ setFeature(c, "hw.optional.arm.FEAT_TLBIRANGE", TLB)
+ setFeature(c, "hw.optional.arm.FEAT_FlagM", TS)
+ setFeature(c, "hw.optional.arm.FEAT_FlagM2", TS)
// setFeature(c, "", SM3)
// setFeature(c, "", SM4)
setFeature(c, "hw.optional.arm.FEAT_SVE", SVE)
diff --git a/vendor/github.com/klauspost/cpuid/v2/os_linux_arm64.go b/vendor/github.com/klauspost/cpuid/v2/os_linux_arm64.go
index ee278b9e4..d96d24438 100644
--- a/vendor/github.com/klauspost/cpuid/v2/os_linux_arm64.go
+++ b/vendor/github.com/klauspost/cpuid/v2/os_linux_arm64.go
@@ -39,6 +39,80 @@ const (
hwcap_SHA512 = 1 << 21
hwcap_SVE = 1 << 22
hwcap_ASIMDFHM = 1 << 23
+ hwcap_DIT = 1 << 24
+ hwcap_USCAT = 1 << 25
+ hwcap_ILRCPC = 1 << 26
+ hwcap_FLAGM = 1 << 27
+ hwcap_SSBS = 1 << 28
+ hwcap_SB = 1 << 29
+ hwcap_PACA = 1 << 30
+ hwcap_PACG = 1 << 31
+ hwcap_GCS = 1 << 32
+
+ hwcap2_DCPODP = 1 << 0
+ hwcap2_SVE2 = 1 << 1
+ hwcap2_SVEAES = 1 << 2
+ hwcap2_SVEPMULL = 1 << 3
+ hwcap2_SVEBITPERM = 1 << 4
+ hwcap2_SVESHA3 = 1 << 5
+ hwcap2_SVESM4 = 1 << 6
+ hwcap2_FLAGM2 = 1 << 7
+ hwcap2_FRINT = 1 << 8
+ hwcap2_SVEI8MM = 1 << 9
+ hwcap2_SVEF32MM = 1 << 10
+ hwcap2_SVEF64MM = 1 << 11
+ hwcap2_SVEBF16 = 1 << 12
+ hwcap2_I8MM = 1 << 13
+ hwcap2_BF16 = 1 << 14
+ hwcap2_DGH = 1 << 15
+ hwcap2_RNG = 1 << 16
+ hwcap2_BTI = 1 << 17
+ hwcap2_MTE = 1 << 18
+ hwcap2_ECV = 1 << 19
+ hwcap2_AFP = 1 << 20
+ hwcap2_RPRES = 1 << 21
+ hwcap2_MTE3 = 1 << 22
+ hwcap2_SME = 1 << 23
+ hwcap2_SME_I16I64 = 1 << 24
+ hwcap2_SME_F64F64 = 1 << 25
+ hwcap2_SME_I8I32 = 1 << 26
+ hwcap2_SME_F16F32 = 1 << 27
+ hwcap2_SME_B16F32 = 1 << 28
+ hwcap2_SME_F32F32 = 1 << 29
+ hwcap2_SME_FA64 = 1 << 30
+ hwcap2_WFXT = 1 << 31
+ hwcap2_EBF16 = 1 << 32
+ hwcap2_SVE_EBF16 = 1 << 33
+ hwcap2_CSSC = 1 << 34
+ hwcap2_RPRFM = 1 << 35
+ hwcap2_SVE2P1 = 1 << 36
+ hwcap2_SME2 = 1 << 37
+ hwcap2_SME2P1 = 1 << 38
+ hwcap2_SME_I16I32 = 1 << 39
+ hwcap2_SME_BI32I32 = 1 << 40
+ hwcap2_SME_B16B16 = 1 << 41
+ hwcap2_SME_F16F16 = 1 << 42
+ hwcap2_MOPS = 1 << 43
+ hwcap2_HBC = 1 << 44
+ hwcap2_SVE_B16B16 = 1 << 45
+ hwcap2_LRCPC3 = 1 << 46
+ hwcap2_LSE128 = 1 << 47
+ hwcap2_FPMR = 1 << 48
+ hwcap2_LUT = 1 << 49
+ hwcap2_FAMINMAX = 1 << 50
+ hwcap2_F8CVT = 1 << 51
+ hwcap2_F8FMA = 1 << 52
+ hwcap2_F8DP4 = 1 << 53
+ hwcap2_F8DP2 = 1 << 54
+ hwcap2_F8E4M3 = 1 << 55
+ hwcap2_F8E5M2 = 1 << 56
+ hwcap2_SME_LUTV2 = 1 << 57
+ hwcap2_SME_F8F16 = 1 << 58
+ hwcap2_SME_F8F32 = 1 << 59
+ hwcap2_SME_SF8FMA = 1 << 60
+ hwcap2_SME_SF8DP4 = 1 << 61
+ hwcap2_SME_SF8DP2 = 1 << 62
+ hwcap2_POE = 1 << 63
)
func detectOS(c *CPUInfo) bool {
@@ -104,11 +178,15 @@ func detectOS(c *CPUInfo) bool {
c.featureSet.setIf(isSet(hwcap, hwcap_DCPOP), DCPOP)
c.featureSet.setIf(isSet(hwcap, hwcap_EVTSTRM), EVTSTRM)
c.featureSet.setIf(isSet(hwcap, hwcap_FCMA), FCMA)
+ c.featureSet.setIf(isSet(hwcap, hwcap_ASIMDFHM), FHM)
c.featureSet.setIf(isSet(hwcap, hwcap_FP), FP)
c.featureSet.setIf(isSet(hwcap, hwcap_FPHP), FPHP)
c.featureSet.setIf(isSet(hwcap, hwcap_JSCVT), JSCVT)
c.featureSet.setIf(isSet(hwcap, hwcap_LRCPC), LRCPC)
c.featureSet.setIf(isSet(hwcap, hwcap_PMULL), PMULL)
+ c.featureSet.setIf(isSet(hwcap, hwcap2_RNG), RNDR)
+ // c.featureSet.setIf(isSet(hwcap, hwcap_), TLB)
+ // c.featureSet.setIf(isSet(hwcap, hwcap_), TS)
c.featureSet.setIf(isSet(hwcap, hwcap_SHA1), SHA1)
c.featureSet.setIf(isSet(hwcap, hwcap_SHA2), SHA2)
c.featureSet.setIf(isSet(hwcap, hwcap_SHA3), SHA3)