mirror of
https://github.com/golang/go
synced 2024-11-08 07:36:21 -07:00
runtime: execute memory barrier conditionally when changing netpoll timers
We only need the memory barrier in poll_runtime_pollSetDeadline only when one of the timers has fired, which is not the expected case. Memory barrier can be somewhat expensive on some archs, so execute it only if one of the timers has in fact fired. name old time/op new time/op delta TCP4OneShotTimeout-6 17.0µs ± 0% 17.1µs ± 0% +0.35% (p=0.032 n=5+5) SetReadDeadline-6 232ns ± 0% 230ns ± 0% -1.03% (p=0.000 n=4+5) Update #25729 Change-Id: Ifce6f505b9e7ba3717bad8f454077a2e94ea6e75 Reviewed-on: https://go-review.googlesource.com/c/146343 Reviewed-by: Ian Lance Taylor <iant@golang.org>
This commit is contained in:
parent
ff51353c38
commit
31e7842f3d
@ -254,6 +254,7 @@ func poll_runtime_pollSetDeadline(pd *pollDesc, d int64, mode int) {
|
|||||||
}
|
}
|
||||||
// If we set the new deadline in the past, unblock currently pending IO if any.
|
// If we set the new deadline in the past, unblock currently pending IO if any.
|
||||||
var rg, wg *g
|
var rg, wg *g
|
||||||
|
if pd.rd < 0 || pd.wd < 0 {
|
||||||
atomicstorep(unsafe.Pointer(&wg), nil) // full memory barrier between stores to rd/wd and load of rg/wg in netpollunblock
|
atomicstorep(unsafe.Pointer(&wg), nil) // full memory barrier between stores to rd/wd and load of rg/wg in netpollunblock
|
||||||
if pd.rd < 0 {
|
if pd.rd < 0 {
|
||||||
rg = netpollunblock(pd, 'r', false)
|
rg = netpollunblock(pd, 'r', false)
|
||||||
@ -261,6 +262,7 @@ func poll_runtime_pollSetDeadline(pd *pollDesc, d int64, mode int) {
|
|||||||
if pd.wd < 0 {
|
if pd.wd < 0 {
|
||||||
wg = netpollunblock(pd, 'w', false)
|
wg = netpollunblock(pd, 'w', false)
|
||||||
}
|
}
|
||||||
|
}
|
||||||
unlock(&pd.lock)
|
unlock(&pd.lock)
|
||||||
if rg != nil {
|
if rg != nil {
|
||||||
netpollgoready(rg, 3)
|
netpollgoready(rg, 3)
|
||||||
|
Loading…
Reference in New Issue
Block a user