// Copyright 2011 The Go Authors. All rights reserved.
// Use of this source code is governed by a BSD-style
// license that can be found in the LICENSE file.
package runtime
type sigTabT struct {
flags int
name string
}
// Incoming notes are compared against this table using strncmp, so the
// order matters: longer patterns must appear before their prefixes.
// There are _SIG constants in os2_plan9.go for the table index of some
// of these.
//
// If you add entries to this table, you must respect the prefix ordering
// and also update the constant values is os2_plan9.go.
var sigtable = [...]sigTabT{
// Traps that we cannot be recovered.
{_SigThrow, "sys: trap: debug exception"},
{_SigThrow, "sys: trap: invalid opcode"},
// We can recover from some memory errors in runtime·sigpanic.
{_SigPanic, "sys: trap: fault read"}, // SIGRFAULT
{_SigPanic, "sys: trap: fault write"}, // SIGWFAULT
// We can also recover from math errors.
{_SigPanic, "sys: trap: divide error"}, // SIGINTDIV
{_SigPanic, "sys: fp:"}, // SIGFLOAT
// All other traps are normally handled as if they were marked SigThrow.
// We mark them SigPanic here so that debug.SetPanicOnFault will work.
{_SigPanic, "sys: trap:"}, // SIGTRAP
// Writes to a closed pipe can be handled if desired, otherwise they're ignored.
{_SigNotify, "sys: write on closed pipe"},
// Other system notes are more serious and cannot be recovered.
{_SigThrow, "sys:"},
// Issued to all other procs when calling runtime·exit.
{_SigGoExit, "go: exit "},
// Kill is sent by external programs to cause an exit.
{_SigKill, "kill"},
// Interrupts can be handled if desired, otherwise they cause an exit.
{_SigNotify + _SigKill, "interrupt"},
{_SigNotify + _SigKill, "hangup"},
// Alarms can be handled if desired, otherwise they're ignored.
{_SigNotify, "alarm"},
// Aborts can be handled if desired, otherwise they cause a stack trace.
{_SigNotify + _SigThrow, "abort"},
}