From: Jakub Jelinek Date: Sat, 3 Jan 2009 00:52:51 +0000 (+0100) Subject: re PR c/38700 (ICE with __builtin_expect and label) X-Git-Tag: releases/gcc-4.4.0~1066 X-Git-Url: http://git.ipfire.org/gitweb.cgi?a=commitdiff_plain;h=5f26a23027acae2712001616c4b13c76cf316cd5;p=thirdparty%2Fgcc.git re PR c/38700 (ICE with __builtin_expect and label) PR c/38700 * builtins.c (fold_builtin_expect): Only check DECL_WEAK for VAR_DECLs and FUNCTION_DECLs. * gcc.dg/pr38700.c: New test. From-SVN: r143028 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index ba31727eaf17..59808900dab3 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,9 @@ +2009-01-03 Jakub Jelinek + + PR c/38700 + * builtins.c (fold_builtin_expect): Only check DECL_WEAK for VAR_DECLs + and FUNCTION_DECLs. + 2009-01-02 Kenneth Zadeck PR rtl-optimization/35805 diff --git a/gcc/builtins.c b/gcc/builtins.c index 607d7dd36b1e..cda94c3cbc06 100644 --- a/gcc/builtins.c +++ b/gcc/builtins.c @@ -1,6 +1,6 @@ /* Expand builtin functions. Copyright (C) 1988, 1992, 1993, 1994, 1995, 1996, 1997, 1998, 1999, - 2000, 2001, 2002, 2003, 2004, 2005, 2006, 2007, 2008 + 2000, 2001, 2002, 2003, 2004, 2005, 2006, 2007, 2008, 2009 Free Software Foundation, Inc. This file is part of GCC. @@ -7324,7 +7324,9 @@ fold_builtin_expect (tree arg0, tree arg1) } while (TREE_CODE (inner) == COMPONENT_REF || TREE_CODE (inner) == ARRAY_REF); - if (DECL_P (inner) && DECL_WEAK (inner)) + if ((TREE_CODE (inner) == VAR_DECL + || TREE_CODE (inner) == FUNCTION_DECL) + && DECL_WEAK (inner)) return NULL_TREE; } diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 199784f52694..4a0c0c64cfa8 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2009-01-03 Jakub Jelinek + + PR c/38700 + * gcc.dg/pr38700.c: New test. + 2009-01-02 Jason Merrill * g++.dg/cpp0x/initlist11.C: New test. diff --git a/gcc/testsuite/gcc.dg/pr38700.c b/gcc/testsuite/gcc.dg/pr38700.c new file mode 100644 index 000000000000..bfa75b0c7cba --- /dev/null +++ b/gcc/testsuite/gcc.dg/pr38700.c @@ -0,0 +1,11 @@ +/* PR c/38700 */ +/* { dg-do compile } */ +/* { dg-options "-O0" } */ + +int +foo () +{ + __SIZE_TYPE__ s = __builtin_expect ((__SIZE_TYPE__)&&L, 0); +L: + return 0; +}