| /* Table of DBX symbol codes for the GNU system. |
| Copyright (C) 1988-2021 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. |
| */ |