AlexVlx created this revision. AlexVlx added reviewers: yaxunl, efriedma, rjmccall. Herald added a project: All. AlexVlx requested review of this revision. Herald added a project: clang. Herald added a subscriber: cfe-commits.
Unfortunately, https://reviews.llvm.org/rG8acdcf4016876d122733991561be706b64026e73 didn't include handling for the fact that `throw`'s implementation takes a pointer to a type's `typeinfo` struct, which implies that its signature needs to change as well. This patch corrects that and adds a test. Repository: rG LLVM Github Monorepo https://reviews.llvm.org/D155759 Files: clang/lib/CodeGen/ItaniumCXXABI.cpp clang/test/CodeGenCXX/throw-expression-typeinfo-in-address-space.cpp Index: clang/test/CodeGenCXX/throw-expression-typeinfo-in-address-space.cpp =================================================================== --- /dev/null +++ clang/test/CodeGenCXX/throw-expression-typeinfo-in-address-space.cpp @@ -0,0 +1,17 @@ +// RUN: %clang_cc1 %s -triple amdgcn-amd-amdhsa -emit-llvm -fcxx-exceptions -fexceptions -std=c++11 -o - | FileCheck %s + +struct X { + ~X(); +}; + +struct Error { + Error(const X&) noexcept; +}; + +void f() { + try { + throw Error(X()); + } catch (...) { } +} + +// CHECK: declare void @__cxa_throw(ptr, ptr addrspace(1), ptr) Index: clang/lib/CodeGen/ItaniumCXXABI.cpp =================================================================== --- clang/lib/CodeGen/ItaniumCXXABI.cpp +++ clang/lib/CodeGen/ItaniumCXXABI.cpp @@ -1252,7 +1252,7 @@ // void __cxa_throw(void *thrown_exception, std::type_info *tinfo, // void (*dest) (void *)); - llvm::Type *Args[3] = { CGM.Int8PtrTy, CGM.Int8PtrTy, CGM.Int8PtrTy }; + llvm::Type *Args[3] = { CGM.Int8PtrTy, CGM.GlobalsInt8PtrTy, CGM.Int8PtrTy }; llvm::FunctionType *FTy = llvm::FunctionType::get(CGM.VoidTy, Args, /*isVarArg=*/false);
Index: clang/test/CodeGenCXX/throw-expression-typeinfo-in-address-space.cpp =================================================================== --- /dev/null +++ clang/test/CodeGenCXX/throw-expression-typeinfo-in-address-space.cpp @@ -0,0 +1,17 @@ +// RUN: %clang_cc1 %s -triple amdgcn-amd-amdhsa -emit-llvm -fcxx-exceptions -fexceptions -std=c++11 -o - | FileCheck %s + +struct X { + ~X(); +}; + +struct Error { + Error(const X&) noexcept; +}; + +void f() { + try { + throw Error(X()); + } catch (...) { } +} + +// CHECK: declare void @__cxa_throw(ptr, ptr addrspace(1), ptr) Index: clang/lib/CodeGen/ItaniumCXXABI.cpp =================================================================== --- clang/lib/CodeGen/ItaniumCXXABI.cpp +++ clang/lib/CodeGen/ItaniumCXXABI.cpp @@ -1252,7 +1252,7 @@ // void __cxa_throw(void *thrown_exception, std::type_info *tinfo, // void (*dest) (void *)); - llvm::Type *Args[3] = { CGM.Int8PtrTy, CGM.Int8PtrTy, CGM.Int8PtrTy }; + llvm::Type *Args[3] = { CGM.Int8PtrTy, CGM.GlobalsInt8PtrTy, CGM.Int8PtrTy }; llvm::FunctionType *FTy = llvm::FunctionType::get(CGM.VoidTy, Args, /*isVarArg=*/false);
_______________________________________________ cfe-commits mailing list cfe-commits@lists.llvm.org https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits