diff options
Diffstat (limited to 'llvm/lib/Target/RISCV/RISCVISelLowering.cpp')
| -rw-r--r-- | llvm/lib/Target/RISCV/RISCVISelLowering.cpp | 25 | 
1 files changed, 22 insertions, 3 deletions
| diff --git a/llvm/lib/Target/RISCV/RISCVISelLowering.cpp b/llvm/lib/Target/RISCV/RISCVISelLowering.cpp index a77d765..26fe9ed 100644 --- a/llvm/lib/Target/RISCV/RISCVISelLowering.cpp +++ b/llvm/lib/Target/RISCV/RISCVISelLowering.cpp @@ -688,7 +688,7 @@ RISCVTargetLowering::RISCVTargetLowering(const TargetMachine &TM,    else if (Subtarget.hasStdExtZicbop())      setOperationAction(ISD::PREFETCH, MVT::Other, Legal); -  if (Subtarget.hasStdExtA()) { +  if (Subtarget.hasStdExtZalrsc()) {      setMaxAtomicSizeInBitsSupported(Subtarget.getXLen());      if (Subtarget.hasStdExtZabha() && Subtarget.hasStdExtZacas())        setMinCmpXchgSizeInBits(8); @@ -1558,7 +1558,7 @@ RISCVTargetLowering::RISCVTargetLowering(const TargetMachine &TM,      }    } -  if (Subtarget.hasStdExtA()) +  if (Subtarget.hasStdExtZaamo())      setOperationAction(ISD::ATOMIC_LOAD_SUB, XLenVT, Expand);    if (Subtarget.hasForcedAtomics()) { @@ -21875,7 +21875,7 @@ unsigned RISCVTargetLowering::ComputeNumSignBitsForTargetNode(        // result is then sign extended to XLEN. With +A, the minimum width is        // 32 for both 64 and 32.        assert(getMinCmpXchgSizeInBits() == 32); -      assert(Subtarget.hasStdExtA()); +      assert(Subtarget.hasStdExtZalrsc());        return Op.getValueSizeInBits() - 31;      }      break; @@ -24471,6 +24471,25 @@ ISD::NodeType RISCVTargetLowering::getExtendForAtomicCmpSwapArg() const {    return Subtarget.hasStdExtZacas() ? ISD::ANY_EXTEND : ISD::SIGN_EXTEND;  } +ISD::NodeType RISCVTargetLowering::getExtendForAtomicRMWArg(unsigned Op) const { +  // Zaamo will use amo<op>.w which does not require extension. +  if (Subtarget.hasStdExtZaamo() || Subtarget.hasForcedAtomics()) +    return ISD::ANY_EXTEND; + +  // Zalrsc pseudo expansions with comparison require sign-extension. +  assert(Subtarget.hasStdExtZalrsc()); +  switch (Op) { +  case ISD::ATOMIC_LOAD_MIN: +  case ISD::ATOMIC_LOAD_MAX: +  case ISD::ATOMIC_LOAD_UMIN: +  case ISD::ATOMIC_LOAD_UMAX: +    return ISD::SIGN_EXTEND; +  default: +    break; +  } +  return ISD::ANY_EXTEND; +} +  Register RISCVTargetLowering::getExceptionPointerRegister(      const Constant *PersonalityFn) const {    return RISCV::X10; | 
