aboutsummaryrefslogtreecommitdiff
path: root/test/codegen/mathbits.go
diff options
context:
space:
mode:
authorAlberto Donizetti <alb.donizetti@gmail.com>2018-03-02 15:16:27 +0100
committerAlberto Donizetti <alb.donizetti@gmail.com>2018-03-05 18:01:19 +0000
commitc1806906d89ecc65136be4bbdfb9020c797be46c (patch)
tree60b513607d53d3e421163ab1525f00cb46a1b844 /test/codegen/mathbits.go
parent63bcabed498a53a24da51ca1264b338c1149be07 (diff)
downloadgo-c1806906d89ecc65136be4bbdfb9020c797be46c.tar.xz
test: port bits.Len intrinsics tests to the new codegen harness
This change move bits.Len* intrinsification tests to the new codegen test harness, removing them from the old ssa_test file. Five different test functions (one for each bit.Len function tested) was used, to avoid possible unwanted interactions between multiple calls inside one function. Change-Id: Iffd5be55b58e88597fa30a562a28dacb01236d8b Reviewed-on: https://go-review.googlesource.com/98156 Run-TryBot: Alberto Donizetti <alb.donizetti@gmail.com> TryBot-Result: Gobot Gobot <gobot@golang.org> Reviewed-by: Giovanni Bajo <rasky@develer.com>
Diffstat (limited to 'test/codegen/mathbits.go')
-rw-r--r--test/codegen/mathbits.go53
1 files changed, 53 insertions, 0 deletions
diff --git a/test/codegen/mathbits.go b/test/codegen/mathbits.go
new file mode 100644
index 0000000000..02552e1fdb
--- /dev/null
+++ b/test/codegen/mathbits.go
@@ -0,0 +1,53 @@
+// asmcheck
+
+// 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.
+
+package codegen
+
+import "math/bits"
+
+// --------------- //
+// bits.Len* //
+// --------------- //
+
+func Len(n uint) int {
+ //amd64:"BSRQ"
+ //s390x:"FLOGR"
+ //arm:"CLZ" arm64:"CLZ"
+ //mips:"CLZ"
+ return bits.Len(n)
+}
+
+func Len64(n uint64) int {
+ //amd64:"BSRQ"
+ //s390x:"FLOGR"
+ //arm:"CLZ" arm64:"CLZ"
+ //mips:"CLZ"
+ return bits.Len64(n)
+}
+
+func Len32(n uint32) int {
+ //amd64:"BSRQ"
+ //s390x:"FLOGR"
+ //arm:"CLZ" arm64:"CLZ"
+ //mips:"CLZ"
+ return bits.Len32(n)
+}
+
+func Len16(n uint16) int {
+ //amd64:"BSRQ"
+ //s390x:"FLOGR"
+ //arm:"CLZ" arm64:"CLZ"
+ //mips:"CLZ"
+ return bits.Len16(n)
+}
+
+func Len8(n uint8) int {
+ //amd64 Len8 not intrisified
+ //s390x:"FLOGR"
+ //arm:"CLZ" arm64:"CLZ"
+ //mips:"CLZ"
+ return bits.Len8(n)
+}