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