]> Cypherpunks repositories - gostls13.git/commitdiff
cmd/gc: don't recurse infinitely when a recursive type references itself more than...
authorShenghou Ma <minux@golang.org>
Tue, 23 Dec 2014 22:14:04 +0000 (17:14 -0500)
committerMinux Ma <minux@golang.org>
Mon, 12 Jan 2015 02:09:50 +0000 (02:09 +0000)
Fixes #9432

Change-Id: I08c92481afa7c7fac890aa780efc1cb2fabad528
Reviewed-on: https://go-review.googlesource.com/2115
Reviewed-by: Josh Bleecher Snyder <josharian@gmail.com>
Reviewed-by: Russ Cox <rsc@golang.org>
src/cmd/gc/align.c
test/fixedbugs/issue9432.go [new file with mode: 0644]

index 29accd353867c1794b04433146b307b750665992..57daaa974558d6a4a7e57a47a1e278bdceef11e2 100644 (file)
@@ -137,6 +137,11 @@ dowidth(Type *t)
                return;
        }
 
+       // break infinite recursion if the broken recursive type
+       // is referenced again
+       if(t->broke && t->width == 0)
+               return;
+
        // defer checkwidth calls until after we're done
        defercalc++;
 
diff --git a/test/fixedbugs/issue9432.go b/test/fixedbugs/issue9432.go
new file mode 100644 (file)
index 0000000..0d0bc96
--- /dev/null
@@ -0,0 +1,15 @@
+// errorcheck
+
+// Copyright 2014 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.
+
+// gc used to recurse infinitely when dowidth is applied
+// to a broken recursive type again.
+// See golang.org/issue/9432.
+package p
+
+type foo struct { // GCCGO_ERROR "invalid recursive type"
+       bar  foo
+       blah foo
+} // ERROR "invalid recursive type foo"