Commit 7b62e984 authored by Michael Munday's avatar Michael Munday

runtime: always mask shift amount regardless of architecture

Currently the shift amount is only masked on x86. Change it so it
is masked on all architectures. In the worst case we generate a
couple of extra instructions to perform the masking and in the best
case we can elide overflow checks.

This particular shift could also be replaced with a rotate
instruction during optimization which would remove both the masking
instructions and overflow checks on all architectures.

Fixes #31165.

Change-Id: I16b7a8800b4ba8813dc83735dfc59564e661d3b4
Reviewed-on: https://go-review.googlesource.com/c/go/+/170122
Run-TryBot: Michael Munday <mike.munday@ibm.com>
TryBot-Result: Gobot Gobot <gobot@golang.org>
Reviewed-by: default avatarKeith Randall <khr@golang.org>
parent e6ad619a
...@@ -181,10 +181,8 @@ type hiter struct { ...@@ -181,10 +181,8 @@ type hiter struct {
// bucketShift returns 1<<b, optimized for code generation. // bucketShift returns 1<<b, optimized for code generation.
func bucketShift(b uint8) uintptr { func bucketShift(b uint8) uintptr {
if sys.GoarchAmd64|sys.GoarchAmd64p32|sys.Goarch386 != 0 { // Masking the shift amount allows overflow checks to be elided.
b &= sys.PtrSize*8 - 1 // help x86 archs remove shift overflow checks return uintptr(1) << (b & (sys.PtrSize*8 - 1))
}
return uintptr(1) << b
} }
// bucketMask returns 1<<b - 1, optimized for code generation. // bucketMask returns 1<<b - 1, optimized for code generation.
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment