mirror of
https://github.com/golang/go
synced 2024-11-02 11:50:30 +00:00
d8f1f8d856
* This is an improved version of an earlier patch. * Verified with gcc up to 100. * Limited to two instructions based on costs from https://gmplib.org/~tege/x86-timing.pdf Change-Id: Ib7c37de6fd8e0ba554459b15c7409508cbcf6728 Reviewed-on: https://go-review.googlesource.com/21103 Reviewed-by: Keith Randall <khr@golang.org> Run-TryBot: Alexandru Moșoi <alexandru@mosoi.ro> TryBot-Result: Gobot Gobot <gobot@golang.org>
45 lines
1 KiB
Go
45 lines
1 KiB
Go
// runoutput
|
|
|
|
// Copyright 2016 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.
|
|
|
|
// Generate test of strength reduction for multiplications
|
|
// with contstants. Especially useful for amd64/386.
|
|
|
|
package main
|
|
|
|
import "fmt"
|
|
|
|
func testMul(fact, bits int) string {
|
|
n := fmt.Sprintf("testMul_%d_%d", fact, bits)
|
|
fmt.Printf("func %s(s int%d) {\n", n, bits)
|
|
|
|
want := 0
|
|
for i := 0; i < 200; i++ {
|
|
fmt.Printf(` if want, got := int%d(%d), s*%d; want != got {
|
|
failed = true
|
|
fmt.Printf("got %d * %%d == %%d, wanted %d\n", s, got)
|
|
}
|
|
`, bits, want, i, i, want)
|
|
want += fact
|
|
}
|
|
|
|
fmt.Printf("}\n")
|
|
return fmt.Sprintf("%s(%d)", n, fact)
|
|
}
|
|
|
|
func main() {
|
|
fmt.Printf("package main\n")
|
|
fmt.Printf("import \"fmt\"\n")
|
|
fmt.Printf("var failed = false\n")
|
|
|
|
f1 := testMul(17, 32)
|
|
f2 := testMul(131, 64)
|
|
|
|
fmt.Printf("func main() {\n")
|
|
fmt.Println(f1)
|
|
fmt.Println(f2)
|
|
fmt.Printf("if failed {\n panic(\"multiplication failed\")\n}\n")
|
|
fmt.Printf("}\n")
|
|
}
|