Commit 37715cce authored by Cherry Zhang's avatar Cherry Zhang

runtime: relax TestAsyncPreempt

In TestAsyncPreempt, the function being tested for preemption,
although still asynchronously preemptible, may have only samll
ranges of PCs that are preemtible. In an unlucky run, it may
take quite a while to have a signal that lands on a preemptible
instruction. The test case is kind of an extreme. Relax it to
make it more preemptible.

In the original version, the first closure has more work to do,
and it is not a leaf function, and the second test case is a
frameless leaf function. In the current version, the first one
is also a frameless leaf function (the atomic is intrinsified).
Add some calls to it. It is still not preemptible without async
preemption.

Fixes #35608.

Change-Id: Ia4f857f2afc55501c6568d7507b517e3b4db191c
Reviewed-on: https://go-review.googlesource.com/c/go/+/208221
Run-TryBot: Cherry Zhang <cherryyz@google.com>
Reviewed-by: default avatarBrad Fitzpatrick <bradfitz@golang.org>
TryBot-Result: Gobot Gobot <gobot@golang.org>
parent c7e73ef6
...@@ -26,6 +26,8 @@ func AsyncPreempt() { ...@@ -26,6 +26,8 @@ func AsyncPreempt() {
go func() { go func() {
for { for {
atomic.StoreUint32(&ready, 1) atomic.StoreUint32(&ready, 1)
dummy()
dummy()
} }
}() }()
// Also start one with a frameless function. // Also start one with a frameless function.
...@@ -53,8 +55,11 @@ func AsyncPreempt() { ...@@ -53,8 +55,11 @@ func AsyncPreempt() {
//go:noinline //go:noinline
func frameless() { func frameless() {
for i := int64(0); i < 1<<62; i++ { for i := int64(0); i < 1<<62; i++ {
out += i out += i * i * i * i * i * 12345
} }
} }
var out int64 var out int64
//go:noinline
func dummy() {}
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