diff options
author | Chris Lattner <sabre@nondot.org> | 2008-10-17 18:15:05 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2008-10-17 18:15:05 +0000 |
commit | 8e2ef196ae5e4969ee0de2ede803450f9ee1a472 (patch) | |
tree | 29a770a550de229c7fb29a271b8463acc6cb058b /llvm/lib | |
parent | c7e65f4377f383df28b6b4318354b7285e3039fd (diff) | |
download | bcm5719-llvm-8e2ef196ae5e4969ee0de2ede803450f9ee1a472.tar.gz bcm5719-llvm-8e2ef196ae5e4969ee0de2ede803450f9ee1a472.zip |
add support for 128 bit inputs on both x86-64 and x86-32.
llvm-svn: 57709
Diffstat (limited to 'llvm/lib')
-rw-r--r-- | llvm/lib/Target/X86/X86ISelLowering.cpp | 15 |
1 files changed, 6 insertions, 9 deletions
diff --git a/llvm/lib/Target/X86/X86ISelLowering.cpp b/llvm/lib/Target/X86/X86ISelLowering.cpp index 0607797b713..fa467693bcf 100644 --- a/llvm/lib/Target/X86/X86ISelLowering.cpp +++ b/llvm/lib/Target/X86/X86ISelLowering.cpp @@ -7509,15 +7509,13 @@ X86TargetLowering::getRegForInlineAsmConstraint(const std::string &Constraint, case 'r': // GENERAL_REGS case 'R': // LEGACY_REGS case 'l': // INDEX_REGS - if (VT == MVT::i64 && Subtarget->is64Bit()) - return std::make_pair(0U, X86::GR64RegisterClass); - if (VT == MVT::i32 || VT == MVT::i64) - return std::make_pair(0U, X86::GR32RegisterClass); - else if (VT == MVT::i16) - return std::make_pair(0U, X86::GR16RegisterClass); - else if (VT == MVT::i8) + if (VT == MVT::i8) return std::make_pair(0U, X86::GR8RegisterClass); - break; + if (VT == MVT::i16) + return std::make_pair(0U, X86::GR16RegisterClass); + if (VT == MVT::i32 || !Subtarget->is64Bit()) + return std::make_pair(0U, X86::GR32RegisterClass); + return std::make_pair(0U, X86::GR64RegisterClass); case 'f': // FP Stack registers. // If SSE is enabled for this VT, use f80 to ensure the isel moves the // value to the correct fpstack register class. @@ -7529,7 +7527,6 @@ X86TargetLowering::getRegForInlineAsmConstraint(const std::string &Constraint, case 'y': // MMX_REGS if MMX allowed. if (!Subtarget->hasMMX()) break; return std::make_pair(0U, X86::VR64RegisterClass); - break; case 'Y': // SSE_REGS if SSE2 allowed if (!Subtarget->hasSSE2()) break; // FALL THROUGH. |