diff options
author | Andrew Bonventre <andybons@golang.org> | 2018-08-30 15:47:04 -0600 |
---|---|---|
committer | Andrew Bonventre <andybons@golang.org> | 2018-08-30 22:48:28 +0000 |
commit | 5ac247674884a93f3a7630649ee00923724e7961 (patch) | |
tree | 60a2e228717199b480e5c95bda781e036821f75f /test/inline_math_bits_rotate.go | |
parent | 8201b92aae7ba51ed2e2645c1f7815bfe845db72 (diff) | |
download | go-5ac247674884a93f3a7630649ee00923724e7961.tar.gz go-5ac247674884a93f3a7630649ee00923724e7961.zip |
cmd/compile: make math/bits.RotateLeft* an intrinsic on amd64
Previously, pattern matching was good enough to achieve good performance
for the RotateLeft* functions, but the inlining cost for them was much
too high. Make RotateLeft* intrinsic on amd64 as a stop-gap for now to
reduce inlining costs.
This should be done (or at least looked at) for other architectures
as well.
Updates golang/go#17566
Change-Id: I6a106ff00b6c4e3f490650af3e083ed2be00c819
Reviewed-on: https://go-review.googlesource.com/132435
Run-TryBot: Andrew Bonventre <andybons@golang.org>
TryBot-Result: Gobot Gobot <gobot@golang.org>
Reviewed-by: David Chase <drchase@google.com>
Diffstat (limited to 'test/inline_math_bits_rotate.go')
-rw-r--r-- | test/inline_math_bits_rotate.go | 28 |
1 files changed, 28 insertions, 0 deletions
diff --git a/test/inline_math_bits_rotate.go b/test/inline_math_bits_rotate.go new file mode 100644 index 0000000000..a0341ea497 --- /dev/null +++ b/test/inline_math_bits_rotate.go @@ -0,0 +1,28 @@ +// +build amd64 +// errorcheck -0 -m + +// Copyright 2018 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. + +// Test that inlining of math/bits.RotateLeft* treats those calls as intrinsics. + +package p + +import "math/bits" + +var ( + x8 uint8 + x16 uint16 + x32 uint32 + x64 uint64 + x uint +) + +func f() { // ERROR "can inline f" + x8 = bits.RotateLeft8(x8, 1) + x16 = bits.RotateLeft16(x16, 1) + x32 = bits.RotateLeft32(x32, 1) + x64 = bits.RotateLeft64(x64, 1) + x = bits.RotateLeft(x, 1) +} |