From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (qmail 22469 invoked by alias); 14 Mar 2005 03:22:20 -0000 Mailing-List: contact gcc-bugs-help@gcc.gnu.org; run by ezmlm Precedence: bulk List-Archive: List-Post: List-Help: Sender: gcc-bugs-owner@gcc.gnu.org Received: (qmail 22422 invoked by uid 48); 14 Mar 2005 03:22:16 -0000 Date: Mon, 14 Mar 2005 03:22:00 -0000 From: "hp at gcc dot gnu dot org" To: gcc-bugs@gcc.gnu.org Message-ID: <20050314032214.20466.hp@gcc.gnu.org> Reply-To: gcc-bugzilla@gcc.gnu.org Subject: [Bug rtl-optimization/20466] New: Missed invalidation of known memory contents in flow2... X-Bugzilla-Reason: CC X-SW-Source: 2005-03/txt/msg01676.txt.bz2 List-Id: ... causes invalid removal of memory write. The following test-case will be committed as gcc.c-torture/execute/prXXXXXX-1.c; it is miscompiled at -O2. The first assignment to **ipp is removed in .flow2. This bug has been there since at least 3.2.1. void f (int **, int *, int *, int **, int **) __attribute__ ((__noinline__)); void f (int **ipp, int *i1p, int *i2p, int **i3, int **i4) { **ipp = *i1p; *ipp = i2p; *i3 = *i4; **ipp = 99; } extern void exit (int); extern void abort (void); int main (void) { int i = 42, i1 = 66, i2 = 1, i3 = -1, i4 = 55; int *ip = &i; int *i3p = &i3; int *i4p = &i4; f (&ip, &i1, &i2, &i3p, &i4p); if (i != 66 || ip != &i2 || i2 != 99 || i3 != -1 || i3p != i4p || i4 != 55) abort (); exit (0); } -- Summary: Missed invalidation of known memory contents in flow2... Product: gcc Version: 4.1.0 Status: UNCONFIRMED Keywords: wrong-code Severity: normal Priority: P2 Component: rtl-optimization AssignedTo: unassigned at gcc dot gnu dot org ReportedBy: hp at gcc dot gnu dot org CC: gcc-bugs at gcc dot gnu dot org GCC target triplet: cris-* http://gcc.gnu.org/bugzilla/show_bug.cgi?id=20466