]> Cypherpunks repositories - gostls13.git/commitdiff
cmd/compile: fix late expand_calls leaf type for OpStructSelect/OpArraySelect
authorCuong Manh Le <cuong.manhle.vn@gmail.com>
Thu, 7 Jan 2021 14:45:00 +0000 (21:45 +0700)
committerAustin Clements <austin@google.com>
Thu, 7 Jan 2021 19:31:03 +0000 (19:31 +0000)
For the example in #43551, before late call expansion, the OpArg type is
decomposed to int64. But the late call expansion is currently decompose
it to "x.Key" instead.

This CL make expand_calls decompose further for struct { 1-field type }
and array [1]elem.

This matches the previous rules for early decompose args:

(StructSelect (StructMake1 x)) => x
(ArraySelect (ArrayMake1 x)) => x

Fixes #43551

Change-Id: I2f1ebe18cb81cb967f494331c3d237535d2859e7
Reviewed-on: https://go-review.googlesource.com/c/go/+/282332
Trust: Cuong Manh Le <cuong.manhle.vn@gmail.com>
Run-TryBot: Cuong Manh Le <cuong.manhle.vn@gmail.com>
TryBot-Result: Go Bot <gobot@golang.org>
Reviewed-by: David Chase <drchase@google.com>
src/cmd/compile/internal/ssa/expand_calls.go
test/fixedbugs/issue43551.dir/a.go [new file with mode: 0644]
test/fixedbugs/issue43551.dir/b.go [new file with mode: 0644]
test/fixedbugs/issue43551.go [new file with mode: 0644]

index fbde19d94c29927a2a50a0d396ced550fed31dcb..679ee8ad1650d71ee663a9c11229ede0f467212e 100644 (file)
@@ -194,7 +194,8 @@ func expandCalls(f *Func) {
                                }
                                break
                        }
-                       if leaf.Op == OpIData {
+                       switch leaf.Op {
+                       case OpIData, OpStructSelect, OpArraySelect:
                                leafType = removeTrivialWrapperTypes(leaf.Type)
                        }
                        aux := selector.Aux
diff --git a/test/fixedbugs/issue43551.dir/a.go b/test/fixedbugs/issue43551.dir/a.go
new file mode 100644 (file)
index 0000000..d890dd0
--- /dev/null
@@ -0,0 +1,13 @@
+package a
+
+type S struct {
+       a Key
+}
+
+func (s S) A() Key {
+       return s.a
+}
+
+type Key struct {
+       key int64
+}
diff --git a/test/fixedbugs/issue43551.dir/b.go b/test/fixedbugs/issue43551.dir/b.go
new file mode 100644 (file)
index 0000000..ba062bf
--- /dev/null
@@ -0,0 +1,14 @@
+// Copyright 2021 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.
+
+package b
+
+import "./a"
+
+type S a.S
+type Key a.Key
+
+func (s S) A() Key {
+       return Key(a.S(s).A())
+}
diff --git a/test/fixedbugs/issue43551.go b/test/fixedbugs/issue43551.go
new file mode 100644 (file)
index 0000000..b83fbd7
--- /dev/null
@@ -0,0 +1,7 @@
+// compiledir
+
+// Copyright 2021 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.
+
+package ignored