]> Git Repo - binutils.git/blame - include/stab.def
Buying into ../include and ../libiberty.
[binutils.git] / include / stab.def
CommitLineData
61a153e5
RP
1/* Table of DBX symbol codes for the GNU system.
2 Copyright (C) 1988 Free Software Foundation, Inc.
3
4 This program is free software; you can redistribute it and/or modify
5 it under the terms of the GNU General Public License as published by
6 the Free Software Foundation; either version 1, or (at your option)
7 any later version.
8
9 This program is distributed in the hope that it will be useful,
10 but WITHOUT ANY WARRANTY; without even the implied warranty of
11 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 GNU General Public License for more details.
13
14 You should have received a copy of the GNU General Public License
15 along with this program; if not, write to the Free Software
16 Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. */
17\f
18/* Global variable. Only the name is significant.
19 To find the address, look in the corresponding external symbol. */
20__define_stab (N_GSYM, 0x20, "GSYM")
21
22/* Function name for BSD Fortran. Only the name is significant.
23 To find the address, look in the corresponding external symbol. */
24__define_stab (N_FNAME, 0x22, "FNAME")
25
26/* Function name or text-segment variable for C. Value is its address.
27 Desc is supposedly starting line number, but GCC doesn't set it
28 and DBX seems not to miss it. */
29__define_stab (N_FUN, 0x24, "FUN")
30
31/* Data-segment variable with internal linkage. Value is its address. */
32__define_stab (N_STSYM, 0x26, "STSYM")
33
34/* BSS-segment variable with internal linkage. Value is its address. */
35__define_stab (N_LCSYM, 0x28, "LCSYM")
36
37/* Name of main routine. Only the name is significant.
38 This is not used in C. */
39__define_stab (N_MAIN, 0x2a, "MAIN")
40
bad3df67
JG
41/* Number of symbols: 0, files,,funcs,lines according to Ultrix V4.0. */
42__define_stab (N_NSYMS, 0x32, "NSYMS")
43
44/* "No DST map for sym: name, ,0,type,ignored" according to Ultrix V4.0. */
45__define_stab (N_NOMAP, 0x34, "NOMAP")
46
61a153e5
RP
47/* Register variable. Value is number of register. */
48__define_stab (N_RSYM, 0x40, "RSYM")
49
50/* Structure or union element. Value is offset in the structure. */
51__define_stab (N_SSYM, 0x60, "SSYM")
52
53/* Parameter variable. Value is offset from argument pointer.
54 (On most machines the argument pointer is the same as the frame pointer. */
55__define_stab (N_PSYM, 0xa0, "PSYM")
56
57/* Automatic variable in the stack. Value is offset from frame pointer.
58 Also used for type descriptions. */
59__define_stab (N_LSYM, 0x80, "LSYM")
60
61/* Alternate entry point. Value is its address. */
62__define_stab (N_ENTRY, 0xa4, "ENTRY")
63
64/* Name of main source file.
65 Value is starting text address of the compilation. */
66__define_stab (N_SO, 0x64, "SO")
67
bad3df67 68/* Name of sub-source file (#include file).
61a153e5
RP
69 Value is starting text address of the compilation. */
70__define_stab (N_SOL, 0x84, "SOL")
71
72/* Line number in text segment. Desc is the line number;
73 value is corresponding address. */
74__define_stab (N_SLINE, 0x44, "SLINE")
75/* Similar, for data segment. */
76__define_stab (N_DSLINE, 0x66, "DSLINE")
77/* Similar, for bss segment. */
78__define_stab (N_BSLINE, 0x68, "BSLINE")
79
80/* Beginning of an include file. Only Sun uses this.
81 In an object file, only the name is significant.
82 The Sun linker puts data into some of the other fields. */
83__define_stab (N_BINCL, 0x82, "BINCL")
84/* End of an include file. No name.
85 These two act as brackets around the file's output.
86 In an object file, there is no significant data in this entry.
87 The Sun linker puts data into some of the fields. */
88__define_stab (N_EINCL, 0xa2, "EINCL")
89/* Place holder for deleted include file.
90 This appears only in output from the Sun linker. */
91__define_stab (N_EXCL, 0xc2, "EXCL")
92
93/* Beginning of lexical block.
94 The desc is the nesting level in lexical blocks.
95 The value is the address of the start of the text for the block.
96 The variables declared inside the block *precede* the N_LBRAC symbol. */
97__define_stab (N_LBRAC, 0xc0, "LBRAC")
98/* End of a lexical block. Desc matches the N_LBRAC's desc.
99 The value is the address of the end of the text for the block. */
100__define_stab (N_RBRAC, 0xe0, "RBRAC")
101
102/* Begin named common block. Only the name is significant. */
103__define_stab (N_BCOMM, 0xe2, "BCOMM")
104/* Begin named common block. Only the name is significant
105 (and it should match the N_BCOMM). */
106__define_stab (N_ECOMM, 0xe4, "ECOMM")
107/* End common (local name): value is address.
108 I'm not sure how this is used. */
109__define_stab (N_ECOML, 0xe8, "ECOML")
110/* Second symbol entry containing a length-value for the preceding entry.
111 The value is the length. */
112__define_stab (N_LENG, 0xfe, "LENG")
113
114/* Global symbol in Pascal.
115 Supposedly the value is its line number; I'm skeptical. */
116__define_stab (N_PC, 0x30, "PC")
117
118/* Modula-2 compilation unit. Can someone say what info it contains? */
119__define_stab (N_M2C, 0x42, "M2C")
120/* Modula-2 scope information. Can someone say what info it contains? */
121__define_stab (N_SCOPE, 0xc4, "SCOPE")
122
123/* Sun's source-code browser stabs. ?? Don't know what the fields are.
124 Supposedly the field is "path to associated .cb file". */
125__define_stab (N_BROWS, 0x48, "BROWS")
126
127/* GNU C++ exception stabs. */
128
bad3df67
JG
129/* THE FOLLOWING TWO STAB VALUES CONFLICT. Happily, one is for Modula-2
130 and one is for C++. Still,... */
61a153e5
RP
131/* GNU C++ exception variable. Name is variable name. */
132__define_stab (N_EHDECL, 0x50, "EHDECL")
bad3df67
JG
133/* Modula2 info "for imc": name,,0,0,0 according to Ultrix V4.0. */
134__define_stab (N_MOD2, 0x50, "MOD2")
135
61a153e5
RP
136
137/* GNU C++ `catch' clause. Value is its address. Desc is nonzero if
138 this entry is immediately followed by a CAUGHT stab saying what exception
139 was caught. Multiple CAUGHT stabs means that multiple exceptions
140 can be caught here. If Desc is 0, it means all exceptions are caught
141 here. */
142__define_stab (N_CATCH, 0x54, "CATCH")
143
144/* These STAB's are used on Gould systems for Non-Base register symbols
145 or something like that. FIXME. I have assigned the values at random
146 since I don't have a Gould here. Fixups from Gould folk welcome... */
147__define_stab (N_NBTEXT, 0xF0, "NBTEXT")
148__define_stab (N_NBDATA, 0xF2, "NBDATA")
149__define_stab (N_NBBSS, 0xF4, "NBBSS")
150__define_stab (N_NBSTS, 0xF6, "NBSTS")
151__define_stab (N_NBLCS, 0xF8, "NBLCS")
61a153e5
RP
152\f
153/* The above information, in matrix format.
154
155 STAB MATRIX
156 _________________________________________________
157 | 00 - 1F are not dbx stab symbols |
158 | Entries with bits 01 set are external symbols |
159 | N_UNDEF | N_ABS | N_TEXT | N_DATA |
160 | N_BSS | N_COMM | | N_FN |
161 |_______________________________________________|
162 | 20 GSYM | 22 FNAME | 24 FUN | 26 STSYM |
163 | 28 LCSYM | 2A MAIN | 2C | 2E |
bad3df67 164 | 30 PC | 32 NSYMS | 34 NOMAP | 36 |
61a153e5
RP
165 | 38 | 3A | 3C | 3E |
166 | 40 RSYM | 42 M2C | 44 SLINE | 46 |
167 | 48 BROWS | 4A | 4C | 4E |
bad3df67 168 | 50 EHDECL*| 52 | 54 CATCH | 56 |
61a153e5
RP
169 | 58 | 5A | 5C | 5E |
170 | 60 SSYM | 62 | 64 SO | 66 DSLINE |
171 | 68 BSLINE | 6A | 6C | 6E |
172 | 70 | 72 | 74 | 76 |
173 | 78 | 7A | 7C | 7E |
174 | 80 LSYM | 82 BINCL | 84 SOL | 86 |
175 | 88 | 8A | 8C | 8E |
176 | 90 | 92 | 94 | 96 |
177 | 98 | 9A | 9C | 9E |
178 | A0 PSYM | A2 EINCL | A4 ENTRY | A6 |
179 | A8 | AA | AC | AE |
180 | B0 | B2 | B4 | B6 |
181 | B8 | BA | BC | BE |
182 | C0 LBRAC | C2 EXCL | C4 SCOPE | C6 |
183 | C8 | CA | CC | CE |
184 | D0 | D2 | D4 | D6 |
185 | D8 | DA | DC | DE |
186 | E0 RBRAC | E2 BCOMM | E4 ECOMM | E6 |
187 | E8 ECOML | EA | EC | EE |
188 | F0 | F2 | F4 | F6 |
189 | F8 | FA | FC | FE LENG |
190 +-----------------------------------------------+
bad3df67 191 * 50 EHDECL is also MOD2.
61a153e5
RP
192
193*/
This page took 0.050778 seconds and 4 git commands to generate.