mirror of
https://github.com/golang/go.git
synced 2025-05-05 23:53:05 +00:00
cmd/compile: ensure we don't reuse temporary register
Before this CL, we could use the same register for both a temporary register and for moving a value in the output register out of the way. Fixes #71857 Change-Id: Iefbfd9d4139136174570d8aadf8a0fb391791ea9 Reviewed-on: https://go-review.googlesource.com/c/go/+/651221 Reviewed-by: David Chase <drchase@google.com> LUCI-TryBot-Result: Go LUCI <golang-scoped@luci-project-accounts.iam.gserviceaccount.com> Reviewed-by: Keith Randall <khr@google.com>
This commit is contained in:
parent
1e92ff11f5
commit
cc16fb52e6
@ -1677,6 +1677,7 @@ func (s *regAllocState) regalloc(f *Func) {
|
|||||||
}
|
}
|
||||||
tmpReg = s.allocReg(m, &tmpVal)
|
tmpReg = s.allocReg(m, &tmpVal)
|
||||||
s.nospill |= regMask(1) << tmpReg
|
s.nospill |= regMask(1) << tmpReg
|
||||||
|
s.tmpused |= regMask(1) << tmpReg
|
||||||
}
|
}
|
||||||
|
|
||||||
// Now that all args are in regs, we're ready to issue the value itself.
|
// Now that all args are in regs, we're ready to issue the value itself.
|
||||||
|
29
test/fixedbugs/issue71857.go
Normal file
29
test/fixedbugs/issue71857.go
Normal file
@ -0,0 +1,29 @@
|
|||||||
|
// run
|
||||||
|
|
||||||
|
// Copyright 2025 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 "sync/atomic"
|
||||||
|
|
||||||
|
//go:noinline
|
||||||
|
func f(p0, p1, p2, p3, p4, p5, p6, p7 *uint64, a *atomic.Uint64) {
|
||||||
|
old := a.Or(0xaaa)
|
||||||
|
*p0 = old
|
||||||
|
*p1 = old
|
||||||
|
*p2 = old
|
||||||
|
*p3 = old
|
||||||
|
*p4 = old
|
||||||
|
*p5 = old
|
||||||
|
*p6 = old
|
||||||
|
*p7 = old
|
||||||
|
}
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
a := new(atomic.Uint64)
|
||||||
|
p := new(uint64)
|
||||||
|
f(p, p, p, p, p, p, p, p, a)
|
||||||
|
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user