annotate gcc/testsuite/g++.dg/ipa/devirt-c-7.C @ 145:1830386684a0

gcc-9.2.0
author anatofuz
date Thu, 13 Feb 2020 11:34:05 +0900
parents 04ced10e8804
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
111
kono
parents:
diff changeset
1 /* Verify that ipa-cp will not get confused by placement new constructing an
kono
parents:
diff changeset
2 object within another one when looking for dynamic type change . */
145
1830386684a0 gcc-9.2.0
anatofuz
parents: 111
diff changeset
3 /* { dg-do run { target { nonpic || pie_enabled } } } */
111
kono
parents:
diff changeset
4 /* { dg-options "-O3 -Wno-attributes" } */
kono
parents:
diff changeset
5
kono
parents:
diff changeset
6 extern "C" void abort (void);
kono
parents:
diff changeset
7 namespace std {
kono
parents:
diff changeset
8 typedef __SIZE_TYPE__ size_t;
kono
parents:
diff changeset
9 }
kono
parents:
diff changeset
10 inline void* __attribute__ ((always_inline))
kono
parents:
diff changeset
11 operator new(std::size_t, void* __p) throw()
kono
parents:
diff changeset
12 {
kono
parents:
diff changeset
13 return __p;
kono
parents:
diff changeset
14 }
kono
parents:
diff changeset
15
kono
parents:
diff changeset
16 class A
kono
parents:
diff changeset
17 {
kono
parents:
diff changeset
18 public:
kono
parents:
diff changeset
19 char data[256];
kono
parents:
diff changeset
20 A();
kono
parents:
diff changeset
21 virtual int foo (int i);
kono
parents:
diff changeset
22 };
kono
parents:
diff changeset
23
kono
parents:
diff changeset
24 class B : public A
kono
parents:
diff changeset
25 {
kono
parents:
diff changeset
26 public:
kono
parents:
diff changeset
27 virtual int foo (int i);
kono
parents:
diff changeset
28 };
kono
parents:
diff changeset
29
kono
parents:
diff changeset
30 class C
kono
parents:
diff changeset
31 {
kono
parents:
diff changeset
32 public:
kono
parents:
diff changeset
33 C();
kono
parents:
diff changeset
34 virtual double foo (double i);
kono
parents:
diff changeset
35 };
kono
parents:
diff changeset
36
kono
parents:
diff changeset
37 int A::foo (int i)
kono
parents:
diff changeset
38 {
kono
parents:
diff changeset
39 return i + 1;
kono
parents:
diff changeset
40 }
kono
parents:
diff changeset
41
kono
parents:
diff changeset
42 int B::foo (int i)
kono
parents:
diff changeset
43 {
kono
parents:
diff changeset
44 return i + 2;
kono
parents:
diff changeset
45 }
kono
parents:
diff changeset
46
kono
parents:
diff changeset
47 double C::foo (double i)
kono
parents:
diff changeset
48 {
kono
parents:
diff changeset
49 return i + 3.5;
kono
parents:
diff changeset
50 }
kono
parents:
diff changeset
51
kono
parents:
diff changeset
52 static int __attribute__ ((noinline)) middleman (class A *obj, int i)
kono
parents:
diff changeset
53 {
kono
parents:
diff changeset
54 return obj->foo (i);
kono
parents:
diff changeset
55 }
kono
parents:
diff changeset
56
kono
parents:
diff changeset
57 int __attribute__ ((noinline,noclone)) get_input(void)
kono
parents:
diff changeset
58 {
kono
parents:
diff changeset
59 return 1;
kono
parents:
diff changeset
60 }
kono
parents:
diff changeset
61
kono
parents:
diff changeset
62 __attribute__ ((always_inline)) C::C ()
kono
parents:
diff changeset
63 {
kono
parents:
diff changeset
64 }
kono
parents:
diff changeset
65
kono
parents:
diff changeset
66 A::A ()
kono
parents:
diff changeset
67 {
kono
parents:
diff changeset
68 }
kono
parents:
diff changeset
69
kono
parents:
diff changeset
70 static __attribute__ ((noinline)) void bah ()
kono
parents:
diff changeset
71 {
kono
parents:
diff changeset
72 class B b;
kono
parents:
diff changeset
73
kono
parents:
diff changeset
74 C *c = new ((void *) &b.data) C;
kono
parents:
diff changeset
75
kono
parents:
diff changeset
76 if (middleman (&b, get_input ()) != 3)
kono
parents:
diff changeset
77 abort ();
kono
parents:
diff changeset
78 }
kono
parents:
diff changeset
79
kono
parents:
diff changeset
80 int main (int argc, char *argv[])
kono
parents:
diff changeset
81 {
kono
parents:
diff changeset
82 int i;
kono
parents:
diff changeset
83
kono
parents:
diff changeset
84 for (i = 0; i < 10; i++)
kono
parents:
diff changeset
85 bah ();
kono
parents:
diff changeset
86 return 0;
kono
parents:
diff changeset
87 }