// Convert v to type typ if v is assignable to a variable
                        // of type t in the language spec.
                        // See issue 28761.
+                       if typ.Kind() == Interface {
+                               // We must clear the destination before calling assignTo,
+                               // in case assignTo writes (with memory barriers) to the
+                               // target location used as scratch space. See issue 39541.
+                               *(*uintptr)(addr) = 0
+                               *(*uintptr)(add(addr, ptrSize, "typ.size == 2*ptrSize")) = 0
+                       }
                        v = v.assignTo("reflect.MakeFunc", typ, addr)
 
                        // We are writing to stack. No write barrier.
 // assignTo returns a value v that can be assigned directly to typ.
 // It panics if v is not assignable to typ.
 // For a conversion to an interface type, target is a suggested scratch space to use.
+// target must be initialized memory (or nil).
 func (v Value) assignTo(context string, dst *rtype, target unsafe.Pointer) Value {
        if v.flag&flagMethod != 0 {
                v = makeMethodValue(context, v)
 
--- /dev/null
+// run
+
+// Copyright 2020 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 "reflect"
+
+func sub(args []reflect.Value) []reflect.Value {
+       type A struct {
+               s int
+               t int
+       }
+       return []reflect.Value{reflect.ValueOf(A{1, 2})}
+}
+
+func main() {
+       f := reflect.MakeFunc(reflect.TypeOf((func() interface{})(nil)), sub).Interface().(func() interface{})
+       c := make(chan bool, 100)
+       for i := 0; i < 100; i++ {
+               go func() {
+                       for j := 0; j < 10000; j++ {
+                               f()
+                       }
+                       c <- true
+               }()
+       }
+       for i := 0; i < 100; i++ {
+               <-c
+       }
+}