summaryrefslogtreecommitdiff
path: root/gcc/testsuite/g++.dg/tree-ssa/20040317-1.C
blob: e2f3dcdceb8752fdf205f52a8b45b3704fdd326a (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
/* { dg-do run } */
/* { dg-options "-O2" } */

/* Test provided by Brian Ryner in PR 14511.  The alias analyzer was
   not handling structures containing arrays properly.  In this case,
   the static cast was introducing two assignments of the form

	  this_6->_vptr.IFoo = &_ZTV4IFoo[2];
	  this_4->_vptr.IFoo = &_ZTV3Bar[2];

   which were not considered to alias each other because the alias
   analyzer was not computing a proper pointer to array elements.
   Another related bug was the type based alias analyzer not computing
   alias relations to _ZTV4IFoo and _ZTV3Bar.  Since those variables
   are read-only, it was disregarding alias information for them.
   So, the memory tags for the two 'this' variables were not being
   marked as aliased with these variables.  Resulting in the two
   assignments not aliasing each other.

   This was causing the optimizers to generate a call to the virtual
   method Foo() instead of the overloaded version.  */

struct IFoo
{
  virtual void Foo() = 0;
};

struct Bar : IFoo
{
  void Foo() { }
};

int main(int argc, char **argv)
{
  Bar* b = new Bar();
  static_cast<IFoo*>(b)->Foo();
  return 0;
}