summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorrguenth <rguenth@138bc75d-0d04-0410-961f-82ee72b054a4>2010-05-09 18:17:33 +0000
committerrguenth <rguenth@138bc75d-0d04-0410-961f-82ee72b054a4>2010-05-09 18:17:33 +0000
commit3760428fe7d598ecb20f6439eb0da84fbcea3830 (patch)
tree3e9d50c5b8a7ede2cd680c832a69dd5133f46e01
parent8af5341f047f26c12d43b721995426f3f177f245 (diff)
downloadgcc-3760428fe7d598ecb20f6439eb0da84fbcea3830.tar.gz
2010-05-09 Richard Guenther <rguenther@suse.de>
PR middle-end/44024 * fold-const.c (tree_single_nonzero_warnv_p): Properly handle &FUNCTION_DECL. * gcc.dg/pr44024.c: New testcase. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@159205 138bc75d-0d04-0410-961f-82ee72b054a4
-rw-r--r--gcc/ChangeLog6
-rw-r--r--gcc/fold-const.c8
-rw-r--r--gcc/testsuite/ChangeLog5
-rw-r--r--gcc/testsuite/gcc.dg/pr44024.c14
4 files changed, 31 insertions, 2 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index 8879737b91c..6551ac0ca53 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,3 +1,9 @@
+2010-05-09 Richard Guenther <rguenther@suse.de>
+
+ PR middle-end/44024
+ * fold-const.c (tree_single_nonzero_warnv_p): Properly
+ handle &FUNCTION_DECL.
+
2010-05-09 Joseph Myers <joseph@codesourcery.com>
PR c/4784
diff --git a/gcc/fold-const.c b/gcc/fold-const.c
index ffd9d30ef2e..17a753692d5 100644
--- a/gcc/fold-const.c
+++ b/gcc/fold-const.c
@@ -14917,7 +14917,9 @@ tree_single_nonzero_warnv_p (tree t, bool *strict_overflow_p)
case ADDR_EXPR:
{
- tree base = get_base_address (TREE_OPERAND (t, 0));
+ tree base = TREE_OPERAND (t, 0);
+ if (!DECL_P (base))
+ base = get_base_address (base);
if (!base)
return false;
@@ -14927,7 +14929,9 @@ tree_single_nonzero_warnv_p (tree t, bool *strict_overflow_p)
allocated on the stack. */
if (DECL_P (base)
&& (flag_delete_null_pointer_checks
- || (TREE_CODE (base) == VAR_DECL && !TREE_STATIC (base))))
+ || (DECL_CONTEXT (base)
+ && TREE_CODE (DECL_CONTEXT (base)) == FUNCTION_DECL
+ && auto_var_in_fn_p (base, DECL_CONTEXT (base)))))
return !VAR_OR_FUNCTION_DECL_P (base) || !DECL_WEAK (base);
/* Constants are never weak. */
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index cf4140d7691..f0a10bba391 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,3 +1,8 @@
+2010-05-09 Richard Guenther <rguenther@suse.de>
+
+ PR middle-end/44024
+ * gcc.dg/pr44024.c: New testcase.
+
2010-05-09 Joseph Myers <joseph@codesourcery.com>
PR c/4784
diff --git a/gcc/testsuite/gcc.dg/pr44024.c b/gcc/testsuite/gcc.dg/pr44024.c
new file mode 100644
index 00000000000..38f41532f95
--- /dev/null
+++ b/gcc/testsuite/gcc.dg/pr44024.c
@@ -0,0 +1,14 @@
+/* { dg-do link } */
+/* { dg-options "-fdelete-null-pointer-checks -fdump-tree-original" } */
+
+void foo();
+
+int main()
+{
+ if (foo == (void *)0)
+ link_error ();
+ return 0;
+}
+
+/* { dg-final { scan-tree-dump-not "foo" "original" } } */
+/* { dg-final { cleanup-tree-dump "original" } } */