xref: /dflybsd-src/contrib/gdb-7/include/aout/stab.def (revision 86d7f5d305c6adaa56ff4582ece9859d73106103)
1*86d7f5d3SJohn Marino/* Table of DBX symbol codes for the GNU system.
2*86d7f5d3SJohn Marino   Copyright 1988, 1991, 1992, 1993, 1994, 1996, 1998, 2004, 2010
3*86d7f5d3SJohn Marino   Free Software Foundation, Inc.
4*86d7f5d3SJohn Marino
5*86d7f5d3SJohn Marino   This program is free software; you can redistribute it and/or
6*86d7f5d3SJohn Marino   modify it under the terms of the GNU General Public License as
7*86d7f5d3SJohn Marino   published by the Free Software Foundation; either version 3 of the
8*86d7f5d3SJohn Marino   License, or (at your option) any later version.
9*86d7f5d3SJohn Marino
10*86d7f5d3SJohn Marino   This program is distributed in the hope that it will be useful,
11*86d7f5d3SJohn Marino   but WITHOUT ANY WARRANTY; without even the implied warranty of
12*86d7f5d3SJohn Marino   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13*86d7f5d3SJohn Marino   GNU General Public License for more details.
14*86d7f5d3SJohn Marino
15*86d7f5d3SJohn Marino   You should have received a copy of the GNU General Public License
16*86d7f5d3SJohn Marino   along with this program; if not, write to the Free Software
17*86d7f5d3SJohn Marino   Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston,
18*86d7f5d3SJohn Marino   MA 02110-1301, USA.  */
19*86d7f5d3SJohn Marino
20*86d7f5d3SJohn Marino/* New stab from Solaris 2.  This uses an n_type of 0, which in a.out files
21*86d7f5d3SJohn Marino   overlaps the N_UNDF used for ordinary symbols.  In ELF files, the
22*86d7f5d3SJohn Marino   debug information is in a different file section, so there is no conflict.
23*86d7f5d3SJohn Marino   This symbol's n_value gives the size of the string section associated
24*86d7f5d3SJohn Marino   with this file.  The symbol's n_strx (relative to the just-updated
25*86d7f5d3SJohn Marino   string section start address) gives the name of the source file,
26*86d7f5d3SJohn Marino   e.g. "foo.c", without any path information.  The symbol's n_desc gives
27*86d7f5d3SJohn Marino   the count of upcoming symbols associated with this file (not including
28*86d7f5d3SJohn Marino   this one).  */
29*86d7f5d3SJohn Marino/* __define_stab (N_UNDF, 0x00, "UNDF")  */
30*86d7f5d3SJohn Marino
31*86d7f5d3SJohn Marino/* Global variable.  Only the name is significant.
32*86d7f5d3SJohn Marino   To find the address, look in the corresponding external symbol.  */
33*86d7f5d3SJohn Marino__define_stab (N_GSYM, 0x20, "GSYM")
34*86d7f5d3SJohn Marino
35*86d7f5d3SJohn Marino/* Function name for BSD Fortran.  Only the name is significant.
36*86d7f5d3SJohn Marino   To find the address, look in the corresponding external symbol.  */
37*86d7f5d3SJohn Marino__define_stab (N_FNAME, 0x22, "FNAME")
38*86d7f5d3SJohn Marino
39*86d7f5d3SJohn Marino/* Function name or text-segment variable for C.  Value is its address.
40*86d7f5d3SJohn Marino   Desc is supposedly starting line number, but GCC doesn't set it
41*86d7f5d3SJohn Marino   and DBX seems not to miss it.  */
42*86d7f5d3SJohn Marino__define_stab (N_FUN, 0x24, "FUN")
43*86d7f5d3SJohn Marino
44*86d7f5d3SJohn Marino/* Data-segment variable with internal linkage.  Value is its address.
45*86d7f5d3SJohn Marino   "Static Sym".  */
46*86d7f5d3SJohn Marino__define_stab (N_STSYM, 0x26, "STSYM")
47*86d7f5d3SJohn Marino
48*86d7f5d3SJohn Marino/* BSS-segment variable with internal linkage.  Value is its address.  */
49*86d7f5d3SJohn Marino__define_stab (N_LCSYM, 0x28, "LCSYM")
50*86d7f5d3SJohn Marino
51*86d7f5d3SJohn Marino/* Name of main routine.  Only the name is significant.  */
52*86d7f5d3SJohn Marino__define_stab (N_MAIN, 0x2a, "MAIN")
53*86d7f5d3SJohn Marino
54*86d7f5d3SJohn Marino/* Solaris2:  Read-only data symbols.  */
55*86d7f5d3SJohn Marino__define_stab (N_ROSYM, 0x2c, "ROSYM")
56*86d7f5d3SJohn Marino
57*86d7f5d3SJohn Marino/* MacOS X:
58*86d7f5d3SJohn Marino   The beginning of a relocatable function block - including stabs.  */
59*86d7f5d3SJohn Marino__define_stab (N_BNSYM, 0x2e, "BNSYM")
60*86d7f5d3SJohn Marino
61*86d7f5d3SJohn Marino/* Global symbol in Pascal.
62*86d7f5d3SJohn Marino   Supposedly the value is its line number; I'm skeptical.  */
63*86d7f5d3SJohn Marino__define_stab (N_PC, 0x30, "PC")
64*86d7f5d3SJohn Marino
65*86d7f5d3SJohn Marino/* Number of symbols:  0, files,,funcs,lines according to Ultrix V4.0. */
66*86d7f5d3SJohn Marino__define_stab (N_NSYMS, 0x32, "NSYMS")
67*86d7f5d3SJohn Marino
68*86d7f5d3SJohn Marino/* "No DST map for sym: name, ,0,type,ignored"  according to Ultrix V4.0. */
69*86d7f5d3SJohn Marino__define_stab (N_NOMAP, 0x34, "NOMAP")
70*86d7f5d3SJohn Marino
71*86d7f5d3SJohn Marino/* New stab from Solaris 2.  Like N_SO, but for the object file.  Two in
72*86d7f5d3SJohn Marino   a row provide the build directory and the relative path of the .o from it.
73*86d7f5d3SJohn Marino   Solaris2 uses this to avoid putting the stabs info into the linked
74*86d7f5d3SJohn Marino   executable; this stab goes into the ".stab.index" section, and the debugger
75*86d7f5d3SJohn Marino   reads the real stabs directly from the .o files instead.  */
76*86d7f5d3SJohn Marino__define_stab (N_OBJ, 0x38, "OBJ")
77*86d7f5d3SJohn Marino
78*86d7f5d3SJohn Marino/* New stab from Solaris 2.  Options for the debugger, related to the
79*86d7f5d3SJohn Marino   source language for this module.  E.g. whether to use ANSI
80*86d7f5d3SJohn Marino   integral promotions or traditional integral promotions.  */
81*86d7f5d3SJohn Marino__define_stab (N_OPT, 0x3c, "OPT")
82*86d7f5d3SJohn Marino
83*86d7f5d3SJohn Marino/* Register variable.  Value is number of register.  */
84*86d7f5d3SJohn Marino__define_stab (N_RSYM, 0x40, "RSYM")
85*86d7f5d3SJohn Marino
86*86d7f5d3SJohn Marino/* Modula-2 compilation unit.  Can someone say what info it contains?  */
87*86d7f5d3SJohn Marino__define_stab (N_M2C, 0x42, "M2C")
88*86d7f5d3SJohn Marino
89*86d7f5d3SJohn Marino/* Line number in text segment.  Desc is the line number;
90*86d7f5d3SJohn Marino   value is corresponding address.  On Solaris2, the line number is
91*86d7f5d3SJohn Marino   relative to the start of the current function.  */
92*86d7f5d3SJohn Marino__define_stab (N_SLINE, 0x44, "SLINE")
93*86d7f5d3SJohn Marino
94*86d7f5d3SJohn Marino/* Similar, for data segment.  */
95*86d7f5d3SJohn Marino__define_stab (N_DSLINE, 0x46, "DSLINE")
96*86d7f5d3SJohn Marino
97*86d7f5d3SJohn Marino/* Similar, for bss segment.  */
98*86d7f5d3SJohn Marino__define_stab (N_BSLINE, 0x48, "BSLINE")
99*86d7f5d3SJohn Marino
100*86d7f5d3SJohn Marino/* Sun's source-code browser stabs.  ?? Don't know what the fields are.
101*86d7f5d3SJohn Marino   Supposedly the field is "path to associated .cb file".  THIS VALUE
102*86d7f5d3SJohn Marino   OVERLAPS WITH N_BSLINE!  */
103*86d7f5d3SJohn Marino__define_stab_duplicate (N_BROWS, 0x48, "BROWS")
104*86d7f5d3SJohn Marino
105*86d7f5d3SJohn Marino/* GNU Modula-2 definition module dependency.  Value is the modification time
106*86d7f5d3SJohn Marino   of the definition file.  Other is non-zero if it is imported with the
107*86d7f5d3SJohn Marino   GNU M2 keyword %INITIALIZE.  Perhaps N_M2C can be used if there
108*86d7f5d3SJohn Marino   are enough empty fields? */
109*86d7f5d3SJohn Marino__define_stab(N_DEFD, 0x4a, "DEFD")
110*86d7f5d3SJohn Marino
111*86d7f5d3SJohn Marino/* New in Solaris2.  Function start/body/end line numbers.  */
112*86d7f5d3SJohn Marino__define_stab(N_FLINE, 0x4C, "FLINE")
113*86d7f5d3SJohn Marino
114*86d7f5d3SJohn Marino/* MacOS X: This tells the end of a relocatable function + debugging info.  */
115*86d7f5d3SJohn Marino__define_stab(N_ENSYM, 0x4E, "ENSYM")
116*86d7f5d3SJohn Marino
117*86d7f5d3SJohn Marino/* THE FOLLOWING TWO STAB VALUES CONFLICT.  Happily, one is for Modula-2
118*86d7f5d3SJohn Marino   and one is for C++.   Still,... */
119*86d7f5d3SJohn Marino/* GNU C++ exception variable.  Name is variable name.  */
120*86d7f5d3SJohn Marino__define_stab (N_EHDECL, 0x50, "EHDECL")
121*86d7f5d3SJohn Marino/* Modula2 info "for imc":  name,,0,0,0  according to Ultrix V4.0.  */
122*86d7f5d3SJohn Marino__define_stab_duplicate (N_MOD2, 0x50, "MOD2")
123*86d7f5d3SJohn Marino
124*86d7f5d3SJohn Marino/* GNU C++ `catch' clause.  Value is its address.  Desc is nonzero if
125*86d7f5d3SJohn Marino   this entry is immediately followed by a CAUGHT stab saying what exception
126*86d7f5d3SJohn Marino   was caught.  Multiple CAUGHT stabs means that multiple exceptions
127*86d7f5d3SJohn Marino   can be caught here.  If Desc is 0, it means all exceptions are caught
128*86d7f5d3SJohn Marino   here.  */
129*86d7f5d3SJohn Marino__define_stab (N_CATCH, 0x54, "CATCH")
130*86d7f5d3SJohn Marino
131*86d7f5d3SJohn Marino/* Structure or union element.  Value is offset in the structure.  */
132*86d7f5d3SJohn Marino__define_stab (N_SSYM, 0x60, "SSYM")
133*86d7f5d3SJohn Marino
134*86d7f5d3SJohn Marino/* Solaris2:  Last stab emitted for module.  */
135*86d7f5d3SJohn Marino__define_stab (N_ENDM, 0x62, "ENDM")
136*86d7f5d3SJohn Marino
137*86d7f5d3SJohn Marino/* Name of main source file.
138*86d7f5d3SJohn Marino   Value is starting text address of the compilation.
139*86d7f5d3SJohn Marino   If multiple N_SO's appear, the first to contain a trailing / is the
140*86d7f5d3SJohn Marino   compilation directory.  The first to not contain a trailing / is the
141*86d7f5d3SJohn Marino   source file name, relative to the compilation directory.  Others (perhaps
142*86d7f5d3SJohn Marino   resulting from cfront) are ignored.
143*86d7f5d3SJohn Marino   On Solaris2, value is undefined, but desc is a source-language code.  */
144*86d7f5d3SJohn Marino
145*86d7f5d3SJohn Marino__define_stab (N_SO, 0x64, "SO")
146*86d7f5d3SJohn Marino
147*86d7f5d3SJohn Marino/* Apple:  This is the stab that associated the .o file with the
148*86d7f5d3SJohn Marino   N_SO stab, in the case where debug info is mostly stored in the .o file.  */
149*86d7f5d3SJohn Marino__define_stab (N_OSO, 0x66, "OSO")
150*86d7f5d3SJohn Marino
151*86d7f5d3SJohn Marino/* SunPro F77:  Name of alias.  */
152*86d7f5d3SJohn Marino__define_stab (N_ALIAS, 0x6c, "ALIAS")
153*86d7f5d3SJohn Marino
154*86d7f5d3SJohn Marino/* Automatic variable in the stack.  Value is offset from frame pointer.
155*86d7f5d3SJohn Marino   Also used for type descriptions.  */
156*86d7f5d3SJohn Marino__define_stab (N_LSYM, 0x80, "LSYM")
157*86d7f5d3SJohn Marino
158*86d7f5d3SJohn Marino/* Beginning of an include file.  Only Sun uses this.
159*86d7f5d3SJohn Marino   In an object file, only the name is significant.
160*86d7f5d3SJohn Marino   The Sun linker puts data into some of the other fields.  */
161*86d7f5d3SJohn Marino__define_stab (N_BINCL, 0x82, "BINCL")
162*86d7f5d3SJohn Marino
163*86d7f5d3SJohn Marino/* Name of sub-source file (#include file).
164*86d7f5d3SJohn Marino   Value is starting text address of the compilation.  */
165*86d7f5d3SJohn Marino__define_stab (N_SOL, 0x84, "SOL")
166*86d7f5d3SJohn Marino
167*86d7f5d3SJohn Marino/* Parameter variable.  Value is offset from argument pointer.
168*86d7f5d3SJohn Marino   (On most machines the argument pointer is the same as the frame pointer.  */
169*86d7f5d3SJohn Marino__define_stab (N_PSYM, 0xa0, "PSYM")
170*86d7f5d3SJohn Marino
171*86d7f5d3SJohn Marino/* End of an include file.  No name.
172*86d7f5d3SJohn Marino   This and N_BINCL act as brackets around the file's output.
173*86d7f5d3SJohn Marino   In an object file, there is no significant data in this entry.
174*86d7f5d3SJohn Marino   The Sun linker puts data into some of the fields.  */
175*86d7f5d3SJohn Marino__define_stab (N_EINCL, 0xa2, "EINCL")
176*86d7f5d3SJohn Marino
177*86d7f5d3SJohn Marino/* Alternate entry point.  Value is its address.  */
178*86d7f5d3SJohn Marino__define_stab (N_ENTRY, 0xa4, "ENTRY")
179*86d7f5d3SJohn Marino
180*86d7f5d3SJohn Marino/* Beginning of lexical block.
181*86d7f5d3SJohn Marino   The desc is the nesting level in lexical blocks.
182*86d7f5d3SJohn Marino   The value is the address of the start of the text for the block.
183*86d7f5d3SJohn Marino   The variables declared inside the block *precede* the N_LBRAC symbol.
184*86d7f5d3SJohn Marino   On Solaris2, the value is relative to the start of the current function.  */
185*86d7f5d3SJohn Marino__define_stab (N_LBRAC, 0xc0, "LBRAC")
186*86d7f5d3SJohn Marino
187*86d7f5d3SJohn Marino/* Place holder for deleted include file.  Replaces a N_BINCL and everything
188*86d7f5d3SJohn Marino   up to the corresponding N_EINCL.  The Sun linker generates these when
189*86d7f5d3SJohn Marino   it finds multiple identical copies of the symbols from an include file.
190*86d7f5d3SJohn Marino   This appears only in output from the Sun linker.  */
191*86d7f5d3SJohn Marino__define_stab (N_EXCL, 0xc2, "EXCL")
192*86d7f5d3SJohn Marino
193*86d7f5d3SJohn Marino/* Modula-2 scope information.  Can someone say what info it contains?  */
194*86d7f5d3SJohn Marino__define_stab (N_SCOPE, 0xc4, "SCOPE")
195*86d7f5d3SJohn Marino
196*86d7f5d3SJohn Marino/* Solaris2: Patch Run Time Checker.  */
197*86d7f5d3SJohn Marino__define_stab (N_PATCH, 0xd0, "PATCH")
198*86d7f5d3SJohn Marino
199*86d7f5d3SJohn Marino/* End of a lexical block.  Desc matches the N_LBRAC's desc.
200*86d7f5d3SJohn Marino   The value is the address of the end of the text for the block.
201*86d7f5d3SJohn Marino   On Solaris2, the value is relative to the start of the current function.  */
202*86d7f5d3SJohn Marino__define_stab (N_RBRAC, 0xe0, "RBRAC")
203*86d7f5d3SJohn Marino
204*86d7f5d3SJohn Marino/* Begin named common block.  Only the name is significant.  */
205*86d7f5d3SJohn Marino__define_stab (N_BCOMM, 0xe2, "BCOMM")
206*86d7f5d3SJohn Marino
207*86d7f5d3SJohn Marino/* End named common block.  Only the name is significant
208*86d7f5d3SJohn Marino   (and it should match the N_BCOMM).  */
209*86d7f5d3SJohn Marino__define_stab (N_ECOMM, 0xe4, "ECOMM")
210*86d7f5d3SJohn Marino
211*86d7f5d3SJohn Marino/* Member of a common block; value is offset within the common block.
212*86d7f5d3SJohn Marino   This should occur within a BCOMM/ECOMM pair.  */
213*86d7f5d3SJohn Marino__define_stab (N_ECOML, 0xe8, "ECOML")
214*86d7f5d3SJohn Marino
215*86d7f5d3SJohn Marino/* Solaris2: Pascal "with" statement: type,,0,0,offset */
216*86d7f5d3SJohn Marino__define_stab (N_WITH, 0xea, "WITH")
217*86d7f5d3SJohn Marino
218*86d7f5d3SJohn Marino/* These STAB's are used on Gould systems for Non-Base register symbols
219*86d7f5d3SJohn Marino   or something like that.  FIXME.  I have assigned the values at random
220*86d7f5d3SJohn Marino   since I don't have a Gould here.  Fixups from Gould folk welcome... */
221*86d7f5d3SJohn Marino__define_stab (N_NBTEXT, 0xF0, "NBTEXT")
222*86d7f5d3SJohn Marino__define_stab (N_NBDATA, 0xF2, "NBDATA")
223*86d7f5d3SJohn Marino__define_stab (N_NBBSS,  0xF4, "NBBSS")
224*86d7f5d3SJohn Marino__define_stab (N_NBSTS,  0xF6, "NBSTS")
225*86d7f5d3SJohn Marino__define_stab (N_NBLCS,  0xF8, "NBLCS")
226*86d7f5d3SJohn Marino
227*86d7f5d3SJohn Marino/* Second symbol entry containing a length-value for the preceding entry.
228*86d7f5d3SJohn Marino   The value is the length.  */
229*86d7f5d3SJohn Marino__define_stab (N_LENG, 0xfe, "LENG")
230*86d7f5d3SJohn Marino
231*86d7f5d3SJohn Marino/* The above information, in matrix format.
232*86d7f5d3SJohn Marino
233*86d7f5d3SJohn Marino			STAB MATRIX
234*86d7f5d3SJohn Marino	_________________________________________________
235*86d7f5d3SJohn Marino	| 00 - 1F are not dbx stab symbols		|
236*86d7f5d3SJohn Marino	| In most cases, the low bit is the EXTernal bit|
237*86d7f5d3SJohn Marino
238*86d7f5d3SJohn Marino	| 00 UNDEF  | 02 ABS	| 04 TEXT   | 06 DATA	|
239*86d7f5d3SJohn Marino	| 01  |EXT  | 03  |EXT	| 05  |EXT  | 07  |EXT	|
240*86d7f5d3SJohn Marino
241*86d7f5d3SJohn Marino	| 08 BSS    | 0A INDR	| 0C FN_SEQ | 0E WEAKA	|
242*86d7f5d3SJohn Marino	| 09  |EXT  | 0B 	| 0D WEAKU  | 0F WEAKT	|
243*86d7f5d3SJohn Marino
244*86d7f5d3SJohn Marino	| 10 WEAKD  | 12 COMM	| 14 SETA   | 16 SETT	|
245*86d7f5d3SJohn Marino	| 11 WEAKB  | 13	| 15 	    | 17	|
246*86d7f5d3SJohn Marino
247*86d7f5d3SJohn Marino	| 18 SETD   | 1A SETB	| 1C SETV   | 1E WARNING|
248*86d7f5d3SJohn Marino	| 19	    | 1B	| 1D 	    | 1F FN	|
249*86d7f5d3SJohn Marino
250*86d7f5d3SJohn Marino	|_______________________________________________|
251*86d7f5d3SJohn Marino	| Debug entries with bit 01 set are unused.	|
252*86d7f5d3SJohn Marino	| 20 GSYM   | 22 FNAME	| 24 FUN    | 26 STSYM	|
253*86d7f5d3SJohn Marino	| 28 LCSYM  | 2A MAIN	| 2C ROSYM  | 2E	|
254*86d7f5d3SJohn Marino	| 30 PC	    | 32 NSYMS	| 34 NOMAP  | 36	|
255*86d7f5d3SJohn Marino	| 38 OBJ    | 3A	| 3C OPT    | 3E	|
256*86d7f5d3SJohn Marino	| 40 RSYM   | 42 M2C	| 44 SLINE  | 46 DSLINE |
257*86d7f5d3SJohn Marino	| 48 BSLINE*| 4A DEFD	| 4C FLINE  | 4E	|
258*86d7f5d3SJohn Marino	| 50 EHDECL*| 52	| 54 CATCH  | 56        |
259*86d7f5d3SJohn Marino	| 58        | 5A        | 5C        | 5E	|
260*86d7f5d3SJohn Marino	| 60 SSYM   | 62 ENDM	| 64 SO	    | 66 	|
261*86d7f5d3SJohn Marino	| 68 	    | 6A	| 6C ALIAS  | 6E	|
262*86d7f5d3SJohn Marino	| 70	    | 72	| 74	    | 76	|
263*86d7f5d3SJohn Marino	| 78	    | 7A	| 7C	    | 7E	|
264*86d7f5d3SJohn Marino	| 80 LSYM   | 82 BINCL	| 84 SOL    | 86	|
265*86d7f5d3SJohn Marino	| 88	    | 8A	| 8C	    | 8E	|
266*86d7f5d3SJohn Marino	| 90	    | 92	| 94	    | 96	|
267*86d7f5d3SJohn Marino	| 98	    | 9A	| 9C	    | 9E	|
268*86d7f5d3SJohn Marino	| A0 PSYM   | A2 EINCL	| A4 ENTRY  | A6	|
269*86d7f5d3SJohn Marino	| A8	    | AA	| AC	    | AE	|
270*86d7f5d3SJohn Marino	| B0	    | B2	| B4	    | B6	|
271*86d7f5d3SJohn Marino	| B8	    | BA	| BC	    | BE	|
272*86d7f5d3SJohn Marino	| C0 LBRAC  | C2 EXCL	| C4 SCOPE  | C6	|
273*86d7f5d3SJohn Marino	| C8	    | CA	| CC	    | CE	|
274*86d7f5d3SJohn Marino	| D0 PATCH  | D2	| D4	    | D6	|
275*86d7f5d3SJohn Marino	| D8	    | DA	| DC	    | DE	|
276*86d7f5d3SJohn Marino	| E0 RBRAC  | E2 BCOMM	| E4 ECOMM  | E6	|
277*86d7f5d3SJohn Marino	| E8 ECOML  | EA WITH	| EC	    | EE	|
278*86d7f5d3SJohn Marino	| F0	    | F2	| F4	    | F6	|
279*86d7f5d3SJohn Marino	| F8	    | FA	| FC	    | FE LENG	|
280*86d7f5d3SJohn Marino	+-----------------------------------------------+
281*86d7f5d3SJohn Marino * 50 EHDECL is also MOD2.
282*86d7f5d3SJohn Marino * 48 BSLINE is also BROWS.
283*86d7f5d3SJohn Marino */
284