mirror of
https://github.com/golang/go.git
synced 2025-12-08 06:10:04 +00:00
runtime: throw if the runtime panics with out of bounds index
If the runtime code panics due to a bad index or slice expression, then throw instead of panicing. This will skip calls to recover and dump the entire runtime stack trace. The runtime should never panic due to an out of bounds index, and this will help with debugging if it does. For #24991 Updates #25201 Change-Id: I85a9feded8f0de914ee1558425931853223c0514 Reviewed-on: https://go-review.googlesource.com/121515 Reviewed-by: Austin Clements <austin@google.com>
This commit is contained in:
parent
955cc07dde
commit
f43aa1df70
3 changed files with 59 additions and 0 deletions
|
|
@ -23,7 +23,23 @@ func panicCheckMalloc(err error) {
|
|||
|
||||
var indexError = error(errorString("index out of range"))
|
||||
|
||||
// The panicindex, panicslice, and panicdivide functions are called by
|
||||
// code generated by the compiler for out of bounds index expressions,
|
||||
// out of bounds slice expressions, and division by zero. The
|
||||
// panicdivide (again), panicoverflow, panicfloat, and panicmem
|
||||
// functions are called by the signal handler when a signal occurs
|
||||
// indicating the respective problem.
|
||||
//
|
||||
// Since panicindex and panicslice are never called directly, and
|
||||
// since the runtime package should never have an out of bounds slice
|
||||
// or array reference, if we see those functions called from the
|
||||
// runtime package we turn the panic into a throw. That will dump the
|
||||
// entire runtime stack for easier debugging.
|
||||
|
||||
func panicindex() {
|
||||
if hasprefix(funcname(findfunc(getcallerpc())), "runtime.") {
|
||||
throw(string(indexError.(errorString)))
|
||||
}
|
||||
panicCheckMalloc(indexError)
|
||||
panic(indexError)
|
||||
}
|
||||
|
|
@ -31,6 +47,9 @@ func panicindex() {
|
|||
var sliceError = error(errorString("slice bounds out of range"))
|
||||
|
||||
func panicslice() {
|
||||
if hasprefix(funcname(findfunc(getcallerpc())), "runtime.") {
|
||||
throw(string(sliceError.(errorString)))
|
||||
}
|
||||
panicCheckMalloc(sliceError)
|
||||
panic(sliceError)
|
||||
}
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue