r220555 - [Thumb] Clang thinks "char" is signed when using a thumb triple
Oliver Stannard
oliver.stannard at arm.com
Fri Oct 24 04:28:47 PDT 2014
Author: olista01
Date: Fri Oct 24 06:28:47 2014
New Revision: 220555
URL: http://llvm.org/viewvc/llvm-project?rev=220555&view=rev
Log:
[Thumb] Clang thinks "char" is signed when using a thumb triple
'char' is unsigned on all ARM and Thumb architectures. Clang gets this
right for ARM, and for thumb when using and arm triple and the -mthumb
option, but gets it wrong for thumb triples. This fixes that.
Modified:
cfe/trunk/lib/Driver/Tools.cpp
cfe/trunk/test/Lexer/wchar-signedness.c
Modified: cfe/trunk/lib/Driver/Tools.cpp
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/Driver/Tools.cpp?rev=220555&r1=220554&r2=220555&view=diff
==============================================================================
--- cfe/trunk/lib/Driver/Tools.cpp (original)
+++ cfe/trunk/lib/Driver/Tools.cpp Fri Oct 24 06:28:47 2014
@@ -459,6 +459,8 @@ static bool isSignedCharDefault(const ll
case llvm::Triple::aarch64_be:
case llvm::Triple::arm:
case llvm::Triple::armeb:
+ case llvm::Triple::thumb:
+ case llvm::Triple::thumbeb:
if (Triple.isOSDarwin() || Triple.isOSWindows())
return true;
return false;
Modified: cfe/trunk/test/Lexer/wchar-signedness.c
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/test/Lexer/wchar-signedness.c?rev=220555&r1=220554&r2=220555&view=diff
==============================================================================
--- cfe/trunk/test/Lexer/wchar-signedness.c (original)
+++ cfe/trunk/test/Lexer/wchar-signedness.c Fri Oct 24 06:28:47 2014
@@ -1,5 +1,6 @@
// RUN: %clang_cc1 -fsyntax-only -dM -E %s -triple x86_64-none-linux-gnu | FileCheck %s --check-prefix=CHECK-X86
// RUN: %clang_cc1 -fsyntax-only -dM -E %s -triple armv7-none-eabi | FileCheck %s --check-prefix=CHECK-ARM
+// RUN: %clang_cc1 -fsyntax-only -dM -E %s -triple thumbv7-none-eabi | FileCheck %s --check-prefix=CHECK-ARM
// CHECK-X86-NOT: #define __WCHAR_UNSIGNED__
// CHECK-X86: #define __WINT_UNSIGNED__ 1
More information about the cfe-commits
mailing list