Commit 08dca4c6 authored by Todd Neal's avatar Todd Neal

cmd/compile: ignore types when considering tuple select for CSE

Fixes #20097

Change-Id: I3c9626ccc8cd0c46a7081ea8650b2ff07a5d4fcd
Reviewed-on: https://go-review.googlesource.com/41505
Run-TryBot: Todd Neal <todd@tneal.org>
TryBot-Result: Gobot Gobot <gobot@golang.org>
Reviewed-by: 's avatarKeith Randall <khr@golang.org>
parent 46b88c9f
...@@ -322,10 +322,14 @@ func cmpVal(v, w *Value, auxIDs auxmap) types.Cmp { ...@@ -322,10 +322,14 @@ func cmpVal(v, w *Value, auxIDs auxmap) types.Cmp {
// that generate memory. // that generate memory.
return lt2Cmp(v.ID < w.ID) return lt2Cmp(v.ID < w.ID)
} }
// OpSelect is a pseudo-op. We need to be more agressive
// regarding CSE to keep multiple OpSelect's of the same
// argument from existing.
if v.Op != OpSelect0 && v.Op != OpSelect1 {
if tc := v.Type.Compare(w.Type); tc != types.CMPeq { if tc := v.Type.Compare(w.Type); tc != types.CMPeq {
return tc return tc
} }
}
if v.Aux != w.Aux { if v.Aux != w.Aux {
if v.Aux == nil { if v.Aux == nil {
......
// compile
// Copyright 2017 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.
// Issue 20097: ensure that we CSE multiple Select ops with
// the same underlying type
package main
type T int64
func f(x, y int64) (int64, T) {
a := x / y
b := T(x) / T(y)
return a, b
}
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment