Skip to content

Commit bc1989f

Browse files
committed
cmd/compile: optimize lookupVarOutgoing
If b has exactly one predecessor, as happens frequently with static calls, we can make lookupVarOutgoing generate less garbage. Instead of generating a value that is just going to be an OpCopy and then get eliminated, loop. This can lead to lots of looping. However, this loop is way cheaper than generating lots of ssa.Values and then eliminating them. For a subset of the code in #15537: Before: 28.31 real 36.17 user 1.68 sys 2282450944 maximum resident set size After: 9.63 real 11.66 user 0.51 sys 638144512 maximum resident set size Updates #15537. Excitingly, it appears that this also helps regular code: name old time/op new time/op delta Template 288ms ± 6% 276ms ± 7% -4.13% (p=0.000 n=21+24) Unicode 143ms ± 8% 141ms ±10% ~ (p=0.287 n=24+25) GoTypes 932ms ± 4% 874ms ± 4% -6.20% (p=0.000 n=23+22) Compiler 4.89s ± 4% 4.58s ± 4% -6.46% (p=0.000 n=22+23) MakeBash 40.2s ±13% 39.8s ± 9% ~ (p=0.648 n=23+23) name old user-ns/op new user-ns/op delta Template 388user-ms ±10% 373user-ms ± 5% -3.80% (p=0.000 n=24+25) Unicode 203user-ms ± 6% 202user-ms ± 7% ~ (p=0.492 n=22+24) GoTypes 1.29user-s ± 4% 1.17user-s ± 4% -9.67% (p=0.000 n=25+23) Compiler 6.86user-s ± 5% 6.28user-s ± 4% -8.49% (p=0.000 n=25+25) name old alloc/op new alloc/op delta Template 51.5MB ± 0% 47.6MB ± 0% -7.47% (p=0.000 n=22+25) Unicode 37.2MB ± 0% 37.1MB ± 0% -0.21% (p=0.000 n=25+25) GoTypes 166MB ± 0% 138MB ± 0% -16.83% (p=0.000 n=25+25) Compiler 756MB ± 0% 628MB ± 0% -16.96% (p=0.000 n=25+23) name old allocs/op new allocs/op delta Template 450k ± 0% 445k ± 0% -1.02% (p=0.000 n=25+25) Unicode 356k ± 0% 356k ± 0% ~ (p=0.374 n=24+25) GoTypes 1.31M ± 0% 1.25M ± 0% -4.18% (p=0.000 n=25+25) Compiler 5.29M ± 0% 5.02M ± 0% -5.15% (p=0.000 n=25+23) It also seems to help in other cases in which phi insertion is a pain point (#14774, #14934). Change-Id: Ibd05ed7b99d262117ece7bb250dfa8c3d1cc5dd2 Reviewed-on: https://go-review.googlesource.com/22790 Reviewed-by: Keith Randall <[email protected]> Run-TryBot: Josh Bleecher Snyder <[email protected]>
1 parent 6ccab44 commit bc1989f

File tree

1 file changed

+13
-6
lines changed
  • src/cmd/compile/internal/gc

1 file changed

+13
-6
lines changed

src/cmd/compile/internal/gc/ssa.go

Lines changed: 13 additions & 6 deletions
Original file line numberDiff line numberDiff line change
@@ -3832,15 +3832,22 @@ func (s *state) resolveFwdRef(v *ssa.Value) {
38323832

38333833
// lookupVarOutgoing finds the variable's value at the end of block b.
38343834
func (s *state) lookupVarOutgoing(b *ssa.Block, t ssa.Type, name *Node, line int32) *ssa.Value {
3835-
m := s.defvars[b.ID]
3836-
if v, ok := m[name]; ok {
3837-
return v
3835+
for {
3836+
if v, ok := s.defvars[b.ID][name]; ok {
3837+
return v
3838+
}
3839+
// The variable is not defined by b and we haven't looked it up yet.
3840+
// If b has exactly one predecessor, loop to look it up there.
3841+
// Otherwise, give up and insert a new FwdRef and resolve it later.
3842+
if len(b.Preds) != 1 {
3843+
break
3844+
}
3845+
b = b.Preds[0].Block()
38383846
}
3839-
// The variable is not defined by b and we haven't
3840-
// looked it up yet. Generate a FwdRef for the variable and return that.
3847+
// Generate a FwdRef for the variable and return that.
38413848
v := b.NewValue0A(line, ssa.OpFwdRef, t, name)
38423849
s.fwdRefs = append(s.fwdRefs, v)
3843-
m[name] = v
3850+
s.defvars[b.ID][name] = v
38443851
s.addNamedValue(name, v)
38453852
return v
38463853
}

0 commit comments

Comments
 (0)