blob: 6862bb2c3f44f65b66804f5d6f85be1681ec220b [file] [log] [blame]
Andrew Scull5e1ddfa2018-08-14 10:06:54 +01001//===- llvm/CodeGen/TailDuplicator.h ----------------------------*- C++ -*-===//
2//
Andrew Walbran16937d02019-10-22 13:54:20 +01003// 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
Andrew Scull5e1ddfa2018-08-14 10:06:54 +01006//
7//===----------------------------------------------------------------------===//
8//
9// This file defines the TailDuplicator class. Used by the
10// TailDuplication pass, and MachineBlockPlacement.
11//
12//===----------------------------------------------------------------------===//
13
14#ifndef LLVM_CODEGEN_TAILDUPLICATOR_H
15#define LLVM_CODEGEN_TAILDUPLICATOR_H
16
17#include "llvm/ADT/DenseMap.h"
18#include "llvm/ADT/DenseSet.h"
19#include "llvm/ADT/SetVector.h"
20#include "llvm/ADT/SmallVector.h"
Olivier Deprezf4ef2d02021-04-20 13:36:24 +020021#include "llvm/CodeGen/MBFIWrapper.h"
Andrew Scull5e1ddfa2018-08-14 10:06:54 +010022#include "llvm/CodeGen/TargetInstrInfo.h"
23#include <utility>
24#include <vector>
25
26namespace llvm {
27
28class MachineBasicBlock;
Olivier Deprezf4ef2d02021-04-20 13:36:24 +020029class MachineBlockFrequencyInfo;
Andrew Scull5e1ddfa2018-08-14 10:06:54 +010030class MachineBranchProbabilityInfo;
31class MachineFunction;
32class MachineInstr;
33class MachineModuleInfo;
34class MachineRegisterInfo;
Olivier Deprezf4ef2d02021-04-20 13:36:24 +020035class ProfileSummaryInfo;
Andrew Scull5e1ddfa2018-08-14 10:06:54 +010036class TargetRegisterInfo;
37
38/// Utility class to perform tail duplication.
39class TailDuplicator {
40 const TargetInstrInfo *TII;
41 const TargetRegisterInfo *TRI;
42 const MachineBranchProbabilityInfo *MBPI;
43 const MachineModuleInfo *MMI;
44 MachineRegisterInfo *MRI;
45 MachineFunction *MF;
Olivier Deprezf4ef2d02021-04-20 13:36:24 +020046 MBFIWrapper *MBFI;
47 ProfileSummaryInfo *PSI;
Andrew Scull5e1ddfa2018-08-14 10:06:54 +010048 bool PreRegAlloc;
49 bool LayoutMode;
50 unsigned TailDupSize;
51
52 // A list of virtual registers for which to update SSA form.
Olivier Deprezf4ef2d02021-04-20 13:36:24 +020053 SmallVector<Register, 16> SSAUpdateVRs;
Andrew Scull5e1ddfa2018-08-14 10:06:54 +010054
55 // For each virtual register in SSAUpdateVals keep a list of source virtual
56 // registers.
Olivier Deprezf4ef2d02021-04-20 13:36:24 +020057 using AvailableValsTy = std::vector<std::pair<MachineBasicBlock *, Register>>;
Andrew Scull5e1ddfa2018-08-14 10:06:54 +010058
Olivier Deprezf4ef2d02021-04-20 13:36:24 +020059 DenseMap<Register, AvailableValsTy> SSAUpdateVals;
Andrew Scull5e1ddfa2018-08-14 10:06:54 +010060
61public:
62 /// Prepare to run on a specific machine function.
63 /// @param MF - Function that will be processed
64 /// @param PreRegAlloc - true if used before register allocation
65 /// @param MBPI - Branch Probability Info. Used to propagate correct
66 /// probabilities when modifying the CFG.
67 /// @param LayoutMode - When true, don't use the existing layout to make
68 /// decisions.
69 /// @param TailDupSize - Maxmimum size of blocks to tail-duplicate. Zero
70 /// default implies using the command line value TailDupSize.
71 void initMF(MachineFunction &MF, bool PreRegAlloc,
72 const MachineBranchProbabilityInfo *MBPI,
Olivier Deprezf4ef2d02021-04-20 13:36:24 +020073 MBFIWrapper *MBFI,
74 ProfileSummaryInfo *PSI,
Andrew Scull5e1ddfa2018-08-14 10:06:54 +010075 bool LayoutMode, unsigned TailDupSize = 0);
76
77 bool tailDuplicateBlocks();
78 static bool isSimpleBB(MachineBasicBlock *TailBB);
79 bool shouldTailDuplicate(bool IsSimple, MachineBasicBlock &TailBB);
80
81 /// Returns true if TailBB can successfully be duplicated into PredBB
82 bool canTailDuplicate(MachineBasicBlock *TailBB, MachineBasicBlock *PredBB);
83
84 /// Tail duplicate a single basic block into its predecessors, and then clean
85 /// up.
86 /// If \p DuplicatePreds is not null, it will be updated to contain the list
87 /// of predecessors that received a copy of \p MBB.
88 /// If \p RemovalCallback is non-null. It will be called before MBB is
89 /// deleted.
Olivier Deprezf4ef2d02021-04-20 13:36:24 +020090 /// If \p CandidatePtr is not null, duplicate into these blocks only.
Andrew Scull5e1ddfa2018-08-14 10:06:54 +010091 bool tailDuplicateAndUpdate(
92 bool IsSimple, MachineBasicBlock *MBB,
93 MachineBasicBlock *ForcedLayoutPred,
94 SmallVectorImpl<MachineBasicBlock*> *DuplicatedPreds = nullptr,
Olivier Deprezf4ef2d02021-04-20 13:36:24 +020095 function_ref<void(MachineBasicBlock *)> *RemovalCallback = nullptr,
96 SmallVectorImpl<MachineBasicBlock *> *CandidatePtr = nullptr);
Andrew Scull5e1ddfa2018-08-14 10:06:54 +010097
98private:
99 using RegSubRegPair = TargetInstrInfo::RegSubRegPair;
100
Olivier Deprezf4ef2d02021-04-20 13:36:24 +0200101 void addSSAUpdateEntry(Register OrigReg, Register NewReg,
Andrew Scull5e1ddfa2018-08-14 10:06:54 +0100102 MachineBasicBlock *BB);
103 void processPHI(MachineInstr *MI, MachineBasicBlock *TailBB,
104 MachineBasicBlock *PredBB,
Olivier Deprezf4ef2d02021-04-20 13:36:24 +0200105 DenseMap<Register, RegSubRegPair> &LocalVRMap,
106 SmallVectorImpl<std::pair<Register, RegSubRegPair>> &Copies,
107 const DenseSet<Register> &UsedByPhi, bool Remove);
Andrew Scull5e1ddfa2018-08-14 10:06:54 +0100108 void duplicateInstruction(MachineInstr *MI, MachineBasicBlock *TailBB,
109 MachineBasicBlock *PredBB,
Olivier Deprezf4ef2d02021-04-20 13:36:24 +0200110 DenseMap<Register, RegSubRegPair> &LocalVRMap,
111 const DenseSet<Register> &UsedByPhi);
Andrew Scull5e1ddfa2018-08-14 10:06:54 +0100112 void updateSuccessorsPHIs(MachineBasicBlock *FromBB, bool isDead,
113 SmallVectorImpl<MachineBasicBlock *> &TDBBs,
114 SmallSetVector<MachineBasicBlock *, 8> &Succs);
115 bool canCompletelyDuplicateBB(MachineBasicBlock &BB);
116 bool duplicateSimpleBB(MachineBasicBlock *TailBB,
117 SmallVectorImpl<MachineBasicBlock *> &TDBBs,
Olivier Deprezf4ef2d02021-04-20 13:36:24 +0200118 const DenseSet<Register> &RegsUsedByPhi,
Andrew Scull5e1ddfa2018-08-14 10:06:54 +0100119 SmallVectorImpl<MachineInstr *> &Copies);
120 bool tailDuplicate(bool IsSimple,
121 MachineBasicBlock *TailBB,
122 MachineBasicBlock *ForcedLayoutPred,
123 SmallVectorImpl<MachineBasicBlock *> &TDBBs,
Olivier Deprezf4ef2d02021-04-20 13:36:24 +0200124 SmallVectorImpl<MachineInstr *> &Copies,
125 SmallVectorImpl<MachineBasicBlock *> *CandidatePtr);
Andrew Scull5e1ddfa2018-08-14 10:06:54 +0100126 void appendCopies(MachineBasicBlock *MBB,
Olivier Deprezf4ef2d02021-04-20 13:36:24 +0200127 SmallVectorImpl<std::pair<Register, RegSubRegPair>> &CopyInfos,
Andrew Scull5e1ddfa2018-08-14 10:06:54 +0100128 SmallVectorImpl<MachineInstr *> &Copies);
129
130 void removeDeadBlock(
131 MachineBasicBlock *MBB,
132 function_ref<void(MachineBasicBlock *)> *RemovalCallback = nullptr);
133};
134
135} // end namespace llvm
136
137#endif // LLVM_CODEGEN_TAILDUPLICATOR_H