aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorMarek Polacek <polacek@redhat.com>2014-05-01 07:29:38 +0000
committerMarek Polacek <mpolacek@gcc.gnu.org>2014-05-01 07:29:38 +0000
commit32e007683d8eeb92afe99367049b28d27845dfc0 (patch)
tree9c7ccefdbc81e75048751b6cf48297475c07ad64 /gcc
parent944052b9aea27456bc0a29ce4bc14a81103936f5 (diff)
downloadgcc-32e007683d8eeb92afe99367049b28d27845dfc0.zip
gcc-32e007683d8eeb92afe99367049b28d27845dfc0.tar.gz
gcc-32e007683d8eeb92afe99367049b28d27845dfc0.tar.bz2
re PR c/43395 (Gcc warns label as local variable)
PR c/43395 c/ * c-typeck.c (c_finish_return): Distinguish between label and variable when warning about returning local address. cp/ * typeck.c (maybe_warn_about_returning_address_of_local): Distinguish between label and variable when warning about returning local address. testsuite/ * c-c++-common/pr43395.c: New test. From-SVN: r209973
Diffstat (limited to 'gcc')
-rw-r--r--gcc/c/ChangeLog6
-rw-r--r--gcc/c/c-typeck.c3
-rw-r--r--gcc/cp/ChangeLog6
-rw-r--r--gcc/cp/typeck.c5
-rw-r--r--gcc/testsuite/ChangeLog5
-rw-r--r--gcc/testsuite/c-c++-common/pr43395.c30
6 files changed, 52 insertions, 3 deletions
diff --git a/gcc/c/ChangeLog b/gcc/c/ChangeLog
index e04a38d..f0630e2 100644
--- a/gcc/c/ChangeLog
+++ b/gcc/c/ChangeLog
@@ -1,5 +1,11 @@
2014-05-01 Marek Polacek <polacek@redhat.com>
+ PR c/43395
+ * c-typeck.c (c_finish_return): Distinguish between label and variable
+ when warning about returning local address.
+
+2014-05-01 Marek Polacek <polacek@redhat.com>
+
PR c/29467
* c-decl.c (declspecs_add_type): Pedwarn if boolean types are used
in C89 mode.
diff --git a/gcc/c/c-typeck.c b/gcc/c/c-typeck.c
index e25a25c..2a40c70 100644
--- a/gcc/c/c-typeck.c
+++ b/gcc/c/c-typeck.c
@@ -9265,7 +9265,8 @@ c_finish_return (location_t loc, tree retval, tree origtype)
&& DECL_CONTEXT (inner) == current_function_decl)
warning_at (loc,
OPT_Wreturn_local_addr, "function returns address "
- "of local variable");
+ "of %s", TREE_CODE (inner) == LABEL_DECL
+ ? "label" : "local variable");
break;
default:
diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog
index c078e06..4d16855 100644
--- a/gcc/cp/ChangeLog
+++ b/gcc/cp/ChangeLog
@@ -1,3 +1,9 @@
+2014-05-01 Marek Polacek <polacek@redhat.com>
+
+ PR c/43395
+ * typeck.c (maybe_warn_about_returning_address_of_local): Distinguish
+ between label and variable when warning about returning local address.
+
2014-04-30 Jason Merrill <jason@redhat.com>
PR c++/60980
diff --git a/gcc/cp/typeck.c b/gcc/cp/typeck.c
index 729e22e..8b7cb8d 100644
--- a/gcc/cp/typeck.c
+++ b/gcc/cp/typeck.c
@@ -8310,8 +8310,9 @@ maybe_warn_about_returning_address_of_local (tree retval)
warning (OPT_Wreturn_local_addr, "reference to local variable %q+D returned",
whats_returned);
else
- warning (OPT_Wreturn_local_addr, "address of local variable %q+D returned",
- whats_returned);
+ warning (OPT_Wreturn_local_addr, "address of %s %q+D returned",
+ TREE_CODE (whats_returned) == LABEL_DECL
+ ? "label" : "local variable", whats_returned);
return;
}
}
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index 05e9240..61a48f3 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,3 +1,8 @@
+2014-05-01 Marek Polacek <polacek@redhat.com>
+
+ PR c/43395
+ * c-c++-common/pr43395.c: New test.
+
2014-05-01 Yuri Rumyantsev <ysrumyan@gmail.com>
* gcc.dg/cond-reduc-1.c: New test.
diff --git a/gcc/testsuite/c-c++-common/pr43395.c b/gcc/testsuite/c-c++-common/pr43395.c
new file mode 100644
index 0000000..92f048d
--- /dev/null
+++ b/gcc/testsuite/c-c++-common/pr43395.c
@@ -0,0 +1,30 @@
+/* PR c/43395 */
+/* { dg-do compile } */
+
+void *
+foo (void)
+{
+lab:
+ return &&lab;
+/* { dg-warning "function returns address of label" "" { target c } 8 } */
+/* { dg-warning "address of label" "" { target c++ } 7 } */
+}
+
+void *
+bar (void)
+{
+ __label__ lab;
+lab:
+ return &&lab;
+/* { dg-warning "function returns address of label" "" { target c } 18 } */
+/* { dg-warning "address of label" "" { target c++ } 17 } */
+}
+
+void *
+baz (void)
+{
+ int i;
+ return &i;
+/* { dg-warning "function returns address of local variable" "" { target c } 27 } */
+/* { dg-warning "address of local variable" "" { target c++ } 26 } */
+}