diff --git a/lib/Target/AArch64/AArch64RegisterInfo.h b/lib/Target/AArch64/AArch64RegisterInfo.h index bb26f1ac9a6..5e9542a4dcf 100644 --- a/lib/Target/AArch64/AArch64RegisterInfo.h +++ b/lib/Target/AArch64/AArch64RegisterInfo.h @@ -30,6 +30,13 @@ struct AArch64RegisterInfo : public AArch64GenRegisterInfo { const MCPhysReg *getCalleeSavedRegs(const MachineFunction *MF = 0) const; const uint32_t *getCallPreservedMask(CallingConv::ID) const; + unsigned getCSRFirstUseCost() const { + // The cost will be compared against BlockFrequency where entry has the + // value of 1 << 14. A value of 5 will choose to spill or split really + // cold path instead of using a callee-saved register. + return 5; + } + const uint32_t *getTLSDescCallPreservedMask() const; BitVector getReservedRegs(const MachineFunction &MF) const;