PR ipa/68184
authorhubicka <hubicka@138bc75d-0d04-0410-961f-82ee72b054a4>
Thu, 3 Dec 2015 04:13:33 +0000 (04:13 +0000)
committerhubicka <hubicka@138bc75d-0d04-0410-961f-82ee72b054a4>
Thu, 3 Dec 2015 04:13:33 +0000 (04:13 +0000)
* g++.dg/torture/pr68184.C: New testcase.
* cgraphunit.c (cgraph_node::analyze): Set can_throw_external.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@231217 138bc75d-0d04-0410-961f-82ee72b054a4

gcc/ChangeLog
gcc/cgraphunit.c
gcc/testsuite/ChangeLog
gcc/testsuite/g++.dg/torture/pr68184.C [new file with mode: 0644]

index f15b2d2..1d96d7b 100644 (file)
@@ -1,3 +1,8 @@
+2015-12-02  Jan Hubicka  <hubicka@ucw.cz>
+
+       PR ipa/68184
+       * cgraphunit.c (cgraph_node::analyze): Set can_throw_external.
+
 2015-12-02  Aditya Kumar  <aditya.k7@samsung.com>
            Sebastian Pop  <s.pop@samsung.com>
 
index 4ce5f9b..4ab6414 100644 (file)
@@ -575,6 +575,7 @@ cgraph_node::analyze (void)
       cgraph_node *t = cgraph_node::get (thunk.alias);
 
       create_edge (t, NULL, 0, CGRAPH_FREQ_BASE);
+      callees->can_throw_external = !TREE_NOTHROW (t->decl);
       /* Target code in expand_thunk may need the thunk's target
         to be analyzed, so recurse here.  */
       if (!t->analyzed)
index 7f39c2d..2e9f6b8 100644 (file)
@@ -1,3 +1,8 @@
+2015-12-02  Jan Hubicka  <hubicka@ucw.cz>
+
+       PR ipa/68184
+       * g++.dg/torture/pr68184.C: New testcase.
+
 2015-12-03  Jakub Jelinek  <jakub@redhat.com>
 
        PR preprocessor/57580
diff --git a/gcc/testsuite/g++.dg/torture/pr68184.C b/gcc/testsuite/g++.dg/torture/pr68184.C
new file mode 100644 (file)
index 0000000..d0c7c84
--- /dev/null
@@ -0,0 +1,31 @@
+// { dg-do run }
+namespace {
+struct IFoo { virtual void foo() = 0; };
+struct IBar { virtual void bar() = 0; };
+
+struct FooBar : private IBar, private IFoo
+{
+    void call_foo()
+    {
+        try
+        {
+            static_cast<IFoo*>(this)->foo();
+        }
+        catch( ... ) {}
+    }
+    void foo() { throw 1; }
+    void bar()  {}
+};
+
+void test()
+{
+    FooBar foobar;
+    foobar.call_foo();
+}
+}
+int main()
+{
+    test();
+    return 0;
+}
+