mirror of
https://github.com/golang/go
synced 2024-11-08 05:36:13 -07:00
69261ecad6
The hardware divider is an optional component of ARMv7. This patch detects whether it is available in runtime and use it or not. 1. The hardware divider is detected at startup and a flag is set/clear according to a perticular bit of runtime.hwcap. 2. Each call of runtime.udiv will check this flag and decide if use the hardware division instruction. A rough test shows the performance improves 40-50% for ARMv7. And the compatibility of ARMv5/v6 is not broken. fixes #19118 Change-Id: Ic586bc9659ebc169553ca2004d2bdb721df823ac Reviewed-on: https://go-review.googlesource.com/37496 Run-TryBot: Cherry Zhang <cherryyz@google.com> TryBot-Result: Gobot Gobot <gobot@golang.org> Reviewed-by: Cherry Zhang <cherryyz@google.com>
26 lines
742 B
Go
26 lines
742 B
Go
// Copyright 2014 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 runtime
|
|
|
|
var hardDiv bool // TODO: set if a hardware divider is available
|
|
|
|
func checkgoarm() {
|
|
// TODO(minux): FP checks like in os_linux_arm.go.
|
|
|
|
// NaCl/ARM only supports ARMv7
|
|
if goarm != 7 {
|
|
print("runtime: NaCl requires ARMv7. Recompile using GOARM=7.\n")
|
|
exit(1)
|
|
}
|
|
}
|
|
|
|
//go:nosplit
|
|
func cputicks() int64 {
|
|
// Currently cputicks() is used in blocking profiler and to seed runtime·fastrand().
|
|
// runtime·nanotime() is a poor approximation of CPU ticks that is enough for the profiler.
|
|
// TODO: need more entropy to better seed fastrand.
|
|
return nanotime()
|
|
}
|