| // Copyright 2020 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 ssa | |
| import ( | |
| "math/rand" | |
| "testing" | |
| ) | |
| var d int | |
| //go:noinline | |
| func fn(a, b int) bool { | |
| c := false | |
| if a > 0 { | |
| if b < 0 { | |
| d = d + 1 | |
| } | |
| c = true | |
| } | |
| return c | |
| } | |
| func BenchmarkPhioptPass(b *testing.B) { | |
| for i := 0; i < b.N; i++ { | |
| a := rand.Perm(i/10 + 10) | |
| for i := 1; i < len(a)/2; i++ { | |
| fn(a[i]-a[i-1], a[i+len(a)/2-2]-a[i+len(a)/2-1]) | |
| } | |
| } | |
| } |