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