1
2
3
4
5 package ssa
6
7 import (
8 "cmd/compile/internal/types"
9 "fmt"
10 "testing"
11 )
12
13 const (
14 blockCount = 1000
15 passCount = 15000
16 )
17
18 type passFunc func(*Func)
19
20 func BenchmarkDSEPass(b *testing.B) { benchFnPass(b, dse, blockCount, genFunction) }
21 func BenchmarkDSEPassBlock(b *testing.B) { benchFnBlock(b, dse, genFunction) }
22 func BenchmarkCSEPass(b *testing.B) { benchFnPass(b, cse, blockCount, genFunction) }
23 func BenchmarkCSEPassBlock(b *testing.B) { benchFnBlock(b, cse, genFunction) }
24 func BenchmarkDeadcodePass(b *testing.B) { benchFnPass(b, deadcode, blockCount, genFunction) }
25 func BenchmarkDeadcodePassBlock(b *testing.B) { benchFnBlock(b, deadcode, genFunction) }
26
27 func multi(f *Func) {
28 cse(f)
29 dse(f)
30 deadcode(f)
31 }
32 func BenchmarkMultiPass(b *testing.B) { benchFnPass(b, multi, blockCount, genFunction) }
33 func BenchmarkMultiPassBlock(b *testing.B) { benchFnBlock(b, multi, genFunction) }
34
35
36 func benchFnPass(b *testing.B, fn passFunc, size int, bg blockGen) {
37 b.ReportAllocs()
38 c := testConfig(b)
39 fun := c.Fun("entry", bg(size)...)
40 CheckFunc(fun.f)
41 b.ResetTimer()
42 for i := 0; i < b.N; i++ {
43 fn(fun.f)
44 b.StopTimer()
45 CheckFunc(fun.f)
46 b.StartTimer()
47 }
48 }
49
50
51 func benchFnBlock(b *testing.B, fn passFunc, bg blockGen) {
52 b.ReportAllocs()
53 c := testConfig(b)
54 fun := c.Fun("entry", bg(b.N)...)
55 CheckFunc(fun.f)
56 b.ResetTimer()
57 for i := 0; i < passCount; i++ {
58 fn(fun.f)
59 }
60 b.StopTimer()
61 }
62
63 func genFunction(size int) []bloc {
64 var blocs []bloc
65 elemType := types.Types[types.TINT64]
66 ptrType := elemType.PtrTo()
67
68 valn := func(s string, m, n int) string { return fmt.Sprintf("%s%d-%d", s, m, n) }
69 blocs = append(blocs,
70 Bloc("entry",
71 Valu(valn("store", 0, 4), OpInitMem, types.TypeMem, 0, nil),
72 Valu("sb", OpSB, types.Types[types.TUINTPTR], 0, nil),
73 Goto(blockn(1)),
74 ),
75 )
76 for i := 1; i < size+1; i++ {
77 blocs = append(blocs, Bloc(blockn(i),
78 Valu(valn("v", i, 0), OpConstBool, types.Types[types.TBOOL], 1, nil),
79 Valu(valn("addr", i, 1), OpAddr, ptrType, 0, nil, "sb"),
80 Valu(valn("addr", i, 2), OpAddr, ptrType, 0, nil, "sb"),
81 Valu(valn("addr", i, 3), OpAddr, ptrType, 0, nil, "sb"),
82 Valu(valn("zero", i, 1), OpZero, types.TypeMem, 8, elemType, valn("addr", i, 3),
83 valn("store", i-1, 4)),
84 Valu(valn("store", i, 1), OpStore, types.TypeMem, 0, elemType, valn("addr", i, 1),
85 valn("v", i, 0), valn("zero", i, 1)),
86 Valu(valn("store", i, 2), OpStore, types.TypeMem, 0, elemType, valn("addr", i, 2),
87 valn("v", i, 0), valn("store", i, 1)),
88 Valu(valn("store", i, 3), OpStore, types.TypeMem, 0, elemType, valn("addr", i, 1),
89 valn("v", i, 0), valn("store", i, 2)),
90 Valu(valn("store", i, 4), OpStore, types.TypeMem, 0, elemType, valn("addr", i, 3),
91 valn("v", i, 0), valn("store", i, 3)),
92 Goto(blockn(i+1))))
93 }
94
95 blocs = append(blocs,
96 Bloc(blockn(size+1), Goto("exit")),
97 Bloc("exit", Exit("store0-4")),
98 )
99
100 return blocs
101 }
102
View as plain text