mirror of https://github.com/golang/go.git
[release-branch.go1.8] 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: Keith Randall <khr@golang.org> Reviewed-on: https://go-review.googlesource.com/43997 Run-TryBot: Chris Broadfoot <cbro@golang.org> Reviewed-by: Brad Fitzpatrick <bradfitz@golang.org>
This commit is contained in:
parent
f55bc1c4eb
commit
195e20a976
|
|
@ -313,9 +313,13 @@ func cmpVal(v, w *Value, auxIDs auxmap) 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
|
||||||
if tc := v.Type.Compare(w.Type); tc != CMPeq {
|
// regarding CSE to keep multiple OpSelect's of the same
|
||||||
return tc
|
// argument from existing.
|
||||||
|
if v.Op != OpSelect0 && v.Op != OpSelect1 {
|
||||||
|
if tc := v.Type.Compare(w.Type); tc != CMPeq {
|
||||||
|
return tc
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if v.Aux != w.Aux {
|
if v.Aux != w.Aux {
|
||||||
|
|
|
||||||
|
|
@ -0,0 +1,18 @@
|
||||||
|
// 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
|
||||||
|
}
|
||||||
Loading…
Reference in New Issue