]> Cypherpunks repositories - gostls13.git/commitdiff
test: add test case for which gccgo generated incorrect GC info
authorIan Lance Taylor <iant@golang.org>
Thu, 1 Dec 2016 17:15:39 +0000 (09:15 -0800)
committerIan Lance Taylor <iant@golang.org>
Fri, 2 Dec 2016 21:29:37 +0000 (21:29 +0000)
Change-Id: I5e33db9e63f70706882b85ab124a48509797b05a
Reviewed-on: https://go-review.googlesource.com/33790
Run-TryBot: Ian Lance Taylor <iant@golang.org>
TryBot-Result: Gobot Gobot <gobot@golang.org>
Reviewed-by: Brad Fitzpatrick <bradfitz@golang.org>
test/fixedbugs/bug500.go [new file with mode: 0644]

diff --git a/test/fixedbugs/bug500.go b/test/fixedbugs/bug500.go
new file mode 100644 (file)
index 0000000..2dd5df1
--- /dev/null
@@ -0,0 +1,41 @@
+// run
+
+// Copyright 2016 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.
+
+// Gccgo generated incorrect GC info when a global variable was
+// initialized to a slice of a value containing pointers.  The initial
+// backing array for the slice was allocated in the .data section,
+// which is fine, but the backing array was not registered as a GC
+// root.
+
+package main
+
+import (
+       "runtime"
+)
+
+type s struct {
+       str string
+}
+
+var a = []struct {
+       str string
+}{
+       {""},
+}
+
+var b = "b"
+var c = "c"
+
+func init() {
+       a[0].str = b + c
+}
+
+func main() {
+       runtime.GC()
+       if a[0].str != b + c {
+               panic(a[0].str)
+       }
+}