Message ID | 54F86A28.8040804@suse.cz |
---|---|
State | New |
Headers | show |
On 03/05/15 07:37, Martin Liška wrote: > > > From 3f35d9ec57880409cde384bb7b9e8dbaae5231ef Mon Sep 17 00:00:00 2001 > From: mliska<mliska@suse.cz> > Date: Thu, 5 Mar 2015 13:41:07 +0100 > Subject: [PATCH] Fix PR ipa/65318. > > gcc/ChangeLog: > > 2015-03-05 Martin Liska<mliska@suse.cz> > > PR ipa/65318 > * ipa-icf.c (sem_variable::equals): Compare variables types. > > gcc/testsuite/ChangeLog: > > 2015-03-05 Martin Liska<mliska@suse.cz> > > * gcc.dg/ipa/pr65318.c: New test. OK. Jeff
> gcc/ChangeLog: > > 2015-03-05 Martin Liska <mliska@suse.cz> > > PR ipa/65318 > * ipa-icf.c (sem_variable::equals): Compare variables types. > > gcc/testsuite/ChangeLog: > > 2015-03-05 Martin Liska <mliska@suse.cz> > > * gcc.dg/ipa/pr65318.c: New test. OK, Honza
> > gcc/ChangeLog: > > > > 2015-03-05 Martin Liska <mliska@suse.cz> > > > > PR ipa/65318 > > * ipa-icf.c (sem_variable::equals): Compare variables types. > > > > gcc/testsuite/ChangeLog: > > > > 2015-03-05 Martin Liska <mliska@suse.cz> > > > > * gcc.dg/ipa/pr65318.c: New test. > > OK, Though actually I think it is papering over folding issue - probably we do want to imply VIEW_CONVERT_EXPR when type of alias and type of variable does not match. Honza > Honza
From 3f35d9ec57880409cde384bb7b9e8dbaae5231ef Mon Sep 17 00:00:00 2001 From: mliska <mliska@suse.cz> Date: Thu, 5 Mar 2015 13:41:07 +0100 Subject: [PATCH] Fix PR ipa/65318. gcc/ChangeLog: 2015-03-05 Martin Liska <mliska@suse.cz> PR ipa/65318 * ipa-icf.c (sem_variable::equals): Compare variables types. gcc/testsuite/ChangeLog: 2015-03-05 Martin Liska <mliska@suse.cz> * gcc.dg/ipa/pr65318.c: New test. --- gcc/ipa-icf.c | 5 +++++ gcc/testsuite/gcc.dg/ipa/pr65318.c | 18 ++++++++++++++++++ 2 files changed, 23 insertions(+) create mode 100644 gcc/testsuite/gcc.dg/ipa/pr65318.c diff --git a/gcc/ipa-icf.c b/gcc/ipa-icf.c index c55a09f..a7f19d6 100644 --- a/gcc/ipa-icf.c +++ b/gcc/ipa-icf.c @@ -1501,6 +1501,11 @@ sem_variable::equals (sem_item *item, if (DECL_INITIAL (item->decl) == error_mark_node && in_lto_p) dyn_cast <varpool_node *>(item->node)->get_constructor (); + /* As seen in PR ipa/65303 we have to compare variables types. */ + if (!func_checker::compatible_types_p (TREE_TYPE (decl), + TREE_TYPE (item->decl))) + return return_false_with_msg ("variables types are different"); + ret = sem_variable::equals (DECL_INITIAL (decl), DECL_INITIAL (item->node->decl)); if (dump_file && (dump_flags & TDF_DETAILS)) diff --git a/gcc/testsuite/gcc.dg/ipa/pr65318.c b/gcc/testsuite/gcc.dg/ipa/pr65318.c new file mode 100644 index 0000000..f23b3a2 --- /dev/null +++ b/gcc/testsuite/gcc.dg/ipa/pr65318.c @@ -0,0 +1,18 @@ +/* { dg-do compile } */ +/* { dg-options "-O2 -fdump-ipa-icf-details" } */ + +static short a = 0; +short b = -1; +static unsigned short c = 0; + +int +main () +{ + if (a <= b) + return 1; + + return 0; +} + +/* { dg-final { scan-ipa-dump "Equal symbols: 0" "icf" } } */ +/* { dg-final { cleanup-ipa-dump "icf" } } */ -- 2.1.2