diff options
Diffstat (limited to 'llvm/lib/Target')
| -rw-r--r-- | llvm/lib/Target/ARM/ARMFastISel.cpp | 7 | ||||
| -rw-r--r-- | llvm/lib/Target/ARM/ARMISelLowering.cpp | 1 | ||||
| -rw-r--r-- | llvm/lib/Target/ARM/ARMISelLowering.h | 6 | 
3 files changed, 14 insertions, 0 deletions
| diff --git a/llvm/lib/Target/ARM/ARMFastISel.cpp b/llvm/lib/Target/ARM/ARMFastISel.cpp index 0f11ac9a3a0..13724da5d4f 100644 --- a/llvm/lib/Target/ARM/ARMFastISel.cpp +++ b/llvm/lib/Target/ARM/ARMFastISel.cpp @@ -1718,6 +1718,13 @@ bool ARMFastISel::SelectRem(const Instruction *I, bool isSigned) {    if (!isTypeLegal(Ty, VT))      return false; +  // Many ABIs do not provide a libcall for standalone remainder, so we need to +  // use divrem (see the RTABI 4.3.1). Since FastISel can't handle non-double +  // multi-reg returns, we'll have to bail out. +  if (!TLI.hasStandaloneRem(VT)) { +    return false; +  } +    RTLIB::Libcall LC = RTLIB::UNKNOWN_LIBCALL;    if (VT == MVT::i8)      LC = isSigned ? RTLIB::SREM_I8 : RTLIB::UREM_I8; diff --git a/llvm/lib/Target/ARM/ARMISelLowering.cpp b/llvm/lib/Target/ARM/ARMISelLowering.cpp index ef019f98726..d6e7caf98a8 100644 --- a/llvm/lib/Target/ARM/ARMISelLowering.cpp +++ b/llvm/lib/Target/ARM/ARMISelLowering.cpp @@ -806,6 +806,7 @@ ARMTargetLowering::ARMTargetLowering(const TargetMachine &TM,        Subtarget->isTargetGNUAEABI() || Subtarget->isTargetMuslAEABI()) {      setOperationAction(ISD::SREM, MVT::i64, Custom);      setOperationAction(ISD::UREM, MVT::i64, Custom); +    HasStandaloneRem = false;      setLibcallName(RTLIB::SDIVREM_I8,  "__aeabi_idivmod");      setLibcallName(RTLIB::SDIVREM_I16, "__aeabi_idivmod"); diff --git a/llvm/lib/Target/ARM/ARMISelLowering.h b/llvm/lib/Target/ARM/ARMISelLowering.h index 1461ae6f673..4906686616b 100644 --- a/llvm/lib/Target/ARM/ARMISelLowering.h +++ b/llvm/lib/Target/ARM/ARMISelLowering.h @@ -478,6 +478,10 @@ namespace llvm {        return true;      } +    bool hasStandaloneRem(EVT VT) const override { +      return HasStandaloneRem; +    } +    protected:      std::pair<const TargetRegisterClass *, uint8_t>      findRepresentativeClass(const TargetRegisterInfo *TRI, @@ -500,6 +504,8 @@ namespace llvm {      // check.      bool InsertFencesForAtomic; +    bool HasStandaloneRem = true; +      void addTypeForNEON(MVT VT, MVT PromotedLdStVT, MVT PromotedBitwiseVT);      void addDRTypeForNEON(MVT VT);      void addQRTypeForNEON(MVT VT); | 

