1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
|
// 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 constants. 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")
}
|