Your message dated Fri, 27 Dec 2002 17:05:03 +0100
with message-id <[EMAIL PROTECTED]>
and subject line Bug#40189: c/6898: gcc produces incorrect minimization code
has caused the attached Bug report to be marked as done.

This means that you claim that the problem has been dealt with.
If this is not the case it is now your responsibility to reopen the
Bug report if necessary, and/or fix the problem forthwith.

(NB: If you are a system administrator and have no idea what I am
talking about this indicates a serious mail system misconfiguration
somewhere.  Please contact me immediately.)

Debian bug tracking system administrator
(administrator, Debian Bugs database)

--------------------------------------
Received: (at submit) by bugs.debian.org; 25 Jun 1999 19:34:28 +0000
Received: (qmail 28888 invoked from network); 25 Jun 1999 19:34:27 -0000
Received: from enhanced.ppp.eticomm.net (HELO intech19.enhanced.com) 
(@206.228.183.5)
  by master.debian.org with SMTP; 25 Jun 1999 19:34:27 -0000
Received: from camm by intech19.enhanced.com with local (Exim 2.05 #1 (Debian))
        id 10xbk0-0008C0-00; Fri, 25 Jun 1999 15:34:24 -0400
From:  <[EMAIL PROTECTED]>
Subject: egcc: egcc produces incorrect minimization code
To: [EMAIL PROTECTED]
X-Mailer: bug 3.1.7
Message-Id: <[EMAIL PROTECTED]>
Date: Fri, 25 Jun 1999 15:34:24 -0400

Package: egcc
Version: 2.91.60-5

The following program inconsistently chooses minimal
array elements in case of equal elements being present.

Here is the code (ttr.c):
------------------------
#include <stdio.h>
#include <math.h>


int
main() {

  double 
a[4]={0.006776,2.5,3.0,0.006776},w[4]={0.000030,3.7,3.0,0.000030},t,amin;
  int ir,i,nr=4;
  double tol=9.31322574615479e-10*3.0;

  for (i=0,ir=-1,amin=DBL_MAX;i<nr;i++) 
    if (a[i]>tol) {
      t=w[i]/a[i];
      if (t<amin || ir==-1) {
        amin=t;
        ir=i;
      }
    }
  
  printf("ir=%d\n",ir);

  for (i=0,ir=-1,amin=DBL_MAX;i<nr;i++) 
    if (a[i]>tol && ((t=w[i]/a[i])<amin || ir==-1)) {
        amin=t;
        ir=i;
      }
  
  printf("ir=%d\n",ir);

  exit(0);

}
---------------  
and here is the execution:
---------------
intech19:~$ egcc -g -Wall ttr.c -o ttr -lm
intech19:~$ ./ttr
ir=0
ir=3
-----------------




-- System Information
Debian Release: 2.1
Kernel Version: Linux intech19 2.2.7 #1 SMP Thu May 27 11:53:43 EDT 1999 i686 
unknown

Versions of the packages egcc depends on:
ii  libc6           2.0.7.19981211 GNU C Library: shared libraries
ii  g++             2.91.60-5      The GNU (egcs) C++ compiler.
ii  g++             2.91.60-5      The GNU (egcs) C++ compiler.
---------------------------------------
Received: (at 40189-done) by bugs.debian.org; 27 Dec 2002 16:08:02 +0000
>From [EMAIL PROTECTED] Fri Dec 27 10:08:01 2002
Return-path: <[EMAIL PROTECTED]>
Received: from mail.cs.tu-berlin.de [130.149.17.13] (root)
        by master.debian.org with esmtp (Exim 3.12 1 (Debian))
        id 18Rx1j-0001Al-00; Fri, 27 Dec 2002 10:07:59 -0600
Received: from bolero.cs.tu-berlin.de ([EMAIL PROTECTED] [130.149.19.1])
        by mail.cs.tu-berlin.de (8.9.3/8.9.3) with ESMTP id RAA00973
        for <[EMAIL PROTECTED]>; Fri, 27 Dec 2002 17:05:04 +0100 (MET)
Received: (from [EMAIL PROTECTED])
        by bolero.cs.tu-berlin.de (8.11.6+Sun/8.9.3) id gBRG54w08658;
        Fri, 27 Dec 2002 17:05:04 +0100 (MET)
From: Matthias Klose <[EMAIL PROTECTED]>
MIME-Version: 1.0
Content-Type: text/plain; charset=us-ascii
Content-Transfer-Encoding: 7bit
Message-ID: <[EMAIL PROTECTED]>
Date: Fri, 27 Dec 2002 17:05:03 +0100
To: [EMAIL PROTECTED]
Subject: Re: Bug#40189: c/6898: gcc produces incorrect minimization code
In-Reply-To: <[EMAIL PROTECTED]>
References: <[EMAIL PROTECTED]>
X-Mailer: VM 7.03 under 21.4 (patch 6) "Common Lisp" XEmacs Lucid
Delivered-To: [EMAIL PROTECTED]
X-Spam-Status: No, hits=-8.9 required=5.0
        tests=IN_REP_TO,QUOTED_EMAIL_TEXT,REFERENCES,SPAM_PHRASE_01_02
        version=2.41
X-Spam-Level: 

therefore closing ...

[EMAIL PROTECTED] writes:
> Synopsis: gcc produces incorrect minimization code
> 
> State-Changed-From-To: open->closed
> State-Changed-By: reichelt
> State-Changed-When: Fri Nov 22 08:47:00 2002
> State-Changed-Why:
>     Not a bug.
>     
>     Whether you get ir=0 or ir=3 is just a matter when rounding will take 
> place.
>     Since the code is rearranged in optimization steps, you'll get varying
>     results with different architectures and optimization options. Similar
>     but not identical code might also lead to different results.
>     Welcome to the world of floating point arithmetic.
>     
>     BTW, declaring t and amin as "volatile double" leads to your "expected"
>     result even for -O0.
> 
> http://gcc.gnu.org/cgi-bin/gnatsweb.pl?cmd=view%20audit-trail&database=gcc&pr=6898


Reply via email to