]> Cypherpunks repositories - gostls13.git/commit
runtime: put allocation headers back at the start the object
authorMichael Anthony Knyszek <mknyszek@google.com>
Thu, 16 Nov 2023 17:42:25 +0000 (17:42 +0000)
committerGopher Robot <gobot@golang.org>
Fri, 17 Nov 2023 22:55:27 +0000 (22:55 +0000)
commit0ef169abb1db6bd4e184ee87204dd883fb20cf1c
tree06b109bb21074b3ae28d6963cf4ccc06ddfb156c
parent0b90c7d4453bb21ec3ad4d6c5a3eebf398a89e77
runtime: put allocation headers back at the start the object

A persistent performance regression was discovered on
perf.golang.org/dashboard and this was narrowed down to the switch to
footers. Using allocation headers instead resolves the issue.

The benchmark results for allocation footers weren't realistic, because
they were performed on a machine with enough L3 cache that it completely
hid the additional cache miss introduced by allocation footers.

This means that in some corner cases the Go runtime may no longer
allocate 16-byte aligned memory. Note however that this property was
*mostly* incidental and never guaranteed in any documentation.

Allocation headers were tested widely within Google and no issues were
found, so we're fairly confident that this will not affect very many
users.

Nonetheless, by Hyrum's Law some code might depend on it. A follow-up
change will add a GODEBUG flag that ensures 16 byte alignment at the
potential cost of some additional memory use. Users experiencing both a
performance regression and an alignment issue can also disable the
GOEXPERIMENT at build time.

This reverts commit 1e250a219900651dad27f29eab0877eee4afd5b9.

Change-Id: Ia7d62a9c60d1773c8b6d33322ee33a80ef814943
Reviewed-on: https://go-review.googlesource.com/c/go/+/543255
Auto-Submit: Michael Knyszek <mknyszek@google.com>
LUCI-TryBot-Result: Go LUCI <golang-scoped@luci-project-accounts.iam.gserviceaccount.com>
Reviewed-by: Cherry Mui <cherryyz@google.com>
src/runtime/malloc.go
src/runtime/mbitmap_allocheaders.go
src/runtime/mfinal.go