re PR sanitizer/59415 (ICE segfault in verify_bb_vtables for g++ -S -fvtable-verify...
authorMarek Polacek <polacek@redhat.com>
Mon, 9 Dec 2013 14:44:03 +0000 (14:44 +0000)
committerMarek Polacek <mpolacek@gcc.gnu.org>
Mon, 9 Dec 2013 14:44:03 +0000 (14:44 +0000)
PR sanitizer/59415
* vtable-verify.c (verify_bb_vtables): Check the return value
of gimple_call_fn.  Use is_gimple_call instead of gimple_code.
testsuite/
* g++.dg/ubsan/pr59415.C: New test.

From-SVN: r205805

gcc/ChangeLog
gcc/testsuite/ChangeLog
gcc/testsuite/g++.dg/ubsan/pr59415.C [new file with mode: 0644]
gcc/vtable-verify.c

index c26294236979909c9ba28f15680f4de40cf589d5..c100cee94ff6f22f4554ab7eb8102e27d973fbcc 100644 (file)
@@ -1,3 +1,9 @@
+2013-12-09  Marek Polacek  <polacek@redhat.com>
+
+       PR sanitizer/59415
+       * vtable-verify.c (verify_bb_vtables): Check the return value
+       of gimple_call_fn.  Use is_gimple_call instead of gimple_code.
+
 2013-12-09  Kyrylo Tkachov  <kyrylo.tkachov@arm.com>
 
        * config/arm/arm.md (generic_sched): Add cortexa12.
index f5adf1a5ff4080f4a137125c01b64da8e2c60d49..d8ff9fa08b497fddcb29a2c6d9319a0ec63ffe6e 100644 (file)
@@ -1,3 +1,8 @@
+2013-12-09  Marek Polacek  <polacek@redhat.com>
+
+       PR sanitizer/59415
+       * g++.dg/ubsan/pr59415.C: New test.
+
 2013-12-09  Paolo Carlini  <paolo.carlini@oracle.com>
 
        PR c++/52707
diff --git a/gcc/testsuite/g++.dg/ubsan/pr59415.C b/gcc/testsuite/g++.dg/ubsan/pr59415.C
new file mode 100644 (file)
index 0000000..4c373f7
--- /dev/null
@@ -0,0 +1,8 @@
+/* { dg-do compile } */
+/* { dg-options "-fsanitize=null -Wall -fvtable-verify=std" } */
+
+void
+foo (void)
+{
+  throw 0;
+}
index b54469517cd29a48e8e3b39a52906b27e4c70b7f..7060189dc7a0151120faacd3b9ea871a18a4dcbf 100644 (file)
@@ -586,10 +586,10 @@ verify_bb_vtables (basic_block bb)
       stmt = gsi_stmt (gsi_virtual_call);
 
       /* Count virtual calls.  */
-      if (gimple_code (stmt) == GIMPLE_CALL)
+      if (is_gimple_call (stmt))
         {
           tree fncall = gimple_call_fn (stmt);
-          if (TREE_CODE (fncall) == OBJ_TYPE_REF)
+          if (fncall && TREE_CODE (fncall) == OBJ_TYPE_REF)
             total_num_virtual_calls++;
         }