From: Shenghou Ma Date: Tue, 23 Dec 2014 22:14:04 +0000 (-0500) Subject: [release-branch.go1.4] cmd/gc: don't recurse infinitely when a recursive type referen... X-Git-Tag: go1.4.2~4 X-Git-Url: http://www.git.cypherpunks.su/?a=commitdiff_plain;h=02cf0526bf76e5990ae3c2a9942866320de0bde3;p=gostls13.git [release-branch.go1.4] cmd/gc: don't recurse infinitely when a recursive type references itself more than once Fixes #9432 Change-Id: I08c92481afa7c7fac890aa780efc1cb2fabad528 Reviewed-on: https://go-review.googlesource.com/2115 Reviewed-by: Josh Bleecher Snyder Reviewed-by: Russ Cox (cherry picked from commit fcff3ba740ed6638cece4dea8478bd1dfb2411bf) Reviewed-on: https://go-review.googlesource.com/5004 Run-TryBot: Andrew Gerrand Reviewed-by: Andrew Gerrand --- diff --git a/src/cmd/gc/align.c b/src/cmd/gc/align.c index 6e5d149c75..63ed2e5af6 100644 --- a/src/cmd/gc/align.c +++ b/src/cmd/gc/align.c @@ -128,6 +128,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 index 0000000000..0d0bc960f9 --- /dev/null +++ b/test/fixedbugs/issue9432.go @@ -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"