Commit 13081942 authored by Dmitriy Vyukov's avatar Dmitriy Vyukov

runtime: zeroize g->fnstart to not prevent GC of the closure

Fixes #5493.

R=golang-dev, minux.ma, iant
CC=golang-dev
https://golang.org/cl/9557043
parent d4cbc80d
...@@ -1232,6 +1232,7 @@ static void ...@@ -1232,6 +1232,7 @@ static void
goexit0(G *gp) goexit0(G *gp)
{ {
gp->status = Gdead; gp->status = Gdead;
gp->fnstart = nil;
gp->m = nil; gp->m = nil;
gp->lockedm = nil; gp->lockedm = nil;
m->curg = nil; m->curg = nil;
......
// run
// Copyright 2013 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.
package main
import (
"runtime"
"sync"
"sync/atomic"
"time"
)
const N = 10
var count int64
func run() error {
f1 := func() {}
f2 := func() {
func() {
f1()
}()
}
runtime.SetFinalizer(&f1, func(f *func()) {
atomic.AddInt64(&count, -1)
})
go f2()
return nil
}
func main() {
count = N
var wg sync.WaitGroup
wg.Add(N)
for i := 0; i < N; i++ {
go func() {
run()
wg.Done()
}()
}
wg.Wait()
for i := 0; i < 2*N; i++ {
time.Sleep(10 * time.Millisecond)
runtime.GC()
}
if count != 0 {
panic("not all finalizers are called")
}
}
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment