r332160 - Force the PS4 clang ABI version to 6.
Douglas Yung via cfe-commits
cfe-commits at lists.llvm.org
Fri May 11 17:07:00 PDT 2018
Author: dyung
Date: Fri May 11 17:06:59 2018
New Revision: 332160
URL: http://llvm.org/viewvc/llvm-project?rev=332160&view=rev
Log:
Force the PS4 clang ABI version to 6.
The PS4 requires clang ABI version 6 for compatibility reasons. This change forces this and if the user specifies a different version when the PS4 target is specified, the compiler emits a warning that the specified version is being ignored.
Reviewers: probinson
Subscribers: cfe-commits
Differential Revision: https://reviews.llvm.org/D46767
Added:
cfe/trunk/test/Driver/clang-abi-compat.cpp
Modified:
cfe/trunk/include/clang/Basic/DiagnosticDriverKinds.td
cfe/trunk/lib/Frontend/CompilerInvocation.cpp
cfe/trunk/test/CodeGenCXX/alignment.cpp
Modified: cfe/trunk/include/clang/Basic/DiagnosticDriverKinds.td
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/include/clang/Basic/DiagnosticDriverKinds.td?rev=332160&r1=332159&r2=332160&view=diff
==============================================================================
--- cfe/trunk/include/clang/Basic/DiagnosticDriverKinds.td (original)
+++ cfe/trunk/include/clang/Basic/DiagnosticDriverKinds.td Fri May 11 17:06:59 2018
@@ -150,6 +150,9 @@ def warn_drv_unknown_argument_clang_cl :
def warn_drv_unknown_argument_clang_cl_with_suggestion : Warning<
"unknown argument ignored in clang-cl '%0' (did you mean '%1'?)">,
InGroup<UnknownArgument>;
+def warn_drv_ignored_clang_abi_version : Warning<
+ "target requires clang ABI version %0, ignoring requested version">,
+ InGroup<UnusedCommandLineArgument>;
def warn_drv_ycyu_no_arg_clang_cl : Warning<
"support for '%0' without a filename not implemented yet; flag ignored">,
Modified: cfe/trunk/lib/Frontend/CompilerInvocation.cpp
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/Frontend/CompilerInvocation.cpp?rev=332160&r1=332159&r2=332160&view=diff
==============================================================================
--- cfe/trunk/lib/Frontend/CompilerInvocation.cpp (original)
+++ cfe/trunk/lib/Frontend/CompilerInvocation.cpp Fri May 11 17:06:59 2018
@@ -2751,6 +2751,16 @@ static void ParseLangArgs(LangOptions &O
<< A->getAsString(Args) << A->getValue();
}
}
+ // The PS4 requires version 6 of the clang ABI.
+ if (T.isPS4()) {
+ // Issue a warning if another version of the ABI was requested.
+ if (Args.getLastArg(OPT_fclang_abi_compat_EQ) &&
+ Opts.getClangABICompat() != LangOptions::ClangABI::Ver6) {
+ Diags.Report(diag::warn_drv_ignored_clang_abi_version)
+ << 6;
+ }
+ Opts.setClangABICompat(LangOptions::ClangABI::Ver6);
+ }
}
static bool isStrictlyPreprocessorAction(frontend::ActionKind Action) {
Modified: cfe/trunk/test/CodeGenCXX/alignment.cpp
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/test/CodeGenCXX/alignment.cpp?rev=332160&r1=332159&r2=332160&view=diff
==============================================================================
--- cfe/trunk/test/CodeGenCXX/alignment.cpp (original)
+++ cfe/trunk/test/CodeGenCXX/alignment.cpp Fri May 11 17:06:59 2018
@@ -1,5 +1,8 @@
// RUN: %clang_cc1 %s -emit-llvm -o - -triple=x86_64-apple-darwin10 | FileCheck %s --check-prefix=CHECK --check-prefix=CHECK-NOCOMPAT
// RUN: %clang_cc1 %s -emit-llvm -o - -triple=x86_64-apple-darwin10 -fclang-abi-compat=6.0 | FileCheck %s --check-prefix=CHECK --check-prefix=CHECK-V6COMPAT
+// Check that the PS4 target uses the 6.0 compat settings.
+// RUN: %clang_cc1 %s -emit-llvm -o - -triple=x86_64-scei-ps4 | FileCheck %s --check-prefix=CHECK --check-prefix=CHECK-V6COMPAT
+// RUN: %clang_cc1 %s -emit-llvm -o - -triple=x86_64-scei-ps4 -fclang-abi-compat=latest | FileCheck %s --check-prefix=CHECK --check-prefix=CHECK-V6COMPAT
extern int int_source();
extern void int_sink(int x);
Added: cfe/trunk/test/Driver/clang-abi-compat.cpp
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/test/Driver/clang-abi-compat.cpp?rev=332160&view=auto
==============================================================================
--- cfe/trunk/test/Driver/clang-abi-compat.cpp (added)
+++ cfe/trunk/test/Driver/clang-abi-compat.cpp Fri May 11 17:06:59 2018
@@ -0,0 +1,6 @@
+// PS4 target requires clang ABI version 6, check that a warning is emitted when a version other than 6 is requested.
+// RUN: %clang -S --target=x86_64-scei-ps4 -fclang-abi-compat=4 %s 2>&1 | FileCheck %s -check-prefix=CHECK-WARNING
+// RUN: %clang -S --target=x86_64-scei-ps4 -fclang-abi-compat=latest %s 2>&1 | FileCheck %s -check-prefix=CHECK-WARNING
+
+// CHECK-WARNING: warning: target requires clang ABI version 6, ignoring requested version
+
More information about the cfe-commits
mailing list