mirror of
https://github.com/golang/go
synced 2024-11-19 13:14:42 -07:00
6b5236ae53
After CL 104636 the feature flags in internal/cpu are initialized before alginit and can now be used for aeshash feature detection. Also remove now unused runtime variables: x86: support_ssse3 support_sse42 support_aes arm64: support_aes Change-Id: I2f64198d91750eaf3c6cf2aac6e9e17615811ec8 Reviewed-on: https://go-review.googlesource.com/106015 Run-TryBot: Brad Fitzpatrick <bradfitz@golang.org> TryBot-Result: Gobot Gobot <gobot@golang.org> Reviewed-by: Brad Fitzpatrick <bradfitz@golang.org>
45 lines
1.2 KiB
Go
45 lines
1.2 KiB
Go
// Copyright 2015 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 arm64
|
|
|
|
package runtime
|
|
|
|
// For go:linkname
|
|
import _ "unsafe"
|
|
|
|
var randomNumber uint32
|
|
|
|
// arm64 doesn't have a 'cpuid' instruction equivalent and relies on
|
|
// HWCAP/HWCAP2 bits for hardware capabilities.
|
|
|
|
//go:linkname cpu_hwcap internal/cpu.arm64_hwcap
|
|
var cpu_hwcap uint
|
|
|
|
//go:linkname cpu_hwcap2 internal/cpu.arm64_hwcap2
|
|
var cpu_hwcap2 uint
|
|
|
|
func archauxv(tag, val uintptr) {
|
|
switch tag {
|
|
case _AT_RANDOM:
|
|
// sysargs filled in startupRandomData, but that
|
|
// pointer may not be word aligned, so we must treat
|
|
// it as a byte array.
|
|
randomNumber = uint32(startupRandomData[4]) | uint32(startupRandomData[5])<<8 |
|
|
uint32(startupRandomData[6])<<16 | uint32(startupRandomData[7])<<24
|
|
case _AT_HWCAP:
|
|
cpu_hwcap = uint(val)
|
|
case _AT_HWCAP2:
|
|
cpu_hwcap2 = uint(val)
|
|
}
|
|
}
|
|
|
|
//go:nosplit
|
|
func cputicks() int64 {
|
|
// Currently cputicks() is used in blocking profiler and to seed fastrand().
|
|
// nanotime() is a poor approximation of CPU ticks that is enough for the profiler.
|
|
// randomNumber provides better seeding of fastrand.
|
|
return nanotime() + int64(randomNumber)
|
|
}
|