Annotation of GNUtools/cc/xcoffout.h, revision 1.1.1.1

1.1       root        1: /* XCOFF definitions.  These are needed in dbxout.c, final.c,
                      2:    and xcoffout.h.  */
                      3: 
                      4: #define ASM_STABS_OP ".stabx"
                      5: 
                      6: /* Tags and typedefs are C_DECL in XCOFF, not C_LSYM.  */
                      7: 
                      8: #define DBX_TYPE_DECL_STABS_CODE N_DECL
                      9: 
                     10: /* Use the XCOFF predefined type numbers.  */
                     11: 
                     12: /* ??? According to metin, typedef stabx must go in text control section,
                     13:    but he did not make this changes everywhere where such typedef stabx
                     14:    can be emitted, so it is really needed or not?  */
                     15: 
                     16: #define DBX_OUTPUT_STANDARD_TYPES(SYMS)                \
                     17: {                                              \
                     18:   text_section ();                             \
                     19:   xcoff_output_standard_types (SYMS);          \
                     20: }
                     21: 
                     22: /* Any type with a negative type index has already been output.  */
                     23: 
                     24: #define DBX_TYPE_DEFINED(TYPE) (TYPE_SYMTAB_ADDRESS (TYPE) < 0)
                     25: 
                     26: /* Must use N_STSYM for static const variables (those in the text section)
                     27:    instead of N_FUN.  */
                     28: 
                     29: #define DBX_STATIC_CONST_VAR_CODE N_STSYM
                     30: 
                     31: /* For static variables, output code to define the start of a static block.
                     32: 
                     33:    ??? The IBM rs6000/AIX assembler has a bug that causes bss block debug
                     34:    info to be occasionally lost.  A simple example is this:
                     35:        int a; static int b;
                     36:    The commands `gcc -g -c tmp.c; dump -t tmp.o' gives
                     37: [10]   m   0x00000016         1     0    0x8f  0x0000            .bs
                     38: [11]   m   0x00000000         1     0    0x90  0x0000            .es
                     39: ...
                     40: [21]   m   0x00000000        -2     0    0x85  0x0000            b:S-1
                     41:    which is wrong.  The `b:S-1' must be between the `.bs' and `.es'.
                     42:    We can apparently work around the problem by forcing the text section
                     43:    (even if we are already in the text section) immediately before outputting
                     44:    the `.bs'.  This should be fixed in the next major AIX release (3.3?).  */
                     45: 
                     46: #define DBX_STATIC_BLOCK_START(ASMFILE,CODE)                           \
                     47: {                                                                      \
                     48:   if ((CODE) == N_STSYM)                                               \
                     49:     fprintf ((ASMFILE), "\t.bs\t%s[RW]\n", xcoff_private_data_section_name);\
                     50:   else if ((CODE) == N_LCSYM)                                          \
                     51:     {                                                                  \
                     52:       fprintf ((ASMFILE), "%s\n", TEXT_SECTION_ASM_OP);                        \
                     53:       fprintf ((ASMFILE), "\t.bs\t%s\n", xcoff_bss_section_name);      \
                     54:     }                                                                  \
                     55: }
                     56: 
                     57: /* For static variables, output code to define the end of a static block.  */
                     58: 
                     59: #define DBX_STATIC_BLOCK_END(ASMFILE,CODE)                             \
                     60: {                                                                      \
                     61:   if (current_sym_code == N_STSYM || current_sym_code == N_LCSYM)      \
                     62:     fprintf (asmfile, "\t.es\n");                                      \
                     63: }
                     64: 
                     65: /* We must use N_RPYSM instead of N_RSYM for register parameters.  */
                     66: 
                     67: #define DBX_REGPARM_STABS_CODE N_RPSYM
                     68: 
                     69: /* We must use 'R' instead of 'P' for register parameters.  */
                     70: 
                     71: #define DBX_REGPARM_STABS_LETTER 'R'
                     72: 
                     73: /* Define our own finish symbol function, since xcoff stabs have their
                     74:    own different format.  */
                     75: 
                     76: #define DBX_FINISH_SYMBOL(SYM)                                 \
                     77: {                                                              \
                     78:   if (current_sym_addr && current_sym_code == N_FUN)           \
                     79:     fprintf (asmfile, "\",.");                                 \
                     80:   else                                                         \
                     81:     fprintf (asmfile, "\",");                                  \
                     82:   /* If we are writing a function name, we must ensure that    \
                     83:      there is no storage-class suffix on the name.  */         \
                     84:   if (current_sym_addr && current_sym_code == N_FUN            \
                     85:       && GET_CODE (current_sym_addr) == SYMBOL_REF)            \
                     86:     {                                                          \
                     87:       char *_p;                                                        \
                     88:       for (_p = XSTR (current_sym_addr, 0); *_p != '[' && *_p; _p++) \
                     89:        fprintf (asmfile, "%c", *_p);                           \
                     90:     }                                                          \
                     91:   else if (current_sym_addr)                                   \
                     92:     output_addr_const (asmfile, current_sym_addr);             \
                     93:   else if (current_sym_code == N_GSYM)                         \
                     94:     fprintf (asmfile, "%s", IDENTIFIER_POINTER (DECL_ASSEMBLER_NAME (SYM))); \
                     95:   else                                                         \
                     96:     fprintf (asmfile, "%d", current_sym_value);                        \
                     97:   fprintf (asmfile, ",%d,0\n", stab_to_sclass (current_sym_code)); \
                     98: }
                     99: 
                    100: /* These are IBM XCOFF extensions we need to reference in dbxout.c
                    101:    and xcoffout.c.  */
                    102: 
                    103: /* AIX XCOFF uses this for typedefs.  This can have any value, since it is
                    104:    only used for translation into a C_DECL storage class.  */
                    105: #ifndef N_DECL
                    106: #define N_DECL 0x8c
                    107: #endif
                    108: /* AIX XCOFF uses this for parameters passed in registers.  This can have
                    109:    any value, since it is only used for translation into a C_RPSYM storage
                    110:    class.  */
                    111: #ifndef N_RPSYM
                    112: #define N_RPSYM 0x8e
                    113: #endif
                    114: 
                    115: /* The line number of the beginning of the current function.
                    116:    xcoffout.c needs this so that it can output relative linenumbers.  */
                    117: 
                    118: extern int xcoff_begin_function_line;
                    119: 
                    120: /* Name of the current include file.  */
                    121: 
                    122: extern char *xcoff_current_include_file;
                    123: 
                    124: /* Name of the current function file.  This is the file the `.bf' is
                    125:    emitted from.  In case a line is emitted from a different file,
                    126:    (by including that file of course), then the line number will be
                    127:    absolute.  */
                    128: 
                    129: extern char *xcoff_current_function_file;
                    130: 
                    131: /* Names of bss and data sections.  These should be unique names for each
                    132:    compilation unit.  */
                    133: 
                    134: extern char *xcoff_bss_section_name;
                    135: extern char *xcoff_private_data_section_name;
                    136: extern char *xcoff_read_only_section_name;
                    137: 
                    138: /* Don't write out path name for main source file.  */
                    139: #define DBX_OUTPUT_MAIN_SOURCE_DIRECTORY(FILE,FILENAME)
                    140: 
                    141: /* Write out main source file name using ".file" rather than ".stabs".  */
                    142: #define DBX_OUTPUT_MAIN_SOURCE_FILENAME(FILE,FILENAME) \
                    143:   do {                                         \
                    144:     fprintf (FILE, "\t.file\t", FILENAME);     \
                    145:     output_quoted_string (FILE, FILENAME);     \
                    146:     fprintf (FILE, "\n");                      \
                    147:   } while (0)
                    148: 
                    149: #define ABS_OR_RELATIVE_LINENO(LINENO)         \
                    150: ((xcoff_current_include_file                   \
                    151:   && xcoff_current_include_file != xcoff_current_function_file)        \
                    152:  ? (LINENO) : (LINENO) - xcoff_begin_function_line)
                    153: 
                    154: /* Output source line numbers via ".line" rather than ".stabd".  */
                    155: #define ASM_OUTPUT_SOURCE_LINE(FILE,LINENUM) \
                    156:   do {                                         \
                    157:     if (xcoff_begin_function_line >= 0)                \
                    158:       fprintf (FILE, "\t.line\t%d\n", ABS_OR_RELATIVE_LINENO (LINENUM)); \
                    159:   } while (0)
                    160: 
                    161: /* We don't want to emit source file names in dbx style. */
                    162: #define DBX_OUTPUT_SOURCE_FILENAME(FILE, FILENAME)     \
                    163: {                                                      \
                    164:   if (xcoff_current_include_file)                      \
                    165:     {                                                  \
                    166:       fprintf (FILE, "\t.ei\t");                       \
                    167:       output_quoted_string (FILE, xcoff_current_include_file); \
                    168:       fprintf (FILE, "\n");                            \
                    169:     }                                                  \
                    170:   if (strcmp (main_input_filename, FILENAME))          \
                    171:     {                                                  \
                    172:       fprintf (FILE, "\t.bi\t");                       \
                    173:       output_quoted_string (FILE, FILENAME);           \
                    174:       fprintf (FILE, "\n");                            \
                    175:       xcoff_current_include_file = FILENAME;           \
                    176:     }                                                  \
                    177:   else                                                 \
                    178:     xcoff_current_include_file = NULL;                 \
                    179: }
                    180: 
                    181: /* If we are still in an include file, its end must be marked.  */
                    182: #define DBX_OUTPUT_MAIN_SOURCE_FILE_END(FILE, FILENAME)        \
                    183: {                                                      \
                    184:   if (xcoff_current_include_file)                      \
                    185:     {                                                  \
                    186:       fprintf (FILE, "\t.ei\t");                       \
                    187:       output_quoted_string (FILE, xcoff_current_include_file); \
                    188:       fprintf (FILE, "\n");                            \
                    189:       xcoff_current_include_file = NULL;               \
                    190:     }                                                  \
                    191: }
                    192: 
                    193: /* Do not break .stabs pseudos into continuations.  */
                    194: #define DBX_CONTIN_LENGTH 0
                    195: 
                    196: /* Don't try to use the `x' type-cross-reference character in DBX data.
                    197:    Also has the consequence of putting each struct, union or enum
                    198:    into a separate .stabs, containing only cross-refs to the others.  */
                    199: #define DBX_NO_XREFS
                    200: 
                    201: /* We must put stabs in the text section.  If we don't the assembler
                    202:    won't handle them correctly; it will sometimes put stabs where gdb
                    203:    can't find them.  */
                    204: 
                    205: #define DEBUG_SYMS_TEXT

unix.superglobalmegacorp.com

This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.