Commit 1956b28a authored by Clément Chigot's avatar Clément Chigot Committed by Ian Lance Taylor

runtime: call atomic.Storeuintptr in noteclear on AIX

The memory might not be synchronized in a thread being woken up after a
semasleep. Using atomic instructions in noteclear function will force
this synchronisation.

Fixes #30189

Change-Id: If7432f29b2a1a56288231822db52f3f8d1d6dbfe
Reviewed-on: https://go-review.googlesource.com/c/go/+/163624
Run-TryBot: Ian Lance Taylor <iant@golang.org>
TryBot-Result: Gobot Gobot <gobot@golang.org>
Reviewed-by: default avatarIan Lance Taylor <iant@golang.org>
parent 46e03c4b
...@@ -122,7 +122,13 @@ func unlock(l *mutex) { ...@@ -122,7 +122,13 @@ func unlock(l *mutex) {
// One-time notifications. // One-time notifications.
func noteclear(n *note) { func noteclear(n *note) {
n.key = 0 if GOOS == "aix" {
// On AIX, semaphores might not synchronize the memory in some
// rare cases. See issue #30189.
atomic.Storeuintptr(&n.key, 0)
} else {
n.key = 0
}
} }
func notewakeup(n *note) { func notewakeup(n *note) {
......
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