mirror of
https://github.com/golang/go.git
synced 2025-12-08 06:10:04 +00:00
runtime: rename m.gcing to m.preemptoff and make it a string
m.gcing has become overloaded to mean "don't preempt this g" in general. Once the garbage collector is preemptible, the one thing it *won't* mean is that we're in the garbage collector. So, rename gcing to "preemptoff" and make it a string giving a reason that preemption is disabled. gcing was never set to anything but 0 or 1, so we don't have to worry about there being a stack of reasons. Change-Id: I4337c29e8e942e7aa4f106fc29597e1b5de4ef46 Reviewed-on: https://go-review.googlesource.com/3660 Reviewed-by: Russ Cox <rsc@golang.org>
This commit is contained in:
parent
f95becaddb
commit
28b5118415
13 changed files with 36 additions and 32 deletions
|
|
@ -353,11 +353,14 @@ func gopanic(e interface{}) {
|
|||
print("\n")
|
||||
throw("panic during malloc")
|
||||
}
|
||||
if gp.m.gcing != 0 {
|
||||
if gp.m.preemptoff != "" {
|
||||
print("panic: ")
|
||||
printany(e)
|
||||
print("\n")
|
||||
throw("panic during gc")
|
||||
print("preempt off reason: ")
|
||||
print(gp.m.preemptoff)
|
||||
print("\n")
|
||||
throw("panic during preemptoff")
|
||||
}
|
||||
if gp.m.locks != 0 {
|
||||
print("panic: ")
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue