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