From: Jakub Jelinek Date: Thu, 14 Jan 2010 22:43:56 +0000 (+0100) Subject: re PR middle-end/42674 (Bogus "no return statement in function returning non-void... X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=ef5d11818dec252c1c843e82645b52ea71ab315c;p=gcc.git re PR middle-end/42674 (Bogus "no return statement in function returning non-void" warning) PR middle-end/42674 * c-decl.c (finish_function): Don't emit -Wreturn-type warnings in functions with noreturn attribute. * decl.c (finish_function): Don't emit -Wreturn-type warnings in functions with noreturn attribute. * c-c++-common/pr42674.c: New test. From-SVN: r155920 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 29f71b12d14..ce96cca5aca 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,5 +1,9 @@ 2010-01-14 Jakub Jelinek + PR middle-end/42674 + * c-decl.c (finish_function): Don't emit -Wreturn-type warnings in + functions with noreturn attribute. + PR c++/42608 * varasm.c (declare_weak): Add weak attribute to decl if it doesn't have one already. diff --git a/gcc/c-decl.c b/gcc/c-decl.c index a244a83e787..91d58844550 100644 --- a/gcc/c-decl.c +++ b/gcc/c-decl.c @@ -8032,6 +8032,8 @@ finish_function (void) && !current_function_returns_value && !current_function_returns_null /* Don't complain if we are no-return. */ && !current_function_returns_abnormally + /* Don't complain if we are declared noreturn. */ + && !TREE_THIS_VOLATILE (fndecl) /* Don't warn for main(). */ && !MAIN_NAME_P (DECL_NAME (fndecl)) /* Or if they didn't actually specify a return type. */ diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog index c6e309f6820..1d132616371 100644 --- a/gcc/cp/ChangeLog +++ b/gcc/cp/ChangeLog @@ -1,3 +1,9 @@ +2010-01-14 Jakub Jelinek + + PR middle-end/42674 + * decl.c (finish_function): Don't emit -Wreturn-type warnings in + functions with noreturn attribute. + 2010-01-14 Jason Merrill PR c++/42701 diff --git a/gcc/cp/decl.c b/gcc/cp/decl.c index e89113a2402..2409aa31b15 100644 --- a/gcc/cp/decl.c +++ b/gcc/cp/decl.c @@ -12541,6 +12541,8 @@ finish_function (int flags) && !current_function_returns_value && !current_function_returns_null /* Don't complain if we abort or throw. */ && !current_function_returns_abnormally + /* Don't complain if we are declared noreturn. */ + && !TREE_THIS_VOLATILE (fndecl) && !DECL_NAME (DECL_RESULT (fndecl)) && !TREE_NO_WARNING (fndecl) /* Structor return values (if any) are set by the compiler. */ diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 5b284490686..f4d13bedd86 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,5 +1,8 @@ 2010-01-14 Jakub Jelinek + PR middle-end/42674 + * c-c++-common/pr42674.c: New test. + PR c++/42608 * g++.dg/template/instantiate11.C: New test. diff --git a/gcc/testsuite/c-c++-common/pr42674.c b/gcc/testsuite/c-c++-common/pr42674.c new file mode 100644 index 00000000000..ae6730c50b0 --- /dev/null +++ b/gcc/testsuite/c-c++-common/pr42674.c @@ -0,0 +1,13 @@ +/* PR middle-end/42674 */ +/* { dg-do compile } */ +/* { dg-options "-Wreturn-type" } */ + +extern void bar (void); +static int foo (void) __attribute__ ((__noreturn__, __used__)); + +static int +foo (void) +{ + while (1) + bar (); +}