From: Tamas Berghammer Date: Wed, 25 Mar 2015 10:38:50 +0000 (+0000) Subject: Create android x86_32 and x86_64 target info X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=61dc389d9368f99eb73d3b10ac8324c548c4cc44;p=clang Create android x86_32 and x86_64 target info On android x86_32 the long double is only 64 bits (compared to 80 bits on linux x86_32) and on android x86_64 the long double is IEEEquad (compared to x87DoubleExtended on linux x86_64). This CL creates new TargetInfo classes for this targets to represent these differences. Differential revision: http://reviews.llvm.org/D8357 git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@233177 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/Basic/Targets.cpp b/lib/Basic/Targets.cpp index d5602b6e9e..25ce32e466 100644 --- a/lib/Basic/Targets.cpp +++ b/lib/Basic/Targets.cpp @@ -6506,6 +6506,30 @@ const Builtin::Info XCoreTargetInfo::BuiltinInfo[] = { }; } // end anonymous namespace. +namespace { +// x86_32 Android target +class AndroidX86_32TargetInfo : public LinuxTargetInfo { +public: + AndroidX86_32TargetInfo(const llvm::Triple &Triple) + : LinuxTargetInfo(Triple) { + SuitableAlign = 32; + LongDoubleWidth = 64; + LongDoubleFormat = &llvm::APFloat::IEEEdouble; + } +}; +} // end anonymous namespace + +namespace { +// x86_64 Android target +class AndroidX86_64TargetInfo : public LinuxTargetInfo { +public: + AndroidX86_64TargetInfo(const llvm::Triple &Triple) + : LinuxTargetInfo(Triple) { + LongDoubleFormat = &llvm::APFloat::IEEEquad; + } +}; +} // end anonymous namespace + //===----------------------------------------------------------------------===// // Driver code @@ -6783,8 +6807,14 @@ static TargetInfo *AllocateTarget(const llvm::Triple &Triple) { return new DarwinI386TargetInfo(Triple); switch (os) { - case llvm::Triple::Linux: - return new LinuxTargetInfo(Triple); + case llvm::Triple::Linux: { + switch (Triple.getEnvironment()) { + default: + return new LinuxTargetInfo(Triple); + case llvm::Triple::Android: + return new AndroidX86_32TargetInfo(Triple); + } + } case llvm::Triple::DragonFly: return new DragonFlyBSDTargetInfo(Triple); case llvm::Triple::NetBSD: @@ -6831,8 +6861,14 @@ static TargetInfo *AllocateTarget(const llvm::Triple &Triple) { switch (os) { case llvm::Triple::CloudABI: return new CloudABITargetInfo(Triple); - case llvm::Triple::Linux: - return new LinuxTargetInfo(Triple); + case llvm::Triple::Linux: { + switch (Triple.getEnvironment()) { + default: + return new LinuxTargetInfo(Triple); + case llvm::Triple::Android: + return new AndroidX86_64TargetInfo(Triple); + } + } case llvm::Triple::DragonFly: return new DragonFlyBSDTargetInfo(Triple); case llvm::Triple::NetBSD: diff --git a/test/Sema/i386-linux-android.c b/test/Sema/i386-linux-android.c new file mode 100644 index 0000000000..a22cef7bfd --- /dev/null +++ b/test/Sema/i386-linux-android.c @@ -0,0 +1,6 @@ +// RUN: %clang_cc1 -triple i386-linux-android -fsyntax-only -verify %s +// expected-no-diagnostics + +extern int a1_0[sizeof(long double) == 8 ? 1 : -1]; +extern int a1_i[__alignof(long double) == 4 ? 1 : -1]; + diff --git a/test/Sema/x86_64-linux-android.c b/test/Sema/x86_64-linux-android.c new file mode 100644 index 0000000000..e09d50ca07 --- /dev/null +++ b/test/Sema/x86_64-linux-android.c @@ -0,0 +1,10 @@ +// RUN: %clang_cc1 -triple x86_64-linux-android -emit-pch -o %t %s +// RUN: %clang_cc1 -x ast -ast-print %t | FileCheck %s + +extern int a1_0[sizeof(long double) == 16 ? 1 : -1]; +extern int a1_i[__alignof(long double) == 16 ? 1 : -1]; + +// Verify that long double is 128 bit IEEEquad + +long double foo = 1.0E4000L; +// CHECK: long double foo = 1.00000000000000000000000000000000004E+4000L;