From 03bb1778b664159e449bc6c9c50256dee4152a83 Mon Sep 17 00:00:00 2001 From: Sven van Haastregt Date: Thu, 17 Oct 2019 14:12:51 +0000 Subject: [OpenCL] Preserve addrspace in CGClass (PR43145) PR43145 revealed two places where Clang was attempting to create a bitcast without considering the address space of class types during C++ class code generation. Differential Revision: https://reviews.llvm.org/D68403 git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@375118 91177308-0d34-0410-b5e6-96231b3b80d8 --- lib/CodeGen/CGClass.cpp | 7 ++++-- test/CodeGenOpenCLCXX/addrspace-derived-base.cl | 30 +++++++++++++++++++++++++ 2 files changed, 35 insertions(+), 2 deletions(-) diff --git a/lib/CodeGen/CGClass.cpp b/lib/CodeGen/CGClass.cpp index 7cff6210c2..04ef912b18 100644 --- a/lib/CodeGen/CGClass.cpp +++ b/lib/CodeGen/CGClass.cpp @@ -246,7 +246,8 @@ ApplyNonVirtualAndVirtualOffset(CodeGenFunction &CGF, Address addr, // Apply the base offset. llvm::Value *ptr = addr.getPointer(); - ptr = CGF.Builder.CreateBitCast(ptr, CGF.Int8PtrTy); + unsigned AddrSpace = ptr->getType()->getPointerAddressSpace(); + ptr = CGF.Builder.CreateBitCast(ptr, CGF.Int8Ty->getPointerTo(AddrSpace)); ptr = CGF.Builder.CreateInBoundsGEP(ptr, baseOffset, "add.ptr"); // If we have a virtual component, the alignment of the result will @@ -381,7 +382,9 @@ CodeGenFunction::GetAddressOfDerivedClass(Address BaseAddr, QualType DerivedTy = getContext().getCanonicalType(getContext().getTagDeclType(Derived)); - llvm::Type *DerivedPtrTy = ConvertType(DerivedTy)->getPointerTo(); + unsigned AddrSpace = + BaseAddr.getPointer()->getType()->getPointerAddressSpace(); + llvm::Type *DerivedPtrTy = ConvertType(DerivedTy)->getPointerTo(AddrSpace); llvm::Value *NonVirtualOffset = CGM.GetNonVirtualBaseClassOffset(Derived, PathBegin, PathEnd); diff --git a/test/CodeGenOpenCLCXX/addrspace-derived-base.cl b/test/CodeGenOpenCLCXX/addrspace-derived-base.cl index 916bb50ae8..ba76dbb4c6 100644 --- a/test/CodeGenOpenCLCXX/addrspace-derived-base.cl +++ b/test/CodeGenOpenCLCXX/addrspace-derived-base.cl @@ -11,6 +11,7 @@ public: void foo() { D d; + //CHECK-LABEL: foo //CHECK: addrspacecast %class.D* %d to %class.D addrspace(4)* //CHECK: call spir_func i32 @_ZNU3AS41D5getmbEv(%class.D addrspace(4)* d.getmb(); @@ -20,3 +21,32 @@ void foo() { //CHECK: define linkonce_odr spir_func i32 @_ZNU3AS41D5getmbEv(%class.D addrspace(4)* %this) //CHECK: bitcast %class.D addrspace(4)* %this1 to %struct.B addrspace(4)* + + +// Calling base method through multiple inheritance. + +class B2 { + public: + void baseMethod() const { } + int bb; +}; + +class Derived : public B, public B2 { + public: + void work() const { baseMethod(); } + // CHECK-LABEL: work + // CHECK: bitcast i8 addrspace(4)* %add.ptr to %class.B2 addrspace(4)* +}; + +void pr43145(const Derived *argDerived) { + argDerived->work(); +} + +// Casting from base to derived. + +void pr43145_2(B *argB) { + Derived *x = (Derived*)argB; +} + +// CHECK-LABEL: @_Z9pr43145_2 +// CHECK: bitcast %struct.B addrspace(4)* %0 to %class.Derived addrspace(4)* -- cgit v1.2.1