PR target/10114 and PR target/10084
authorEric Botcazou <ebotcazou@libertysurf.fr>
Fri, 28 Mar 2003 07:47:57 +0000 (08:47 +0100)
committerEric Botcazou <ebotcazou@gcc.gnu.org>
Fri, 28 Mar 2003 07:47:57 +0000 (07:47 +0000)
PR target/10114 and PR target/10084
* dwarf2out.c (mem_loc_descriptor): Handle LO_SUM.

Co-Authored-By: Richard Henderson <rth@redhat.com>
From-SVN: r64947

gcc/ChangeLog
gcc/dwarf2out.c
gcc/testsuite/ChangeLog
gcc/testsuite/gcc.dg/sparc-dwarf2.c [new file with mode: 0644]

index dd898e3aaaf5f6776cb8595249d9330667389b9d..3d8e52cd67f83562b9098d38647c42b976818b76 100644 (file)
@@ -1,3 +1,9 @@
+2003-03-28  Eric Botcazou  <ebotcazou@libertysurf.fr>
+            Richard Henderson  <rth@redhat.com>
+
+       PR target/10114 and PR target/10084
+       * dwarf2out.c (mem_loc_descriptor): Handle LO_SUM.
+
 2003-03-27  Richard Henderson  <rth@redhat.com>
 
        * config/alpha/alpha.md (adddi_er_high_l): Valid only after reload.
index a1e27cbf7f0dd01053113416bf842d09c61bcae5..3c6dec78d1bffc04e8ea8d0a51e0899e15b5a174 100644 (file)
@@ -8423,6 +8423,11 @@ mem_loc_descriptor (rtl, mode)
        add_loc_descr (&mem_loc_result, new_loc_descr (DW_OP_deref, 0, 0));
       break;
 
+    case LO_SUM:
+        rtl = XEXP (rtl, 1);
+
+      /* ... fall through ...  */
+
     case LABEL_REF:
       /* Some ports can transform a symbol ref into a label ref, because
         the symbol ref is too far away and has to be dumped into a constant
index f9d63b210a7d51287a0c55e942120faad2bb6a82..3794bdd2f6b34855dd37710c43f5371c65a6734b 100644 (file)
@@ -1,3 +1,7 @@
+2003-03-28  Eric Botcazou  <ebotcazou@libertysurf.fr>
+
+       * gcc.dg/sparc-dwarf2.c: New test.
+
 2003-03-27  Roger Sayle  <roger@eyesopen.com>
 
        * gcc.c-torture/execute/ieee/fp-cmp-6.c: New test case.
diff --git a/gcc/testsuite/gcc.dg/sparc-dwarf2.c b/gcc/testsuite/gcc.dg/sparc-dwarf2.c
new file mode 100644 (file)
index 0000000..d68cf62
--- /dev/null
@@ -0,0 +1,31 @@
+/* PR target/10114 */
+/* Originator: James Troup <james@nocrew.org> */
+/* { dg-do compile { target sparc-*-linux* } } */
+/* { dg-options "-g -O1" } */
+
+extern __inline double sqrt (double __x)
+{
+  register double __r;
+  __asm ("fsqrtd %1,%0" : "=f" (__r) : "f" (__x));
+  return __r;
+}
+
+static double our_skew, max_update_skew;
+
+static double Sqr(double x)
+{
+  return x*x;
+}
+
+void REF_SetReference(double skew)
+{
+  double previous_skew, new_skew;
+  double old_weight, new_weight, sum_weight;
+  double delta_freq1, delta_freq2;
+  double skew1, skew2;
+
+  previous_skew = our_skew;
+  skew1 = sqrt((Sqr(delta_freq1) * old_weight + Sqr(delta_freq2) * new_weight) / sum_weight);
+  skew2 = (previous_skew * old_weight + new_skew * new_weight) / sum_weight;
+  our_skew = skew1 + skew2;
+}