]> Cypherpunks repositories - gostls13.git/commitdiff
cmd/compile: fix infinite recursion in isdirectiface
authorMatthew Dempsky <mdempsky@google.com>
Tue, 28 Nov 2017 21:42:04 +0000 (13:42 -0800)
committerMatthew Dempsky <mdempsky@google.com>
Tue, 28 Nov 2017 21:58:16 +0000 (21:58 +0000)
Fixes #22904.

Change-Id: Id504504eda7275c10d3c665add8b7ccd23f65820
Reviewed-on: https://go-review.googlesource.com/80301
Run-TryBot: Matthew Dempsky <mdempsky@google.com>
Reviewed-by: Emmanuel Odeke <emm.odeke@gmail.com>
Reviewed-by: Brad Fitzpatrick <bradfitz@golang.org>
TryBot-Result: Gobot Gobot <gobot@golang.org>

src/cmd/compile/internal/gc/subr.go
test/fixedbugs/issue22904.go [new file with mode: 0644]

index 81441ba7004e90cfd2a0aeb2bbaac77cfed088ef..0735a0c4089f9815b03db374a20644d41e66230c 100644 (file)
@@ -2022,6 +2022,10 @@ func checknil(x *Node, init *Nodes) {
 // Can this type be stored directly in an interface word?
 // Yes, if the representation is a single pointer.
 func isdirectiface(t *types.Type) bool {
+       if t.Broke() {
+               return false
+       }
+
        switch t.Etype {
        case TPTR32,
                TPTR64,
diff --git a/test/fixedbugs/issue22904.go b/test/fixedbugs/issue22904.go
new file mode 100644 (file)
index 0000000..46cb7c0
--- /dev/null
@@ -0,0 +1,19 @@
+// errorcheck
+
+// 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 22904: Make sure the compiler emits a proper error message about
+// invalid recursive types rather than crashing.
+
+package p
+
+type a struct{ b }
+type b struct{ a } // ERROR "invalid recursive type"
+
+var x interface{}
+
+func f() {
+       x = a{}
+}