OSDN Git Service

* real.c (toe64): Remove stale #endif from the last change.
[pf3gnuchains/gcc-fork.git] / gcc / xcoffout.h
index 9c38fc5..5e912be 100644 (file)
@@ -1,5 +1,24 @@
 /* XCOFF definitions.  These are needed in dbxout.c, final.c,
-   and xcoffout.h.  */
+   and xcoffout.h. 
+   Copyright (C) 1998, 2000 Free Software Foundation, Inc.
+
+This file is part of GNU CC.
+
+GNU CC 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 2, or (at your option)
+any later version.
+
+GNU CC 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 GNU CC; see the file COPYING.  If not, write to
+the Free Software Foundation, 59 Temple Place - Suite 330,
+Boston, MA 02111-1307, USA.  */
+
 
 #define ASM_STABS_OP ".stabx"
 
 
 #define DBX_STATIC_CONST_VAR_CODE N_STSYM
 
-/* For static variables, output code to define the start of a static block.  */
+/* For static variables, output code to define the start of a static block.
+
+   ??? The IBM rs6000/AIX assembler has a bug that causes bss block debug
+   info to be occasionally lost.  A simple example is this:
+       int a; static int b;
+   The commands `gcc -g -c tmp.c; dump -t tmp.o' gives
+[10]   m   0x00000016         1     0    0x8f  0x0000            .bs
+[11]   m   0x00000000         1     0    0x90  0x0000            .es
+...
+[21]   m   0x00000000        -2     0    0x85  0x0000            b:S-1
+   which is wrong.  The `b:S-1' must be between the `.bs' and `.es'.
+   We can apparently work around the problem by forcing the text section
+   (even if we are already in the text section) immediately before outputting
+   the `.bs'.  This should be fixed in the next major AIX release (3.3?).  */
 
 #define DBX_STATIC_BLOCK_START(ASMFILE,CODE)                           \
 {                                                                      \
   if ((CODE) == N_STSYM)                                               \
     fprintf ((ASMFILE), "\t.bs\t%s[RW]\n", xcoff_private_data_section_name);\
   else if ((CODE) == N_LCSYM)                                          \
-    fprintf ((ASMFILE), "\t.bs\t%s\n", xcoff_bss_section_name);                \
+    {                                                                  \
+      fprintf ((ASMFILE), "%s\n", TEXT_SECTION_ASM_OP);                        \
+      fprintf ((ASMFILE), "\t.bs\t%s\n", xcoff_bss_section_name);      \
+    }                                                                  \
 }
 
 /* For static variables, output code to define the end of a static block.  */
 
 #define DBX_STATIC_BLOCK_END(ASMFILE,CODE)                             \
 {                                                                      \
-  if (current_sym_code == N_STSYM || current_sym_code == N_LCSYM)      \
-    fprintf (asmfile, "\t.es\n");                                      \
+  if ((CODE) == N_STSYM || (CODE) == N_LCSYM)                          \
+    fputs ("\t.es\n", (ASMFILE));                                      \
 }
 
 /* We must use N_RPYSM instead of N_RSYM for register parameters.  */
   if (current_sym_addr && current_sym_code == N_FUN            \
       && GET_CODE (current_sym_addr) == SYMBOL_REF)            \
     {                                                          \
-      char *_p;                                                        \
-      for (_p = XSTR (current_sym_addr, 0); *_p != '[' && *_p; _p++) \
-       fprintf (asmfile, "%c", *_p);                           \
+      const char *_p = XSTR (current_sym_addr, 0);             \
+      if (*_p == '*')                                          \
+       fprintf (asmfile, "%s", _p+1);                          \
+      else                                                     \
+        for (; *_p != '[' && *_p; _p++)                                \
+         fprintf (asmfile, "%c", *_p);                         \
     }                                                          \
   else if (current_sym_addr)                                   \
     output_addr_const (asmfile, current_sym_addr);             \
   else if (current_sym_code == N_GSYM)                         \
-    fprintf (asmfile, "%s", IDENTIFIER_POINTER (DECL_ASSEMBLER_NAME (SYM))); \
+    assemble_name (asmfile, XSTR (XEXP (DECL_RTL (sym), 0), 0)); \
   else                                                         \
     fprintf (asmfile, "%d", current_sym_value);                        \
   fprintf (asmfile, ",%d,0\n", stab_to_sclass (current_sym_code)); \
 #define N_RPSYM 0x8e
 #endif
 
-/* The line number of the beginning of the current function.
-   xcoffout.c needs this so that it can output relative linenumbers.  */
-
-extern int xcoff_begin_function_line;
-
 /* Name of the current include file.  */
 
 extern char *xcoff_current_include_file;
 
-/* Name of the current function file.  This is the file the `.bf' is
-   emitted from.  In case a line is emitted from a different file,
-   (by including that file of course), then the line number will be
-   absolute.  */
-
-extern char *xcoff_current_function_file;
-
 /* Names of bss and data sections.  These should be unique names for each
    compilation unit.  */
 
@@ -119,46 +145,29 @@ extern char *xcoff_bss_section_name;
 extern char *xcoff_private_data_section_name;
 extern char *xcoff_read_only_section_name;
 
+/* Last source file name mentioned in a NOTE insn.  */
+
+extern char *xcoff_lastfile;
+
 /* Don't write out path name for main source file.  */
 #define DBX_OUTPUT_MAIN_SOURCE_DIRECTORY(FILE,FILENAME)
 
-/* Write out main source file name using ".file" rather than ".stabs".  */
+/* Write out main source file name using ".file" rather than ".stabs".
+   We don't actually do this here, because the assembler gets confused if there
+   is more than one .file directive.  ASM_FILE_START in config/rs6000/rs6000.h
+   is already emitting a .file directory, so we don't output one here also.
+   Initialize xcoff_lastfile.  */
 #define DBX_OUTPUT_MAIN_SOURCE_FILENAME(FILE,FILENAME) \
-  fprintf (FILE, "\t.file\t\"%s\"\n", FILENAME);
-
-#define ABS_OR_RELATIVE_LINENO(LINENO)         \
-((xcoff_current_include_file                   \
-  && xcoff_current_include_file != xcoff_current_function_file)        \
- ? (LINENO) : (LINENO) - xcoff_begin_function_line)
-
-/* Output source line numbers via ".line" rather than ".stabd".  */
-#define ASM_OUTPUT_SOURCE_LINE(FILE,LINENUM) \
-  do {                                         \
-    if (xcoff_begin_function_line >= 0)                \
-      fprintf (FILE, "\t.line\t%d\n", ABS_OR_RELATIVE_LINENO (LINENUM)); \
-  } while (0)
-
-/* We don't want to emit source file names in dbx style. */
-#define DBX_OUTPUT_SOURCE_FILENAME(FILE, FILENAME)     \
-{                                                      \
-  if (xcoff_current_include_file)                      \
-    fprintf (FILE, "\t.ei\t\"%s\"\n", xcoff_current_include_file);\
-  if (strcmp (main_input_filename, FILENAME))          \
-    {                                                  \
-      fprintf (FILE, "\t.bi\t\"%s\"\n", FILENAME);     \
-      xcoff_current_include_file = FILENAME;           \
-    }                                                  \
-  else                                                 \
-    xcoff_current_include_file = NULL;                 \
-}
+  xcoff_lastfile = (FILENAME)
 
 /* If we are still in an include file, its end must be marked.  */
 #define DBX_OUTPUT_MAIN_SOURCE_FILE_END(FILE, FILENAME)        \
 {                                                      \
   if (xcoff_current_include_file)                      \
     {                                                  \
-      fprintf ((FILE), "\t.ei\t\"%s\"\n",              \
-              xcoff_current_include_file);             \
+      fputs ("\t.ei\t", (FILE));                       \
+      output_quoted_string ((FILE), xcoff_current_include_file);       \
+      putc ('\n', (FILE));                             \
       xcoff_current_include_file = NULL;               \
     }                                                  \
 }
@@ -176,3 +185,27 @@ extern char *xcoff_read_only_section_name;
    can't find them.  */
 
 #define DEBUG_SYMS_TEXT
+
+/* Prototype functions in xcoffout.c. */
+
+extern int stab_to_sclass                      PARAMS ((int));
+#ifdef BUFSIZ
+extern void xcoffout_begin_function            PARAMS ((FILE *, int));
+extern void xcoffout_begin_block               PARAMS ((FILE *, int, int));
+extern void xcoffout_end_epilogue              PARAMS ((FILE *));
+extern void xcoffout_end_function              PARAMS ((FILE *, int));
+extern void xcoffout_end_block                 PARAMS ((FILE *, int, int));
+#endif /* BUFSIZ */
+
+#ifdef TREE_CODE
+extern void xcoff_output_standard_types                PARAMS ((tree));
+#ifdef BUFSIZ
+extern void xcoffout_declare_function          PARAMS ((FILE *, tree, char *));
+#endif /* BUFSIZ */
+#endif /* TREE_CODE */
+
+#ifdef RTX_CODE
+#ifdef BUFSIZ
+extern void xcoffout_source_line               PARAMS ((FILE *, char *, rtx));
+#endif /* BUFSIZ */
+#endif /* RTX_CODE */