1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
|
/******************************************************************
Copyright 1990, 1992 Free Software Foundation, Inc.
This code was donated by Intel Corp.
Intel hereby grants you permission to copy, modify, and
distribute this software and its documentation. Intel grants
this permission provided that the above copyright notice
appears in all copies and that both the copyright notice and
this permission notice appear in supporting documentation. In
addition, Intel grants this permission provided that you
prominently mark as not part of the original any modifications
made to this software or documentation, and that the name of
Intel Corporation not be used in advertising or publicity
pertaining to distribution of the software or the documentation
without specific, written prior permission.
Intel Corporation does not warrant, guarantee or make any
representations regarding the use of, or the results of the use
of, the software and documentation in terms of correctness,
accuracy, reliability, currentness, or otherwise; and you rely
on the software, documentation and results solely at your own
risk. */
/******************************************************************/
/******************************************************************
*
* REASONS WHY NINDY CAN STOP EXECUTING AN APPLICATION PROGRAM
*
* When NINDY stops executing an application program that was running
* under remote host ("gdb") control, it signals the host by sending
* a single ^P. The host can then query as to the reason for the halt.
* NINDY responds with two bytes of information.
*
* The first byte is a boolean flag that indicates whether or not
* the application has exited.
*
* If the flag is true, the second byte contains the exit code.
*
* If the flag is false, the second byte contains a "reason for
* stopping" code. This file defines the possible values of that
* code.
*
* There are three categories of reasons why the halt may have occurred:
* faults, traces, and software interactions. The first two categories
* are processor-dependent; the values of these codes are tightly coupled
* to the hardware and should not be changed without first examining
* src/nindy/common/fault.c. The software interactions involve
* communication between NINDY and the host debugger; their codes are
* arbitrary.
*
******************************************************************/
#define FAULT_PARALLEL 0x00
#define FAULT_UNKNOWN 0x01
#define FAULT_OPERATION 0x02
#define FAULT_ARITH 0x03
#define FAULT_FP 0x04
#define FAULT_CONSTR 0x05
#define FAULT_VM 0x06
#define FAULT_PROTECT 0x07
#define FAULT_MACHINE 0x08
#define FAULT_STRUCT 0x09
#define FAULT_TYPE 0x0a
/* 0x0b reserved */
#define FAULT_PROCESS 0x0c
#define FAULT_DESC 0x0d
#define FAULT_EVENT 0x0e
/* 0x0f reserved */
#define LAST_FAULT 0x0f
#define TRACE_STEP 0x10
#define TRACE_BRANCH 0x11
#define TRACE_CALL 0x12
#define TRACE_RET 0x13
#define TRACE_PRERET 0x14
#define TRACE_SVC 0x15
#define TRACE_BKPT 0x16
#define STOP_SRQ 0xfe
/* Application program has service request to make of host */
#define STOP_GDB_BPT 0xff
/* Application program has reached breakpoint (fmark) set by host */
|