annotate lib/Target/Lanai/LanaiMemAluCombiner.cpp @ 145:9987f868744e

fix CbC_llvm
author mir3636
date Tue, 05 Jun 2018 21:59:34 +0900
parents 3a76565eade5
children c2174574ed3a
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
120
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
1 //===-- LanaiMemAluCombiner.cpp - Pass to combine memory & ALU operations -===//
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
2 //
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
3 // The LLVM Compiler Infrastructure
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
4 //
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
5 // This file is distributed under the University of Illinois Open Source
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
6 // License. See LICENSE.TXT for details.
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
7 //
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
8 //===----------------------------------------------------------------------===//
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
9 // Simple pass to combine memory and ALU operations
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
10 //
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
11 // The Lanai ISA supports instructions where a load/store modifies the base
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
12 // register used in the load/store operation. This pass finds suitable
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
13 // load/store and ALU instructions and combines them into one instruction.
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
14 //
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
15 // For example,
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
16 // ld [ %r6 -- ], %r12
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
17 // is a supported instruction that is not currently generated by the instruction
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
18 // selection pass of this backend. This pass generates these instructions by
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
19 // merging
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
20 // add %r6, -4, %r6
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
21 // followed by
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
22 // ld [ %r6 ], %r12
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
23 // in the same machine basic block into one machine instruction.
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
24 //===----------------------------------------------------------------------===//
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
25
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
26 #include "Lanai.h"
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
27 #include "LanaiTargetMachine.h"
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
28 #include "llvm/ADT/SmallSet.h"
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
29 #include "llvm/ADT/Statistic.h"
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
30 #include "llvm/CodeGen/MachineFunctionPass.h"
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
31 #include "llvm/CodeGen/MachineInstrBuilder.h"
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
32 #include "llvm/CodeGen/RegisterScavenging.h"
134
3a76565eade5 update 5.0.1
mir3636
parents: 120
diff changeset
33 #include "llvm/CodeGen/TargetInstrInfo.h"
120
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
34 #include "llvm/Support/CommandLine.h"
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
35 using namespace llvm;
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
36
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
37 #define GET_INSTRMAP_INFO
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
38 #include "LanaiGenInstrInfo.inc"
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
39
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
40 #define DEBUG_TYPE "lanai-mem-alu-combiner"
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
41
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
42 STATISTIC(NumLdStAluCombined, "Number of memory and ALU instructions combined");
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
43
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
44 static llvm::cl::opt<bool> DisableMemAluCombiner(
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
45 "disable-lanai-mem-alu-combiner", llvm::cl::init(false),
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
46 llvm::cl::desc("Do not combine ALU and memory operators"),
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
47 llvm::cl::Hidden);
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
48
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
49 namespace llvm {
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
50 void initializeLanaiMemAluCombinerPass(PassRegistry &);
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
51 } // namespace llvm
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
52
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
53 namespace {
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
54 typedef MachineBasicBlock::iterator MbbIterator;
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
55 typedef MachineFunction::iterator MfIterator;
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
56
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
57 class LanaiMemAluCombiner : public MachineFunctionPass {
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
58 public:
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
59 static char ID;
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
60 explicit LanaiMemAluCombiner() : MachineFunctionPass(ID) {
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
61 initializeLanaiMemAluCombinerPass(*PassRegistry::getPassRegistry());
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
62 }
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
63
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
64 StringRef getPassName() const override {
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
65 return "Lanai load / store optimization pass";
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
66 }
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
67
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
68 bool runOnMachineFunction(MachineFunction &F) override;
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
69
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
70 MachineFunctionProperties getRequiredProperties() const override {
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
71 return MachineFunctionProperties().set(
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
72 MachineFunctionProperties::Property::NoVRegs);
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
73 }
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
74
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
75 private:
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
76 MbbIterator findClosestSuitableAluInstr(MachineBasicBlock *BB,
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
77 const MbbIterator &MemInstr,
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
78 bool Decrement);
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
79 void insertMergedInstruction(MachineBasicBlock *BB,
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
80 const MbbIterator &MemInstr,
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
81 const MbbIterator &AluInstr, bool Before);
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
82 bool combineMemAluInBasicBlock(MachineBasicBlock *BB);
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
83
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
84 // Target machine description which we query for register names, data
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
85 // layout, etc.
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
86 const TargetInstrInfo *TII;
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
87 };
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
88 } // namespace
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
89
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
90 char LanaiMemAluCombiner::ID = 0;
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
91
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
92 INITIALIZE_PASS(LanaiMemAluCombiner, DEBUG_TYPE,
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
93 "Lanai memory ALU combiner pass", false, false)
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
94
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
95 namespace {
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
96 bool isSpls(uint16_t Opcode) { return Lanai::splsIdempotent(Opcode) == Opcode; }
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
97
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
98 // Determine the opcode for the merged instruction created by considering the
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
99 // old memory operation's opcode and whether the merged opcode will have an
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
100 // immediate offset.
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
101 unsigned mergedOpcode(unsigned OldOpcode, bool ImmediateOffset) {
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
102 switch (OldOpcode) {
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
103 case Lanai::LDW_RI:
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
104 case Lanai::LDW_RR:
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
105 if (ImmediateOffset)
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
106 return Lanai::LDW_RI;
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
107 return Lanai::LDW_RR;
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
108 case Lanai::LDHs_RI:
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
109 case Lanai::LDHs_RR:
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
110 if (ImmediateOffset)
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
111 return Lanai::LDHs_RI;
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
112 return Lanai::LDHs_RR;
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
113 case Lanai::LDHz_RI:
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
114 case Lanai::LDHz_RR:
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
115 if (ImmediateOffset)
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
116 return Lanai::LDHz_RI;
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
117 return Lanai::LDHz_RR;
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
118 case Lanai::LDBs_RI:
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
119 case Lanai::LDBs_RR:
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
120 if (ImmediateOffset)
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
121 return Lanai::LDBs_RI;
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
122 return Lanai::LDBs_RR;
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
123 case Lanai::LDBz_RI:
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
124 case Lanai::LDBz_RR:
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
125 if (ImmediateOffset)
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
126 return Lanai::LDBz_RI;
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
127 return Lanai::LDBz_RR;
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
128 case Lanai::SW_RI:
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
129 case Lanai::SW_RR:
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
130 if (ImmediateOffset)
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
131 return Lanai::SW_RI;
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
132 return Lanai::SW_RR;
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
133 case Lanai::STB_RI:
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
134 case Lanai::STB_RR:
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
135 if (ImmediateOffset)
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
136 return Lanai::STB_RI;
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
137 return Lanai::STB_RR;
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
138 case Lanai::STH_RI:
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
139 case Lanai::STH_RR:
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
140 if (ImmediateOffset)
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
141 return Lanai::STH_RI;
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
142 return Lanai::STH_RR;
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
143 default:
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
144 return 0;
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
145 }
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
146 }
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
147
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
148 // Check if the machine instruction has non-volatile memory operands of the type
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
149 // supported for combining with ALU instructions.
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
150 bool isNonVolatileMemoryOp(const MachineInstr &MI) {
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
151 if (!MI.hasOneMemOperand())
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
152 return false;
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
153
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
154 // Determine if the machine instruction is a supported memory operation by
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
155 // testing if the computed merge opcode is a valid memory operation opcode.
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
156 if (mergedOpcode(MI.getOpcode(), false) == 0)
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
157 return false;
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
158
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
159 const MachineMemOperand *MemOperand = *MI.memoperands_begin();
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
160
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
161 // Don't move volatile memory accesses
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
162 if (MemOperand->isVolatile())
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
163 return false;
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
164
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
165 return true;
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
166 }
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
167
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
168 // Test to see if two machine operands are of the same type. This test is less
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
169 // strict than the MachineOperand::isIdenticalTo function.
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
170 bool isSameOperand(const MachineOperand &Op1, const MachineOperand &Op2) {
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
171 if (Op1.getType() != Op2.getType())
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
172 return false;
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
173
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
174 switch (Op1.getType()) {
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
175 case MachineOperand::MO_Register:
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
176 return Op1.getReg() == Op2.getReg();
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
177 case MachineOperand::MO_Immediate:
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
178 return Op1.getImm() == Op2.getImm();
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
179 default:
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
180 return false;
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
181 }
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
182 }
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
183
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
184 bool isZeroOperand(const MachineOperand &Op) {
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
185 return ((Op.isReg() && Op.getReg() == Lanai::R0) ||
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
186 (Op.isImm() && Op.getImm() == 0));
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
187 }
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
188
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
189 // Determines whether a register is used by an instruction.
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
190 bool InstrUsesReg(const MbbIterator &Instr, const MachineOperand *Reg) {
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
191 for (MachineInstr::const_mop_iterator Mop = Instr->operands_begin();
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
192 Mop != Instr->operands_end(); ++Mop) {
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
193 if (isSameOperand(*Mop, *Reg))
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
194 return true;
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
195 }
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
196 return false;
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
197 }
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
198
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
199 // Converts between machine opcode and AluCode.
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
200 // Flag using/modifying ALU operations should not be considered for merging and
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
201 // are omitted from this list.
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
202 LPAC::AluCode mergedAluCode(unsigned AluOpcode) {
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
203 switch (AluOpcode) {
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
204 case Lanai::ADD_I_LO:
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
205 case Lanai::ADD_R:
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
206 return LPAC::ADD;
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
207 case Lanai::SUB_I_LO:
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
208 case Lanai::SUB_R:
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
209 return LPAC::SUB;
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
210 case Lanai::AND_I_LO:
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
211 case Lanai::AND_R:
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
212 return LPAC::AND;
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
213 case Lanai::OR_I_LO:
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
214 case Lanai::OR_R:
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
215 return LPAC::OR;
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
216 case Lanai::XOR_I_LO:
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
217 case Lanai::XOR_R:
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
218 return LPAC::XOR;
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
219 case Lanai::SHL_R:
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
220 return LPAC::SHL;
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
221 case Lanai::SRL_R:
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
222 return LPAC::SRL;
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
223 case Lanai::SRA_R:
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
224 return LPAC::SRA;
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
225 case Lanai::SA_I:
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
226 case Lanai::SL_I:
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
227 default:
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
228 return LPAC::UNKNOWN;
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
229 }
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
230 }
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
231
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
232 // Insert a new combined memory and ALU operation instruction.
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
233 //
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
234 // This function builds a new machine instruction using the MachineInstrBuilder
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
235 // class and inserts it before the memory instruction.
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
236 void LanaiMemAluCombiner::insertMergedInstruction(MachineBasicBlock *BB,
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
237 const MbbIterator &MemInstr,
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
238 const MbbIterator &AluInstr,
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
239 bool Before) {
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
240 // Insert new combined load/store + alu operation
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
241 MachineOperand Dest = MemInstr->getOperand(0);
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
242 MachineOperand Base = MemInstr->getOperand(1);
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
243 MachineOperand MemOffset = MemInstr->getOperand(2);
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
244 MachineOperand AluOffset = AluInstr->getOperand(2);
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
245
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
246 // Abort if ALU offset is not a register or immediate
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
247 assert((AluOffset.isReg() || AluOffset.isImm()) &&
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
248 "Unsupported operand type in merge");
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
249
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
250 // Determined merged instructions opcode and ALU code
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
251 LPAC::AluCode AluOpcode = mergedAluCode(AluInstr->getOpcode());
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
252 unsigned NewOpc = mergedOpcode(MemInstr->getOpcode(), AluOffset.isImm());
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
253
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
254 assert(AluOpcode != LPAC::UNKNOWN && "Unknown ALU code in merging");
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
255 assert(NewOpc != 0 && "Unknown merged node opcode");
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
256
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
257 // Build and insert new machine instruction
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
258 MachineInstrBuilder InstrBuilder =
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
259 BuildMI(*BB, MemInstr, MemInstr->getDebugLoc(), TII->get(NewOpc));
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
260 InstrBuilder.addReg(Dest.getReg(), getDefRegState(true));
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
261 InstrBuilder.addReg(Base.getReg(), getKillRegState(true));
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
262
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
263 // Add offset to machine instruction
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
264 if (AluOffset.isReg())
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
265 InstrBuilder.addReg(AluOffset.getReg());
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
266 else if (AluOffset.isImm())
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
267 InstrBuilder.addImm(AluOffset.getImm());
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
268 else
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
269 llvm_unreachable("Unsupported ld/st ALU merge.");
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
270
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
271 // Create a pre-op if the ALU operation preceded the memory operation or the
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
272 // MemOffset is non-zero (i.e. the memory value should be adjusted before
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
273 // accessing it), else create a post-op.
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
274 if (Before || !isZeroOperand(MemOffset))
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
275 InstrBuilder.addImm(LPAC::makePreOp(AluOpcode));
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
276 else
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
277 InstrBuilder.addImm(LPAC::makePostOp(AluOpcode));
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
278
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
279 // Transfer memory operands.
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
280 InstrBuilder->setMemRefs(MemInstr->memoperands_begin(),
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
281 MemInstr->memoperands_end());
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
282 }
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
283
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
284 // Function determines if ALU operation (in alu_iter) can be combined with
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
285 // a load/store with base and offset.
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
286 bool isSuitableAluInstr(bool IsSpls, const MbbIterator &AluIter,
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
287 const MachineOperand &Base,
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
288 const MachineOperand &Offset) {
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
289 // ALU operations have 3 operands
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
290 if (AluIter->getNumOperands() != 3)
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
291 return false;
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
292
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
293 MachineOperand &Dest = AluIter->getOperand(0);
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
294 MachineOperand &Op1 = AluIter->getOperand(1);
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
295 MachineOperand &Op2 = AluIter->getOperand(2);
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
296
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
297 // Only match instructions using the base register as destination and with the
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
298 // base and first operand equal
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
299 if (!isSameOperand(Dest, Base) || !isSameOperand(Dest, Op1))
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
300 return false;
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
301
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
302 if (Op2.isImm()) {
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
303 // It is not a match if the 2nd operand in the ALU operation is an
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
304 // immediate but the ALU operation is not an addition.
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
305 if (AluIter->getOpcode() != Lanai::ADD_I_LO)
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
306 return false;
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
307
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
308 if (Offset.isReg() && Offset.getReg() == Lanai::R0)
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
309 return true;
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
310
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
311 if (Offset.isImm() &&
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
312 ((Offset.getImm() == 0 &&
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
313 // Check that the Op2 would fit in the immediate field of the
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
314 // memory operation.
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
315 ((IsSpls && isInt<10>(Op2.getImm())) ||
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
316 (!IsSpls && isInt<16>(Op2.getImm())))) ||
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
317 Offset.getImm() == Op2.getImm()))
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
318 return true;
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
319 } else if (Op2.isReg()) {
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
320 // The Offset and 2nd operand are both registers and equal
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
321 if (Offset.isReg() && Op2.getReg() == Offset.getReg())
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
322 return true;
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
323 } else
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
324 // Only consider operations with register or immediate values
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
325 return false;
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
326
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
327 return false;
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
328 }
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
329
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
330 MbbIterator LanaiMemAluCombiner::findClosestSuitableAluInstr(
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
331 MachineBasicBlock *BB, const MbbIterator &MemInstr, const bool Decrement) {
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
332 MachineOperand *Base = &MemInstr->getOperand(1);
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
333 MachineOperand *Offset = &MemInstr->getOperand(2);
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
334 bool IsSpls = isSpls(MemInstr->getOpcode());
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
335
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
336 MbbIterator First = MemInstr;
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
337 MbbIterator Last = Decrement ? BB->begin() : BB->end();
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
338
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
339 while (First != Last) {
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
340 Decrement ? --First : ++First;
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
341
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
342 if (First == Last)
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
343 break;
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
344
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
345 // Skip over debug instructions
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
346 if (First->isDebugValue())
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
347 continue;
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
348
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
349 if (isSuitableAluInstr(IsSpls, First, *Base, *Offset)) {
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
350 return First;
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
351 }
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
352
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
353 // Usage of the base or offset register is not a form suitable for merging.
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
354 if (First != Last) {
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
355 if (InstrUsesReg(First, Base))
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
356 break;
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
357 if (Offset->isReg() && InstrUsesReg(First, Offset))
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
358 break;
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
359 }
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
360 }
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
361
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
362 return MemInstr;
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
363 }
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
364
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
365 bool LanaiMemAluCombiner::combineMemAluInBasicBlock(MachineBasicBlock *BB) {
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
366 bool Modified = false;
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
367
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
368 MbbIterator MBBIter = BB->begin(), End = BB->end();
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
369 while (MBBIter != End) {
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
370 bool IsMemOp = isNonVolatileMemoryOp(*MBBIter);
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
371
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
372 if (IsMemOp) {
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
373 MachineOperand AluOperand = MBBIter->getOperand(3);
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
374 unsigned int DestReg = MBBIter->getOperand(0).getReg(),
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
375 BaseReg = MBBIter->getOperand(1).getReg();
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
376 assert(AluOperand.isImm() && "Unexpected memory operator type");
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
377 LPAC::AluCode AluOpcode = static_cast<LPAC::AluCode>(AluOperand.getImm());
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
378
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
379 // Skip memory operations that already modify the base register or if
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
380 // the destination and base register are the same
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
381 if (!LPAC::modifiesOp(AluOpcode) && DestReg != BaseReg) {
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
382 for (int Inc = 0; Inc <= 1; ++Inc) {
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
383 MbbIterator AluIter =
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
384 findClosestSuitableAluInstr(BB, MBBIter, Inc == 0);
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
385 if (AluIter != MBBIter) {
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
386 insertMergedInstruction(BB, MBBIter, AluIter, Inc == 0);
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
387
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
388 ++NumLdStAluCombined;
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
389 Modified = true;
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
390
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
391 // Erase the matching ALU instruction
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
392 BB->erase(AluIter);
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
393 // Erase old load/store instruction
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
394 BB->erase(MBBIter++);
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
395 break;
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
396 }
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
397 }
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
398 }
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
399 }
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
400 if (MBBIter == End)
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
401 break;
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
402 ++MBBIter;
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
403 }
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
404
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
405 return Modified;
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
406 }
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
407
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
408 // Driver function that iterates over the machine basic building blocks of a
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
409 // machine function
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
410 bool LanaiMemAluCombiner::runOnMachineFunction(MachineFunction &MF) {
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
411 if (DisableMemAluCombiner)
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
412 return false;
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
413
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
414 TII = MF.getSubtarget<LanaiSubtarget>().getInstrInfo();
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
415 bool Modified = false;
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
416 for (MfIterator MFI = MF.begin(); MFI != MF.end(); ++MFI) {
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
417 Modified |= combineMemAluInBasicBlock(&*MFI);
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
418 }
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
419 return Modified;
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
420 }
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
421 } // namespace
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
422
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
423 FunctionPass *llvm::createLanaiMemAluCombinerPass() {
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
424 return new LanaiMemAluCombiner();
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
425 }