From: Anton Korobeynikov Date: Sat, 22 Mar 2008 20:57:27 +0000 (+0000) Subject: Add convenient helper for win64 check. Simplify things slightly. X-Git-Url: http://plrg.eecs.uci.edu/git/?a=commitdiff_plain;h=1a979d9eab68b353208cdff87b09ff703d5bf15d;p=oota-llvm.git Add convenient helper for win64 check. Simplify things slightly. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@48691 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/Target/X86/X86CallingConv.td b/lib/Target/X86/X86CallingConv.td index 3206e183eb7..d4f4e265c23 100644 --- a/lib/Target/X86/X86CallingConv.td +++ b/lib/Target/X86/X86CallingConv.td @@ -101,8 +101,7 @@ def RetCC_X86_32 : CallingConv<[ // This is the root return-value convention for the X86-64 backend. def RetCC_X86_64 : CallingConv<[ // Mingw64 and native Win64 use Win64 CC - CCIfSubtarget<"isTargetMingw()", CCDelegateTo>, - CCIfSubtarget<"isTargetWindows()", CCDelegateTo>, + CCIfSubtarget<"isTargetWin64()", CCDelegateTo>, // Otherwise, drop to normal X86-64 CC CCDelegateTo diff --git a/lib/Target/X86/X86ISelLowering.cpp b/lib/Target/X86/X86ISelLowering.cpp index 933c33e3d4d..dd2d7849d77 100644 --- a/lib/Target/X86/X86ISelLowering.cpp +++ b/lib/Target/X86/X86ISelLowering.cpp @@ -1009,7 +1009,7 @@ CCAssignFn *X86TargetLowering::CCAssignFnForNode(SDOperand Op) const { unsigned CC = cast(Op.getOperand(1))->getValue(); if (Subtarget->is64Bit()) { - if (Subtarget->isTargetWindows() || Subtarget->isTargetMingw()) + if (Subtarget->isTargetWin64()) return CC_X86_Win64_C; else { if (CC == CallingConv::Fast && PerformTailCallOpt) diff --git a/lib/Target/X86/X86Subtarget.h b/lib/Target/X86/X86Subtarget.h index e34d1f1aeef..6488d474d19 100644 --- a/lib/Target/X86/X86Subtarget.h +++ b/lib/Target/X86/X86Subtarget.h @@ -138,6 +138,9 @@ public: bool isTargetCygMing() const { return (TargetType == isMingw || TargetType == isCygwin); } bool isTargetCygwin() const { return TargetType == isCygwin; } + bool isTargetWin64() const { + return (Is64Bit && (TargetType == isMingw || TargetType == isWindows)); + } std::string getDataLayout() const { const char *p;