diff options
Diffstat (limited to 'clang')
| -rw-r--r-- | clang/lib/Basic/Targets.cpp | 17 | ||||
| -rw-r--r-- | clang/test/Preprocessor/init.c | 17 |
2 files changed, 19 insertions, 15 deletions
diff --git a/clang/lib/Basic/Targets.cpp b/clang/lib/Basic/Targets.cpp index 9756b0577c4..503bc1203c9 100644 --- a/clang/lib/Basic/Targets.cpp +++ b/clang/lib/Basic/Targets.cpp @@ -5726,16 +5726,19 @@ class SparcV8TargetInfo : public SparcTargetInfo { public: SparcV8TargetInfo(const llvm::Triple &Triple) : SparcTargetInfo(Triple) { DataLayoutString = "E-m:e-p:32:32-i64:64-f128:64-n32-S64"; - // NetBSD uses long (same as llvm default); everyone else uses int. - if (getTriple().getOS() == llvm::Triple::NetBSD) { - SizeType = UnsignedLong; - IntPtrType = SignedLong; - PtrDiffType = SignedLong; - } else { + // NetBSD / OpenBSD use long (same as llvm default); everyone else uses int. + switch (getTriple().getOS()) { + default: SizeType = UnsignedInt; IntPtrType = SignedInt; PtrDiffType = SignedInt; - } + break; + case llvm::Triple::NetBSD: + case llvm::Triple::OpenBSD: + SizeType = UnsignedLong; + IntPtrType = SignedLong; + PtrDiffType = SignedLong; + break; } void getTargetDefines(const LangOptions &Opts, diff --git a/clang/test/Preprocessor/init.c b/clang/test/Preprocessor/init.c index a937a018eb8..6e639370e00 100644 --- a/clang/test/Preprocessor/init.c +++ b/clang/test/Preprocessor/init.c @@ -6984,14 +6984,15 @@ // SPARC:#define __sparcv8 1 // SPARC:#define sparc 1 // -// RUN: %clang_cc1 -E -dM -ffreestanding -triple=sparc-none-netbsd < /dev/null | FileCheck -check-prefix SPARC-NETBSD %s -// SPARC-NETBSD:#define __INTPTR_FMTd__ "ld" -// SPARC-NETBSD:#define __INTPTR_FMTi__ "li" -// SPARC-NETBSD:#define __INTPTR_MAX__ 2147483647L -// SPARC-NETBSD:#define __INTPTR_TYPE__ long int -// SPARC-NETBSD:#define __PTRDIFF_TYPE__ long int -// SPARC-NETBSD:#define __SIZE_TYPE__ long unsigned int -// SPARC-NETBSD:#define __UINTPTR_TYPE__ long unsigned int +// RUN: %clang_cc1 -E -dM -ffreestanding -triple=sparc-none-netbsd < /dev/null | FileCheck -check-prefix SPARC-NETOPENBSD %s +// RUN: %clang_cc1 -E -dM -ffreestanding -triple=sparc-none-openbsd < /dev/null | FileCheck -check-prefix SPARC-NETOPENBSD %s +// SPARC-NETOPENBSD:#define __INTPTR_FMTd__ "ld" +// SPARC-NETOPENBSD:#define __INTPTR_FMTi__ "li" +// SPARC-NETOPENBSD:#define __INTPTR_MAX__ 2147483647L +// SPARC-NETOPENBSD:#define __INTPTR_TYPE__ long int +// SPARC-NETOPENBSD:#define __PTRDIFF_TYPE__ long int +// SPARC-NETOPENBSD:#define __SIZE_TYPE__ long unsigned int +// SPARC-NETOPENBSD:#define __UINTPTR_TYPE__ long unsigned int // RUN: %clang_cc1 -E -dM -ffreestanding -triple=tce-none-none < /dev/null | FileCheck -check-prefix TCE %s // |

