From: Ian Lance Taylor Date: Tue, 11 Dec 2018 15:46:10 +0000 (-0800) Subject: cmd/cgo: don't cache bad pointer typedefs X-Git-Tag: go1.12beta1~111 X-Git-Url: http://www.git.cypherpunks.su/?a=commitdiff_plain;h=01e072db5d26c224dfbe7763a5b94ab23c163983;p=gostls13.git cmd/cgo: don't cache bad pointer typedefs The set of bad pointer typedefs changes as we see more typedefs, so avoid looking in the cache when we find one. Fixes #29175 Change-Id: Idd82289bdd8628d11a983fa5ec96517e3a5bcbf1 Reviewed-on: https://go-review.googlesource.com/c/153597 Run-TryBot: Ian Lance Taylor Reviewed-by: Keith Randall TryBot-Result: Gobot Gobot --- diff --git a/src/cmd/cgo/gcc.go b/src/cmd/cgo/gcc.go index 17a9936e6a..321d4db040 100644 --- a/src/cmd/cgo/gcc.go +++ b/src/cmd/cgo/gcc.go @@ -2177,12 +2177,22 @@ func (c *typeConv) FinishType(pos token.Pos) { // Type returns a *Type with the same memory layout as // dtype when used as the type of a variable or a struct field. func (c *typeConv) Type(dtype dwarf.Type, pos token.Pos) *Type { + // Always recompute bad pointer typedefs, as the set of such + // typedefs changes as we see more types. + checkCache := true + if dtt, ok := dtype.(*dwarf.TypedefType); ok && c.badPointerTypedef(dtt) { + checkCache = false + } + key := dtype.String() - if t, ok := c.m[key]; ok { - if t.Go == nil { - fatalf("%s: type conversion loop at %s", lineno(pos), dtype) + + if checkCache { + if t, ok := c.m[key]; ok { + if t.Go == nil { + fatalf("%s: type conversion loop at %s", lineno(pos), dtype) + } + return t } - return t } t := new(Type)