mirror of
https://github.com/llvm/llvm-project.git
synced 2025-05-09 21:26:06 +00:00

This implements the flag proposed in RFC http://lists.llvm.org/pipermail/cfe-dev/2020-August/066437.html. The goal is to add a way to override the default target C++ ABI through a compiler flag. This makes it easier to test and transition between different C++ ABIs through compile flags rather than build flags. In this patch: - Store -fc++-abi= in a LangOpt. This isn't stored in a CodeGenOpt because there are instances outside of codegen where Clang needs to know what the ABI is (particularly through ASTContext::createCXXABI), and we should be able to override the target default if the flag is provided at that point. - Expose the existing ABIs in TargetCXXABI as values that can be passed through this flag. - Create a .def file for these ABIs to make it easier to check flag values. - Add an error for diagnosing bad ABI flag values. Differential Revision: https://reviews.llvm.org/D85802
29 lines
894 B
C++
29 lines
894 B
C++
// Assert that the ABI switch uses the proper codegen. Fuchsia uses the
|
|
// "return this" ABI on constructors and destructors by default, but if we
|
|
// explicitly choose the generic itanium C++ ABI, we should not return "this" on
|
|
// ctors/dtors.
|
|
//
|
|
// RUN: %clang_cc1 %s -emit-llvm -o - -triple=x86_64-unknown-fuchsia -fc++-abi=itanium | FileCheck %s
|
|
// RUN: %clang_cc1 %s -emit-llvm -o - -triple=aarch64-unknown-fuchsia -fc++-abi=itanium | FileCheck %s
|
|
|
|
class A {
|
|
public:
|
|
virtual ~A();
|
|
int x_;
|
|
};
|
|
|
|
class B : public A {
|
|
public:
|
|
B(int *i);
|
|
virtual ~B();
|
|
int *i_;
|
|
};
|
|
|
|
B::B(int *i) : i_(i) {}
|
|
B::~B() {}
|
|
|
|
// CHECK: define{{.*}} void @_ZN1BC2EPi(%class.B* {{[^,]*}} %this, i32* %i)
|
|
// CHECK: define{{.*}} void @_ZN1BC1EPi(%class.B* {{[^,]*}} %this, i32* %i)
|
|
// CHECK: define{{.*}} void @_ZN1BD2Ev(%class.B* {{[^,]*}} %this)
|
|
// CHECK: define{{.*}} void @_ZN1BD1Ev(%class.B* {{[^,]*}} %this)
|