Golang程序  |  58行  |  1.93 KB

// 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"},
}