// 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 import "internal/cpu" var randomNumber uint32 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: // arm64 doesn't have a 'cpuid' instruction equivalent and relies on // HWCAP/HWCAP2 bits for hardware capabilities. hwcap := uint(val) if GOOS == "android" { // The Samsung S9+ kernel reports support for atomics, but not all cores // actually support them, resulting in SIGILL. See issue #28431. // TODO(elias.naur): Only disable the optimization on bad chipsets. const hwcap_ATOMICS = 1 << 8 hwcap &= ^uint(hwcap_ATOMICS) } cpu.HWCap = hwcap 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) }