diff options
| author | Ivan A. Kosarev <ikosarev@accesssoftek.com> | 2018-01-08 15:36:06 +0000 |
|---|---|---|
| committer | Ivan A. Kosarev <ikosarev@accesssoftek.com> | 2018-01-08 15:36:06 +0000 |
| commit | ed4f330174e1cdcf349b3ca74d16d8f0a396723b (patch) | |
| tree | a7ea74bb790e9c269d7111b76519f8a1e2a583ba /clang/test | |
| parent | 31b4b76f99e1b8f10724e6b64f36b8a8c83db768 (diff) | |
| download | bcm5719-llvm-ed4f330174e1cdcf349b3ca74d16d8f0a396723b.tar.gz bcm5719-llvm-ed4f330174e1cdcf349b3ca74d16d8f0a396723b.zip | |
[CodeGen] Fix TBAA info for accesses to members of base classes
Resolves:
Bug 35724 - regression (r315984): fatal error: error in backend:
Broken function found (Did not see access type in access path!)
https://bugs.llvm.org/show_bug.cgi?id=35724
Differential Revision: https://reviews.llvm.org/D41547
llvm-svn: 321999
Diffstat (limited to 'clang/test')
| -rw-r--r-- | clang/test/CodeGen/tbaa-base.cpp | 53 |
1 files changed, 53 insertions, 0 deletions
diff --git a/clang/test/CodeGen/tbaa-base.cpp b/clang/test/CodeGen/tbaa-base.cpp new file mode 100644 index 00000000000..175c55f08a1 --- /dev/null +++ b/clang/test/CodeGen/tbaa-base.cpp @@ -0,0 +1,53 @@ +// RUN: %clang_cc1 -triple x86_64-linux-gnu -O1 %s -emit-llvm -o - | FileCheck %s +// +// Test generating of TBAA metadata for accesses to members of base classes. + +struct A { + int x, y, z; +}; + +struct B : A { + int i; +}; + +struct C { + int i; + B b; + int j; +}; + +int f1(B *b) { +// CHECK-LABEL: _Z2f1P1B +// CHECK: load i32, {{.*}}, !tbaa [[TAG_A_y:!.*]] + return b->y; +} + +int f2(C *c) { +// CHECK-LABEL: _Z2f2P1C +// CHECK: load i32, {{.*}}, !tbaa [[TAG_A_y]] + return (&(c->b))->y; +} + +struct D : virtual A +{}; + +struct E { + D d; +}; + +int f3(D *d) { +// CHECK-LABEL: _Z2f3P1D +// CHECK: load i32, {{.*}}, !tbaa [[TAG_A_y]] + return d->y; +} + +int f4(E *e) { +// CHECK-LABEL: _Z2f4P1E +// CHECK: load i32, {{.*}}, !tbaa [[TAG_A_y]] + return (&(e->d))->y; +} + +// CHECK-DAG: [[TYPE_char:!.*]] = !{!"omnipotent char", {{.*}}, i64 0} +// CHECK-DAG: [[TYPE_int:!.*]] = !{!"int", [[TYPE_char]], i64 0} +// CHECK-DAG: [[TYPE_A:!.*]] = !{!"_ZTS1A", [[TYPE_int]], i64 0, [[TYPE_int]], i64 4, [[TYPE_int]], i64 8} +// CHECK-DAG: [[TAG_A_y]] = !{[[TYPE_A]], [[TYPE_int]], i64 4} |

