mirror of
https://github.com/golang/go
synced 2024-11-23 20:00:04 -07:00
runtime: add scavenge -> traceBuf to lock partial order
Under the scavenge lock it's possible to ready a goroutine (or now injectglist, which has mostly the same effect) which could cause an unpark trace event to be emitted. If there's no active trace buffer for the P, then we might acquire the lock. The total order between the two is correct, but there's no partial order edge between them. Add in the edge. Change-Id: I3fc5d86a3b6bdd0b5648181fb76b5ebc90c3d69f Reviewed-on: https://go-review.googlesource.com/c/go/+/231197 Run-TryBot: Michael Knyszek <mknyszek@google.com> TryBot-Result: Gobot Gobot <gobot@golang.org> Reviewed-by: Dan Scales <danscales@google.com>
This commit is contained in:
parent
2491c5fd24
commit
0f8fecaba7
@ -201,7 +201,7 @@ var lockPartialOrder [][]lockRank = [][]lockRank{
|
||||
lockRankHchan: {lockRankScavenge, lockRankSweep, lockRankHchan},
|
||||
lockRankFin: {lockRankSched, lockRankAllg, lockRankTimers, lockRankHchan},
|
||||
lockRankNotifyList: {},
|
||||
lockRankTraceBuf: {},
|
||||
lockRankTraceBuf: {lockRankScavenge},
|
||||
lockRankTraceStrings: {lockRankTraceBuf},
|
||||
lockRankMspanSpecial: {lockRankScavenge, lockRankCpuprof, lockRankSched, lockRankAllg, lockRankAllp, lockRankTimers, lockRankItab, lockRankReflectOffs, lockRankHchan, lockRankNotifyList, lockRankTraceBuf, lockRankTraceStrings},
|
||||
lockRankProf: {lockRankScavenge, lockRankAssistQueue, lockRankCpuprof, lockRankSweep, lockRankSched, lockRankAllg, lockRankAllp, lockRankTimers, lockRankItab, lockRankReflectOffs, lockRankNotifyList, lockRankTraceBuf, lockRankTraceStrings, lockRankHchan},
|
||||
|
Loading…
Reference in New Issue
Block a user