1 //===- llvm/CodeGen/MachineRegisterInfo.h -----------------------*- C++ -*-===//
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
7 //===----------------------------------------------------------------------===//
9 // This file defines the MachineRegisterInfo class.
11 //===----------------------------------------------------------------------===//
13 #ifndef LLVM_CODEGEN_MACHINEREGISTERINFO_H
14 #define LLVM_CODEGEN_MACHINEREGISTERINFO_H
16 #include "llvm/ADT/ArrayRef.h"
17 #include "llvm/ADT/BitVector.h"
18 #include "llvm/ADT/DenseMap.h"
19 #include "llvm/ADT/IndexedMap.h"
20 #include "llvm/ADT/PointerUnion.h"
21 #include "llvm/ADT/SmallVector.h"
22 #include "llvm/ADT/StringSet.h"
23 #include "llvm/ADT/iterator_range.h"
24 #include "llvm/CodeGen/GlobalISel/RegisterBank.h"
25 #include "llvm/CodeGen/LowLevelType.h"
26 #include "llvm/CodeGen/MachineBasicBlock.h"
27 #include "llvm/CodeGen/MachineFunction.h"
28 #include "llvm/CodeGen/MachineInstrBundle.h"
29 #include "llvm/CodeGen/MachineOperand.h"
30 #include "llvm/CodeGen/TargetRegisterInfo.h"
31 #include "llvm/CodeGen/TargetSubtargetInfo.h"
32 #include "llvm/MC/LaneBitmask.h"
45 /// Convenient type to represent either a register class or a register bank.
46 using RegClassOrRegBank
=
47 PointerUnion
<const TargetRegisterClass
*, const RegisterBank
*>;
49 /// MachineRegisterInfo - Keep track of information for virtual and physical
50 /// registers, including vreg register classes, use/def chains for registers,
52 class MachineRegisterInfo
{
55 virtual void anchor();
58 virtual ~Delegate() = default;
60 virtual void MRI_NoteNewVirtualRegister(unsigned Reg
) = 0;
65 Delegate
*TheDelegate
= nullptr;
67 /// True if subregister liveness is tracked.
68 const bool TracksSubRegLiveness
;
70 /// VRegInfo - Information we keep for each virtual register.
72 /// Each element in this list contains the register class of the vreg and the
73 /// start of the use/def list for the register.
74 IndexedMap
<std::pair
<RegClassOrRegBank
, MachineOperand
*>,
78 /// Map for recovering vreg name from vreg number.
79 /// This map is used by the MIR Printer.
80 IndexedMap
<std::string
, VirtReg2IndexFunctor
> VReg2Name
;
82 /// StringSet that is used to unique vreg names.
83 StringSet
<> VRegNames
;
85 /// The flag is true upon \p UpdatedCSRs initialization
86 /// and false otherwise.
87 bool IsUpdatedCSRsInitialized
;
89 /// Contains the updated callee saved register list.
90 /// As opposed to the static list defined in register info,
91 /// all registers that were disabled are removed from the list.
92 SmallVector
<MCPhysReg
, 16> UpdatedCSRs
;
94 /// RegAllocHints - This vector records register allocation hints for
95 /// virtual registers. For each virtual register, it keeps a pair of hint
96 /// type and hints vector making up the allocation hints. Only the first
97 /// hint may be target specific, and in that case this is reflected by the
98 /// first member of the pair being non-zero. If the hinted register is
99 /// virtual, it means the allocator should prefer the physical register
100 /// allocated to it if any.
101 IndexedMap
<std::pair
<unsigned, SmallVector
<unsigned, 4>>,
102 VirtReg2IndexFunctor
> RegAllocHints
;
104 /// PhysRegUseDefLists - This is an array of the head of the use/def list for
105 /// physical registers.
106 std::unique_ptr
<MachineOperand
*[]> PhysRegUseDefLists
;
108 /// getRegUseDefListHead - Return the head pointer for the register use/def
109 /// list for the specified virtual or physical register.
110 MachineOperand
*&getRegUseDefListHead(unsigned RegNo
) {
111 if (TargetRegisterInfo::isVirtualRegister(RegNo
))
112 return VRegInfo
[RegNo
].second
;
113 return PhysRegUseDefLists
[RegNo
];
116 MachineOperand
*getRegUseDefListHead(unsigned RegNo
) const {
117 if (TargetRegisterInfo::isVirtualRegister(RegNo
))
118 return VRegInfo
[RegNo
].second
;
119 return PhysRegUseDefLists
[RegNo
];
122 /// Get the next element in the use-def chain.
123 static MachineOperand
*getNextOperandForReg(const MachineOperand
*MO
) {
124 assert(MO
&& MO
->isReg() && "This is not a register operand!");
125 return MO
->Contents
.Reg
.Next
;
128 /// UsedPhysRegMask - Additional used physregs including aliases.
129 /// This bit vector represents all the registers clobbered by function calls.
130 BitVector UsedPhysRegMask
;
132 /// ReservedRegs - This is a bit vector of reserved registers. The target
133 /// may change its mind about which registers should be reserved. This
134 /// vector is the frozen set of reserved registers when register allocation
136 BitVector ReservedRegs
;
138 using VRegToTypeMap
= IndexedMap
<LLT
, VirtReg2IndexFunctor
>;
139 /// Map generic virtual registers to their low-level type.
140 VRegToTypeMap VRegToType
;
142 /// Keep track of the physical registers that are live in to the function.
143 /// Live in values are typically arguments in registers. LiveIn values are
144 /// allowed to have virtual registers associated with them, stored in the
146 std::vector
<std::pair
<unsigned, unsigned>> LiveIns
;
149 explicit MachineRegisterInfo(MachineFunction
*MF
);
150 MachineRegisterInfo(const MachineRegisterInfo
&) = delete;
151 MachineRegisterInfo
&operator=(const MachineRegisterInfo
&) = delete;
153 const TargetRegisterInfo
*getTargetRegisterInfo() const {
154 return MF
->getSubtarget().getRegisterInfo();
157 void resetDelegate(Delegate
*delegate
) {
158 // Ensure another delegate does not take over unless the current
159 // delegate first unattaches itself. If we ever need to multicast
160 // notifications, we will need to change to using a list.
161 assert(TheDelegate
== delegate
&&
162 "Only the current delegate can perform reset!");
163 TheDelegate
= nullptr;
166 void setDelegate(Delegate
*delegate
) {
167 assert(delegate
&& !TheDelegate
&&
168 "Attempted to set delegate to null, or to change it without "
169 "first resetting it!");
171 TheDelegate
= delegate
;
174 //===--------------------------------------------------------------------===//
176 //===--------------------------------------------------------------------===//
178 // isSSA - Returns true when the machine function is in SSA form. Early
179 // passes require the machine function to be in SSA form where every virtual
180 // register has a single defining instruction.
182 // The TwoAddressInstructionPass and PHIElimination passes take the machine
183 // function out of SSA form when they introduce multiple defs per virtual
186 return MF
->getProperties().hasProperty(
187 MachineFunctionProperties::Property::IsSSA
);
190 // leaveSSA - Indicates that the machine function is no longer in SSA form.
192 MF
->getProperties().reset(MachineFunctionProperties::Property::IsSSA
);
195 /// tracksLiveness - Returns true when tracking register liveness accurately.
196 /// (see MachineFUnctionProperties::Property description for details)
197 bool tracksLiveness() const {
198 return MF
->getProperties().hasProperty(
199 MachineFunctionProperties::Property::TracksLiveness
);
202 /// invalidateLiveness - Indicates that register liveness is no longer being
203 /// tracked accurately.
205 /// This should be called by late passes that invalidate the liveness
207 void invalidateLiveness() {
208 MF
->getProperties().reset(
209 MachineFunctionProperties::Property::TracksLiveness
);
212 /// Returns true if liveness for register class @p RC should be tracked at
213 /// the subregister level.
214 bool shouldTrackSubRegLiveness(const TargetRegisterClass
&RC
) const {
215 return subRegLivenessEnabled() && RC
.HasDisjunctSubRegs
;
217 bool shouldTrackSubRegLiveness(unsigned VReg
) const {
218 assert(TargetRegisterInfo::isVirtualRegister(VReg
) && "Must pass a VReg");
219 return shouldTrackSubRegLiveness(*getRegClass(VReg
));
221 bool subRegLivenessEnabled() const {
222 return TracksSubRegLiveness
;
225 //===--------------------------------------------------------------------===//
227 //===--------------------------------------------------------------------===//
229 /// Returns true if the updated CSR list was initialized and false otherwise.
230 bool isUpdatedCSRsInitialized() const { return IsUpdatedCSRsInitialized
; }
232 /// Disables the register from the list of CSRs.
233 /// I.e. the register will not appear as part of the CSR mask.
234 /// \see UpdatedCalleeSavedRegs.
235 void disableCalleeSavedRegister(unsigned Reg
);
237 /// Returns list of callee saved registers.
238 /// The function returns the updated CSR list (after taking into account
239 /// registers that are disabled from the CSR list).
240 const MCPhysReg
*getCalleeSavedRegs() const;
242 /// Sets the updated Callee Saved Registers list.
243 /// Notice that it will override ant previously disabled/saved CSRs.
244 void setCalleeSavedRegs(ArrayRef
<MCPhysReg
> CSRs
);
246 // Strictly for use by MachineInstr.cpp.
247 void addRegOperandToUseList(MachineOperand
*MO
);
249 // Strictly for use by MachineInstr.cpp.
250 void removeRegOperandFromUseList(MachineOperand
*MO
);
252 // Strictly for use by MachineInstr.cpp.
253 void moveOperands(MachineOperand
*Dst
, MachineOperand
*Src
, unsigned NumOps
);
255 /// Verify the sanity of the use list for Reg.
256 void verifyUseList(unsigned Reg
) const;
258 /// Verify the use list of all registers.
259 void verifyUseLists() const;
261 /// reg_begin/reg_end - Provide iteration support to walk over all definitions
262 /// and uses of a register within the MachineFunction that corresponds to this
263 /// MachineRegisterInfo object.
264 template<bool Uses
, bool Defs
, bool SkipDebug
,
265 bool ByOperand
, bool ByInstr
, bool ByBundle
>
266 class defusechain_iterator
;
267 template<bool Uses
, bool Defs
, bool SkipDebug
,
268 bool ByOperand
, bool ByInstr
, bool ByBundle
>
269 class defusechain_instr_iterator
;
271 // Make it a friend so it can access getNextOperandForReg().
272 template<bool, bool, bool, bool, bool, bool>
273 friend class defusechain_iterator
;
274 template<bool, bool, bool, bool, bool, bool>
275 friend class defusechain_instr_iterator
;
277 /// reg_iterator/reg_begin/reg_end - Walk all defs and uses of the specified
280 defusechain_iterator
<true, true, false, true, false, false>;
281 reg_iterator
reg_begin(unsigned RegNo
) const {
282 return reg_iterator(getRegUseDefListHead(RegNo
));
284 static reg_iterator
reg_end() { return reg_iterator(nullptr); }
286 inline iterator_range
<reg_iterator
> reg_operands(unsigned Reg
) const {
287 return make_range(reg_begin(Reg
), reg_end());
290 /// reg_instr_iterator/reg_instr_begin/reg_instr_end - Walk all defs and uses
291 /// of the specified register, stepping by MachineInstr.
292 using reg_instr_iterator
=
293 defusechain_instr_iterator
<true, true, false, false, true, false>;
294 reg_instr_iterator
reg_instr_begin(unsigned RegNo
) const {
295 return reg_instr_iterator(getRegUseDefListHead(RegNo
));
297 static reg_instr_iterator
reg_instr_end() {
298 return reg_instr_iterator(nullptr);
301 inline iterator_range
<reg_instr_iterator
>
302 reg_instructions(unsigned Reg
) const {
303 return make_range(reg_instr_begin(Reg
), reg_instr_end());
306 /// reg_bundle_iterator/reg_bundle_begin/reg_bundle_end - Walk all defs and uses
307 /// of the specified register, stepping by bundle.
308 using reg_bundle_iterator
=
309 defusechain_instr_iterator
<true, true, false, false, false, true>;
310 reg_bundle_iterator
reg_bundle_begin(unsigned RegNo
) const {
311 return reg_bundle_iterator(getRegUseDefListHead(RegNo
));
313 static reg_bundle_iterator
reg_bundle_end() {
314 return reg_bundle_iterator(nullptr);
317 inline iterator_range
<reg_bundle_iterator
> reg_bundles(unsigned Reg
) const {
318 return make_range(reg_bundle_begin(Reg
), reg_bundle_end());
321 /// reg_empty - Return true if there are no instructions using or defining the
322 /// specified register (it may be live-in).
323 bool reg_empty(unsigned RegNo
) const { return reg_begin(RegNo
) == reg_end(); }
325 /// reg_nodbg_iterator/reg_nodbg_begin/reg_nodbg_end - Walk all defs and uses
326 /// of the specified register, skipping those marked as Debug.
327 using reg_nodbg_iterator
=
328 defusechain_iterator
<true, true, true, true, false, false>;
329 reg_nodbg_iterator
reg_nodbg_begin(unsigned RegNo
) const {
330 return reg_nodbg_iterator(getRegUseDefListHead(RegNo
));
332 static reg_nodbg_iterator
reg_nodbg_end() {
333 return reg_nodbg_iterator(nullptr);
336 inline iterator_range
<reg_nodbg_iterator
>
337 reg_nodbg_operands(unsigned Reg
) const {
338 return make_range(reg_nodbg_begin(Reg
), reg_nodbg_end());
341 /// reg_instr_nodbg_iterator/reg_instr_nodbg_begin/reg_instr_nodbg_end - Walk
342 /// all defs and uses of the specified register, stepping by MachineInstr,
343 /// skipping those marked as Debug.
344 using reg_instr_nodbg_iterator
=
345 defusechain_instr_iterator
<true, true, true, false, true, false>;
346 reg_instr_nodbg_iterator
reg_instr_nodbg_begin(unsigned RegNo
) const {
347 return reg_instr_nodbg_iterator(getRegUseDefListHead(RegNo
));
349 static reg_instr_nodbg_iterator
reg_instr_nodbg_end() {
350 return reg_instr_nodbg_iterator(nullptr);
353 inline iterator_range
<reg_instr_nodbg_iterator
>
354 reg_nodbg_instructions(unsigned Reg
) const {
355 return make_range(reg_instr_nodbg_begin(Reg
), reg_instr_nodbg_end());
358 /// reg_bundle_nodbg_iterator/reg_bundle_nodbg_begin/reg_bundle_nodbg_end - Walk
359 /// all defs and uses of the specified register, stepping by bundle,
360 /// skipping those marked as Debug.
361 using reg_bundle_nodbg_iterator
=
362 defusechain_instr_iterator
<true, true, true, false, false, true>;
363 reg_bundle_nodbg_iterator
reg_bundle_nodbg_begin(unsigned RegNo
) const {
364 return reg_bundle_nodbg_iterator(getRegUseDefListHead(RegNo
));
366 static reg_bundle_nodbg_iterator
reg_bundle_nodbg_end() {
367 return reg_bundle_nodbg_iterator(nullptr);
370 inline iterator_range
<reg_bundle_nodbg_iterator
>
371 reg_nodbg_bundles(unsigned Reg
) const {
372 return make_range(reg_bundle_nodbg_begin(Reg
), reg_bundle_nodbg_end());
375 /// reg_nodbg_empty - Return true if the only instructions using or defining
376 /// Reg are Debug instructions.
377 bool reg_nodbg_empty(unsigned RegNo
) const {
378 return reg_nodbg_begin(RegNo
) == reg_nodbg_end();
381 /// def_iterator/def_begin/def_end - Walk all defs of the specified register.
383 defusechain_iterator
<false, true, false, true, false, false>;
384 def_iterator
def_begin(unsigned RegNo
) const {
385 return def_iterator(getRegUseDefListHead(RegNo
));
387 static def_iterator
def_end() { return def_iterator(nullptr); }
389 inline iterator_range
<def_iterator
> def_operands(unsigned Reg
) const {
390 return make_range(def_begin(Reg
), def_end());
393 /// def_instr_iterator/def_instr_begin/def_instr_end - Walk all defs of the
394 /// specified register, stepping by MachineInst.
395 using def_instr_iterator
=
396 defusechain_instr_iterator
<false, true, false, false, true, false>;
397 def_instr_iterator
def_instr_begin(unsigned RegNo
) const {
398 return def_instr_iterator(getRegUseDefListHead(RegNo
));
400 static def_instr_iterator
def_instr_end() {
401 return def_instr_iterator(nullptr);
404 inline iterator_range
<def_instr_iterator
>
405 def_instructions(unsigned Reg
) const {
406 return make_range(def_instr_begin(Reg
), def_instr_end());
409 /// def_bundle_iterator/def_bundle_begin/def_bundle_end - Walk all defs of the
410 /// specified register, stepping by bundle.
411 using def_bundle_iterator
=
412 defusechain_instr_iterator
<false, true, false, false, false, true>;
413 def_bundle_iterator
def_bundle_begin(unsigned RegNo
) const {
414 return def_bundle_iterator(getRegUseDefListHead(RegNo
));
416 static def_bundle_iterator
def_bundle_end() {
417 return def_bundle_iterator(nullptr);
420 inline iterator_range
<def_bundle_iterator
> def_bundles(unsigned Reg
) const {
421 return make_range(def_bundle_begin(Reg
), def_bundle_end());
424 /// def_empty - Return true if there are no instructions defining the
425 /// specified register (it may be live-in).
426 bool def_empty(unsigned RegNo
) const { return def_begin(RegNo
) == def_end(); }
428 StringRef
getVRegName(unsigned Reg
) const {
429 return VReg2Name
.inBounds(Reg
) ? StringRef(VReg2Name
[Reg
]) : "";
432 void insertVRegByName(StringRef Name
, unsigned Reg
) {
433 assert((Name
.empty() || VRegNames
.find(Name
) == VRegNames
.end()) &&
434 "Named VRegs Must be Unique.");
436 VRegNames
.insert(Name
);
438 VReg2Name
[Reg
] = Name
.str();
442 /// Return true if there is exactly one operand defining the specified
444 bool hasOneDef(unsigned RegNo
) const {
445 def_iterator DI
= def_begin(RegNo
);
448 return ++DI
== def_end();
451 /// use_iterator/use_begin/use_end - Walk all uses of the specified register.
453 defusechain_iterator
<true, false, false, true, false, false>;
454 use_iterator
use_begin(unsigned RegNo
) const {
455 return use_iterator(getRegUseDefListHead(RegNo
));
457 static use_iterator
use_end() { return use_iterator(nullptr); }
459 inline iterator_range
<use_iterator
> use_operands(unsigned Reg
) const {
460 return make_range(use_begin(Reg
), use_end());
463 /// use_instr_iterator/use_instr_begin/use_instr_end - Walk all uses of the
464 /// specified register, stepping by MachineInstr.
465 using use_instr_iterator
=
466 defusechain_instr_iterator
<true, false, false, false, true, false>;
467 use_instr_iterator
use_instr_begin(unsigned RegNo
) const {
468 return use_instr_iterator(getRegUseDefListHead(RegNo
));
470 static use_instr_iterator
use_instr_end() {
471 return use_instr_iterator(nullptr);
474 inline iterator_range
<use_instr_iterator
>
475 use_instructions(unsigned Reg
) const {
476 return make_range(use_instr_begin(Reg
), use_instr_end());
479 /// use_bundle_iterator/use_bundle_begin/use_bundle_end - Walk all uses of the
480 /// specified register, stepping by bundle.
481 using use_bundle_iterator
=
482 defusechain_instr_iterator
<true, false, false, false, false, true>;
483 use_bundle_iterator
use_bundle_begin(unsigned RegNo
) const {
484 return use_bundle_iterator(getRegUseDefListHead(RegNo
));
486 static use_bundle_iterator
use_bundle_end() {
487 return use_bundle_iterator(nullptr);
490 inline iterator_range
<use_bundle_iterator
> use_bundles(unsigned Reg
) const {
491 return make_range(use_bundle_begin(Reg
), use_bundle_end());
494 /// use_empty - Return true if there are no instructions using the specified
496 bool use_empty(unsigned RegNo
) const { return use_begin(RegNo
) == use_end(); }
498 /// hasOneUse - Return true if there is exactly one instruction using the
499 /// specified register.
500 bool hasOneUse(unsigned RegNo
) const {
501 use_iterator UI
= use_begin(RegNo
);
504 return ++UI
== use_end();
507 /// use_nodbg_iterator/use_nodbg_begin/use_nodbg_end - Walk all uses of the
508 /// specified register, skipping those marked as Debug.
509 using use_nodbg_iterator
=
510 defusechain_iterator
<true, false, true, true, false, false>;
511 use_nodbg_iterator
use_nodbg_begin(unsigned RegNo
) const {
512 return use_nodbg_iterator(getRegUseDefListHead(RegNo
));
514 static use_nodbg_iterator
use_nodbg_end() {
515 return use_nodbg_iterator(nullptr);
518 inline iterator_range
<use_nodbg_iterator
>
519 use_nodbg_operands(unsigned Reg
) const {
520 return make_range(use_nodbg_begin(Reg
), use_nodbg_end());
523 /// use_instr_nodbg_iterator/use_instr_nodbg_begin/use_instr_nodbg_end - Walk
524 /// all uses of the specified register, stepping by MachineInstr, skipping
525 /// those marked as Debug.
526 using use_instr_nodbg_iterator
=
527 defusechain_instr_iterator
<true, false, true, false, true, false>;
528 use_instr_nodbg_iterator
use_instr_nodbg_begin(unsigned RegNo
) const {
529 return use_instr_nodbg_iterator(getRegUseDefListHead(RegNo
));
531 static use_instr_nodbg_iterator
use_instr_nodbg_end() {
532 return use_instr_nodbg_iterator(nullptr);
535 inline iterator_range
<use_instr_nodbg_iterator
>
536 use_nodbg_instructions(unsigned Reg
) const {
537 return make_range(use_instr_nodbg_begin(Reg
), use_instr_nodbg_end());
540 /// use_bundle_nodbg_iterator/use_bundle_nodbg_begin/use_bundle_nodbg_end - Walk
541 /// all uses of the specified register, stepping by bundle, skipping
542 /// those marked as Debug.
543 using use_bundle_nodbg_iterator
=
544 defusechain_instr_iterator
<true, false, true, false, false, true>;
545 use_bundle_nodbg_iterator
use_bundle_nodbg_begin(unsigned RegNo
) const {
546 return use_bundle_nodbg_iterator(getRegUseDefListHead(RegNo
));
548 static use_bundle_nodbg_iterator
use_bundle_nodbg_end() {
549 return use_bundle_nodbg_iterator(nullptr);
552 inline iterator_range
<use_bundle_nodbg_iterator
>
553 use_nodbg_bundles(unsigned Reg
) const {
554 return make_range(use_bundle_nodbg_begin(Reg
), use_bundle_nodbg_end());
557 /// use_nodbg_empty - Return true if there are no non-Debug instructions
558 /// using the specified register.
559 bool use_nodbg_empty(unsigned RegNo
) const {
560 return use_nodbg_begin(RegNo
) == use_nodbg_end();
563 /// hasOneNonDBGUse - Return true if there is exactly one non-Debug
564 /// use of the specified register.
565 bool hasOneNonDBGUse(unsigned RegNo
) const;
567 /// hasOneNonDBGUse - Return true if there is exactly one non-Debug
568 /// instruction using the specified register. Said instruction may have
570 bool hasOneNonDBGUser(unsigned RegNo
) const;
572 /// replaceRegWith - Replace all instances of FromReg with ToReg in the
573 /// machine function. This is like llvm-level X->replaceAllUsesWith(Y),
574 /// except that it also changes any definitions of the register as well.
576 /// Note that it is usually necessary to first constrain ToReg's register
577 /// class and register bank to match the FromReg constraints using one of the
580 /// constrainRegClass(ToReg, getRegClass(FromReg))
581 /// constrainRegAttrs(ToReg, FromReg)
582 /// RegisterBankInfo::constrainGenericRegister(ToReg,
583 /// *MRI.getRegClass(FromReg), MRI)
585 /// These functions will return a falsy result if the virtual registers have
586 /// incompatible constraints.
588 /// Note that if ToReg is a physical register the function will replace and
589 /// apply sub registers to ToReg in order to obtain a final/proper physical
591 void replaceRegWith(unsigned FromReg
, unsigned ToReg
);
593 /// getVRegDef - Return the machine instr that defines the specified virtual
594 /// register or null if none is found. This assumes that the code is in SSA
595 /// form, so there should only be one definition.
596 MachineInstr
*getVRegDef(unsigned Reg
) const;
598 /// getUniqueVRegDef - Return the unique machine instr that defines the
599 /// specified virtual register or null if none is found. If there are
600 /// multiple definitions or no definition, return null.
601 MachineInstr
*getUniqueVRegDef(unsigned Reg
) const;
603 /// clearKillFlags - Iterate over all the uses of the given register and
604 /// clear the kill flag from the MachineOperand. This function is used by
605 /// optimization passes which extend register lifetimes and need only
606 /// preserve conservative kill flag information.
607 void clearKillFlags(unsigned Reg
) const;
609 void dumpUses(unsigned RegNo
) const;
611 /// Returns true if PhysReg is unallocatable and constant throughout the
612 /// function. Writing to a constant register has no effect.
613 bool isConstantPhysReg(unsigned PhysReg
) const;
615 /// Returns true if either isConstantPhysReg or TRI->isCallerPreservedPhysReg
616 /// returns true. This is a utility member function.
617 bool isCallerPreservedOrConstPhysReg(unsigned PhysReg
) const;
619 /// Get an iterator over the pressure sets affected by the given physical or
620 /// virtual register. If RegUnit is physical, it must be a register unit (from
621 /// MCRegUnitIterator).
622 PSetIterator
getPressureSets(unsigned RegUnit
) const;
624 //===--------------------------------------------------------------------===//
625 // Virtual Register Info
626 //===--------------------------------------------------------------------===//
628 /// Return the register class of the specified virtual register.
629 /// This shouldn't be used directly unless \p Reg has a register class.
630 /// \see getRegClassOrNull when this might happen.
631 const TargetRegisterClass
*getRegClass(unsigned Reg
) const {
632 assert(VRegInfo
[Reg
].first
.is
<const TargetRegisterClass
*>() &&
633 "Register class not set, wrong accessor");
634 return VRegInfo
[Reg
].first
.get
<const TargetRegisterClass
*>();
637 /// Return the register class of \p Reg, or null if Reg has not been assigned
638 /// a register class yet.
640 /// \note A null register class can only happen when these two
641 /// conditions are met:
642 /// 1. Generic virtual registers are created.
643 /// 2. The machine function has not completely been through the
644 /// instruction selection process.
645 /// None of this condition is possible without GlobalISel for now.
646 /// In other words, if GlobalISel is not used or if the query happens after
647 /// the select pass, using getRegClass is safe.
648 const TargetRegisterClass
*getRegClassOrNull(unsigned Reg
) const {
649 const RegClassOrRegBank
&Val
= VRegInfo
[Reg
].first
;
650 return Val
.dyn_cast
<const TargetRegisterClass
*>();
653 /// Return the register bank of \p Reg, or null if Reg has not been assigned
654 /// a register bank or has been assigned a register class.
655 /// \note It is possible to get the register bank from the register class via
656 /// RegisterBankInfo::getRegBankFromRegClass.
657 const RegisterBank
*getRegBankOrNull(unsigned Reg
) const {
658 const RegClassOrRegBank
&Val
= VRegInfo
[Reg
].first
;
659 return Val
.dyn_cast
<const RegisterBank
*>();
662 /// Return the register bank or register class of \p Reg.
663 /// \note Before the register bank gets assigned (i.e., before the
664 /// RegBankSelect pass) \p Reg may not have either.
665 const RegClassOrRegBank
&getRegClassOrRegBank(unsigned Reg
) const {
666 return VRegInfo
[Reg
].first
;
669 /// setRegClass - Set the register class of the specified virtual register.
670 void setRegClass(unsigned Reg
, const TargetRegisterClass
*RC
);
672 /// Set the register bank to \p RegBank for \p Reg.
673 void setRegBank(unsigned Reg
, const RegisterBank
&RegBank
);
675 void setRegClassOrRegBank(unsigned Reg
,
676 const RegClassOrRegBank
&RCOrRB
){
677 VRegInfo
[Reg
].first
= RCOrRB
;
680 /// constrainRegClass - Constrain the register class of the specified virtual
681 /// register to be a common subclass of RC and the current register class,
682 /// but only if the new class has at least MinNumRegs registers. Return the
683 /// new register class, or NULL if no such class exists.
684 /// This should only be used when the constraint is known to be trivial, like
685 /// GR32 -> GR32_NOSP. Beware of increasing register pressure.
687 /// \note Assumes that the register has a register class assigned.
688 /// Use RegisterBankInfo::constrainGenericRegister in GlobalISel's
689 /// InstructionSelect pass and constrainRegAttrs in every other pass,
690 /// including non-select passes of GlobalISel, instead.
691 const TargetRegisterClass
*constrainRegClass(unsigned Reg
,
692 const TargetRegisterClass
*RC
,
693 unsigned MinNumRegs
= 0);
695 /// Constrain the register class or the register bank of the virtual register
696 /// \p Reg (and low-level type) to be a common subclass or a common bank of
697 /// both registers provided respectively (and a common low-level type). Do
698 /// nothing if any of the attributes (classes, banks, or low-level types) of
699 /// the registers are deemed incompatible, or if the resulting register will
700 /// have a class smaller than before and of size less than \p MinNumRegs.
701 /// Return true if such register attributes exist, false otherwise.
703 /// \note Use this method instead of constrainRegClass and
704 /// RegisterBankInfo::constrainGenericRegister everywhere but SelectionDAG
705 /// ISel / FastISel and GlobalISel's InstructionSelect pass respectively.
706 bool constrainRegAttrs(unsigned Reg
, unsigned ConstrainingReg
,
707 unsigned MinNumRegs
= 0);
709 /// recomputeRegClass - Try to find a legal super-class of Reg's register
710 /// class that still satisfies the constraints from the instructions using
711 /// Reg. Returns true if Reg was upgraded.
713 /// This method can be used after constraints have been removed from a
714 /// virtual register, for example after removing instructions or splitting
716 bool recomputeRegClass(unsigned Reg
);
718 /// createVirtualRegister - Create and return a new virtual register in the
719 /// function with the specified register class.
720 Register
createVirtualRegister(const TargetRegisterClass
*RegClass
,
721 StringRef Name
= "");
723 /// Create and return a new virtual register in the function with the same
724 /// attributes as the given register.
725 Register
cloneVirtualRegister(Register VReg
, StringRef Name
= "");
727 /// Get the low-level type of \p Reg or LLT{} if Reg is not a generic
728 /// (target independent) virtual register.
729 LLT
getType(unsigned Reg
) const {
730 if (TargetRegisterInfo::isVirtualRegister(Reg
) && VRegToType
.inBounds(Reg
))
731 return VRegToType
[Reg
];
735 /// Set the low-level type of \p VReg to \p Ty.
736 void setType(unsigned VReg
, LLT Ty
);
738 /// Create and return a new generic virtual register with low-level
740 Register
createGenericVirtualRegister(LLT Ty
, StringRef Name
= "");
742 /// Remove all types associated to virtual registers (after instruction
743 /// selection and constraining of all generic virtual registers).
744 void clearVirtRegTypes();
746 /// Creates a new virtual register that has no register class, register bank
747 /// or size assigned yet. This is only allowed to be used
748 /// temporarily while constructing machine instructions. Most operations are
749 /// undefined on an incomplete register until one of setRegClass(),
750 /// setRegBank() or setSize() has been called on it.
751 unsigned createIncompleteVirtualRegister(StringRef Name
= "");
753 /// getNumVirtRegs - Return the number of virtual registers created.
754 unsigned getNumVirtRegs() const { return VRegInfo
.size(); }
756 /// clearVirtRegs - Remove all virtual registers (after physreg assignment).
757 void clearVirtRegs();
759 /// setRegAllocationHint - Specify a register allocation hint for the
760 /// specified virtual register. This is typically used by target, and in case
761 /// of an earlier hint it will be overwritten.
762 void setRegAllocationHint(unsigned VReg
, unsigned Type
, unsigned PrefReg
) {
763 assert(TargetRegisterInfo::isVirtualRegister(VReg
));
764 RegAllocHints
[VReg
].first
= Type
;
765 RegAllocHints
[VReg
].second
.clear();
766 RegAllocHints
[VReg
].second
.push_back(PrefReg
);
769 /// addRegAllocationHint - Add a register allocation hint to the hints
771 void addRegAllocationHint(unsigned VReg
, unsigned PrefReg
) {
772 assert(TargetRegisterInfo::isVirtualRegister(VReg
));
773 RegAllocHints
[VReg
].second
.push_back(PrefReg
);
776 /// Specify the preferred (target independent) register allocation hint for
777 /// the specified virtual register.
778 void setSimpleHint(unsigned VReg
, unsigned PrefReg
) {
779 setRegAllocationHint(VReg
, /*Type=*/0, PrefReg
);
782 void clearSimpleHint(unsigned VReg
) {
783 assert (RegAllocHints
[VReg
].first
== 0 &&
784 "Expected to clear a non-target hint!");
785 RegAllocHints
[VReg
].second
.clear();
788 /// getRegAllocationHint - Return the register allocation hint for the
789 /// specified virtual register. If there are many hints, this returns the
790 /// one with the greatest weight.
791 std::pair
<unsigned, unsigned>
792 getRegAllocationHint(unsigned VReg
) const {
793 assert(TargetRegisterInfo::isVirtualRegister(VReg
));
794 unsigned BestHint
= (RegAllocHints
[VReg
].second
.size() ?
795 RegAllocHints
[VReg
].second
[0] : 0);
796 return std::pair
<unsigned, unsigned>(RegAllocHints
[VReg
].first
, BestHint
);
799 /// getSimpleHint - same as getRegAllocationHint except it will only return
800 /// a target independent hint.
801 unsigned getSimpleHint(unsigned VReg
) const {
802 assert(TargetRegisterInfo::isVirtualRegister(VReg
));
803 std::pair
<unsigned, unsigned> Hint
= getRegAllocationHint(VReg
);
804 return Hint
.first
? 0 : Hint
.second
;
807 /// getRegAllocationHints - Return a reference to the vector of all
808 /// register allocation hints for VReg.
809 const std::pair
<unsigned, SmallVector
<unsigned, 4>>
810 &getRegAllocationHints(unsigned VReg
) const {
811 assert(TargetRegisterInfo::isVirtualRegister(VReg
));
812 return RegAllocHints
[VReg
];
815 /// markUsesInDebugValueAsUndef - Mark every DBG_VALUE referencing the
816 /// specified register as undefined which causes the DBG_VALUE to be
817 /// deleted during LiveDebugVariables analysis.
818 void markUsesInDebugValueAsUndef(unsigned Reg
) const;
820 /// Return true if the specified register is modified in this function.
821 /// This checks that no defining machine operands exist for the register or
822 /// any of its aliases. Definitions found on functions marked noreturn are
823 /// ignored, to consider them pass 'true' for optional parameter
824 /// SkipNoReturnDef. The register is also considered modified when it is set
825 /// in the UsedPhysRegMask.
826 bool isPhysRegModified(unsigned PhysReg
, bool SkipNoReturnDef
= false) const;
828 /// Return true if the specified register is modified or read in this
829 /// function. This checks that no machine operands exist for the register or
830 /// any of its aliases. The register is also considered used when it is set
831 /// in the UsedPhysRegMask.
832 bool isPhysRegUsed(unsigned PhysReg
) const;
834 /// addPhysRegsUsedFromRegMask - Mark any registers not in RegMask as used.
835 /// This corresponds to the bit mask attached to register mask operands.
836 void addPhysRegsUsedFromRegMask(const uint32_t *RegMask
) {
837 UsedPhysRegMask
.setBitsNotInMask(RegMask
);
840 const BitVector
&getUsedPhysRegsMask() const { return UsedPhysRegMask
; }
842 //===--------------------------------------------------------------------===//
843 // Reserved Register Info
844 //===--------------------------------------------------------------------===//
846 // The set of reserved registers must be invariant during register
847 // allocation. For example, the target cannot suddenly decide it needs a
848 // frame pointer when the register allocator has already used the frame
849 // pointer register for something else.
851 // These methods can be used by target hooks like hasFP() to avoid changing
852 // the reserved register set during register allocation.
854 /// freezeReservedRegs - Called by the register allocator to freeze the set
855 /// of reserved registers before allocation begins.
856 void freezeReservedRegs(const MachineFunction
&);
858 /// reservedRegsFrozen - Returns true after freezeReservedRegs() was called
859 /// to ensure the set of reserved registers stays constant.
860 bool reservedRegsFrozen() const {
861 return !ReservedRegs
.empty();
864 /// canReserveReg - Returns true if PhysReg can be used as a reserved
865 /// register. Any register can be reserved before freezeReservedRegs() is
867 bool canReserveReg(unsigned PhysReg
) const {
868 return !reservedRegsFrozen() || ReservedRegs
.test(PhysReg
);
871 /// getReservedRegs - Returns a reference to the frozen set of reserved
872 /// registers. This method should always be preferred to calling
873 /// TRI::getReservedRegs() when possible.
874 const BitVector
&getReservedRegs() const {
875 assert(reservedRegsFrozen() &&
876 "Reserved registers haven't been frozen yet. "
877 "Use TRI::getReservedRegs().");
881 /// isReserved - Returns true when PhysReg is a reserved register.
883 /// Reserved registers may belong to an allocatable register class, but the
884 /// target has explicitly requested that they are not used.
885 bool isReserved(unsigned PhysReg
) const {
886 return getReservedRegs().test(PhysReg
);
889 /// Returns true when the given register unit is considered reserved.
891 /// Register units are considered reserved when for at least one of their
892 /// root registers, the root register and all super registers are reserved.
893 /// This currently iterates the register hierarchy and may be slower than
895 bool isReservedRegUnit(unsigned Unit
) const;
897 /// isAllocatable - Returns true when PhysReg belongs to an allocatable
898 /// register class and it hasn't been reserved.
900 /// Allocatable registers may show up in the allocation order of some virtual
901 /// register, so a register allocator needs to track its liveness and
903 bool isAllocatable(unsigned PhysReg
) const {
904 return getTargetRegisterInfo()->isInAllocatableClass(PhysReg
) &&
905 !isReserved(PhysReg
);
908 //===--------------------------------------------------------------------===//
910 //===--------------------------------------------------------------------===//
912 /// addLiveIn - Add the specified register as a live-in. Note that it
913 /// is an error to add the same register to the same set more than once.
914 void addLiveIn(unsigned Reg
, unsigned vreg
= 0) {
915 LiveIns
.push_back(std::make_pair(Reg
, vreg
));
918 // Iteration support for the live-ins set. It's kept in sorted order
919 // by register number.
920 using livein_iterator
=
921 std::vector
<std::pair
<unsigned,unsigned>>::const_iterator
;
922 livein_iterator
livein_begin() const { return LiveIns
.begin(); }
923 livein_iterator
livein_end() const { return LiveIns
.end(); }
924 bool livein_empty() const { return LiveIns
.empty(); }
926 ArrayRef
<std::pair
<unsigned, unsigned>> liveins() const {
930 bool isLiveIn(unsigned Reg
) const;
932 /// getLiveInPhysReg - If VReg is a live-in virtual register, return the
933 /// corresponding live-in physical register.
934 unsigned getLiveInPhysReg(unsigned VReg
) const;
936 /// getLiveInVirtReg - If PReg is a live-in physical register, return the
937 /// corresponding live-in physical register.
938 unsigned getLiveInVirtReg(unsigned PReg
) const;
940 /// EmitLiveInCopies - Emit copies to initialize livein virtual registers
941 /// into the given entry block.
942 void EmitLiveInCopies(MachineBasicBlock
*EntryMBB
,
943 const TargetRegisterInfo
&TRI
,
944 const TargetInstrInfo
&TII
);
946 /// Returns a mask covering all bits that can appear in lane masks of
947 /// subregisters of the virtual register @p Reg.
948 LaneBitmask
getMaxLaneMaskForVReg(unsigned Reg
) const;
950 /// defusechain_iterator - This class provides iterator support for machine
951 /// operands in the function that use or define a specific register. If
952 /// ReturnUses is true it returns uses of registers, if ReturnDefs is true it
953 /// returns defs. If neither are true then you are silly and it always
954 /// returns end(). If SkipDebug is true it skips uses marked Debug
955 /// when incrementing.
956 template<bool ReturnUses
, bool ReturnDefs
, bool SkipDebug
,
957 bool ByOperand
, bool ByInstr
, bool ByBundle
>
958 class defusechain_iterator
959 : public std::iterator
<std::forward_iterator_tag
, MachineInstr
, ptrdiff_t> {
960 friend class MachineRegisterInfo
;
962 MachineOperand
*Op
= nullptr;
964 explicit defusechain_iterator(MachineOperand
*op
) : Op(op
) {
965 // If the first node isn't one we're interested in, advance to one that
966 // we are interested in.
968 if ((!ReturnUses
&& op
->isUse()) ||
969 (!ReturnDefs
&& op
->isDef()) ||
970 (SkipDebug
&& op
->isDebug()))
976 assert(Op
&& "Cannot increment end iterator!");
977 Op
= getNextOperandForReg(Op
);
979 // All defs come before the uses, so stop def_iterator early.
985 assert(!Op
->isDebug() && "Can't have debug defs");
988 // If this is an operand we don't care about, skip it.
989 while (Op
&& ((!ReturnDefs
&& Op
->isDef()) ||
990 (SkipDebug
&& Op
->isDebug())))
991 Op
= getNextOperandForReg(Op
);
996 using reference
= std::iterator
<std::forward_iterator_tag
,
997 MachineInstr
, ptrdiff_t>::reference
;
998 using pointer
= std::iterator
<std::forward_iterator_tag
,
999 MachineInstr
, ptrdiff_t>::pointer
;
1001 defusechain_iterator() = default;
1003 bool operator==(const defusechain_iterator
&x
) const {
1006 bool operator!=(const defusechain_iterator
&x
) const {
1007 return !operator==(x
);
1010 /// atEnd - return true if this iterator is equal to reg_end() on the value.
1011 bool atEnd() const { return Op
== nullptr; }
1013 // Iterator traversal: forward iteration only
1014 defusechain_iterator
&operator++() { // Preincrement
1015 assert(Op
&& "Cannot increment end iterator!");
1019 MachineInstr
*P
= Op
->getParent();
1022 } while (Op
&& Op
->getParent() == P
);
1023 } else if (ByBundle
) {
1024 MachineBasicBlock::instr_iterator P
=
1025 getBundleStart(Op
->getParent()->getIterator());
1028 } while (Op
&& getBundleStart(Op
->getParent()->getIterator()) == P
);
1033 defusechain_iterator
operator++(int) { // Postincrement
1034 defusechain_iterator tmp
= *this; ++*this; return tmp
;
1037 /// getOperandNo - Return the operand # of this MachineOperand in its
1039 unsigned getOperandNo() const {
1040 assert(Op
&& "Cannot dereference end iterator!");
1041 return Op
- &Op
->getParent()->getOperand(0);
1044 // Retrieve a reference to the current operand.
1045 MachineOperand
&operator*() const {
1046 assert(Op
&& "Cannot dereference end iterator!");
1050 MachineOperand
*operator->() const {
1051 assert(Op
&& "Cannot dereference end iterator!");
1056 /// defusechain_iterator - This class provides iterator support for machine
1057 /// operands in the function that use or define a specific register. If
1058 /// ReturnUses is true it returns uses of registers, if ReturnDefs is true it
1059 /// returns defs. If neither are true then you are silly and it always
1060 /// returns end(). If SkipDebug is true it skips uses marked Debug
1061 /// when incrementing.
1062 template<bool ReturnUses
, bool ReturnDefs
, bool SkipDebug
,
1063 bool ByOperand
, bool ByInstr
, bool ByBundle
>
1064 class defusechain_instr_iterator
1065 : public std::iterator
<std::forward_iterator_tag
, MachineInstr
, ptrdiff_t> {
1066 friend class MachineRegisterInfo
;
1068 MachineOperand
*Op
= nullptr;
1070 explicit defusechain_instr_iterator(MachineOperand
*op
) : Op(op
) {
1071 // If the first node isn't one we're interested in, advance to one that
1072 // we are interested in.
1074 if ((!ReturnUses
&& op
->isUse()) ||
1075 (!ReturnDefs
&& op
->isDef()) ||
1076 (SkipDebug
&& op
->isDebug()))
1082 assert(Op
&& "Cannot increment end iterator!");
1083 Op
= getNextOperandForReg(Op
);
1085 // All defs come before the uses, so stop def_iterator early.
1091 assert(!Op
->isDebug() && "Can't have debug defs");
1094 // If this is an operand we don't care about, skip it.
1095 while (Op
&& ((!ReturnDefs
&& Op
->isDef()) ||
1096 (SkipDebug
&& Op
->isDebug())))
1097 Op
= getNextOperandForReg(Op
);
1102 using reference
= std::iterator
<std::forward_iterator_tag
,
1103 MachineInstr
, ptrdiff_t>::reference
;
1104 using pointer
= std::iterator
<std::forward_iterator_tag
,
1105 MachineInstr
, ptrdiff_t>::pointer
;
1107 defusechain_instr_iterator() = default;
1109 bool operator==(const defusechain_instr_iterator
&x
) const {
1112 bool operator!=(const defusechain_instr_iterator
&x
) const {
1113 return !operator==(x
);
1116 /// atEnd - return true if this iterator is equal to reg_end() on the value.
1117 bool atEnd() const { return Op
== nullptr; }
1119 // Iterator traversal: forward iteration only
1120 defusechain_instr_iterator
&operator++() { // Preincrement
1121 assert(Op
&& "Cannot increment end iterator!");
1125 MachineInstr
*P
= Op
->getParent();
1128 } while (Op
&& Op
->getParent() == P
);
1129 } else if (ByBundle
) {
1130 MachineBasicBlock::instr_iterator P
=
1131 getBundleStart(Op
->getParent()->getIterator());
1134 } while (Op
&& getBundleStart(Op
->getParent()->getIterator()) == P
);
1139 defusechain_instr_iterator
operator++(int) { // Postincrement
1140 defusechain_instr_iterator tmp
= *this; ++*this; return tmp
;
1143 // Retrieve a reference to the current operand.
1144 MachineInstr
&operator*() const {
1145 assert(Op
&& "Cannot dereference end iterator!");
1147 return *getBundleStart(Op
->getParent()->getIterator());
1148 return *Op
->getParent();
1151 MachineInstr
*operator->() const { return &operator*(); }
1155 /// Iterate over the pressure sets affected by the given physical or virtual
1156 /// register. If Reg is physical, it must be a register unit (from
1157 /// MCRegUnitIterator).
1158 class PSetIterator
{
1159 const int *PSet
= nullptr;
1160 unsigned Weight
= 0;
1163 PSetIterator() = default;
1165 PSetIterator(unsigned RegUnit
, const MachineRegisterInfo
*MRI
) {
1166 const TargetRegisterInfo
*TRI
= MRI
->getTargetRegisterInfo();
1167 if (TargetRegisterInfo::isVirtualRegister(RegUnit
)) {
1168 const TargetRegisterClass
*RC
= MRI
->getRegClass(RegUnit
);
1169 PSet
= TRI
->getRegClassPressureSets(RC
);
1170 Weight
= TRI
->getRegClassWeight(RC
).RegWeight
;
1173 PSet
= TRI
->getRegUnitPressureSets(RegUnit
);
1174 Weight
= TRI
->getRegUnitWeight(RegUnit
);
1180 bool isValid() const { return PSet
; }
1182 unsigned getWeight() const { return Weight
; }
1184 unsigned operator*() const { return *PSet
; }
1187 assert(isValid() && "Invalid PSetIterator.");
1194 inline PSetIterator
MachineRegisterInfo::
1195 getPressureSets(unsigned RegUnit
) const {
1196 return PSetIterator(RegUnit
, this);
1199 } // end namespace llvm
1201 #endif // LLVM_CODEGEN_MACHINEREGISTERINFO_H