LLVM 23.0.0git
RISCVRegisterInfo.cpp
Go to the documentation of this file.
1//===-- RISCVRegisterInfo.cpp - RISC-V Register Information -----*- C++ -*-===//
2//
3// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4// See https://llvm.org/LICENSE.txt for license information.
5// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6//
7//===----------------------------------------------------------------------===//
8//
9// This file contains the RISC-V implementation of the TargetRegisterInfo class.
10//
11//===----------------------------------------------------------------------===//
12
13#include "RISCVRegisterInfo.h"
14#include "RISCV.h"
15#include "RISCVSubtarget.h"
16#include "llvm/ADT/SmallSet.h"
26
27#define GET_REGINFO_TARGET_DESC
28#include "RISCVGenRegisterInfo.inc"
29
30using namespace llvm;
31
32static cl::opt<bool> DisableCostPerUse("riscv-disable-cost-per-use",
33 cl::init(false), cl::Hidden);
34static cl::opt<bool>
35 DisableRegAllocHints("riscv-disable-regalloc-hints", cl::Hidden,
36 cl::init(false),
37 cl::desc("Disable two address hints for register "
38 "allocation"));
39
40static_assert(RISCV::X1 == RISCV::X0 + 1, "Register list not consecutive");
41static_assert(RISCV::X31 == RISCV::X0 + 31, "Register list not consecutive");
42static_assert(RISCV::F1_H == RISCV::F0_H + 1, "Register list not consecutive");
43static_assert(RISCV::F31_H == RISCV::F0_H + 31,
44 "Register list not consecutive");
45static_assert(RISCV::F1_F == RISCV::F0_F + 1, "Register list not consecutive");
46static_assert(RISCV::F31_F == RISCV::F0_F + 31,
47 "Register list not consecutive");
48static_assert(RISCV::F1_D == RISCV::F0_D + 1, "Register list not consecutive");
49static_assert(RISCV::F31_D == RISCV::F0_D + 31,
50 "Register list not consecutive");
51static_assert(RISCV::F1_Q == RISCV::F0_Q + 1, "Register list not consecutive");
52static_assert(RISCV::F31_Q == RISCV::F0_Q + 31,
53 "Register list not consecutive");
54static_assert(RISCV::V1 == RISCV::V0 + 1, "Register list not consecutive");
55static_assert(RISCV::V31 == RISCV::V0 + 31, "Register list not consecutive");
56
58 : RISCVGenRegisterInfo(RISCV::X1, /*DwarfFlavour*/0, /*EHFlavor*/0,
59 /*PC*/0, HwMode) {}
60
61const MCPhysReg *
63 return CSR_IPRA_SaveList;
64}
65
66const MCPhysReg *
68 auto &Subtarget = MF->getSubtarget<RISCVSubtarget>();
70 return CSR_NoRegs_SaveList;
72 return Subtarget.hasStdExtE() ? CSR_RT_MostRegs_RVE_SaveList
73 : CSR_RT_MostRegs_SaveList;
74 if (MF->getFunction().hasFnAttribute("interrupt")) {
75 if (Subtarget.hasVInstructions()) {
76 if (Subtarget.hasStdExtD())
77 return Subtarget.hasStdExtE() ? CSR_XLEN_F64_V_Interrupt_RVE_SaveList
78 : CSR_XLEN_F64_V_Interrupt_SaveList;
79 if (Subtarget.hasStdExtF())
80 return Subtarget.hasStdExtE() ? CSR_XLEN_F32_V_Interrupt_RVE_SaveList
81 : CSR_XLEN_F32_V_Interrupt_SaveList;
82 return Subtarget.hasStdExtE() ? CSR_XLEN_V_Interrupt_RVE_SaveList
83 : CSR_XLEN_V_Interrupt_SaveList;
84 }
85 if (Subtarget.hasStdExtD())
86 return Subtarget.hasStdExtE() ? CSR_XLEN_F64_Interrupt_RVE_SaveList
87 : CSR_XLEN_F64_Interrupt_SaveList;
88 if (Subtarget.hasStdExtF())
89 return Subtarget.hasStdExtE() ? CSR_XLEN_F32_Interrupt_RVE_SaveList
90 : CSR_XLEN_F32_Interrupt_SaveList;
91 return Subtarget.hasStdExtE() ? CSR_Interrupt_RVE_SaveList
92 : CSR_Interrupt_SaveList;
93 }
94
95 bool HasVectorCSR =
97 Subtarget.hasVInstructions();
98
99 switch (Subtarget.getTargetABI()) {
100 default:
101 llvm_unreachable("Unrecognized ABI");
104 return CSR_ILP32E_LP64E_SaveList;
107 if (HasVectorCSR)
108 return CSR_ILP32_LP64_V_SaveList;
109 return CSR_ILP32_LP64_SaveList;
112 if (HasVectorCSR)
113 return CSR_ILP32F_LP64F_V_SaveList;
114 return CSR_ILP32F_LP64F_SaveList;
117 if (HasVectorCSR)
118 return CSR_ILP32D_LP64D_V_SaveList;
119 return CSR_ILP32D_LP64D_SaveList;
120 }
121}
122
124 const MachineOperand &MO, const MachineRegisterInfo &MRI) const {
125 const RISCVSubtarget &STI = MRI.getMF().getSubtarget<RISCVSubtarget>();
126
127 const RegClassOrRegBank &RCOrRB = MRI.getRegClassOrRegBank(MO.getReg());
128 if (const RegisterBank *RB = dyn_cast<const RegisterBank *>(RCOrRB))
129 return getRegClassForTypeOnBank(MRI.getType(MO.getReg()), *RB,
130 STI.is64Bit());
131
132 if (const auto *RC = dyn_cast<const TargetRegisterClass *>(RCOrRB)) {
133 return getAllocatableClass(RC);
134 }
135
136 return nullptr;
137}
138
141 bool Is64Bit) const {
142 if (RB.getID() == RISCV::GPRBRegBankID) {
143 if (Ty.getSizeInBits() <= 32 || (Is64Bit && Ty.getSizeInBits() == 64))
144 return &RISCV::GPRRegClass;
145 }
146
147 if (RB.getID() == RISCV::FPRBRegBankID) {
148 if (Ty.getSizeInBits() == 16)
149 return &RISCV::FPR16RegClass;
150 if (Ty.getSizeInBits() == 32)
151 return &RISCV::FPR32RegClass;
152 if (Ty.getSizeInBits() == 64)
153 return &RISCV::FPR64RegClass;
154 }
155
156 if (RB.getID() == RISCV::VRBRegBankID) {
157 if (Ty.getSizeInBits().getKnownMinValue() <= 64)
158 return &RISCV::VRRegClass;
159
160 if (Ty.getSizeInBits().getKnownMinValue() == 128)
161 return &RISCV::VRM2RegClass;
162
163 if (Ty.getSizeInBits().getKnownMinValue() == 256)
164 return &RISCV::VRM4RegClass;
165
166 if (Ty.getSizeInBits().getKnownMinValue() == 512)
167 return &RISCV::VRM8RegClass;
168 }
169
170 return nullptr;
171}
172
174 const RISCVFrameLowering *TFI = getFrameLowering(MF);
175 BitVector Reserved(getNumRegs());
176 auto &Subtarget = MF.getSubtarget<RISCVSubtarget>();
177
178 for (size_t Reg = 0; Reg < getNumRegs(); Reg++) {
179 // Mark any GPRs requested to be reserved as such
180 if (Subtarget.isRegisterReservedByUser(Reg)) {
181 for (MCPhysReg Sub : subregs_inclusive(Reg))
182 markSuperRegs(Reserved, Sub);
183 }
184
185 // Mark all the registers defined as constant in TableGen as reserved.
186 if (isConstantPhysReg(Reg)) {
187 for (MCPhysReg Sub : subregs_inclusive(Reg))
188 markSuperRegs(Reserved, Sub);
189 }
190 }
191
192 // Use markSuperRegs to ensure any register aliases are also reserved
193 markSuperRegs(Reserved, RISCV::X2_H); // sp
194 markSuperRegs(Reserved, RISCV::X3_H); // gp
195 markSuperRegs(Reserved, RISCV::X4_H); // tp
196 if (TFI->hasFP(MF))
197 markSuperRegs(Reserved, RISCV::X8_H); // fp
198 // Reserve the base register if we need to realign the stack and allocate
199 // variable-sized objects at runtime.
200 if (TFI->hasBP(MF))
201 markSuperRegs(Reserved, RISCVABI::getBPReg()); // bp
202
203 // Additionally reserve dummy register used to form the register pair
204 // beginning with 'x0' for instructions that take register pairs.
205 markSuperRegs(Reserved, RISCV::DUMMY_REG_PAIR_WITH_X0);
206
207 // There are only 16 GPRs for RVE.
208 if (Subtarget.hasStdExtE())
209 for (MCPhysReg Reg = RISCV::X16_H; Reg <= RISCV::X31_H; Reg++)
210 markSuperRegs(Reserved, Reg);
211
212 // V registers for code generation. We handle them manually.
213 markSuperRegs(Reserved, RISCV::VL);
214 markSuperRegs(Reserved, RISCV::VTYPE);
215 markSuperRegs(Reserved, RISCV::VXSAT);
216 markSuperRegs(Reserved, RISCV::VXRM);
217
218 // Floating point environment registers.
219 markSuperRegs(Reserved, RISCV::FRM);
220 markSuperRegs(Reserved, RISCV::FFLAGS);
221
222 // SiFive VCIX state registers.
223 markSuperRegs(Reserved, RISCV::SF_VCIX_STATE);
224
226 if (Subtarget.hasStdExtE())
227 reportFatalUsageError("Graal reserved registers do not exist in RVE");
228 markSuperRegs(Reserved, RISCV::X23_H);
229 markSuperRegs(Reserved, RISCV::X27_H);
230 }
231
232 // Shadow stack pointer.
233 markSuperRegs(Reserved, RISCV::SSP);
234
235 // XSfmmbase
236 for (MCPhysReg Reg = RISCV::T0; Reg <= RISCV::T15; Reg++)
237 markSuperRegs(Reserved, Reg);
238
239 assert(checkAllSuperRegsMarked(Reserved));
240 return Reserved;
241}
242
244 MCRegister PhysReg) const {
245 return !MF.getSubtarget().isRegisterReservedByUser(PhysReg);
246}
247
249 return CSR_NoRegs_RegMask;
250}
251
254 const DebugLoc &DL, Register DestReg,
257 MaybeAlign RequiredAlign) const {
258
259 if (DestReg == SrcReg && !Offset.getFixed() && !Offset.getScalable())
260 return;
261
262 MachineFunction &MF = *MBB.getParent();
265 const RISCVInstrInfo *TII = ST.getInstrInfo();
266
267 // Optimize compile time offset case
268 if (Offset.getScalable()) {
269 if (auto VLEN = ST.getRealVLen()) {
270 // 1. Multiply the number of v-slots by the (constant) length of register
271 const int64_t VLENB = *VLEN / 8;
272 assert(Offset.getScalable() % RISCV::RVVBytesPerBlock == 0 &&
273 "Reserve the stack by the multiple of one vector size.");
274 const int64_t NumOfVReg = Offset.getScalable() / 8;
275 const int64_t FixedOffset = NumOfVReg * VLENB;
276 if (!isInt<32>(FixedOffset)) {
278 "Frame size outside of the signed 32-bit range not supported");
279 }
280 Offset = StackOffset::getFixed(FixedOffset + Offset.getFixed());
281 }
282 }
283
284 bool KillSrcReg = false;
285
286 if (Offset.getScalable()) {
287 unsigned ScalableAdjOpc = RISCV::ADD;
288 int64_t ScalableValue = Offset.getScalable();
289 if (ScalableValue < 0) {
290 ScalableValue = -ScalableValue;
291 ScalableAdjOpc = RISCV::SUB;
292 }
293 // Get vlenb and multiply vlen with the number of vector registers.
294 Register ScratchReg = DestReg;
295 if (DestReg == SrcReg)
296 ScratchReg = MRI.createVirtualRegister(&RISCV::GPRRegClass);
297
298 assert(ScalableValue > 0 && "There is no need to get VLEN scaled value.");
299 assert(ScalableValue % RISCV::RVVBytesPerBlock == 0 &&
300 "Reserve the stack by the multiple of one vector size.");
301 assert(isInt<32>(ScalableValue / RISCV::RVVBytesPerBlock) &&
302 "Expect the number of vector registers within 32-bits.");
303 uint32_t NumOfVReg = ScalableValue / RISCV::RVVBytesPerBlock;
304 // Only use vsetvli rather than vlenb if adjusting in the prologue or
305 // epilogue, otherwise it may disturb the VTYPE and VL status.
306 bool IsPrologueOrEpilogue =
308 bool UseVsetvliRatherThanVlenb =
309 IsPrologueOrEpilogue && ST.preferVsetvliOverReadVLENB();
310 if (UseVsetvliRatherThanVlenb && (NumOfVReg == 1 || NumOfVReg == 2 ||
311 NumOfVReg == 4 || NumOfVReg == 8)) {
312 BuildMI(MBB, II, DL, TII->get(RISCV::PseudoReadVLENBViaVSETVLIX0),
313 ScratchReg)
314 .addImm(NumOfVReg)
315 .setMIFlag(Flag);
316 BuildMI(MBB, II, DL, TII->get(ScalableAdjOpc), DestReg)
317 .addReg(SrcReg)
318 .addReg(ScratchReg, RegState::Kill)
319 .setMIFlag(Flag);
320 } else {
321 if (UseVsetvliRatherThanVlenb)
322 BuildMI(MBB, II, DL, TII->get(RISCV::PseudoReadVLENBViaVSETVLIX0),
323 ScratchReg)
324 .addImm(1)
325 .setMIFlag(Flag);
326 else
327 BuildMI(MBB, II, DL, TII->get(RISCV::PseudoReadVLENB), ScratchReg)
328 .setMIFlag(Flag);
329
330 if (ScalableAdjOpc == RISCV::ADD && ST.hasStdExtZba() &&
331 (NumOfVReg == 2 || NumOfVReg == 4 || NumOfVReg == 8)) {
332 unsigned Opc = NumOfVReg == 2
333 ? RISCV::SH1ADD
334 : (NumOfVReg == 4 ? RISCV::SH2ADD : RISCV::SH3ADD);
335 BuildMI(MBB, II, DL, TII->get(Opc), DestReg)
336 .addReg(ScratchReg, RegState::Kill)
337 .addReg(SrcReg)
338 .setMIFlag(Flag);
339 } else {
340 TII->mulImm(MF, MBB, II, DL, ScratchReg, NumOfVReg, Flag);
341 BuildMI(MBB, II, DL, TII->get(ScalableAdjOpc), DestReg)
342 .addReg(SrcReg)
343 .addReg(ScratchReg, RegState::Kill)
344 .setMIFlag(Flag);
345 }
346 }
347 SrcReg = DestReg;
348 KillSrcReg = true;
349 }
350
351 int64_t Val = Offset.getFixed();
352 if (DestReg == SrcReg && Val == 0)
353 return;
354
355 const uint64_t Align = RequiredAlign.valueOrOne().value();
356
357 if (isInt<12>(Val)) {
358 BuildMI(MBB, II, DL, TII->get(RISCV::ADDI), DestReg)
359 .addReg(SrcReg, getKillRegState(KillSrcReg))
360 .addImm(Val)
361 .setMIFlag(Flag);
362 return;
363 }
364
365 // Use the QC_E_ADDI instruction from the Xqcilia extension that can take a
366 // signed 26-bit immediate.
367 if (ST.hasVendorXqcilia() && isInt<26>(Val)) {
368 // The one case where using this instruction is sub-optimal is if Val can be
369 // materialized with a single compressible LUI and following add/sub is also
370 // compressible. Avoid doing this if that is the case.
371 int Hi20 = (Val & 0xFFFFF000) >> 12;
372 bool IsCompressLUI =
373 ((Val & 0xFFF) == 0) && (Hi20 != 0) &&
374 (isUInt<5>(Hi20) || (Hi20 >= 0xfffe0 && Hi20 <= 0xfffff));
375 bool IsCompressAddSub =
376 (SrcReg == DestReg) &&
377 ((Val > 0 && RISCV::GPRNoX0RegClass.contains(SrcReg)) ||
378 (Val < 0 && RISCV::GPRCRegClass.contains(SrcReg)));
379
380 if (!(IsCompressLUI && IsCompressAddSub)) {
381 BuildMI(MBB, II, DL, TII->get(RISCV::QC_E_ADDI), DestReg)
382 .addReg(SrcReg, getKillRegState(KillSrcReg))
383 .addImm(Val)
384 .setMIFlag(Flag);
385 return;
386 }
387 }
388
389 // Try to split the offset across two ADDIs. We need to keep the intermediate
390 // result aligned after each ADDI. We need to determine the maximum value we
391 // can put in each ADDI. In the negative direction, we can use -2048 which is
392 // always sufficiently aligned. In the positive direction, we need to find the
393 // largest 12-bit immediate that is aligned. Exclude -4096 since it can be
394 // created with LUI.
395 assert(Align < 2048 && "Required alignment too large");
396 int64_t MaxPosAdjStep = 2048 - Align;
397 if (Val > -4096 && Val <= (2 * MaxPosAdjStep)) {
398 int64_t FirstAdj = Val < 0 ? -2048 : MaxPosAdjStep;
399 Val -= FirstAdj;
400 BuildMI(MBB, II, DL, TII->get(RISCV::ADDI), DestReg)
401 .addReg(SrcReg, getKillRegState(KillSrcReg))
402 .addImm(FirstAdj)
403 .setMIFlag(Flag);
404 BuildMI(MBB, II, DL, TII->get(RISCV::ADDI), DestReg)
405 .addReg(DestReg, RegState::Kill)
406 .addImm(Val)
407 .setMIFlag(Flag);
408 return;
409 }
410
411 // Use shNadd if doing so lets us materialize a 12 bit immediate with a single
412 // instruction. This saves 1 instruction over the full lui/addi+add fallback
413 // path. We avoid anything which can be done with a single lui as it might
414 // be compressible. Note that the sh1add case is fully covered by the 2x addi
415 // case just above and is thus omitted.
416 if (ST.hasStdExtZba() && (Val & 0xFFF) != 0) {
417 unsigned Opc = 0;
418 if (isShiftedInt<12, 3>(Val)) {
419 Opc = RISCV::SH3ADD;
420 Val = Val >> 3;
421 } else if (isShiftedInt<12, 2>(Val)) {
422 Opc = RISCV::SH2ADD;
423 Val = Val >> 2;
424 }
425 if (Opc) {
426 Register ScratchReg = MRI.createVirtualRegister(&RISCV::GPRRegClass);
427 TII->movImm(MBB, II, DL, ScratchReg, Val, Flag);
428 BuildMI(MBB, II, DL, TII->get(Opc), DestReg)
429 .addReg(ScratchReg, RegState::Kill)
430 .addReg(SrcReg, getKillRegState(KillSrcReg))
431 .setMIFlag(Flag);
432 return;
433 }
434 }
435
436 unsigned Opc = RISCV::ADD;
437 if (Val < 0) {
438 Val = -Val;
439 Opc = RISCV::SUB;
440 }
441
442 Register ScratchReg = MRI.createVirtualRegister(&RISCV::GPRRegClass);
443 TII->movImm(MBB, II, DL, ScratchReg, Val, Flag);
444 BuildMI(MBB, II, DL, TII->get(Opc), DestReg)
445 .addReg(SrcReg, getKillRegState(KillSrcReg))
446 .addReg(ScratchReg, RegState::Kill)
447 .setMIFlag(Flag);
448}
449
450static std::tuple<RISCVVType::VLMUL, const TargetRegisterClass &, unsigned>
451getSpillReloadInfo(unsigned NumRemaining, uint16_t RegEncoding, bool IsSpill) {
452 if (NumRemaining >= 8 && RegEncoding % 8 == 0)
453 return {RISCVVType::LMUL_8, RISCV::VRM8RegClass,
454 IsSpill ? RISCV::VS8R_V : RISCV::VL8RE8_V};
455 if (NumRemaining >= 4 && RegEncoding % 4 == 0)
456 return {RISCVVType::LMUL_4, RISCV::VRM4RegClass,
457 IsSpill ? RISCV::VS4R_V : RISCV::VL4RE8_V};
458 if (NumRemaining >= 2 && RegEncoding % 2 == 0)
459 return {RISCVVType::LMUL_2, RISCV::VRM2RegClass,
460 IsSpill ? RISCV::VS2R_V : RISCV::VL2RE8_V};
461 return {RISCVVType::LMUL_1, RISCV::VRRegClass,
462 IsSpill ? RISCV::VS1R_V : RISCV::VL1RE8_V};
463}
464
465// Split a VSPILLx_Mx/VSPILLx_Mx pseudo into multiple whole register stores
466// separated by LMUL*VLENB bytes.
468 bool IsSpill) const {
469 DebugLoc DL = II->getDebugLoc();
470 MachineBasicBlock &MBB = *II->getParent();
471 MachineFunction &MF = *MBB.getParent();
473 const RISCVSubtarget &STI = MF.getSubtarget<RISCVSubtarget>();
474 const TargetInstrInfo *TII = STI.getInstrInfo();
476
477 auto ZvlssegInfo = RISCV::isRVVSpillForZvlsseg(II->getOpcode());
478 unsigned NF = ZvlssegInfo->first;
479 unsigned LMUL = ZvlssegInfo->second;
480 unsigned NumRegs = NF * LMUL;
481 assert(NumRegs <= 8 && "Invalid NF/LMUL combinations.");
482
483 Register Reg = II->getOperand(0).getReg();
484 uint16_t RegEncoding = TRI->getEncodingValue(Reg);
485 Register Base = II->getOperand(1).getReg();
486 bool IsBaseKill = II->getOperand(1).isKill();
487 Register NewBase = MRI.createVirtualRegister(&RISCV::GPRRegClass);
488
489 auto *OldMMO = *(II->memoperands_begin());
490 LocationSize OldLoc = OldMMO->getSize();
491 assert(OldLoc.isPrecise() && OldLoc.getValue().isKnownMultipleOf(NF));
492 TypeSize VRegSize = OldLoc.getValue().divideCoefficientBy(NumRegs);
493
494 Register VLENB = 0;
495 unsigned VLENBShift = 0;
496 unsigned PrevHandledNum = 0;
497 unsigned I = 0;
498 while (I != NumRegs) {
499 auto [LMulHandled, RegClass, Opcode] =
500 getSpillReloadInfo(NumRegs - I, RegEncoding, IsSpill);
501 auto [RegNumHandled, _] = RISCVVType::decodeVLMUL(LMulHandled);
502 bool IsLast = I + RegNumHandled == NumRegs;
503 if (PrevHandledNum) {
504 Register Step;
505 // Optimize for constant VLEN.
506 if (auto VLEN = STI.getRealVLen()) {
507 int64_t Offset = *VLEN / 8 * PrevHandledNum;
508 Step = MRI.createVirtualRegister(&RISCV::GPRRegClass);
509 STI.getInstrInfo()->movImm(MBB, II, DL, Step, Offset);
510 } else {
511 if (!VLENB) {
512 VLENB = MRI.createVirtualRegister(&RISCV::GPRRegClass);
513 BuildMI(MBB, II, DL, TII->get(RISCV::PseudoReadVLENB), VLENB);
514 }
515 uint32_t ShiftAmount = Log2_32(PrevHandledNum);
516 // To avoid using an extra register, we shift the VLENB register and
517 // remember how much it has been shifted. We can then use relative
518 // shifts to adjust to the desired shift amount.
519 if (VLENBShift > ShiftAmount) {
520 BuildMI(MBB, II, DL, TII->get(RISCV::SRLI), VLENB)
521 .addReg(VLENB, RegState::Kill)
522 .addImm(VLENBShift - ShiftAmount);
523 } else if (VLENBShift < ShiftAmount) {
524 BuildMI(MBB, II, DL, TII->get(RISCV::SLLI), VLENB)
525 .addReg(VLENB, RegState::Kill)
526 .addImm(ShiftAmount - VLENBShift);
527 }
528 VLENBShift = ShiftAmount;
529 Step = VLENB;
530 }
531
532 BuildMI(MBB, II, DL, TII->get(RISCV::ADD), NewBase)
533 .addReg(Base, getKillRegState(I != 0 || IsBaseKill))
534 .addReg(Step, getKillRegState(Step != VLENB || IsLast));
535 Base = NewBase;
536 }
537
538 MCRegister ActualReg = findVRegWithEncoding(RegClass, RegEncoding);
540 BuildMI(MBB, II, DL, TII->get(Opcode))
541 .addReg(ActualReg, getDefRegState(!IsSpill))
542 .addReg(Base, getKillRegState(IsLast))
543 .addMemOperand(MF.getMachineMemOperand(OldMMO, OldMMO->getOffset(),
544 VRegSize * RegNumHandled));
545
546 // Adding implicit-use of super register to describe we are using part of
547 // super register, that prevents machine verifier complaining when part of
548 // subreg is undef, see comment in MachineVerifier::checkLiveness for more
549 // detail.
550 if (IsSpill)
551 MIB.addReg(Reg, RegState::Implicit);
552
553 PrevHandledNum = RegNumHandled;
554 RegEncoding += RegNumHandled;
555 I += RegNumHandled;
556 }
557 II->eraseFromParent();
558}
559
561 int SPAdj, unsigned FIOperandNum,
562 RegScavenger *RS) const {
563 assert(SPAdj == 0 && "Unexpected non-zero SPAdj value");
564
565 MachineInstr &MI = *II;
566 MachineFunction &MF = *MI.getParent()->getParent();
568 DebugLoc DL = MI.getDebugLoc();
569
570 int FrameIndex = MI.getOperand(FIOperandNum).getIndex();
571 Register FrameReg;
573 getFrameLowering(MF)->getFrameIndexReference(MF, FrameIndex, FrameReg);
574 bool IsRVVSpill = RISCV::isRVVSpill(MI);
575 if (!IsRVVSpill)
576 Offset += StackOffset::getFixed(MI.getOperand(FIOperandNum + 1).getImm());
577
578 if (!isInt<32>(Offset.getFixed())) {
580 "Frame offsets outside of the signed 32-bit range not supported");
581 }
582
583 if (!IsRVVSpill) {
584 int64_t Val = Offset.getFixed();
585 int64_t Lo12 = SignExtend64<12>(Val);
586 unsigned Opc = MI.getOpcode();
587
588 if (Opc == RISCV::ADDI && !isInt<12>(Val)) {
589 // We chose to emit the canonical immediate sequence rather than folding
590 // the offset into the using add under the theory that doing so doesn't
591 // save dynamic instruction count and some target may fuse the canonical
592 // 32 bit immediate sequence. We still need to clear the portion of the
593 // offset encoded in the immediate.
594 MI.getOperand(FIOperandNum + 1).ChangeToImmediate(0);
595 } else if ((Opc == RISCV::PREFETCH_I || Opc == RISCV::PREFETCH_R ||
596 Opc == RISCV::PREFETCH_W) &&
597 (Lo12 & 0b11111) != 0) {
598 // Prefetch instructions require the offset to be 32 byte aligned.
599 MI.getOperand(FIOperandNum + 1).ChangeToImmediate(0);
600 } else if (Opc == RISCV::MIPS_PREF && !isUInt<9>(Val)) {
601 // MIPS Prefetch instructions require the offset to be 9 bits encoded.
602 MI.getOperand(FIOperandNum + 1).ChangeToImmediate(0);
603 } else if ((Opc == RISCV::PseudoRV32ZdinxLD ||
604 Opc == RISCV::PseudoRV32ZdinxSD ||
605 Opc == RISCV::PseudoLD_RV32_OPT ||
606 Opc == RISCV::PseudoSD_RV32_OPT) &&
607 Lo12 >= 2044) {
608 // This instruction will/might be split into 2 instructions. The second
609 // instruction will add 4 to the immediate. If that would overflow 12
610 // bits, we can't fold the offset.
611 MI.getOperand(FIOperandNum + 1).ChangeToImmediate(0);
612 } else {
613 // We can encode an add with 12 bit signed immediate in the immediate
614 // operand of our user instruction. As a result, the remaining
615 // offset can by construction, at worst, a LUI and a ADD.
616 MI.getOperand(FIOperandNum + 1).ChangeToImmediate(Lo12);
618 Offset.getScalable());
619 }
620 }
621
622 if (Offset.getScalable() || Offset.getFixed()) {
623 Register DestReg;
624 if (MI.getOpcode() == RISCV::ADDI)
625 DestReg = MI.getOperand(0).getReg();
626 else
627 DestReg = MRI.createVirtualRegister(&RISCV::GPRRegClass);
628 adjustReg(*II->getParent(), II, DL, DestReg, FrameReg, Offset,
629 MachineInstr::NoFlags, std::nullopt);
630 MI.getOperand(FIOperandNum).ChangeToRegister(DestReg, /*IsDef*/false,
631 /*IsImp*/false,
632 /*IsKill*/true);
633 } else {
634 MI.getOperand(FIOperandNum).ChangeToRegister(FrameReg, /*IsDef*/false,
635 /*IsImp*/false,
636 /*IsKill*/false);
637 }
638
639 // If after materializing the adjustment, we have a pointless ADDI, remove it
640 if (MI.getOpcode() == RISCV::ADDI &&
641 MI.getOperand(0).getReg() == MI.getOperand(1).getReg() &&
642 MI.getOperand(2).getImm() == 0) {
643 MI.eraseFromParent();
644 return true;
645 }
646
647 // Handle spill/fill of synthetic register classes for segment operations to
648 // ensure correctness in the edge case one gets spilled.
649 switch (MI.getOpcode()) {
650 case RISCV::PseudoVSPILL2_M1:
651 case RISCV::PseudoVSPILL2_M2:
652 case RISCV::PseudoVSPILL2_M4:
653 case RISCV::PseudoVSPILL3_M1:
654 case RISCV::PseudoVSPILL3_M2:
655 case RISCV::PseudoVSPILL4_M1:
656 case RISCV::PseudoVSPILL4_M2:
657 case RISCV::PseudoVSPILL5_M1:
658 case RISCV::PseudoVSPILL6_M1:
659 case RISCV::PseudoVSPILL7_M1:
660 case RISCV::PseudoVSPILL8_M1:
661 lowerSegmentSpillReload(II, /*IsSpill=*/true);
662 return true;
663 case RISCV::PseudoVRELOAD2_M1:
664 case RISCV::PseudoVRELOAD2_M2:
665 case RISCV::PseudoVRELOAD2_M4:
666 case RISCV::PseudoVRELOAD3_M1:
667 case RISCV::PseudoVRELOAD3_M2:
668 case RISCV::PseudoVRELOAD4_M1:
669 case RISCV::PseudoVRELOAD4_M2:
670 case RISCV::PseudoVRELOAD5_M1:
671 case RISCV::PseudoVRELOAD6_M1:
672 case RISCV::PseudoVRELOAD7_M1:
673 case RISCV::PseudoVRELOAD8_M1:
674 lowerSegmentSpillReload(II, /*IsSpill=*/false);
675 return true;
676 }
677
678 return false;
679}
680
682 const MachineFunction &MF) const {
683 return true;
684}
685
686// Returns true if the instruction's frame index reference would be better
687// served by a base register other than FP or SP.
688// Used by LocalStackSlotAllocation pass to determine which frame index
689// references it should create new base registers for.
691 int64_t Offset) const {
692 unsigned FIOperandNum = 0;
693 for (; !MI->getOperand(FIOperandNum).isFI(); FIOperandNum++)
694 assert(FIOperandNum < MI->getNumOperands() &&
695 "Instr doesn't have FrameIndex operand");
696
697 // For RISC-V, The machine instructions that include a FrameIndex operand
698 // are load/store, ADDI instructions.
699 unsigned MIFrm = RISCVII::getFormat(MI->getDesc().TSFlags);
700 if (MIFrm != RISCVII::InstFormatI && MIFrm != RISCVII::InstFormatS)
701 return false;
702 // We only generate virtual base registers for loads and stores, so
703 // return false for everything else.
704 if (!MI->mayLoad() && !MI->mayStore())
705 return false;
706
707 const MachineFunction &MF = *MI->getMF();
708 const MachineFrameInfo &MFI = MF.getFrameInfo();
709 const RISCVFrameLowering *TFI = getFrameLowering(MF);
710 const MachineRegisterInfo &MRI = MF.getRegInfo();
711
712 if (TFI->hasFP(MF) && !shouldRealignStack(MF)) {
713 auto &Subtarget = MF.getSubtarget<RISCVSubtarget>();
714 // Estimate the stack size used to store callee saved registers(
715 // excludes reserved registers).
716 unsigned CalleeSavedSize = 0;
717 for (const MCPhysReg *R = MRI.getCalleeSavedRegs(); MCPhysReg Reg = *R;
718 ++R) {
719 if (Subtarget.isRegisterReservedByUser(Reg))
720 continue;
721
722 if (RISCV::GPRRegClass.contains(Reg))
723 CalleeSavedSize += getSpillSize(RISCV::GPRRegClass);
724 else if (RISCV::FPR64RegClass.contains(Reg))
725 CalleeSavedSize += getSpillSize(RISCV::FPR64RegClass);
726 else if (RISCV::FPR32RegClass.contains(Reg))
727 CalleeSavedSize += getSpillSize(RISCV::FPR32RegClass);
728 // Ignore vector registers.
729 }
730
731 int64_t MaxFPOffset = Offset - CalleeSavedSize;
732 if (isFrameOffsetLegal(MI, RISCV::X8, MaxFPOffset))
733 return false;
734
735 // If the FP-relative offset doesn't fit, fall through to check the
736 // SP-relative offset. getFrameIndexReference may select SP over FP when
737 // the SP offset fits in the compressed instruction immediate range, so a
738 // base register might not be needed.
739 }
740
741 // Assume 128 bytes spill slots size to estimate the maximum possible
742 // offset relative to the stack pointer.
743 // FIXME: The 128 is copied from ARM. We should run some statistics and pick a
744 // real one for RISC-V.
745 int64_t MaxSPOffset = Offset + 128;
746 MaxSPOffset += MFI.getLocalFrameSize();
747 return !isFrameOffsetLegal(MI, RISCV::X2, MaxSPOffset);
748}
749
750// Determine whether a given base register plus offset immediate is
751// encodable to resolve a frame index.
753 Register BaseReg,
754 int64_t Offset) const {
755 unsigned FIOperandNum = 0;
756 while (!MI->getOperand(FIOperandNum).isFI()) {
757 FIOperandNum++;
758 assert(FIOperandNum < MI->getNumOperands() &&
759 "Instr does not have a FrameIndex operand!");
760 }
761
762 Offset += getFrameIndexInstrOffset(MI, FIOperandNum);
763 return isInt<12>(Offset);
764}
765
766// Insert defining instruction(s) for a pointer to FrameIdx before
767// insertion point I.
768// Return materialized frame pointer.
770 int FrameIdx,
771 int64_t Offset) const {
773 DebugLoc DL;
774 if (MBBI != MBB->end())
775 DL = MBBI->getDebugLoc();
776 MachineFunction *MF = MBB->getParent();
777 MachineRegisterInfo &MFI = MF->getRegInfo();
779
780 Register BaseReg = MFI.createVirtualRegister(&RISCV::GPRRegClass);
781 BuildMI(*MBB, MBBI, DL, TII->get(RISCV::ADDI), BaseReg)
782 .addFrameIndex(FrameIdx)
783 .addImm(Offset);
784 return BaseReg;
785}
786
787// Resolve a frame index operand of an instruction to reference the
788// indicated base register plus offset instead.
790 int64_t Offset) const {
791 unsigned FIOperandNum = 0;
792 while (!MI.getOperand(FIOperandNum).isFI()) {
793 FIOperandNum++;
794 assert(FIOperandNum < MI.getNumOperands() &&
795 "Instr does not have a FrameIndex operand!");
796 }
797
798 Offset += getFrameIndexInstrOffset(&MI, FIOperandNum);
799 // FrameIndex Operands are always represented as a
800 // register followed by an immediate.
801 MI.getOperand(FIOperandNum).ChangeToRegister(BaseReg, false);
802 MI.getOperand(FIOperandNum + 1).ChangeToImmediate(Offset);
803}
804
805// Get the offset from the referenced frame index in the instruction,
806// if there is one.
808 int Idx) const {
809 assert((RISCVII::getFormat(MI->getDesc().TSFlags) == RISCVII::InstFormatI ||
810 RISCVII::getFormat(MI->getDesc().TSFlags) == RISCVII::InstFormatS) &&
811 "The MI must be I or S format.");
812 assert(MI->getOperand(Idx).isFI() && "The Idx'th operand of MI is not a "
813 "FrameIndex operand");
814 return MI->getOperand(Idx + 1).getImm();
815}
816
818 const TargetFrameLowering *TFI = getFrameLowering(MF);
819 return TFI->hasFP(MF) ? RISCV::X8 : RISCV::X2;
820}
821
823 if (Reg == RISCV::SF_VCIX_STATE)
824 return "sf.vcix_state";
826}
827
828const uint32_t *
830 CallingConv::ID CC) const {
831 auto &Subtarget = MF.getSubtarget<RISCVSubtarget>();
832
833 if (CC == CallingConv::GHC)
834 return CSR_NoRegs_RegMask;
835 RISCVABI::ABI ABI = Subtarget.getTargetABI();
836 if (CC == CallingConv::PreserveMost) {
837 if (ABI == RISCVABI::ABI_ILP32E || ABI == RISCVABI::ABI_LP64E)
838 return CSR_RT_MostRegs_RVE_RegMask;
839 return CSR_RT_MostRegs_RegMask;
840 }
841 switch (ABI) {
842 default:
843 llvm_unreachable("Unrecognized ABI");
846 return CSR_ILP32E_LP64E_RegMask;
850 return CSR_ILP32_LP64_V_RegMask;
851 return CSR_ILP32_LP64_RegMask;
855 return CSR_ILP32F_LP64F_V_RegMask;
856 return CSR_ILP32F_LP64F_RegMask;
860 return CSR_ILP32D_LP64D_V_RegMask;
861 return CSR_ILP32D_LP64D_RegMask;
862 }
863}
864
867 const MachineFunction &) const {
868 if (RC == &RISCV::VMV0RegClass)
869 return &RISCV::VRRegClass;
870 if (RC == &RISCV::VRNoV0RegClass)
871 return &RISCV::VRRegClass;
872 if (RC == &RISCV::VRM2NoV0RegClass)
873 return &RISCV::VRM2RegClass;
874 if (RC == &RISCV::VRM4NoV0RegClass)
875 return &RISCV::VRM4RegClass;
876 if (RC == &RISCV::VRM8NoV0RegClass)
877 return &RISCV::VRM8RegClass;
878 return RC;
879}
880
883 // VLENB is the length of a vector register in bytes. We use <vscale x 8 x i8>
884 // to represent one vector register. The dwarf offset is
885 // VLENB * scalable_offset / 8.
886 assert(Offset.getScalable() % 8 == 0 && "Invalid frame offset");
887
888 // Add fixed-sized offset using existing DIExpression interface.
890
891 unsigned VLENB = getDwarfRegNum(RISCV::VLENB, true);
892 int64_t VLENBSized = Offset.getScalable() / 8;
893 if (VLENBSized > 0) {
894 Ops.push_back(dwarf::DW_OP_constu);
895 Ops.push_back(VLENBSized);
896 Ops.append({dwarf::DW_OP_bregx, VLENB, 0ULL});
897 Ops.push_back(dwarf::DW_OP_mul);
898 Ops.push_back(dwarf::DW_OP_plus);
899 } else if (VLENBSized < 0) {
900 Ops.push_back(dwarf::DW_OP_constu);
901 Ops.push_back(-VLENBSized);
902 Ops.append({dwarf::DW_OP_bregx, VLENB, 0ULL});
903 Ops.push_back(dwarf::DW_OP_mul);
904 Ops.push_back(dwarf::DW_OP_minus);
905 }
906}
907
908unsigned
910 return MF.getSubtarget<RISCVSubtarget>().hasStdExtZca() && !DisableCostPerUse
911 ? 1
912 : 0;
913}
914
916 const TargetRegisterClass *RC) const {
917 return getRegClassWeight(RC).RegWeight;
918}
919
920// Add two address hints to improve chances of being able to use a compressed
921// instruction.
923 Register VirtReg, ArrayRef<MCPhysReg> Order,
925 const VirtRegMap *VRM, const LiveRegMatrix *Matrix) const {
926 const MachineRegisterInfo *MRI = &MF.getRegInfo();
927 auto &Subtarget = MF.getSubtarget<RISCVSubtarget>();
928
929 // Handle RegPairEven/RegPairOdd hints for Zilsd register pairs
930 std::pair<unsigned, Register> Hint = MRI->getRegAllocationHint(VirtReg);
931 unsigned HintType = Hint.first;
932 Register Partner = Hint.second;
933
934 MCRegister TargetReg;
935 if (HintType == RISCVRI::RegPairEven || HintType == RISCVRI::RegPairOdd) {
936 // Check if we want the even or odd register of a consecutive pair
937 bool WantOdd = (HintType == RISCVRI::RegPairOdd);
938
939 // First priority: Check if partner is already allocated
940 if (Partner.isVirtual() && VRM && VRM->hasPhys(Partner)) {
941 MCRegister PartnerPhys = VRM->getPhys(Partner);
942 // Calculate the exact register we need for consecutive pairing
943 TargetReg = PartnerPhys.id() + (WantOdd ? 1 : -1);
944
945 // Verify it's valid and available
946 if (RISCV::GPRRegClass.contains(TargetReg) &&
947 is_contained(Order, TargetReg))
948 Hints.push_back(TargetReg.id());
949 }
950
951 // Second priority: Try to find consecutive register pairs in the allocation
952 // order
953 for (MCPhysReg PhysReg : Order) {
954 // Don't add the hint if we already added above.
955 if (TargetReg == PhysReg)
956 continue;
957
958 unsigned RegNum = getEncodingValue(PhysReg);
959 // Check if this register matches the even/odd requirement
960 bool IsOdd = (RegNum % 2 != 0);
961
962 // Don't provide hints that are paired to a reserved register.
963 MCRegister Paired = PhysReg + (IsOdd ? -1 : 1);
964 if (WantOdd == IsOdd && !MRI->isReserved(Paired))
965 Hints.push_back(PhysReg);
966 }
967 }
968
969 bool BaseImplRetVal = TargetRegisterInfo::getRegAllocationHints(
970 VirtReg, Order, Hints, MF, VRM, Matrix);
971
972 if (!VRM || DisableRegAllocHints)
973 return BaseImplRetVal;
974
975 // Add any two address hints after any copy hints.
976 SmallSet<Register, 4> TwoAddrHints;
977
978 auto tryAddHint = [&](const MachineOperand &VRRegMO, const MachineOperand &MO,
979 bool NeedGPRC) -> void {
980 Register Reg = MO.getReg();
981 Register PhysReg = Reg.isPhysical() ? Reg : Register(VRM->getPhys(Reg));
982 // TODO: Support GPRPair subregisters? Need to be careful with even/odd
983 // registers. If the virtual register is an odd register of a pair and the
984 // physical register is even (or vice versa), we should not add the hint.
985 if (PhysReg && (!NeedGPRC || RISCV::GPRCRegClass.contains(PhysReg)) &&
986 !MO.getSubReg() && !VRRegMO.getSubReg()) {
987 if (!MRI->isReserved(PhysReg) && !is_contained(Hints, PhysReg))
988 TwoAddrHints.insert(PhysReg);
989 }
990 };
991
992 // This is all of the compressible binary instructions. If an instruction
993 // needs GPRC register class operands \p NeedGPRC will be set to true.
994 auto isCompressible = [&Subtarget](const MachineInstr &MI, bool &NeedGPRC) {
995 NeedGPRC = false;
996 switch (MI.getOpcode()) {
997 default:
998 return false;
999 case RISCV::AND:
1000 case RISCV::OR:
1001 case RISCV::XOR:
1002 case RISCV::SUB:
1003 case RISCV::ADDW:
1004 case RISCV::SUBW:
1005 NeedGPRC = true;
1006 return true;
1007 case RISCV::ANDI: {
1008 NeedGPRC = true;
1009 if (!MI.getOperand(2).isImm())
1010 return false;
1011 int64_t Imm = MI.getOperand(2).getImm();
1012 if (isInt<6>(Imm))
1013 return true;
1014 // c.zext.b
1015 return Subtarget.hasStdExtZcb() && Imm == 255;
1016 }
1017 case RISCV::SRAI:
1018 case RISCV::SRLI:
1019 NeedGPRC = true;
1020 return true;
1021 case RISCV::ADD:
1022 case RISCV::SLLI:
1023 return true;
1024 case RISCV::ADDI:
1025 case RISCV::ADDIW:
1026 return MI.getOperand(2).isImm() && isInt<6>(MI.getOperand(2).getImm());
1027 case RISCV::MUL:
1028 // c.mul
1029 NeedGPRC = true;
1030 return Subtarget.hasStdExtZcb();
1031 case RISCV::SEXT_B:
1032 case RISCV::SEXT_H:
1033 case RISCV::ZEXT_H_RV32:
1034 case RISCV::ZEXT_H_RV64:
1035 // c.sext.b, c.sext.h, c.zext.h
1036 NeedGPRC = true;
1037 return Subtarget.hasStdExtZcb() && Subtarget.hasStdExtZbb();
1038 case RISCV::ADD_UW:
1039 // c.zext.w
1040 NeedGPRC = true;
1041 return Subtarget.hasStdExtZcb() && MI.getOperand(2).isReg() &&
1042 MI.getOperand(2).getReg() == RISCV::X0;
1043 case RISCV::XORI:
1044 // c.not
1045 NeedGPRC = true;
1046 return Subtarget.hasStdExtZcb() && MI.getOperand(2).isImm() &&
1047 MI.getOperand(2).getImm() == -1;
1048 case RISCV::QC_EXTU:
1049 return MI.getOperand(2).getImm() >= 6 && MI.getOperand(3).getImm() == 0;
1050 case RISCV::BSETI:
1051 case RISCV::BEXTI:
1052 // qc.c.bseti, qc.c.bexti
1053 NeedGPRC = true;
1054 return Subtarget.hasVendorXqcibm() && MI.getOperand(2).getImm() != 0;
1055 }
1056 };
1057
1058 // Returns true if this operand is compressible. For non-registers it always
1059 // returns true. Immediate range was already checked in isCompressible.
1060 // For registers, it checks if the register is a GPRC register. reg-reg
1061 // instructions that require GPRC need all register operands to be GPRC.
1062 auto isCompressibleOpnd = [&](const MachineOperand &MO) {
1063 if (!MO.isReg())
1064 return true;
1065 Register Reg = MO.getReg();
1066 Register PhysReg = Reg.isPhysical() ? Reg : Register(VRM->getPhys(Reg));
1067 return PhysReg && RISCV::GPRCRegClass.contains(PhysReg);
1068 };
1069
1070 for (auto &MO : MRI->reg_nodbg_operands(VirtReg)) {
1071 const MachineInstr &MI = *MO.getParent();
1072 unsigned OpIdx = MO.getOperandNo();
1073 bool NeedGPRC;
1074 if (isCompressible(MI, NeedGPRC)) {
1075 if (OpIdx == 0 && MI.getOperand(1).isReg()) {
1076 if (!NeedGPRC || MI.getNumExplicitOperands() < 3 ||
1077 MI.getOpcode() == RISCV::ADD_UW ||
1078 isCompressibleOpnd(MI.getOperand(2)))
1079 tryAddHint(MO, MI.getOperand(1), NeedGPRC);
1080 if (MI.isCommutable() && MI.getOperand(2).isReg() &&
1081 (!NeedGPRC || isCompressibleOpnd(MI.getOperand(1))))
1082 tryAddHint(MO, MI.getOperand(2), NeedGPRC);
1083 } else if (OpIdx == 1 && (!NeedGPRC || MI.getNumExplicitOperands() < 3 ||
1084 isCompressibleOpnd(MI.getOperand(2)))) {
1085 tryAddHint(MO, MI.getOperand(0), NeedGPRC);
1086 } else if (MI.isCommutable() && OpIdx == 2 &&
1087 (!NeedGPRC || isCompressibleOpnd(MI.getOperand(1)))) {
1088 tryAddHint(MO, MI.getOperand(0), NeedGPRC);
1089 }
1090 }
1091
1092 // Add a hint if it would allow auipc/lui+addi(w) fusion. We do this even
1093 // without the fusions explicitly enabled as the impact is rarely negative
1094 // and some cores do implement this fusion.
1095 if ((MI.getOpcode() == RISCV::ADDIW || MI.getOpcode() == RISCV::ADDI) &&
1096 MI.getOperand(1).isReg()) {
1097 const MachineBasicBlock &MBB = *MI.getParent();
1098 MachineBasicBlock::const_iterator I = MI.getIterator();
1099 // Is the previous instruction a LUI or AUIPC that can be fused?
1100 if (I != MBB.begin()) {
1101 I = skipDebugInstructionsBackward(std::prev(I), MBB.begin());
1102 if ((I->getOpcode() == RISCV::LUI || I->getOpcode() == RISCV::AUIPC) &&
1103 I->getOperand(0).getReg() == MI.getOperand(1).getReg()) {
1104 if (OpIdx == 0)
1105 tryAddHint(MO, MI.getOperand(1), /*NeedGPRC=*/false);
1106 else
1107 tryAddHint(MO, MI.getOperand(0), /*NeedGPRC=*/false);
1108 }
1109 }
1110 }
1111 }
1112
1113 for (MCPhysReg OrderReg : Order)
1114 if (TwoAddrHints.count(OrderReg))
1115 Hints.push_back(OrderReg);
1116
1117 return BaseImplRetVal;
1118}
1119
1121 MachineFunction &MF) const {
1122 MachineRegisterInfo *MRI = &MF.getRegInfo();
1123 std::pair<unsigned, Register> Hint = MRI->getRegAllocationHint(Reg);
1124
1125 // Handle RegPairEven/RegPairOdd hints for Zilsd register pairs
1126 if ((Hint.first == RISCVRI::RegPairOdd ||
1127 Hint.first == RISCVRI::RegPairEven) &&
1128 Hint.second.isVirtual()) {
1129 // If 'Reg' is one of the even/odd register pair and it's now changed
1130 // (e.g. coalesced) into a different register, the other register of the
1131 // pair allocation hint must be updated to reflect the relationship change.
1132 Register Partner = Hint.second;
1133 std::pair<unsigned, Register> PartnerHint =
1134 MRI->getRegAllocationHint(Partner);
1135
1136 // Make sure partner still points to us
1137 if (PartnerHint.second == Reg) {
1138 // Update partner to point to NewReg instead of Reg
1139 MRI->setRegAllocationHint(Partner, PartnerHint.first, NewReg);
1140
1141 // If NewReg is virtual, set up the reciprocal hint
1142 // NewReg takes over Reg's role, so it gets the SAME hint type as Reg
1143 if (NewReg.isVirtual())
1144 MRI->setRegAllocationHint(NewReg, Hint.first, Partner);
1145 }
1146 }
1147}
1148
1151 uint16_t Encoding) const {
1152 MCRegister Reg = RISCV::V0 + Encoding;
1154 return Reg;
1155 return getMatchingSuperReg(Reg, RISCV::sub_vrm1_0, &RegClass);
1156}
assert(UImm &&(UImm !=~static_cast< T >(0)) &&"Invalid immediate!")
MachineBasicBlock & MBB
MachineBasicBlock MachineBasicBlock::iterator DebugLoc DL
MachineBasicBlock MachineBasicBlock::iterator MBBI
This file contains constants used for implementing Dwarf debug support.
const HexagonInstrInfo * TII
#define _
IRTranslator LLVM IR MI
const AbstractManglingParser< Derived, Alloc >::OperatorInfo AbstractManglingParser< Derived, Alloc >::Ops[]
Live Register Matrix
#define I(x, y, z)
Definition MD5.cpp:57
Register const TargetRegisterInfo * TRI
Promote Memory to Register
Definition Mem2Reg.cpp:110
MachineInstr unsigned OpIdx
uint64_t IntrinsicInst * II
static cl::opt< bool > DisableRegAllocHints("riscv-disable-regalloc-hints", cl::Hidden, cl::init(false), cl::desc("Disable two address hints for register " "allocation"))
static cl::opt< bool > DisableCostPerUse("riscv-disable-cost-per-use", cl::init(false), cl::Hidden)
static std::tuple< RISCVVType::VLMUL, const TargetRegisterClass &, unsigned > getSpillReloadInfo(unsigned NumRemaining, uint16_t RegEncoding, bool IsSpill)
This file declares the machine register scavenger class.
static bool contains(SmallPtrSetImpl< ConstantExpr * > &Cache, ConstantExpr *Expr, Constant *C)
Definition Value.cpp:483
This file defines the SmallSet class.
static unsigned getDwarfRegNum(MCRegister Reg, const TargetRegisterInfo *TRI)
Go up the super-register chain until we hit a valid dwarf register number.
Represent a constant reference to an array (0 or more elements consecutively in memory),...
Definition ArrayRef.h:40
static LLVM_ABI void appendOffset(SmallVectorImpl< uint64_t > &Ops, int64_t Offset)
Append Ops with operations to apply the Offset.
A debug info location.
Definition DebugLoc.h:123
CallingConv::ID getCallingConv() const
getCallingConv()/setCallingConv(CC) - These method get and set the calling convention of this functio...
Definition Function.h:272
bool hasFnAttribute(Attribute::AttrKind Kind) const
Return true if the function has the attribute.
Definition Function.cpp:728
TypeSize getValue() const
bool isPrecise() const
Wrapper class representing physical registers. Should be passed by value.
Definition MCRegister.h:41
constexpr unsigned id() const
Definition MCRegister.h:82
MachineInstrBundleIterator< const MachineInstr > const_iterator
MachineInstrBundleIterator< MachineInstr > iterator
The MachineFrameInfo class represents an abstract stack frame until prolog/epilog code is inserted.
int64_t getLocalFrameSize() const
Get the size of the local object blob.
const TargetSubtargetInfo & getSubtarget() const
getSubtarget - Return the subtarget for which this machine code is being compiled.
MachineMemOperand * getMachineMemOperand(MachinePointerInfo PtrInfo, MachineMemOperand::Flags f, LLT MemTy, Align base_alignment, const AAMDNodes &AAInfo=AAMDNodes(), const MDNode *Ranges=nullptr, SyncScope::ID SSID=SyncScope::System, AtomicOrdering Ordering=AtomicOrdering::NotAtomic, AtomicOrdering FailureOrdering=AtomicOrdering::NotAtomic)
getMachineMemOperand - Allocate a new MachineMemOperand.
MachineFrameInfo & getFrameInfo()
getFrameInfo - Return the frame info object for the current function.
MachineRegisterInfo & getRegInfo()
getRegInfo - Return information about the registers currently in use.
Function & getFunction()
Return the LLVM function that this machine code represents.
const MachineInstrBuilder & addReg(Register RegNo, RegState Flags={}, unsigned SubReg=0) const
Add a new virtual register operand.
const MachineInstrBuilder & setMIFlag(MachineInstr::MIFlag Flag) const
const MachineInstrBuilder & addImm(int64_t Val) const
Add a new immediate operand.
const MachineInstrBuilder & addFrameIndex(int Idx) const
const MachineInstrBuilder & addMemOperand(MachineMemOperand *MMO) const
Representation of each machine instruction.
MachineOperand class - Representation of each machine instruction operand.
unsigned getSubReg() const
Register getReg() const
getReg - Returns the register number.
MachineRegisterInfo - Keep track of information for virtual and physical registers,...
const RegClassOrRegBank & getRegClassOrRegBank(Register Reg) const
Return the register bank or register class of Reg.
bool isReserved(MCRegister PhysReg) const
isReserved - Returns true when PhysReg is a reserved register.
LLVM_ABI Register createVirtualRegister(const TargetRegisterClass *RegClass, StringRef Name="")
createVirtualRegister - Create and return a new virtual register in the function with the specified r...
LLT getType(Register Reg) const
Get the low-level type of Reg or LLT{} if Reg is not a generic (target independent) virtual register.
LLVM_ABI const MCPhysReg * getCalleeSavedRegs() const
Returns list of callee saved registers.
std::pair< unsigned, Register > getRegAllocationHint(Register VReg) const
getRegAllocationHint - Return the register allocation hint for the specified virtual register.
void setRegAllocationHint(Register VReg, unsigned Type, Register PrefReg)
setRegAllocationHint - Specify a register allocation hint for the specified virtual register.
const MachineFunction & getMF() const
iterator_range< reg_nodbg_iterator > reg_nodbg_operands(Register Reg) const
bool hasBP(const MachineFunction &MF) const
void movImm(MachineBasicBlock &MBB, MachineBasicBlock::iterator MBBI, const DebugLoc &DL, Register DstReg, uint64_t Val, MachineInstr::MIFlag Flag=MachineInstr::NoFlags, bool DstRenamable=false, bool DstIsDead=false) const
std::optional< unsigned > getRealVLen() const
const RISCVRegisterInfo * getRegisterInfo() const override
const RISCVInstrInfo * getInstrInfo() const override
This class implements the register bank concept.
unsigned getID() const
Get the identifier of this register bank.
Wrapper class representing virtual and physical registers.
Definition Register.h:20
constexpr bool isVirtual() const
Return true if the specified register number is in the virtual register namespace.
Definition Register.h:79
constexpr bool isPhysical() const
Return true if the specified register number is in the physical register namespace.
Definition Register.h:83
SmallSet - This maintains a set of unique values, optimizing for the case when the set is small (less...
Definition SmallSet.h:134
size_type count(const T &V) const
count - Return 1 if the element is in the set, 0 otherwise.
Definition SmallSet.h:176
std::pair< const_iterator, bool > insert(const T &V)
insert - Insert an element into the set if it isn't already there.
Definition SmallSet.h:184
This class consists of common code factored out of the SmallVector class to reduce code duplication b...
void push_back(const T &Elt)
StackOffset holds a fixed and a scalable offset in bytes.
Definition TypeSize.h:30
int64_t getFixed() const
Returns the fixed component of the stack.
Definition TypeSize.h:46
static StackOffset get(int64_t Fixed, int64_t Scalable)
Definition TypeSize.h:41
Represent a constant reference to a string, i.e.
Definition StringRef.h:56
Information about stack frame layout on the target.
bool hasFP(const MachineFunction &MF) const
hasFP - Return true if the specified function should have a dedicated frame pointer register.
TargetInstrInfo - Interface to description of machine instruction set.
const uint8_t TSFlags
Configurable target specific flags.
TargetRegisterInfo base class - We assume that the target defines a static array of TargetRegisterDes...
virtual StringRef getRegAsmName(MCRegister Reg) const
Return the assembly name for Reg.
virtual bool getRegAllocationHints(Register VirtReg, ArrayRef< MCPhysReg > Order, SmallVectorImpl< MCPhysReg > &Hints, const MachineFunction &MF, const VirtRegMap *VRM=nullptr, const LiveRegMatrix *Matrix=nullptr) const
Get a list of 'hint' registers that the register allocator should try first when allocating a physica...
virtual bool isRegisterReservedByUser(Register R) const
virtual const TargetInstrInfo * getInstrInfo() const
MCRegister getPhys(Register virtReg) const
returns the physical register mapped to the specified virtual register
Definition VirtRegMap.h:91
bool hasPhys(Register virtReg) const
returns true if the specified virtual register is mapped to a physical register
Definition VirtRegMap.h:87
constexpr bool isKnownMultipleOf(ScalarTy RHS) const
This function tells the caller whether the element count is known at compile time to be a multiple of...
Definition TypeSize.h:180
constexpr LeafTy divideCoefficientBy(ScalarTy RHS) const
We do not provide the '/' operator here because division for polynomial types does not work in the sa...
Definition TypeSize.h:252
#define llvm_unreachable(msg)
Marks that the current location is not supposed to be reachable.
unsigned ID
LLVM IR allows to use arbitrary numbers as calling convention identifiers.
Definition CallingConv.h:24
@ RISCV_VectorCall
Calling convention used for RISC-V V-extension.
@ PreserveMost
Used for runtime calls that preserves most registers.
Definition CallingConv.h:63
@ GHC
Used by the Glasgow Haskell Compiler (GHC).
Definition CallingConv.h:50
@ GRAAL
Used by GraalVM. Two additional registers are reserved.
MCRegister getBPReg()
static unsigned getFormat(uint64_t TSFlags)
static RISCVVType::VLMUL getLMul(uint8_t TSFlags)
LLVM_ABI std::pair< unsigned, bool > decodeVLMUL(VLMUL VLMul)
std::optional< std::pair< unsigned, unsigned > > isRVVSpillForZvlsseg(unsigned Opcode)
bool isRVVSpill(const MachineInstr &MI)
static constexpr unsigned RVVBytesPerBlock
initializer< Ty > init(const Ty &Val)
This is an optimization pass for GlobalISel generic memory operations.
@ Offset
Definition DWP.cpp:558
PointerUnion< const TargetRegisterClass *, const RegisterBank * > RegClassOrRegBank
Convenient type to represent either a register class or a register bank.
MachineInstrBuilder BuildMI(MachineFunction &MF, const MIMetadata &MIMD, const MCInstrDesc &MCID)
Builder interface. Specify how to create the initial instruction itself.
constexpr bool isInt(int64_t x)
Checks if an integer fits into the given bit width.
Definition MathExtras.h:165
@ Implicit
Not emitted register (e.g. carry, or temporary result).
@ Kill
The last use of a register.
constexpr RegState getKillRegState(bool B)
decltype(auto) dyn_cast(const From &Val)
dyn_cast<X> - Return the argument parameter cast to the specified type.
Definition Casting.h:643
unsigned Log2_32(uint32_t Value)
Return the floor log base 2 of the specified value, -1 if the value is zero.
Definition MathExtras.h:331
constexpr RegState getDefRegState(bool B)
constexpr bool isUInt(uint64_t x)
Checks if an unsigned integer fits into the given bit width.
Definition MathExtras.h:189
IterT skipDebugInstructionsBackward(IterT It, IterT Begin, bool SkipPseudoOp=true)
Decrement It until it points to a non-debug instruction or to Begin and return the resulting iterator...
@ Sub
Subtraction of integers.
uint16_t MCPhysReg
An unsigned integer type large enough to represent all physical registers, but not necessarily virtua...
Definition MCRegister.h:21
constexpr bool isShiftedInt(int64_t x)
Checks if a signed integer is an N bit number shifted left by S.
Definition MathExtras.h:182
bool is_contained(R &&Range, const E &Element)
Returns true if Element is found in Range.
Definition STLExtras.h:1946
constexpr int64_t SignExtend64(uint64_t x)
Sign-extend the number in the bottom B bits of X to a 64-bit integer.
Definition MathExtras.h:572
LLVM_ABI void reportFatalUsageError(Error Err)
Report a fatal error that does not indicate a bug in LLVM.
Definition Error.cpp:177
This struct is a compact representation of a valid (non-zero power of two) alignment.
Definition Alignment.h:39
constexpr uint64_t value() const
This is a hole in the type system and should not be abused.
Definition Alignment.h:77
This struct is a compact representation of a valid (power of two) or undefined (0) alignment.
Definition Alignment.h:106
Align valueOrOne() const
For convenience, returns a valid alignment or 1 if undefined.
Definition Alignment.h:130
bool needsFrameBaseReg(MachineInstr *MI, int64_t Offset) const override
bool requiresVirtualBaseRegisters(const MachineFunction &MF) const override
Register findVRegWithEncoding(const TargetRegisterClass &RegClass, uint16_t Encoding) const
const TargetRegisterClass * getLargestLegalSuperClass(const TargetRegisterClass *RC, const MachineFunction &) const override
const MCPhysReg * getCalleeSavedRegs(const MachineFunction *MF) const override
BitVector getReservedRegs(const MachineFunction &MF) const override
const uint32_t * getCallPreservedMask(const MachineFunction &MF, CallingConv::ID) const override
Register materializeFrameBaseRegister(MachineBasicBlock *MBB, int FrameIdx, int64_t Offset) const override
RISCVRegisterInfo(unsigned HwMode)
void getOffsetOpcodes(const StackOffset &Offset, SmallVectorImpl< uint64_t > &Ops) const override
const TargetRegisterClass * getConstrainedRegClassForOperand(const MachineOperand &MO, const MachineRegisterInfo &MRI) const override
bool isFrameOffsetLegal(const MachineInstr *MI, Register BaseReg, int64_t Offset) const override
Register getFrameRegister(const MachineFunction &MF) const override
const MCPhysReg * getIPRACSRegs(const MachineFunction *MF) const override
void lowerSegmentSpillReload(MachineBasicBlock::iterator II, bool IsSpill) const
const TargetRegisterClass * getRegClassForTypeOnBank(LLT Ty, const RegisterBank &RB, bool Is64Bit) const
void adjustReg(MachineBasicBlock &MBB, MachineBasicBlock::iterator II, const DebugLoc &DL, Register DestReg, Register SrcReg, StackOffset Offset, MachineInstr::MIFlag Flag, MaybeAlign RequiredAlign) const
void updateRegAllocHint(Register Reg, Register NewReg, MachineFunction &MF) const override
bool isAsmClobberable(const MachineFunction &MF, MCRegister PhysReg) const override
const uint32_t * getNoPreservedMask() const override
float getSpillWeightScaleFactor(const TargetRegisterClass *RC) const override
void resolveFrameIndex(MachineInstr &MI, Register BaseReg, int64_t Offset) const override
bool getRegAllocationHints(Register VirtReg, ArrayRef< MCPhysReg > Order, SmallVectorImpl< MCPhysReg > &Hints, const MachineFunction &MF, const VirtRegMap *VRM, const LiveRegMatrix *Matrix) const override
int64_t getFrameIndexInstrOffset(const MachineInstr *MI, int Idx) const override
unsigned getRegisterCostTableIndex(const MachineFunction &MF) const override
StringRef getRegAsmName(MCRegister Reg) const override
bool eliminateFrameIndex(MachineBasicBlock::iterator MI, int SPAdj, unsigned FIOperandNum, RegScavenger *RS=nullptr) const override