]> Cypherpunks.ru repositories - gostls13.git/commitdiff
hash/maphash: mark call into runtime hash function as not escaping
authorKeith Randall <khr@golang.org>
Sat, 16 Nov 2019 15:12:53 +0000 (07:12 -0800)
committerKeith Randall <khr@golang.org>
Sat, 16 Nov 2019 20:31:45 +0000 (20:31 +0000)
This allows maphash.Hash to be allocated on the stack for typical uses.

Fixes #35636

Change-Id: I8366507d26ea717f47a9fb46d3bd69ba799845ac
Reviewed-on: https://go-review.googlesource.com/c/go/+/207444
Run-TryBot: Keith Randall <khr@golang.org>
TryBot-Result: Gobot Gobot <gobot@golang.org>
Reviewed-by: Brad Fitzpatrick <bradfitz@golang.org>
src/hash/maphash/maphash.go
test/escape_hash_maphash.go [new file with mode: 0644]

index 9b6c0cfb99860300f09b0d0bad438ded899ea00e..3f406e9db634e629d07e8e07f750140507a69931 100644 (file)
@@ -193,6 +193,7 @@ func rthash(b []byte, seed uint64) uint64 {
 }
 
 //go:linkname runtime_memhash runtime.memhash
+//go:noescape
 func runtime_memhash(p unsafe.Pointer, seed, s uintptr) uintptr
 
 // Sum appends the hash's current 64-bit value to b.
diff --git a/test/escape_hash_maphash.go b/test/escape_hash_maphash.go
new file mode 100644 (file)
index 0000000..f8dcc54
--- /dev/null
@@ -0,0 +1,19 @@
+// errorcheck -0 -m -l
+
+// Copyright 2019 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.
+
+// Test escape analysis for hash/maphash.
+
+package escape
+
+import (
+       "hash/maphash"
+)
+
+func f() {
+       var x maphash.Hash // should be stack allocatable
+       x.WriteString("foo")
+       x.Sum64()
+}