]> Cypherpunks repositories - gostls13.git/commit
cmd/compile: fix CSE with commutative ops
authorKeith Randall <khr@golang.org>
Sun, 27 Nov 2016 18:41:37 +0000 (10:41 -0800)
committerKeith Randall <khr@golang.org>
Thu, 2 Feb 2017 17:45:43 +0000 (17:45 +0000)
commit6317f92f6e51f679712deec6094c6b5fc2948a5b
treeabc842dac66292c9be9ac01ec22129e260246433
parent34b563f447280f9d386f208646ac4f94cafc4ab6
cmd/compile: fix CSE with commutative ops

CSE opportunities were being missed for commutative ops. We used to
order the args of commutative ops (by arg ID) once at the start of CSE.
But that may not be enough.

i1 = (Load ptr mem)
i2 = (Load ptr mem)
x1 = (Add i1 j)
x2 = (Add i2 j)

Equivalent commutative ops x1 and x2 may not get their args ordered in
the same way because because at the start of CSE, we don't know that
the i values will be CSEd. If x1 and x2 get opposite orders we won't
CSE them.

Instead, (re)order the args of commutative operations by their
equivalence class IDs each time we partition an equivalence class.

Change-Id: Ic609fa83b85299782a5e85bf93dc6023fccf4b0c
Reviewed-on: https://go-review.googlesource.com/33632
Run-TryBot: Keith Randall <khr@golang.org>
TryBot-Result: Gobot Gobot <gobot@golang.org>
Reviewed-by: Todd Neal <todd@tneal.org>
src/cmd/compile/internal/ssa/cse.go
test/prove.go