support collecting deep cpu and memory profiles from benchmarks
This allows me to collect a full CPU profile, showing us that we clearly spend too much CPU time in garbage collection. When collecting a full memory profile, we can see where the allocations come from now: Showing nodes accounting for 5636770, 31.07% of 18141579 total Dropped 630 nodes (cum <= 90707) Showing top 10 nodes out of 278 flat flat% sum% cum cum% 1692229 9.33% 9.33% 1910679 10.53% encoding/gob.decStringSlice 1005596 5.54% 14.87% 1005596 5.54% golang.org/x/tools/go/ssa.buildReferrers 458753 2.53% 17.40% 458753 2.53% go/scanner.(*Scanner).scanIdentifier 458752 2.53% 19.93% 458752 2.53% reflect.(*structType).Field 425984 2.35% 22.28% 448136 2.47% go/parser.(*parser).parseIdent 390049 2.15% 24.43% 390049 2.15% golang.org/x/tools/go/ssa.(*BasicBlock).emit 327683 1.81% 26.23% 371373 2.05% golang.org/x/tools/go/ssa.NewConst 311296 1.72% 27.95% 1024551 5.65% mvdan.cc/garble.(*transformer).transformGoFile.func1 287891 1.59% 29.54% 287891 1.59% encoding/gob.decString 278537 1.54% 31.07% 657043 3.62% golang.org/x/tools/go/ssa.(*builder).compLit This method can work for any invocation of garble, but for now we only directly wire it up for `go test -bench`. It can still be used for regular invocations of `garble build`.pull/850/head
parent
acec5954ce
commit
ec5b6df439
Loading…
Reference in New Issue