Commit 9be01c2e authored by Alex Brainman's avatar Alex Brainman

runtime: correct isAbortPC check in isgoexception

The expression passed into isAbortPC call was written specifically
for windows/amd64 and windows/386 runtime.abort implementation.
Adjust the code, so it also works for windows/arm.

Fixes #29050

Change-Id: I3dc8ddd08031f34115396429eff512827264826f
Reviewed-on: https://go-review.googlesource.com/c/152357Reviewed-by: default avatarIan Lance Taylor <iant@golang.org>
parent a7af4743
...@@ -38,6 +38,23 @@ func initExceptionHandler() { ...@@ -38,6 +38,23 @@ func initExceptionHandler() {
} }
} }
// isAbort returns true, if context r describes exception raised
// by calling runtime.abort function.
//
//go:nosplit
func isAbort(r *context) bool {
switch GOARCH {
case "386", "amd64":
// In the case of an abort, the exception IP is one byte after
// the INT3 (this differs from UNIX OSes).
return isAbortPC(r.ip() - 1)
case "arm":
return isAbortPC(r.ip())
default:
return false
}
}
// isgoexception reports whether this exception should be translated // isgoexception reports whether this exception should be translated
// into a Go panic. // into a Go panic.
// //
...@@ -53,9 +70,7 @@ func isgoexception(info *exceptionrecord, r *context) bool { ...@@ -53,9 +70,7 @@ func isgoexception(info *exceptionrecord, r *context) bool {
return false return false
} }
// In the case of an abort, the exception IP is one byte after if isAbort(r) {
// the INT3 (this differs from UNIX OSes).
if isAbortPC(r.ip() - 1) {
// Never turn abort into a panic. // Never turn abort into a panic.
return false return false
} }
......
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