* config/pa/xm-hppah.h (HPPA_COMPILER_BUG): Delete. GDB only
authorAndrew Cagney <cagney@redhat.com>
Fri, 23 Mar 2001 00:41:02 +0000 (00:41 +0000)
committerAndrew Cagney <cagney@redhat.com>
Fri, 23 Mar 2001 00:41:02 +0000 (00:41 +0000)
compiles using an ISO-C compiler.
(MALLOC_INCOMPATIBLE): Ditto.
* linespec.c (decode_line_1): Delete hack to work around
HPPA_COMPILER_BUG.

gdb/ChangeLog
gdb/config/pa/xm-hppah.h
gdb/linespec.c

index 84d19b072e9a7b053659acd794dc35f182e8483d..5ad26d3ddf71dde59a20e7980e2a52a0885d2e97 100644 (file)
@@ -1,3 +1,11 @@
+2001-03-22  Andrew Cagney  <ac131313@redhat.com>
+
+       * config/pa/xm-hppah.h (HPPA_COMPILER_BUG): Delete. GDB only
+       compiles using an ISO-C compiler.
+       (MALLOC_INCOMPATIBLE): Ditto.
+       * linespec.c (decode_line_1): Delete hack to work around
+       HPPA_COMPILER_BUG.
+
 2001-03-22  Andrew Cagney  <ac131313@redhat.com>
 
        * exec.c (xfer_memory): Always initialize section.
index 497d2a738b05d4cd472aab9921d99f09244265eb..796b17af24cfae5e18e35ca34bd08decd11204f1 100644 (file)
 
 #define USG
 
-#ifndef __STDC__
-/* This define is discussed in decode_line_1 in symtab.c  */
-#define HPPA_COMPILER_BUG
-#endif
-
 #define HAVE_TERMIOS
 
 /* HP defines malloc and realloc as returning void *, even for non-ANSI
index f78751b943aa9a243ed6af8a2a3c0d02aa00b9f9..35f225cf2da0062ebf0bff1246eb7cdd5c0b78c1 100644 (file)
@@ -459,36 +459,7 @@ decode_line_1 (char **argptr, int funfirstline, struct symtab *default_symtab,
               int default_line, char ***canonical)
 {
   struct symtabs_and_lines values;
-#ifdef HPPA_COMPILER_BUG
-  /* FIXME: The native HP 9000/700 compiler has a bug which appears
-     when optimizing this file with target i960-vxworks.  I haven't
-     been able to construct a simple test case.  The problem is that
-     in the second call to SKIP_PROLOGUE below, the compiler somehow
-     does not realize that the statement val = find_pc_line (...) will
-     change the values of the fields of val.  It extracts the elements
-     into registers at the top of the block, and does not update the
-     registers after the call to find_pc_line.  You can check this by
-     inserting a printf at the end of find_pc_line to show what values
-     it is returning for val.pc and val.end and another printf after
-     the call to see what values the function actually got (remember,
-     this is compiling with cc -O, with this patch removed).  You can
-     also examine the assembly listing: search for the second call to
-     skip_prologue; the LDO statement before the next call to
-     find_pc_line loads the address of the structure which
-     find_pc_line will return; if there is a LDW just before the LDO,
-     which fetches an element of the structure, then the compiler
-     still has the bug.
-
-     Setting val to volatile avoids the problem.  We must undef
-     volatile, because the HPPA native compiler does not define
-     __STDC__, although it does understand volatile, and so volatile
-     will have been defined away in defs.h.  */
-#undef volatile
-  volatile struct symtab_and_line val;
-#define volatile               /*nothing */
-#else
   struct symtab_and_line val;
-#endif
   register char *p, *p1;
   char *q, *pp, *ii, *p2;
 #if 0