From 09b6e6e8854cc4a824060101a9633082e55d7a33 Mon Sep 17 00:00:00 2001 From: Anders Carlsson Date: Tue, 29 Dec 2009 20:20:19 +0000 Subject: [PATCH] Fix function type RTTI linkage and add tests. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@92266 91177308-0d34-0410-b5e6-96231b3b80d8 --- lib/CodeGen/CGRTTI.cpp | 18 ++++++++++++++---- test/CodeGenCXX/rtti-linkage.cpp | 17 ++++++++++++++++- 2 files changed, 30 insertions(+), 5 deletions(-) diff --git a/lib/CodeGen/CGRTTI.cpp b/lib/CodeGen/CGRTTI.cpp index 937a4420ef..fc1098c985 100644 --- a/lib/CodeGen/CGRTTI.cpp +++ b/lib/CodeGen/CGRTTI.cpp @@ -365,11 +365,10 @@ public: case Type::Pointer: case Type::MemberPointer: - return BuildTypeInfo(Ty); - case Type::FunctionProto: case Type::FunctionNoProto: - return BuildSimpleType(Ty, "_ZTVN10__cxxabiv120__function_type_infoE"); + return BuildTypeInfo(Ty); + case Type::ConstantArray: case Type::IncompleteArray: case Type::VariableArray: @@ -681,8 +680,13 @@ void RTTIBuilder::BuildVtablePointer(const Type *Ty) { break; case Type::MemberPointer: // abi::__pointer_to_member_type_info - VtableName = "_ZTVN10__cxxabiv129__pointer_to_member_type_infoE"; + VtableName = "_ZTVN10__cxxabiv129__pointer_to_member_type_infoE"; break; + + case Type::FunctionNoProto: + case Type::FunctionProto: + // abi::__function_type_info + VtableName = "_ZTVN10__cxxabiv120__function_type_infoE"; } llvm::Constant *Vtable = @@ -730,6 +734,12 @@ llvm::Constant *RTTIBuilder::BuildTypeInfo(QualType Ty) { assert(false && "Builtin type info must be in the standard library!"); break; + case Type::FunctionNoProto: + case Type::FunctionProto: + // Itanium C++ ABI 2.9.5p4: + // abi::__function_type_info adds no data members to std::type_info; + break; + case Type::Record: { const CXXRecordDecl *RD = cast(cast(Ty)->getDecl()); diff --git a/test/CodeGenCXX/rtti-linkage.cpp b/test/CodeGenCXX/rtti-linkage.cpp index 11f328a1e4..b4caa86229 100644 --- a/test/CodeGenCXX/rtti-linkage.cpp +++ b/test/CodeGenCXX/rtti-linkage.cpp @@ -28,6 +28,15 @@ // CHECK: _ZTIN12_GLOBAL__N_11DE = internal constant // CHECK: _ZTSPN12_GLOBAL__N_11DE = internal constant // CHECK: _ZTIPN12_GLOBAL__N_11DE = internal constant +// CHECK: _ZTSFN12_GLOBAL__N_11DEvE = internal constant +// CHECK: _ZTIFN12_GLOBAL__N_11DEvE = internal constant +// CHECK: _ZTSFvN12_GLOBAL__N_11DEE = internal constant +// CHECK: _ZTIFvN12_GLOBAL__N_11DEE = internal constant + +// CHECK: _ZTSPFvvE = weak_odr constant +// CHECK: _ZTSFvvE = weak_odr constant +// CHECK: _ZTIFvvE = weak_odr +// CHECK: _ZTIPFvvE = weak_odr constant // A has no key function, so its RTTI data should be weak_odr. struct A { }; @@ -64,7 +73,13 @@ const D getD(); const std::type_info &t2() { (void)typeid(const D); - (void)typeid(D *); + (void)typeid(D *); + (void)typeid(D (*)()); + (void)typeid(void (*)(D)); + // The exception specification is not part of the RTTI descriptor, so it should not have + // internal linkage. + (void)typeid(void (*)() throw (D)); + // CHECK: _ZTIN12_GLOBAL__N_11DE to return typeid(getD()); } -- 2.50.1