blob: 58834a550be1dcabe45710972369e594493817dc [file] [log] [blame]
Hans Wennborgc9bd88e2014-01-14 19:35:09 +00001// RUN: %clang_cc1 -emit-llvm %s -verify -fno-rtti -triple %itanium_abi_triple -o - | FileCheck %s
Arnaud A. de Grandmaisoncb6f9432013-08-01 08:28:32 +00002// expected-no-diagnostics
3
4struct A {
5 virtual ~A(){};
6};
7
8struct B : public A {
9 B() : A() {}
10};
11
12// An upcast can be resolved statically and can be used with -fno-rtti, iff it
13// does not use runtime support.
14A *upcast(B *b) {
15 return dynamic_cast<A *>(b);
David Blaikieea3e51d2015-06-29 17:29:50 +000016// CHECK-LABEL: define {{.*}}%struct.A* @_Z6upcastP1B
17// CHECK-NOT: call {{.*}}i8* @__dynamic_cast
Arnaud A. de Grandmaisoncb6f9432013-08-01 08:28:32 +000018}
19
20// A NoOp dynamic_cast can be used with -fno-rtti iff it does not use
21// runtime support.
22B *samecast(B *b) {
23 return dynamic_cast<B *>(b);
David Blaikieea3e51d2015-06-29 17:29:50 +000024// CHECK-LABEL: define {{.*}}%struct.B* @_Z8samecastP1B
25// CHECK-NOT: call {{.*}}i8* @__dynamic_cast
Arnaud A. de Grandmaisoncb6f9432013-08-01 08:28:32 +000026}