| /* Table of DBX symbol codes for the GNU system. | 
 |    Copyright (C) 1988-2015 Free Software Foundation, Inc. | 
 |  | 
 |    This program is free software; you can redistribute it and/or | 
 |    modify it under the terms of the GNU General Public License as | 
 |    published by the Free Software Foundation; either version 3 of the | 
 |    License, or (at your option) any later version. | 
 |  | 
 |    This program is distributed in the hope that it will be useful, | 
 |    but WITHOUT ANY WARRANTY; without even the implied warranty of | 
 |    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 
 |    GNU General Public License for more details. | 
 |  | 
 |    You should have received a copy of the GNU General Public License | 
 |    along with this program; if not, write to the Free Software | 
 |    Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston, | 
 |    MA 02110-1301, USA.  */ | 
 |  | 
 | /* New stab from Solaris 2.  This uses an n_type of 0, which in a.out files | 
 |    overlaps the N_UNDF used for ordinary symbols.  In ELF files, the | 
 |    debug information is in a different file section, so there is no conflict. | 
 |    This symbol's n_value gives the size of the string section associated | 
 |    with this file.  The symbol's n_strx (relative to the just-updated | 
 |    string section start address) gives the name of the source file, | 
 |    e.g. "foo.c", without any path information.  The symbol's n_desc gives | 
 |    the count of upcoming symbols associated with this file (not including | 
 |    this one).  */ | 
 | /* __define_stab (N_UNDF, 0x00, "UNDF")  */ | 
 |  | 
 | /* Global variable.  Only the name is significant. | 
 |    To find the address, look in the corresponding external symbol.  */ | 
 | __define_stab (N_GSYM, 0x20, "GSYM") | 
 |  | 
 | /* Function name for BSD Fortran.  Only the name is significant. | 
 |    To find the address, look in the corresponding external symbol.  */ | 
 | __define_stab (N_FNAME, 0x22, "FNAME") | 
 |  | 
 | /* Function name or text-segment variable for C.  Value is its address. | 
 |    Desc is supposedly starting line number, but GCC doesn't set it | 
 |    and DBX seems not to miss it.  */ | 
 | __define_stab (N_FUN, 0x24, "FUN") | 
 |  | 
 | /* Data-segment variable with internal linkage.  Value is its address. | 
 |    "Static Sym".  */ | 
 | __define_stab (N_STSYM, 0x26, "STSYM") | 
 |  | 
 | /* BSS-segment variable with internal linkage.  Value is its address.  */ | 
 | __define_stab (N_LCSYM, 0x28, "LCSYM") | 
 |  | 
 | /* Name of main routine.  Only the name is significant.  */ | 
 | __define_stab (N_MAIN, 0x2a, "MAIN") | 
 |  | 
 | /* Solaris2:  Read-only data symbols.  */ | 
 | __define_stab (N_ROSYM, 0x2c, "ROSYM") | 
 |  | 
 | /* MacOS X: | 
 |    The beginning of a relocatable function block - including stabs.  */ | 
 | __define_stab (N_BNSYM, 0x2e, "BNSYM") | 
 |  | 
 | /* Global symbol in Pascal. | 
 |    Supposedly the value is its line number; I'm skeptical.  */ | 
 | __define_stab (N_PC, 0x30, "PC") | 
 |  | 
 | /* Number of symbols:  0, files,,funcs,lines according to Ultrix V4.0. */ | 
 | __define_stab (N_NSYMS, 0x32, "NSYMS") | 
 |  | 
 | /* "No DST map for sym: name, ,0,type,ignored"  according to Ultrix V4.0. */ | 
 | __define_stab (N_NOMAP, 0x34, "NOMAP") | 
 |  | 
 | /* New stab from Solaris 2.  Like N_SO, but for the object file.  Two in | 
 |    a row provide the build directory and the relative path of the .o from it. | 
 |    Solaris2 uses this to avoid putting the stabs info into the linked | 
 |    executable; this stab goes into the ".stab.index" section, and the debugger | 
 |    reads the real stabs directly from the .o files instead.  */ | 
 | __define_stab (N_OBJ, 0x38, "OBJ") | 
 |  | 
 | /* New stab from Solaris 2.  Options for the debugger, related to the | 
 |    source language for this module.  E.g. whether to use ANSI | 
 |    integral promotions or traditional integral promotions.  */ | 
 | __define_stab (N_OPT, 0x3c, "OPT") | 
 |  | 
 | /* Register variable.  Value is number of register.  */ | 
 | __define_stab (N_RSYM, 0x40, "RSYM") | 
 |  | 
 | /* Modula-2 compilation unit.  Can someone say what info it contains?  */ | 
 | __define_stab (N_M2C, 0x42, "M2C") | 
 |  | 
 | /* Line number in text segment.  Desc is the line number; | 
 |    value is corresponding address.  On Solaris2, the line number is | 
 |    relative to the start of the current function.  */ | 
 | __define_stab (N_SLINE, 0x44, "SLINE") | 
 |  | 
 | /* Similar, for data segment.  */ | 
 | __define_stab (N_DSLINE, 0x46, "DSLINE") | 
 |  | 
 | /* Similar, for bss segment.  */ | 
 | __define_stab (N_BSLINE, 0x48, "BSLINE") | 
 |  | 
 | /* Sun's source-code browser stabs.  ?? Don't know what the fields are. | 
 |    Supposedly the field is "path to associated .cb file".  THIS VALUE | 
 |    OVERLAPS WITH N_BSLINE!  */ | 
 | __define_stab_duplicate (N_BROWS, 0x48, "BROWS") | 
 |  | 
 | /* GNU Modula-2 definition module dependency.  Value is the modification time | 
 |    of the definition file.  Other is non-zero if it is imported with the | 
 |    GNU M2 keyword %INITIALIZE.  Perhaps N_M2C can be used if there | 
 |    are enough empty fields? */ | 
 | __define_stab(N_DEFD, 0x4a, "DEFD") | 
 |  | 
 | /* New in Solaris2.  Function start/body/end line numbers.  */ | 
 | __define_stab(N_FLINE, 0x4C, "FLINE") | 
 |  | 
 | /* MacOS X: This tells the end of a relocatable function + debugging info.  */ | 
 | __define_stab(N_ENSYM, 0x4E, "ENSYM") | 
 |  | 
 | /* THE FOLLOWING TWO STAB VALUES CONFLICT.  Happily, one is for Modula-2 | 
 |    and one is for C++.   Still,... */ | 
 | /* GNU C++ exception variable.  Name is variable name.  */ | 
 | __define_stab (N_EHDECL, 0x50, "EHDECL") | 
 | /* Modula2 info "for imc":  name,,0,0,0  according to Ultrix V4.0.  */ | 
 | __define_stab_duplicate (N_MOD2, 0x50, "MOD2") | 
 |  | 
 | /* GNU C++ `catch' clause.  Value is its address.  Desc is nonzero if | 
 |    this entry is immediately followed by a CAUGHT stab saying what exception | 
 |    was caught.  Multiple CAUGHT stabs means that multiple exceptions | 
 |    can be caught here.  If Desc is 0, it means all exceptions are caught | 
 |    here.  */ | 
 | __define_stab (N_CATCH, 0x54, "CATCH") | 
 |  | 
 | /* Structure or union element.  Value is offset in the structure.  */ | 
 | __define_stab (N_SSYM, 0x60, "SSYM") | 
 |  | 
 | /* Solaris2:  Last stab emitted for module.  */ | 
 | __define_stab (N_ENDM, 0x62, "ENDM") | 
 |  | 
 | /* Name of main source file. | 
 |    Value is starting text address of the compilation. | 
 |    If multiple N_SO's appear, the first to contain a trailing / is the | 
 |    compilation directory.  The first to not contain a trailing / is the | 
 |    source file name, relative to the compilation directory.  Others (perhaps | 
 |    resulting from cfront) are ignored. | 
 |    On Solaris2, value is undefined, but desc is a source-language code.  */ | 
 |  | 
 | __define_stab (N_SO, 0x64, "SO") | 
 |  | 
 | /* Apple:  This is the stab that associated the .o file with the | 
 |    N_SO stab, in the case where debug info is mostly stored in the .o file.  */ | 
 | __define_stab (N_OSO, 0x66, "OSO") | 
 |  | 
 | /* SunPro F77:  Name of alias.  */ | 
 | __define_stab (N_ALIAS, 0x6c, "ALIAS") | 
 |  | 
 | /* Automatic variable in the stack.  Value is offset from frame pointer. | 
 |    Also used for type descriptions.  */ | 
 | __define_stab (N_LSYM, 0x80, "LSYM") | 
 |  | 
 | /* Beginning of an include file.  Only Sun uses this. | 
 |    In an object file, only the name is significant. | 
 |    The Sun linker puts data into some of the other fields.  */ | 
 | __define_stab (N_BINCL, 0x82, "BINCL") | 
 |  | 
 | /* Name of sub-source file (#include file). | 
 |    Value is starting text address of the compilation.  */ | 
 | __define_stab (N_SOL, 0x84, "SOL") | 
 |  | 
 | /* Parameter variable.  Value is offset from argument pointer. | 
 |    (On most machines the argument pointer is the same as the frame pointer.  */ | 
 | __define_stab (N_PSYM, 0xa0, "PSYM") | 
 |  | 
 | /* End of an include file.  No name. | 
 |    This and N_BINCL act as brackets around the file's output. | 
 |    In an object file, there is no significant data in this entry. | 
 |    The Sun linker puts data into some of the fields.  */ | 
 | __define_stab (N_EINCL, 0xa2, "EINCL") | 
 |  | 
 | /* Alternate entry point.  Value is its address.  */ | 
 | __define_stab (N_ENTRY, 0xa4, "ENTRY") | 
 |  | 
 | /* Beginning of lexical block. | 
 |    The desc is the nesting level in lexical blocks. | 
 |    The value is the address of the start of the text for the block. | 
 |    The variables declared inside the block *precede* the N_LBRAC symbol. | 
 |    On Solaris2, the value is relative to the start of the current function.  */ | 
 | __define_stab (N_LBRAC, 0xc0, "LBRAC") | 
 |  | 
 | /* Place holder for deleted include file.  Replaces a N_BINCL and everything | 
 |    up to the corresponding N_EINCL.  The Sun linker generates these when | 
 |    it finds multiple identical copies of the symbols from an include file. | 
 |    This appears only in output from the Sun linker.  */ | 
 | __define_stab (N_EXCL, 0xc2, "EXCL") | 
 |  | 
 | /* Modula-2 scope information.  Can someone say what info it contains?  */ | 
 | __define_stab (N_SCOPE, 0xc4, "SCOPE") | 
 |  | 
 | /* Solaris2: Patch Run Time Checker.  */ | 
 | __define_stab (N_PATCH, 0xd0, "PATCH") | 
 |  | 
 | /* End of a lexical block.  Desc matches the N_LBRAC's desc. | 
 |    The value is the address of the end of the text for the block. | 
 |    On Solaris2, the value is relative to the start of the current function.  */ | 
 | __define_stab (N_RBRAC, 0xe0, "RBRAC") | 
 |  | 
 | /* Begin named common block.  Only the name is significant.  */ | 
 | __define_stab (N_BCOMM, 0xe2, "BCOMM") | 
 |  | 
 | /* End named common block.  Only the name is significant | 
 |    (and it should match the N_BCOMM).  */ | 
 | __define_stab (N_ECOMM, 0xe4, "ECOMM") | 
 |  | 
 | /* Member of a common block; value is offset within the common block. | 
 |    This should occur within a BCOMM/ECOMM pair.  */ | 
 | __define_stab (N_ECOML, 0xe8, "ECOML") | 
 |  | 
 | /* Solaris2: Pascal "with" statement: type,,0,0,offset */ | 
 | __define_stab (N_WITH, 0xea, "WITH") | 
 |  | 
 | /* These STAB's are used on Gould systems for Non-Base register symbols | 
 |    or something like that.  FIXME.  I have assigned the values at random | 
 |    since I don't have a Gould here.  Fixups from Gould folk welcome... */ | 
 | __define_stab (N_NBTEXT, 0xF0, "NBTEXT") | 
 | __define_stab (N_NBDATA, 0xF2, "NBDATA") | 
 | __define_stab (N_NBBSS,  0xF4, "NBBSS") | 
 | __define_stab (N_NBSTS,  0xF6, "NBSTS") | 
 | __define_stab (N_NBLCS,  0xF8, "NBLCS") | 
 |  | 
 | /* Second symbol entry containing a length-value for the preceding entry. | 
 |    The value is the length.  */ | 
 | __define_stab (N_LENG, 0xfe, "LENG") | 
 |  | 
 | /* The above information, in matrix format. | 
 |  | 
 | 			STAB MATRIX | 
 | 	_________________________________________________ | 
 | 	| 00 - 1F are not dbx stab symbols		| | 
 | 	| In most cases, the low bit is the EXTernal bit| | 
 |  | 
 | 	| 00 UNDEF  | 02 ABS	| 04 TEXT   | 06 DATA	| | 
 | 	| 01  |EXT  | 03  |EXT	| 05  |EXT  | 07  |EXT	| | 
 |  | 
 | 	| 08 BSS    | 0A INDR	| 0C FN_SEQ | 0E WEAKA	| | 
 | 	| 09  |EXT  | 0B 	| 0D WEAKU  | 0F WEAKT	| | 
 |  | 
 | 	| 10 WEAKD  | 12 COMM	| 14 SETA   | 16 SETT	| | 
 | 	| 11 WEAKB  | 13	| 15 	    | 17	| | 
 |  | 
 | 	| 18 SETD   | 1A SETB	| 1C SETV   | 1E WARNING| | 
 | 	| 19	    | 1B	| 1D 	    | 1F FN	| | 
 |  | 
 | 	|_______________________________________________| | 
 | 	| Debug entries with bit 01 set are unused.	| | 
 | 	| 20 GSYM   | 22 FNAME	| 24 FUN    | 26 STSYM	| | 
 | 	| 28 LCSYM  | 2A MAIN	| 2C ROSYM  | 2E	| | 
 | 	| 30 PC	    | 32 NSYMS	| 34 NOMAP  | 36	| | 
 | 	| 38 OBJ    | 3A	| 3C OPT    | 3E	| | 
 | 	| 40 RSYM   | 42 M2C	| 44 SLINE  | 46 DSLINE | | 
 | 	| 48 BSLINE*| 4A DEFD	| 4C FLINE  | 4E	| | 
 | 	| 50 EHDECL*| 52	| 54 CATCH  | 56        | | 
 | 	| 58        | 5A        | 5C        | 5E	| | 
 | 	| 60 SSYM   | 62 ENDM	| 64 SO	    | 66 	| | 
 | 	| 68 	    | 6A	| 6C ALIAS  | 6E	| | 
 | 	| 70	    | 72	| 74	    | 76	| | 
 | 	| 78	    | 7A	| 7C	    | 7E	| | 
 | 	| 80 LSYM   | 82 BINCL	| 84 SOL    | 86	| | 
 | 	| 88	    | 8A	| 8C	    | 8E	| | 
 | 	| 90	    | 92	| 94	    | 96	| | 
 | 	| 98	    | 9A	| 9C	    | 9E	| | 
 | 	| A0 PSYM   | A2 EINCL	| A4 ENTRY  | A6	| | 
 | 	| A8	    | AA	| AC	    | AE	| | 
 | 	| B0	    | B2	| B4	    | B6	| | 
 | 	| B8	    | BA	| BC	    | BE	| | 
 | 	| C0 LBRAC  | C2 EXCL	| C4 SCOPE  | C6	| | 
 | 	| C8	    | CA	| CC	    | CE	| | 
 | 	| D0 PATCH  | D2	| D4	    | D6	| | 
 | 	| D8	    | DA	| DC	    | DE	| | 
 | 	| E0 RBRAC  | E2 BCOMM	| E4 ECOMM  | E6	| | 
 | 	| E8 ECOML  | EA WITH	| EC	    | EE	| | 
 | 	| F0	    | F2	| F4	    | F6	| | 
 | 	| F8	    | FA	| FC	    | FE LENG	| | 
 | 	+-----------------------------------------------+ | 
 |  * 50 EHDECL is also MOD2. | 
 |  * 48 BSLINE is also BROWS. | 
 |  */ |