From 1ce324c330173b65db7170925856f723a5316c18 Mon Sep 17 00:00:00 2001 From: Eric Botcazou Date: Fri, 28 Mar 2003 08:47:57 +0100 Subject: [PATCH] PR target/10114 and PR target/10084 PR target/10114 and PR target/10084 * dwarf2out.c (mem_loc_descriptor): Handle LO_SUM. Co-Authored-By: Richard Henderson From-SVN: r64947 --- gcc/ChangeLog | 6 ++++++ gcc/dwarf2out.c | 5 +++++ gcc/testsuite/ChangeLog | 4 ++++ gcc/testsuite/gcc.dg/sparc-dwarf2.c | 31 +++++++++++++++++++++++++++++ 4 files changed, 46 insertions(+) create mode 100644 gcc/testsuite/gcc.dg/sparc-dwarf2.c diff --git a/gcc/ChangeLog b/gcc/ChangeLog index dd898e3aaaf..3d8e52cd67f 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,9 @@ +2003-03-28 Eric Botcazou + Richard Henderson + + PR target/10114 and PR target/10084 + * dwarf2out.c (mem_loc_descriptor): Handle LO_SUM. + 2003-03-27 Richard Henderson * config/alpha/alpha.md (adddi_er_high_l): Valid only after reload. diff --git a/gcc/dwarf2out.c b/gcc/dwarf2out.c index a1e27cbf7f0..3c6dec78d1b 100644 --- a/gcc/dwarf2out.c +++ b/gcc/dwarf2out.c @@ -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 diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index f9d63b210a7..3794bdd2f6b 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,7 @@ +2003-03-28 Eric Botcazou + + * gcc.dg/sparc-dwarf2.c: New test. + 2003-03-27 Roger Sayle * 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 index 00000000000..d68cf620428 --- /dev/null +++ b/gcc/testsuite/gcc.dg/sparc-dwarf2.c @@ -0,0 +1,31 @@ +/* PR target/10114 */ +/* Originator: James Troup */ +/* { 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; +} -- 2.30.2