blob: b4d23a136410d10d7ca076741a0b74fd71bbc6b0 [file] [log] [blame]
Sebastian Pop082cea82012-05-07 16:20:07 +00001//===------ IslCodeGeneration.cpp - Code generate the Scops using ISL. ----===//
2//
3// The LLVM Compiler Infrastructure
4//
5// This file is distributed under the University of Illinois Open Source
6// License. See LICENSE.TXT for details.
7//
8//===----------------------------------------------------------------------===//
9//
10// The IslCodeGeneration pass takes a Scop created by ScopInfo and translates it
11// back to LLVM-IR using the ISL code generator.
12//
13// The Scop describes the high level memory behaviour of a control flow region.
14// Transformation passes can update the schedule (execution order) of statements
15// in the Scop. ISL is used to generate an abstract syntax tree that reflects
16// the updated execution order. This clast is used to create new LLVM-IR that is
17// computationally equivalent to the original control flow region, but executes
18// its code in the new execution order defined by the changed scattering.
19//
20//===----------------------------------------------------------------------===//
Tobias Grosser8a5bc6e2012-10-02 19:50:43 +000021#include "polly/Config/config.h"
Johannes Doerferta63b2572014-08-03 01:51:59 +000022#include "polly/CodeGen/IslExprBuilder.h"
Tobias Grosser83628182013-05-07 08:11:54 +000023#include "polly/CodeGen/BlockGenerators.h"
24#include "polly/CodeGen/CodeGeneration.h"
25#include "polly/CodeGen/IslAst.h"
26#include "polly/CodeGen/LoopGenerators.h"
27#include "polly/CodeGen/Utils.h"
Tobias Grosser8a5bc6e2012-10-02 19:50:43 +000028#include "polly/Dependences.h"
29#include "polly/LinkAllPasses.h"
30#include "polly/ScopInfo.h"
Tobias Grosser8a5bc6e2012-10-02 19:50:43 +000031#include "polly/Support/GICHelper.h"
Tobias Grosser0ee50f62013-04-10 06:55:31 +000032#include "polly/Support/ScopHelper.h"
Tobias Grossere3c05582014-11-15 21:32:53 +000033#include "polly/Support/SCEVValidator.h"
Tobias Grosser83628182013-05-07 08:11:54 +000034#include "polly/TempScopInfo.h"
Tobias Grossere3c05582014-11-15 21:32:53 +000035
36#include "llvm/ADT/PostOrderIterator.h"
37#include "llvm/ADT/SmallPtrSet.h"
Tobias Grosser8a5bc6e2012-10-02 19:50:43 +000038#include "llvm/Analysis/LoopInfo.h"
Matt Arsenault8ca36812014-07-19 18:40:17 +000039#include "llvm/Analysis/PostDominators.h"
Tobias Grosser8a5bc6e2012-10-02 19:50:43 +000040#include "llvm/Analysis/ScalarEvolutionExpander.h"
Tobias Grosser83628182013-05-07 08:11:54 +000041#include "llvm/IR/Module.h"
Tobias Grosser8a5bc6e2012-10-02 19:50:43 +000042#include "llvm/Support/CommandLine.h"
43#include "llvm/Support/Debug.h"
Johannes Doerfert0b169c02015-02-27 17:37:05 +000044#include "llvm/IR/Verifier.h"
Chandler Carruth535d52c2013-01-02 11:47:44 +000045#include "llvm/IR/DataLayout.h"
Tobias Grosser8a5bc6e2012-10-02 19:50:43 +000046#include "llvm/Transforms/Utils/BasicBlockUtils.h"
47
48#include "isl/union_map.h"
49#include "isl/list.h"
50#include "isl/ast.h"
51#include "isl/ast_build.h"
52#include "isl/set.h"
53#include "isl/map.h"
54#include "isl/aff.h"
55
Tobias Grosser8a5bc6e2012-10-02 19:50:43 +000056using namespace polly;
57using namespace llvm;
58
Chandler Carruth95fef942014-04-22 03:30:19 +000059#define DEBUG_TYPE "polly-codegen-isl"
60
Tobias Grosser8a5bc6e2012-10-02 19:50:43 +000061class IslNodeBuilder {
62public:
Johannes Doerfert51d1c742014-10-02 15:32:17 +000063 IslNodeBuilder(PollyIRBuilder &Builder, ScopAnnotator &Annotator, Pass *P,
Tobias Grossere3c05582014-11-15 21:32:53 +000064 const DataLayout &DL, LoopInfo &LI, ScalarEvolution &SE,
65 DominatorTree &DT, Scop &S)
66 : S(S), Builder(Builder), Annotator(Annotator),
Johannes Doerfert2ef33e92014-10-05 11:33:59 +000067 Rewriter(new SCEVExpander(SE, "polly")),
Johannes Doerfertbe9c9112015-02-06 21:39:31 +000068 ExprBuilder(Builder, IDToValue, *Rewriter),
Johannes Doerfert275a1752015-02-24 16:16:32 +000069 BlockGen(Builder, LI, SE, DT, &ExprBuilder), RegionGen(BlockGen), P(P),
70 DL(DL), LI(LI), SE(SE), DT(DT) {}
Johannes Doerfert2ef33e92014-10-05 11:33:59 +000071
72 ~IslNodeBuilder() { delete Rewriter; }
Tobias Grosser8a5bc6e2012-10-02 19:50:43 +000073
74 void addParameters(__isl_take isl_set *Context);
75 void create(__isl_take isl_ast_node *Node);
Tobias Grosser54ee0ba2013-11-17 03:18:25 +000076 IslExprBuilder &getExprBuilder() { return ExprBuilder; }
Tobias Grosser8a5bc6e2012-10-02 19:50:43 +000077
78private:
Tobias Grossere3c05582014-11-15 21:32:53 +000079 Scop &S;
Tobias Grosser5103ba72014-03-04 14:58:49 +000080 PollyIRBuilder &Builder;
Johannes Doerfert51d1c742014-10-02 15:32:17 +000081 ScopAnnotator &Annotator;
Johannes Doerfert2ef33e92014-10-05 11:33:59 +000082
83 /// @brief A SCEVExpander to create llvm values from SCEVs.
84 SCEVExpander *Rewriter;
85
Tobias Grosser8a5bc6e2012-10-02 19:50:43 +000086 IslExprBuilder ExprBuilder;
Johannes Doerfertbe9c9112015-02-06 21:39:31 +000087 BlockGenerator BlockGen;
Johannes Doerfert275a1752015-02-24 16:16:32 +000088
89 /// @brief Generator for region statements.
90 RegionGenerator RegionGen;
91
Tobias Grosser8a5bc6e2012-10-02 19:50:43 +000092 Pass *P;
Tobias Grossere3c05582014-11-15 21:32:53 +000093 const DataLayout &DL;
Johannes Doerfert2ef3f4f2014-08-07 17:14:54 +000094 LoopInfo &LI;
95 ScalarEvolution &SE;
96 DominatorTree &DT;
Tobias Grosser8a5bc6e2012-10-02 19:50:43 +000097
Tobias Grossere3c05582014-11-15 21:32:53 +000098 /// @brief The current iteration of out-of-scop loops
99 ///
100 /// This map provides for a given loop a llvm::Value that contains the current
101 /// loop iteration.
102 LoopToScevMapT OutsideLoopIterations;
103
Tobias Grosser8a5bc6e2012-10-02 19:50:43 +0000104 // This maps an isl_id* to the Value* it has in the generated program. For now
105 // on, the only isl_ids that are stored here are the newly calculated loop
106 // ivs.
Tobias Grosser566ad582014-08-31 16:21:12 +0000107 IslExprBuilder::IDToValueTy IDToValue;
Tobias Grosser8a5bc6e2012-10-02 19:50:43 +0000108
Tobias Grosserec7d67e2014-11-06 00:27:01 +0000109 /// Generate code for a given SCEV*
110 ///
111 /// This function generates code for a given SCEV expression. It generated
112 /// code is emmitted at the end of the basic block our Builder currently
113 /// points to and the resulting value is returned.
114 ///
115 /// @param Expr The expression to code generate.
116 Value *generateSCEV(const SCEV *Expr);
117
Tobias Grossere3c05582014-11-15 21:32:53 +0000118 /// A set of Value -> Value remappings to apply when generating new code.
119 ///
120 /// When generating new code for a ScopStmt this map is used to map certain
121 /// llvm::Values to new llvm::Values.
122 ValueMapT ValueMap;
123
Tobias Grosser8a5bc6e2012-10-02 19:50:43 +0000124 // Extract the upper bound of this loop
125 //
126 // The isl code generation can generate arbitrary expressions to check if the
127 // upper bound of a loop is reached, but it provides an option to enforce
128 // 'atomic' upper bounds. An 'atomic upper bound is always of the form
129 // iv <= expr, where expr is an (arbitrary) expression not containing iv.
130 //
131 // This function extracts 'atomic' upper bounds. Polly, in general, requires
132 // atomic upper bounds for the following reasons:
133 //
134 // 1. An atomic upper bound is loop invariant
135 //
136 // It must not be calculated at each loop iteration and can often even be
137 // hoisted out further by the loop invariant code motion.
138 //
139 // 2. OpenMP needs a loop invarient upper bound to calculate the number
140 // of loop iterations.
141 //
142 // 3. With the existing code, upper bounds have been easier to implement.
Tobias Grossere602a072013-05-07 07:30:56 +0000143 __isl_give isl_ast_expr *getUpperBound(__isl_keep isl_ast_node *For,
144 CmpInst::Predicate &Predicate);
Tobias Grosser8a5bc6e2012-10-02 19:50:43 +0000145
Sebastian Pop04c4ce32012-12-18 07:46:13 +0000146 unsigned getNumberOfIterations(__isl_keep isl_ast_node *For);
147
Tobias Grossere3c05582014-11-15 21:32:53 +0000148 /// Compute the values and loops referenced in this subtree.
149 ///
150 /// This function looks at all ScopStmts scheduled below the provided For node
151 /// and finds the llvm::Value[s] and llvm::Loops[s] which are referenced but
152 /// not locally defined.
153 ///
154 /// Values that can be synthesized or that are available as globals are
155 /// considered locally defined.
156 ///
157 /// Loops that contain the scop or that are part of the scop are considered
158 /// locally defined. Loops that are before the scop, but do not contain the
159 /// scop itself are considered not locally defined.
160 ///
161 /// @param For The node defining the subtree.
162 /// @param Values A vector that will be filled with the Values referenced in
163 /// this subtree.
164 /// @param Loops A vector that will be filled with the Loops referenced in
165 /// this subtree.
166 void getReferencesInSubtree(__isl_keep isl_ast_node *For,
167 SetVector<Value *> &Values,
168 SetVector<const Loop *> &Loops);
169
170 /// Change the llvm::Value(s) used for code generation.
171 ///
172 /// When generating code certain values (e.g., references to induction
173 /// variables or array base pointers) in the original code may be replaced by
174 /// new values. This function allows to (partially) update the set of values
175 /// used. A typical use case for this function is the case when we continue
176 /// code generation in a subfunction/kernel function and need to explicitly
177 /// pass down certain values.
178 ///
179 /// @param NewValues A map that maps certain llvm::Values to new llvm::Values.
180 void updateValues(ParallelLoopGenerator::ValueToValueMapTy &NewValues);
181
Tobias Grosser8a5bc6e2012-10-02 19:50:43 +0000182 void createFor(__isl_take isl_ast_node *For);
Sebastian Pop04c4ce32012-12-18 07:46:13 +0000183 void createForVector(__isl_take isl_ast_node *For, int VectorWidth);
184 void createForSequential(__isl_take isl_ast_node *For);
Tobias Grosserce67a042014-07-02 16:26:47 +0000185
Tobias Grossere3c05582014-11-15 21:32:53 +0000186 /// Create LLVM-IR that executes a for node thread parallel.
187 ///
188 /// @param For The FOR isl_ast_node for which code is generated.
189 void createForParallel(__isl_take isl_ast_node *For);
190
Tobias Grosserce67a042014-07-02 16:26:47 +0000191 /// Generate LLVM-IR that computes the values of the original induction
192 /// variables in function of the newly generated loop induction variables.
193 ///
194 /// Example:
195 ///
196 /// // Original
197 /// for i
198 /// for j
199 /// S(i)
200 ///
201 /// Schedule: [i,j] -> [i+j, j]
202 ///
203 /// // New
204 /// for c0
205 /// for c1
206 /// S(c0 - c1, c1)
207 ///
208 /// Assuming the original code consists of two loops which are
209 /// transformed according to a schedule [i,j] -> [c0=i+j,c1=j]. The resulting
210 /// ast models the original statement as a call expression where each argument
211 /// is an expression that computes the old induction variables from the new
212 /// ones, ordered such that the first argument computes the value of induction
213 /// variable that was outermost in the original code.
214 ///
215 /// @param Expr The call expression that represents the statement.
216 /// @param Stmt The statement that is called.
217 /// @param VMap The value map into which the mapping from the old induction
218 /// variable to the new one is inserted. This mapping is used
219 /// for the classical code generation (not scev-based) and
220 /// gives an explicit mapping from an original, materialized
221 /// induction variable. It consequently can only be expressed
222 /// if there was an explicit induction variable.
223 /// @param LTS The loop to SCEV map in which the mapping from the original
224 /// loop to a SCEV representing the new loop iv is added. This
225 /// mapping does not require an explicit induction variable.
226 /// Instead, we think in terms of an implicit induction variable
227 /// that counts the number of times a loop is executed. For each
228 /// original loop this count, expressed in function of the new
229 /// induction variables, is added to the LTS map.
230 void createSubstitutions(__isl_take isl_ast_expr *Expr, ScopStmt *Stmt,
Sebastian Pop9d10fff2013-02-15 20:55:59 +0000231 ValueMapT &VMap, LoopToScevMapT &LTS);
Tobias Grosserce67a042014-07-02 16:26:47 +0000232 void createSubstitutionsVector(__isl_take isl_ast_expr *Expr, ScopStmt *Stmt,
233 VectorValueMapT &VMap,
Tobias Grossere602a072013-05-07 07:30:56 +0000234 std::vector<LoopToScevMapT> &VLTS,
235 std::vector<Value *> &IVS,
236 __isl_take isl_id *IteratorID);
Tobias Grosser8a5bc6e2012-10-02 19:50:43 +0000237 void createIf(__isl_take isl_ast_node *If);
Tobias Grossere602a072013-05-07 07:30:56 +0000238 void createUserVector(__isl_take isl_ast_node *User,
239 std::vector<Value *> &IVS,
240 __isl_take isl_id *IteratorID,
241 __isl_take isl_union_map *Schedule);
Tobias Grosser8a5bc6e2012-10-02 19:50:43 +0000242 void createUser(__isl_take isl_ast_node *User);
243 void createBlock(__isl_take isl_ast_node *Block);
244};
245
Tobias Grossere602a072013-05-07 07:30:56 +0000246__isl_give isl_ast_expr *
247IslNodeBuilder::getUpperBound(__isl_keep isl_ast_node *For,
248 ICmpInst::Predicate &Predicate) {
Tobias Grosser8a5bc6e2012-10-02 19:50:43 +0000249 isl_id *UBID, *IteratorID;
250 isl_ast_expr *Cond, *Iterator, *UB, *Arg0;
Tobias Grosserc967d8e2012-10-16 07:29:13 +0000251 isl_ast_op_type Type;
Tobias Grosser8a5bc6e2012-10-02 19:50:43 +0000252
253 Cond = isl_ast_node_for_get_cond(For);
254 Iterator = isl_ast_node_for_get_iterator(For);
Tobias Grosser2784b082015-01-10 07:40:39 +0000255 isl_ast_expr_get_type(Cond);
Tobias Grosserae2d83e2012-12-29 23:57:18 +0000256 assert(isl_ast_expr_get_type(Cond) == isl_ast_expr_op &&
257 "conditional expression is not an atomic upper bound");
Tobias Grosser8a5bc6e2012-10-02 19:50:43 +0000258
Tobias Grosser2784b082015-01-10 07:40:39 +0000259 Type = isl_ast_expr_get_op_type(Cond);
260
Tobias Grosserc967d8e2012-10-16 07:29:13 +0000261 switch (Type) {
Tobias Grosserc14582f2013-02-05 18:01:29 +0000262 case isl_ast_op_le:
263 Predicate = ICmpInst::ICMP_SLE;
264 break;
265 case isl_ast_op_lt:
266 Predicate = ICmpInst::ICMP_SLT;
267 break;
268 default:
269 llvm_unreachable("Unexpected comparision type in loop conditon");
Tobias Grosserc967d8e2012-10-16 07:29:13 +0000270 }
Tobias Grosser8a5bc6e2012-10-02 19:50:43 +0000271
272 Arg0 = isl_ast_expr_get_op_arg(Cond, 0);
273
Tobias Grosserae2d83e2012-12-29 23:57:18 +0000274 assert(isl_ast_expr_get_type(Arg0) == isl_ast_expr_id &&
275 "conditional expression is not an atomic upper bound");
Tobias Grosser8a5bc6e2012-10-02 19:50:43 +0000276
277 UBID = isl_ast_expr_get_id(Arg0);
278
Tobias Grosserae2d83e2012-12-29 23:57:18 +0000279 assert(isl_ast_expr_get_type(Iterator) == isl_ast_expr_id &&
280 "Could not get the iterator");
Tobias Grosser8a5bc6e2012-10-02 19:50:43 +0000281
282 IteratorID = isl_ast_expr_get_id(Iterator);
283
Tobias Grosserae2d83e2012-12-29 23:57:18 +0000284 assert(UBID == IteratorID &&
285 "conditional expression is not an atomic upper bound");
Tobias Grosser8a5bc6e2012-10-02 19:50:43 +0000286
287 UB = isl_ast_expr_get_op_arg(Cond, 1);
288
289 isl_ast_expr_free(Cond);
290 isl_ast_expr_free(Iterator);
291 isl_ast_expr_free(Arg0);
292 isl_id_free(IteratorID);
293 isl_id_free(UBID);
294
295 return UB;
296}
297
Sebastian Pop04c4ce32012-12-18 07:46:13 +0000298unsigned IslNodeBuilder::getNumberOfIterations(__isl_keep isl_ast_node *For) {
Johannes Doerfert94d90822014-07-23 20:26:25 +0000299 isl_union_map *Schedule = IslAstInfo::getSchedule(For);
Sebastian Pop04c4ce32012-12-18 07:46:13 +0000300 isl_set *LoopDomain = isl_set_from_union_set(isl_union_map_range(Schedule));
Sebastian Pop2aa5c242012-12-18 08:56:51 +0000301 int NumberOfIterations = polly::getNumberOfIterations(LoopDomain);
302 if (NumberOfIterations == -1)
303 return -1;
304 return NumberOfIterations + 1;
Sebastian Pop04c4ce32012-12-18 07:46:13 +0000305}
306
Tobias Grossere3c05582014-11-15 21:32:53 +0000307struct FindValuesUser {
308 LoopInfo &LI;
309 ScalarEvolution &SE;
310 Region &R;
311 SetVector<Value *> &Values;
312 SetVector<const SCEV *> &SCEVs;
313};
314
Johannes Doerfertbbf30842015-03-02 13:41:53 +0000315/// @brief Extract the values and SCEVs needed to generate code for a block.
316static int findValuesInBlock(struct FindValuesUser &User, const ScopStmt *Stmt,
317 const BasicBlock *BB) {
Tobias Grossere3c05582014-11-15 21:32:53 +0000318 // Check all the operands of instructions in the basic block.
319 for (const Instruction &Inst : *BB) {
320 for (Value *SrcVal : Inst.operands()) {
321 if (Instruction *OpInst = dyn_cast<Instruction>(SrcVal))
322 if (canSynthesize(OpInst, &User.LI, &User.SE, &User.R)) {
323 User.SCEVs.insert(
324 User.SE.getSCEVAtScope(OpInst, User.LI.getLoopFor(BB)));
325 continue;
326 }
327 if (Instruction *OpInst = dyn_cast<Instruction>(SrcVal))
328 if (Stmt->getParent()->getRegion().contains(OpInst))
329 continue;
330
331 if (isa<Instruction>(SrcVal) || isa<Argument>(SrcVal))
332 User.Values.insert(SrcVal);
333 }
334 }
Johannes Doerfertbbf30842015-03-02 13:41:53 +0000335 return 0;
336}
337
338/// Extract the values and SCEVs needed to generate code for a ScopStmt.
339///
340/// This function extracts a ScopStmt from a given isl_set and computes the
341/// Values this statement depends on as well as a set of SCEV expressions that
342/// need to be synthesized when generating code for this statment.
343static int findValuesInStmt(isl_set *Set, void *UserPtr) {
344 isl_id *Id = isl_set_get_tuple_id(Set);
345 struct FindValuesUser &User = *static_cast<struct FindValuesUser *>(UserPtr);
346 const ScopStmt *Stmt = static_cast<const ScopStmt *>(isl_id_get_user(Id));
347
348 if (Stmt->isBlockStmt())
349 findValuesInBlock(User, Stmt, Stmt->getBasicBlock());
350 else {
351 assert(Stmt->isRegionStmt() &&
352 "Stmt was neither block nor region statement");
353 for (const BasicBlock *BB : Stmt->getRegion()->blocks())
354 findValuesInBlock(User, Stmt, BB);
355 }
356
Tobias Grossere3c05582014-11-15 21:32:53 +0000357 isl_id_free(Id);
358 isl_set_free(Set);
359 return 0;
360}
361
362void IslNodeBuilder::getReferencesInSubtree(__isl_keep isl_ast_node *For,
363 SetVector<Value *> &Values,
364 SetVector<const Loop *> &Loops) {
365
366 SetVector<const SCEV *> SCEVs;
367 struct FindValuesUser FindValues = {LI, SE, S.getRegion(), Values, SCEVs};
368
369 for (const auto &I : IDToValue)
370 Values.insert(I.second);
371
372 for (const auto &I : OutsideLoopIterations)
373 Values.insert(cast<SCEVUnknown>(I.second)->getValue());
374
375 isl_union_set *Schedule = isl_union_map_domain(IslAstInfo::getSchedule(For));
376
377 isl_union_set_foreach_set(Schedule, findValuesInStmt, &FindValues);
378 isl_union_set_free(Schedule);
379
380 for (const SCEV *Expr : SCEVs) {
381 findValues(Expr, Values);
382 findLoops(Expr, Loops);
383 }
384
385 Values.remove_if([](const Value *V) { return isa<GlobalValue>(V); });
386
387 /// Remove loops that contain the scop or that are part of the scop, as they
388 /// are considered local. This leaves only loops that are before the scop, but
389 /// do not contain the scop itself.
390 Loops.remove_if([this](const Loop *L) {
391 return this->S.getRegion().contains(L) ||
392 L->contains(S.getRegion().getEntry());
393 });
394}
395
396void IslNodeBuilder::updateValues(
397 ParallelLoopGenerator::ValueToValueMapTy &NewValues) {
398 SmallPtrSet<Value *, 5> Inserted;
399
400 for (const auto &I : IDToValue) {
401 IDToValue[I.first] = NewValues[I.second];
402 Inserted.insert(I.second);
403 }
404
405 for (const auto &I : NewValues) {
406 if (Inserted.count(I.first))
407 continue;
408
409 ValueMap[I.first] = I.second;
410 }
411}
412
Tobias Grossere602a072013-05-07 07:30:56 +0000413void IslNodeBuilder::createUserVector(__isl_take isl_ast_node *User,
414 std::vector<Value *> &IVS,
415 __isl_take isl_id *IteratorID,
416 __isl_take isl_union_map *Schedule) {
Tobias Grosserce67a042014-07-02 16:26:47 +0000417 isl_ast_expr *Expr = isl_ast_node_user_get_expr(User);
418 isl_ast_expr *StmtExpr = isl_ast_expr_get_op_arg(Expr, 0);
419 isl_id *Id = isl_ast_expr_get_id(StmtExpr);
420 isl_ast_expr_free(StmtExpr);
Tobias Grosserc14582f2013-02-05 18:01:29 +0000421 ScopStmt *Stmt = (ScopStmt *)isl_id_get_user(Id);
Johannes Doerfertbe9c9112015-02-06 21:39:31 +0000422 Stmt->setAstBuild(IslAstInfo::getBuild(User));
Sebastian Pop04c4ce32012-12-18 07:46:13 +0000423 VectorValueMapT VectorMap(IVS.size());
Sebastian Pop9d10fff2013-02-15 20:55:59 +0000424 std::vector<LoopToScevMapT> VLTS(IVS.size());
Sebastian Pop04c4ce32012-12-18 07:46:13 +0000425
426 isl_union_set *Domain = isl_union_set_from_set(Stmt->getDomain());
427 Schedule = isl_union_map_intersect_domain(Schedule, Domain);
428 isl_map *S = isl_map_from_union_map(Schedule);
429
Tobias Grosserce67a042014-07-02 16:26:47 +0000430 createSubstitutionsVector(Expr, Stmt, VectorMap, VLTS, IVS, IteratorID);
Johannes Doerfertbe9c9112015-02-06 21:39:31 +0000431 VectorBlockGenerator::generate(BlockGen, *Stmt, VectorMap, VLTS, S);
Sebastian Pop04c4ce32012-12-18 07:46:13 +0000432
Sebastian Pop04c4ce32012-12-18 07:46:13 +0000433 isl_map_free(S);
Sebastian Pop04c4ce32012-12-18 07:46:13 +0000434 isl_id_free(Id);
435 isl_ast_node_free(User);
436}
437
Tobias Grossere602a072013-05-07 07:30:56 +0000438void IslNodeBuilder::createForVector(__isl_take isl_ast_node *For,
439 int VectorWidth) {
Sebastian Pop04c4ce32012-12-18 07:46:13 +0000440 isl_ast_node *Body = isl_ast_node_for_get_body(For);
441 isl_ast_expr *Init = isl_ast_node_for_get_init(For);
442 isl_ast_expr *Inc = isl_ast_node_for_get_inc(For);
443 isl_ast_expr *Iterator = isl_ast_node_for_get_iterator(For);
444 isl_id *IteratorID = isl_ast_expr_get_id(Iterator);
Sebastian Pop04c4ce32012-12-18 07:46:13 +0000445
446 Value *ValueLB = ExprBuilder.create(Init);
Sebastian Pop04c4ce32012-12-18 07:46:13 +0000447 Value *ValueInc = ExprBuilder.create(Inc);
448
449 Type *MaxType = ExprBuilder.getType(Iterator);
450 MaxType = ExprBuilder.getWidestType(MaxType, ValueLB->getType());
Sebastian Pop04c4ce32012-12-18 07:46:13 +0000451 MaxType = ExprBuilder.getWidestType(MaxType, ValueInc->getType());
452
453 if (MaxType != ValueLB->getType())
454 ValueLB = Builder.CreateSExt(ValueLB, MaxType);
Sebastian Pop04c4ce32012-12-18 07:46:13 +0000455 if (MaxType != ValueInc->getType())
456 ValueInc = Builder.CreateSExt(ValueInc, MaxType);
457
Tobias Grosserc14582f2013-02-05 18:01:29 +0000458 std::vector<Value *> IVS(VectorWidth);
Sebastian Pop04c4ce32012-12-18 07:46:13 +0000459 IVS[0] = ValueLB;
460
461 for (int i = 1; i < VectorWidth; i++)
Tobias Grosserc14582f2013-02-05 18:01:29 +0000462 IVS[i] = Builder.CreateAdd(IVS[i - 1], ValueInc, "p_vector_iv");
Sebastian Pop04c4ce32012-12-18 07:46:13 +0000463
Johannes Doerfert94d90822014-07-23 20:26:25 +0000464 isl_union_map *Schedule = IslAstInfo::getSchedule(For);
Sebastian Pop04c4ce32012-12-18 07:46:13 +0000465 assert(Schedule && "For statement annotation does not contain its schedule");
466
467 IDToValue[IteratorID] = ValueLB;
468
469 switch (isl_ast_node_get_type(Body)) {
470 case isl_ast_node_user:
471 createUserVector(Body, IVS, isl_id_copy(IteratorID),
472 isl_union_map_copy(Schedule));
473 break;
474 case isl_ast_node_block: {
475 isl_ast_node_list *List = isl_ast_node_block_get_children(Body);
476
477 for (int i = 0; i < isl_ast_node_list_n_ast_node(List); ++i)
478 createUserVector(isl_ast_node_list_get_ast_node(List, i), IVS,
Tobias Grosser1bb59b02012-12-29 23:47:38 +0000479 isl_id_copy(IteratorID), isl_union_map_copy(Schedule));
Sebastian Pop04c4ce32012-12-18 07:46:13 +0000480
481 isl_ast_node_free(Body);
482 isl_ast_node_list_free(List);
483 break;
484 }
485 default:
486 isl_ast_node_dump(Body);
487 llvm_unreachable("Unhandled isl_ast_node in vectorizer");
488 }
489
Tobias Grossere3c05582014-11-15 21:32:53 +0000490 IDToValue.erase(IDToValue.find(IteratorID));
Sebastian Pop04c4ce32012-12-18 07:46:13 +0000491 isl_id_free(IteratorID);
Sebastian Pop04c4ce32012-12-18 07:46:13 +0000492 isl_union_map_free(Schedule);
493
494 isl_ast_node_free(For);
495 isl_ast_expr_free(Iterator);
496}
497
498void IslNodeBuilder::createForSequential(__isl_take isl_ast_node *For) {
Tobias Grosser8a5bc6e2012-10-02 19:50:43 +0000499 isl_ast_node *Body;
500 isl_ast_expr *Init, *Inc, *Iterator, *UB;
501 isl_id *IteratorID;
502 Value *ValueLB, *ValueUB, *ValueInc;
503 Type *MaxType;
Tobias Grosser5db6ffd2013-05-16 06:40:06 +0000504 BasicBlock *ExitBlock;
Tobias Grosser8a5bc6e2012-10-02 19:50:43 +0000505 Value *IV;
Tobias Grosserc967d8e2012-10-16 07:29:13 +0000506 CmpInst::Predicate Predicate;
Tobias Grosser37c9b8e2014-03-04 14:59:00 +0000507 bool Parallel;
508
Johannes Doerfertc7b719f2014-10-01 20:10:44 +0000509 Parallel =
510 IslAstInfo::isParallel(For) && !IslAstInfo::isReductionParallel(For);
Tobias Grosser8a5bc6e2012-10-02 19:50:43 +0000511
512 Body = isl_ast_node_for_get_body(For);
513
514 // isl_ast_node_for_is_degenerate(For)
515 //
516 // TODO: For degenerated loops we could generate a plain assignment.
517 // However, for now we just reuse the logic for normal loops, which will
518 // create a loop with a single iteration.
519
520 Init = isl_ast_node_for_get_init(For);
521 Inc = isl_ast_node_for_get_inc(For);
522 Iterator = isl_ast_node_for_get_iterator(For);
523 IteratorID = isl_ast_expr_get_id(Iterator);
Tobias Grosserc967d8e2012-10-16 07:29:13 +0000524 UB = getUpperBound(For, Predicate);
Tobias Grosser8a5bc6e2012-10-02 19:50:43 +0000525
526 ValueLB = ExprBuilder.create(Init);
527 ValueUB = ExprBuilder.create(UB);
528 ValueInc = ExprBuilder.create(Inc);
529
530 MaxType = ExprBuilder.getType(Iterator);
531 MaxType = ExprBuilder.getWidestType(MaxType, ValueLB->getType());
532 MaxType = ExprBuilder.getWidestType(MaxType, ValueUB->getType());
533 MaxType = ExprBuilder.getWidestType(MaxType, ValueInc->getType());
534
535 if (MaxType != ValueLB->getType())
536 ValueLB = Builder.CreateSExt(ValueLB, MaxType);
537 if (MaxType != ValueUB->getType())
538 ValueUB = Builder.CreateSExt(ValueUB, MaxType);
539 if (MaxType != ValueInc->getType())
540 ValueInc = Builder.CreateSExt(ValueInc, MaxType);
541
Johannes Doerfertdd5c1442014-09-10 17:33:32 +0000542 // If we can show that LB <Predicate> UB holds at least once, we can
543 // omit the GuardBB in front of the loop.
544 bool UseGuardBB =
545 !SE.isKnownPredicate(Predicate, SE.getSCEV(ValueLB), SE.getSCEV(ValueUB));
Johannes Doerfert2ef3f4f2014-08-07 17:14:54 +0000546 IV = createLoop(ValueLB, ValueUB, ValueInc, Builder, P, LI, DT, ExitBlock,
Johannes Doerfertdd5c1442014-09-10 17:33:32 +0000547 Predicate, &Annotator, Parallel, UseGuardBB);
Tobias Grosser8a5bc6e2012-10-02 19:50:43 +0000548 IDToValue[IteratorID] = IV;
549
550 create(Body);
551
Johannes Doerfertc7b719f2014-10-01 20:10:44 +0000552 Annotator.popLoop(Parallel);
Tobias Grosser37c9b8e2014-03-04 14:59:00 +0000553
Tobias Grossere3c05582014-11-15 21:32:53 +0000554 IDToValue.erase(IDToValue.find(IteratorID));
Tobias Grosser8a5bc6e2012-10-02 19:50:43 +0000555
Tobias Grosser5db6ffd2013-05-16 06:40:06 +0000556 Builder.SetInsertPoint(ExitBlock->begin());
Tobias Grosser8a5bc6e2012-10-02 19:50:43 +0000557
558 isl_ast_node_free(For);
559 isl_ast_expr_free(Iterator);
560 isl_id_free(IteratorID);
561}
562
Tobias Grossere3c05582014-11-15 21:32:53 +0000563/// @brief Remove the BBs contained in a (sub)function from the dominator tree.
564///
565/// This function removes the basic blocks that are part of a subfunction from
566/// the dominator tree. Specifically, when generating code it may happen that at
567/// some point the code generation continues in a new sub-function (e.g., when
568/// generating OpenMP code). The basic blocks that are created in this
569/// sub-function are then still part of the dominator tree of the original
570/// function, such that the dominator tree reaches over function boundaries.
571/// This is not only incorrect, but also causes crashes. This function now
572/// removes from the dominator tree all basic blocks that are dominated (and
573/// consequently reachable) from the entry block of this (sub)function.
574///
575/// FIXME: A LLVM (function or region) pass should not touch anything outside of
576/// the function/region it runs on. Hence, the pure need for this function shows
577/// that we do not comply to this rule. At the moment, this does not cause any
578/// issues, but we should be aware that such issues may appear. Unfortunately
579/// the current LLVM pass infrastructure does not allow to make Polly a module
580/// or call-graph pass to solve this issue, as such a pass would not have access
581/// to the per-function analyses passes needed by Polly. A future pass manager
582/// infrastructure is supposed to enable such kind of access possibly allowing
583/// us to create a cleaner solution here.
584///
585/// FIXME: Instead of adding the dominance information and then dropping it
586/// later on, we should try to just not add it in the first place. This requires
587/// some careful testing to make sure this does not break in interaction with
588/// the SCEVBuilder and SplitBlock which may rely on the dominator tree or
589/// which may try to update it.
590///
591/// @param F The function which contains the BBs to removed.
592/// @param DT The dominator tree from which to remove the BBs.
593static void removeSubFuncFromDomTree(Function *F, DominatorTree &DT) {
594 DomTreeNode *N = DT.getNode(&F->getEntryBlock());
595 std::vector<BasicBlock *> Nodes;
596
597 // We can only remove an element from the dominator tree, if all its children
598 // have been removed. To ensure this we obtain the list of nodes to remove
599 // using a post-order tree traversal.
600 for (po_iterator<DomTreeNode *> I = po_begin(N), E = po_end(N); I != E; ++I)
601 Nodes.push_back(I->getBlock());
602
603 for (BasicBlock *BB : Nodes)
604 DT.eraseNode(BB);
605}
606
607void IslNodeBuilder::createForParallel(__isl_take isl_ast_node *For) {
608 isl_ast_node *Body;
609 isl_ast_expr *Init, *Inc, *Iterator, *UB;
610 isl_id *IteratorID;
611 Value *ValueLB, *ValueUB, *ValueInc;
612 Type *MaxType;
613 Value *IV;
614 CmpInst::Predicate Predicate;
615
616 Body = isl_ast_node_for_get_body(For);
617 Init = isl_ast_node_for_get_init(For);
618 Inc = isl_ast_node_for_get_inc(For);
619 Iterator = isl_ast_node_for_get_iterator(For);
620 IteratorID = isl_ast_expr_get_id(Iterator);
621 UB = getUpperBound(For, Predicate);
622
623 ValueLB = ExprBuilder.create(Init);
624 ValueUB = ExprBuilder.create(UB);
625 ValueInc = ExprBuilder.create(Inc);
626
627 // OpenMP always uses SLE. In case the isl generated AST uses a SLT
628 // expression, we need to adjust the loop blound by one.
629 if (Predicate == CmpInst::ICMP_SLT)
630 ValueUB = Builder.CreateAdd(
631 ValueUB, Builder.CreateSExt(Builder.getTrue(), ValueUB->getType()));
632
633 MaxType = ExprBuilder.getType(Iterator);
634 MaxType = ExprBuilder.getWidestType(MaxType, ValueLB->getType());
635 MaxType = ExprBuilder.getWidestType(MaxType, ValueUB->getType());
636 MaxType = ExprBuilder.getWidestType(MaxType, ValueInc->getType());
637
638 if (MaxType != ValueLB->getType())
639 ValueLB = Builder.CreateSExt(ValueLB, MaxType);
640 if (MaxType != ValueUB->getType())
641 ValueUB = Builder.CreateSExt(ValueUB, MaxType);
642 if (MaxType != ValueInc->getType())
643 ValueInc = Builder.CreateSExt(ValueInc, MaxType);
644
645 BasicBlock::iterator LoopBody;
646
647 SetVector<Value *> SubtreeValues;
648 SetVector<const Loop *> Loops;
649
650 getReferencesInSubtree(For, SubtreeValues, Loops);
651
652 // Create for all loops we depend on values that contain the current loop
653 // iteration. These values are necessary to generate code for SCEVs that
654 // depend on such loops. As a result we need to pass them to the subfunction.
655 for (const Loop *L : Loops) {
656 const SCEV *OuterLIV = SE.getAddRecExpr(SE.getUnknown(Builder.getInt64(0)),
657 SE.getUnknown(Builder.getInt64(1)),
658 L, SCEV::FlagAnyWrap);
659 Value *V = generateSCEV(OuterLIV);
660 OutsideLoopIterations[L] = SE.getUnknown(V);
661 SubtreeValues.insert(V);
662 }
663
664 ParallelLoopGenerator::ValueToValueMapTy NewValues;
665 ParallelLoopGenerator ParallelLoopGen(Builder, P, LI, DT, DL);
666
667 IV = ParallelLoopGen.createParallelLoop(ValueLB, ValueUB, ValueInc,
668 SubtreeValues, NewValues, &LoopBody);
669 BasicBlock::iterator AfterLoop = Builder.GetInsertPoint();
670 Builder.SetInsertPoint(LoopBody);
671
672 // Save the current values.
673 ValueMapT ValueMapCopy = ValueMap;
674 IslExprBuilder::IDToValueTy IDToValueCopy = IDToValue;
675
676 updateValues(NewValues);
677 IDToValue[IteratorID] = IV;
678
679 create(Body);
680
681 // Restore the original values.
682 ValueMap = ValueMapCopy;
683 IDToValue = IDToValueCopy;
684
685 Builder.SetInsertPoint(AfterLoop);
686 removeSubFuncFromDomTree((*LoopBody).getParent()->getParent(), DT);
687
688 for (const Loop *L : Loops)
689 OutsideLoopIterations.erase(L);
690
691 isl_ast_node_free(For);
692 isl_ast_expr_free(Iterator);
693 isl_id_free(IteratorID);
694}
695
Sebastian Pop04c4ce32012-12-18 07:46:13 +0000696void IslNodeBuilder::createFor(__isl_take isl_ast_node *For) {
697 bool Vector = PollyVectorizerChoice != VECTORIZER_NONE;
698
Johannes Doerferted67f8b2014-08-01 08:14:28 +0000699 if (Vector && IslAstInfo::isInnermostParallel(For) &&
700 !IslAstInfo::isReductionParallel(For)) {
Sebastian Pop04c4ce32012-12-18 07:46:13 +0000701 int VectorWidth = getNumberOfIterations(For);
702 if (1 < VectorWidth && VectorWidth <= 16) {
703 createForVector(For, VectorWidth);
704 return;
705 }
706 }
Tobias Grossere3c05582014-11-15 21:32:53 +0000707
708 if (IslAstInfo::isExecutedInParallel(For)) {
709 createForParallel(For);
710 return;
711 }
Sebastian Pop04c4ce32012-12-18 07:46:13 +0000712 createForSequential(For);
713}
714
Tobias Grosser8a5bc6e2012-10-02 19:50:43 +0000715void IslNodeBuilder::createIf(__isl_take isl_ast_node *If) {
716 isl_ast_expr *Cond = isl_ast_node_if_get_cond(If);
717
718 Function *F = Builder.GetInsertBlock()->getParent();
719 LLVMContext &Context = F->getContext();
720
Tobias Grosserc14582f2013-02-05 18:01:29 +0000721 BasicBlock *CondBB =
Chandler Carruth5ec33332015-01-18 10:52:23 +0000722 SplitBlock(Builder.GetInsertBlock(), Builder.GetInsertPoint(), &DT, &LI);
Tobias Grosser8a5bc6e2012-10-02 19:50:43 +0000723 CondBB->setName("polly.cond");
Chandler Carruth5ec33332015-01-18 10:52:23 +0000724 BasicBlock *MergeBB = SplitBlock(CondBB, CondBB->begin(), &DT, &LI);
Tobias Grosser8a5bc6e2012-10-02 19:50:43 +0000725 MergeBB->setName("polly.merge");
726 BasicBlock *ThenBB = BasicBlock::Create(Context, "polly.then", F);
727 BasicBlock *ElseBB = BasicBlock::Create(Context, "polly.else", F);
728
Tobias Grosser8a5bc6e2012-10-02 19:50:43 +0000729 DT.addNewBlock(ThenBB, CondBB);
730 DT.addNewBlock(ElseBB, CondBB);
731 DT.changeImmediateDominator(MergeBB, CondBB);
732
Tobias Grosser3081b0f2013-05-16 06:40:24 +0000733 Loop *L = LI.getLoopFor(CondBB);
734 if (L) {
Chandler Carruth6adcf562015-01-18 01:47:30 +0000735 L->addBasicBlockToLoop(ThenBB, LI);
736 L->addBasicBlockToLoop(ElseBB, LI);
Tobias Grosser3081b0f2013-05-16 06:40:24 +0000737 }
738
Tobias Grosser8a5bc6e2012-10-02 19:50:43 +0000739 CondBB->getTerminator()->eraseFromParent();
740
741 Builder.SetInsertPoint(CondBB);
742 Value *Predicate = ExprBuilder.create(Cond);
743 Builder.CreateCondBr(Predicate, ThenBB, ElseBB);
744 Builder.SetInsertPoint(ThenBB);
745 Builder.CreateBr(MergeBB);
746 Builder.SetInsertPoint(ElseBB);
747 Builder.CreateBr(MergeBB);
748 Builder.SetInsertPoint(ThenBB->begin());
749
750 create(isl_ast_node_if_get_then(If));
751
752 Builder.SetInsertPoint(ElseBB->begin());
753
754 if (isl_ast_node_if_has_else(If))
755 create(isl_ast_node_if_get_else(If));
756
757 Builder.SetInsertPoint(MergeBB->begin());
758
759 isl_ast_node_free(If);
760}
761
Tobias Grosserce67a042014-07-02 16:26:47 +0000762void IslNodeBuilder::createSubstitutions(isl_ast_expr *Expr, ScopStmt *Stmt,
763 ValueMapT &VMap, LoopToScevMapT &LTS) {
764 assert(isl_ast_expr_get_type(Expr) == isl_ast_expr_op &&
765 "Expression of type 'op' expected");
766 assert(isl_ast_expr_get_op_type(Expr) == isl_ast_op_call &&
767 "Opertation of type 'call' expected");
768 for (int i = 0; i < isl_ast_expr_get_op_n_arg(Expr) - 1; ++i) {
769 isl_ast_expr *SubExpr;
Tobias Grosser8a5bc6e2012-10-02 19:50:43 +0000770 Value *V;
771
Tobias Grosserce67a042014-07-02 16:26:47 +0000772 SubExpr = isl_ast_expr_get_op_arg(Expr, i + 1);
773 V = ExprBuilder.create(SubExpr);
Sebastian Pope039bb12013-03-18 19:09:49 +0000774 ScalarEvolution *SE = Stmt->getParent()->getSE();
775 LTS[Stmt->getLoopForDimension(i)] = SE->getUnknown(V);
Tobias Grosser8a5bc6e2012-10-02 19:50:43 +0000776 }
777
Tobias Grossere3c05582014-11-15 21:32:53 +0000778 // Add the current ValueMap to our per-statement value map.
779 //
780 // This is needed e.g. to rewrite array base addresses when moving code
781 // into a parallely executed subfunction.
782 VMap.insert(ValueMap.begin(), ValueMap.end());
783
Tobias Grosserce67a042014-07-02 16:26:47 +0000784 isl_ast_expr_free(Expr);
Sebastian Pop04c4ce32012-12-18 07:46:13 +0000785}
786
Tobias Grosserc14582f2013-02-05 18:01:29 +0000787void IslNodeBuilder::createSubstitutionsVector(
Tobias Grosserce67a042014-07-02 16:26:47 +0000788 __isl_take isl_ast_expr *Expr, ScopStmt *Stmt, VectorValueMapT &VMap,
789 std::vector<LoopToScevMapT> &VLTS, std::vector<Value *> &IVS,
790 __isl_take isl_id *IteratorID) {
Sebastian Pop04c4ce32012-12-18 07:46:13 +0000791 int i = 0;
792
793 Value *OldValue = IDToValue[IteratorID];
Tobias Grosser91f5b262014-06-04 08:06:40 +0000794 for (Value *IV : IVS) {
795 IDToValue[IteratorID] = IV;
Tobias Grosserce67a042014-07-02 16:26:47 +0000796 createSubstitutions(isl_ast_expr_copy(Expr), Stmt, VMap[i], VLTS[i]);
Sebastian Pop04c4ce32012-12-18 07:46:13 +0000797 i++;
798 }
799
800 IDToValue[IteratorID] = OldValue;
801 isl_id_free(IteratorID);
Tobias Grosserce67a042014-07-02 16:26:47 +0000802 isl_ast_expr_free(Expr);
Sebastian Pop04c4ce32012-12-18 07:46:13 +0000803}
804
805void IslNodeBuilder::createUser(__isl_take isl_ast_node *User) {
806 ValueMapT VMap;
Sebastian Pop9d10fff2013-02-15 20:55:59 +0000807 LoopToScevMapT LTS;
Tobias Grosserce67a042014-07-02 16:26:47 +0000808 isl_id *Id;
Sebastian Pop04c4ce32012-12-18 07:46:13 +0000809 ScopStmt *Stmt;
810
Tobias Grosserce67a042014-07-02 16:26:47 +0000811 isl_ast_expr *Expr = isl_ast_node_user_get_expr(User);
812 isl_ast_expr *StmtExpr = isl_ast_expr_get_op_arg(Expr, 0);
813 Id = isl_ast_expr_get_id(StmtExpr);
814 isl_ast_expr_free(StmtExpr);
Sebastian Pop04c4ce32012-12-18 07:46:13 +0000815
Tobias Grossere3c05582014-11-15 21:32:53 +0000816 LTS.insert(OutsideLoopIterations.begin(), OutsideLoopIterations.end());
817
Tobias Grosserc14582f2013-02-05 18:01:29 +0000818 Stmt = (ScopStmt *)isl_id_get_user(Id);
Johannes Doerfertbe9c9112015-02-06 21:39:31 +0000819 Stmt->setAstBuild(IslAstInfo::getBuild(User));
Johannes Doerferta63b2572014-08-03 01:51:59 +0000820
Tobias Grosserce67a042014-07-02 16:26:47 +0000821 createSubstitutions(Expr, Stmt, VMap, LTS);
Johannes Doerfert275a1752015-02-24 16:16:32 +0000822 if (Stmt->isBlockStmt())
823 BlockGen.copyStmt(*Stmt, VMap, LTS);
824 else
825 RegionGen.copyStmt(*Stmt, VMap, LTS);
Tobias Grosser8a5bc6e2012-10-02 19:50:43 +0000826
827 isl_ast_node_free(User);
Tobias Grosser8a5bc6e2012-10-02 19:50:43 +0000828 isl_id_free(Id);
829}
830
831void IslNodeBuilder::createBlock(__isl_take isl_ast_node *Block) {
832 isl_ast_node_list *List = isl_ast_node_block_get_children(Block);
833
834 for (int i = 0; i < isl_ast_node_list_n_ast_node(List); ++i)
835 create(isl_ast_node_list_get_ast_node(List, i));
836
837 isl_ast_node_free(Block);
838 isl_ast_node_list_free(List);
839}
840
841void IslNodeBuilder::create(__isl_take isl_ast_node *Node) {
842 switch (isl_ast_node_get_type(Node)) {
843 case isl_ast_node_error:
844 llvm_unreachable("code generation error");
845 case isl_ast_node_for:
846 createFor(Node);
847 return;
848 case isl_ast_node_if:
849 createIf(Node);
850 return;
851 case isl_ast_node_user:
852 createUser(Node);
853 return;
854 case isl_ast_node_block:
855 createBlock(Node);
856 return;
857 }
858
859 llvm_unreachable("Unknown isl_ast_node type");
860}
861
862void IslNodeBuilder::addParameters(__isl_take isl_set *Context) {
Tobias Grosser8a5bc6e2012-10-02 19:50:43 +0000863
864 for (unsigned i = 0; i < isl_set_dim(Context, isl_dim_param); ++i) {
865 isl_id *Id;
Tobias Grosser8a5bc6e2012-10-02 19:50:43 +0000866
867 Id = isl_set_get_dim_id(Context, isl_dim_param, i);
Tobias Grosserec7d67e2014-11-06 00:27:01 +0000868 IDToValue[Id] = generateSCEV((const SCEV *)isl_id_get_user(Id));
Tobias Grosser8a5bc6e2012-10-02 19:50:43 +0000869
870 isl_id_free(Id);
871 }
872
Tobias Grossere3c05582014-11-15 21:32:53 +0000873 // Generate values for the current loop iteration for all surrounding loops.
874 //
875 // We may also reference loops outside of the scop which do not contain the
876 // scop itself, but as the number of such scops may be arbitrarily large we do
877 // not generate code for them here, but only at the point of code generation
878 // where these values are needed.
879 Region &R = S.getRegion();
880 Loop *L = LI.getLoopFor(R.getEntry());
881
882 while (L != nullptr && R.contains(L))
883 L = L->getParentLoop();
884
885 while (L != nullptr) {
886 const SCEV *OuterLIV = SE.getAddRecExpr(SE.getUnknown(Builder.getInt64(0)),
887 SE.getUnknown(Builder.getInt64(1)),
888 L, SCEV::FlagAnyWrap);
889 Value *V = generateSCEV(OuterLIV);
890 OutsideLoopIterations[L] = SE.getUnknown(V);
891 L = L->getParentLoop();
892 }
893
Tobias Grosser8a5bc6e2012-10-02 19:50:43 +0000894 isl_set_free(Context);
895}
896
Tobias Grosserec7d67e2014-11-06 00:27:01 +0000897Value *IslNodeBuilder::generateSCEV(const SCEV *Expr) {
898 Instruction *InsertLocation = --(Builder.GetInsertBlock()->end());
Tobias Grosser55bc4c02015-01-08 19:26:53 +0000899 return Rewriter->expandCodeFor(Expr, Expr->getType(), InsertLocation);
Tobias Grosserec7d67e2014-11-06 00:27:01 +0000900}
901
Tobias Grosser8a5bc6e2012-10-02 19:50:43 +0000902namespace {
903class IslCodeGeneration : public ScopPass {
Tobias Grosser1bb59b02012-12-29 23:47:38 +0000904public:
Tobias Grosser8a5bc6e2012-10-02 19:50:43 +0000905 static char ID;
906
907 IslCodeGeneration() : ScopPass(ID) {}
908
Tobias Grossere3c05582014-11-15 21:32:53 +0000909 /// @brief The datalayout used
910 const DataLayout *DL;
911
Johannes Doerfert38262242014-09-10 14:50:23 +0000912 /// @name The analysis passes we need to generate code.
913 ///
914 ///{
915 LoopInfo *LI;
916 IslAstInfo *AI;
917 DominatorTree *DT;
918 ScalarEvolution *SE;
919 ///}
920
921 /// @brief The loop annotator to generate llvm.loop metadata.
Johannes Doerfert51d1c742014-10-02 15:32:17 +0000922 ScopAnnotator Annotator;
Johannes Doerfert38262242014-09-10 14:50:23 +0000923
924 /// @brief Build the runtime condition.
925 ///
926 /// Build the condition that evaluates at run-time to true iff all
927 /// assumptions taken for the SCoP hold, and to false otherwise.
928 ///
929 /// @return A value evaluating to true/false if execution is save/unsafe.
930 Value *buildRTC(PollyIRBuilder &Builder, IslExprBuilder &ExprBuilder) {
931 Builder.SetInsertPoint(Builder.GetInsertBlock()->getTerminator());
932 Value *RTC = ExprBuilder.create(AI->getRunCondition());
Johannes Doerfertb164c792014-09-18 11:17:17 +0000933 if (!RTC->getType()->isIntegerTy(1))
934 RTC = Builder.CreateIsNotNull(RTC);
935 return RTC;
Johannes Doerfert38262242014-09-10 14:50:23 +0000936 }
937
Johannes Doerfert0b169c02015-02-27 17:37:05 +0000938 bool verifyGeneratedFunction(Scop &S, Function &F) {
939 if (!verifyFunction(F))
940 return false;
941
942 DEBUG({
943 errs() << "== ISL Codegen created an invalid function ==\n\n== The "
944 "SCoP ==\n";
945 S.print(errs());
946 errs() << "\n== The isl AST ==\n";
Johannes Doerfert3fe584d2015-03-01 18:40:25 +0000947 AI->printScop(errs(), S);
Johannes Doerfert0b169c02015-02-27 17:37:05 +0000948 errs() << "\n== The invalid function ==\n";
949 F.print(errs());
950 errs() << "\n== The errors ==\n";
951 verifyFunction(F, &errs());
952 });
953
954 return true;
955 }
956
Johannes Doerfert909a3bf2015-03-01 18:42:08 +0000957 bool runOnScop(Scop &S) override {
Johannes Doerfert38262242014-09-10 14:50:23 +0000958 AI = &getAnalysis<IslAstInfo>();
Johannes Doerfert7ceb0402015-02-11 17:25:09 +0000959
960 // Check if we created an isl_ast root node, otherwise exit.
961 isl_ast_node *AstRoot = AI->getAst();
962 if (!AstRoot)
963 return false;
964
965 LI = &getAnalysis<LoopInfoWrapperPass>().getLoopInfo();
Johannes Doerfert38262242014-09-10 14:50:23 +0000966 DT = &getAnalysis<DominatorTreeWrapperPass>().getDomTree();
967 SE = &getAnalysis<ScalarEvolution>();
Tobias Grossere3c05582014-11-15 21:32:53 +0000968 DL = &getAnalysis<DataLayoutPass>().getDataLayout();
Tobias Grosser0ee50f62013-04-10 06:55:31 +0000969
Tobias Grossere602a072013-05-07 07:30:56 +0000970 assert(!S.getRegion().isTopLevelRegion() &&
971 "Top level regions are not supported");
Tobias Grosser0ee50f62013-04-10 06:55:31 +0000972
Johannes Doerfertecdf2632014-10-02 15:31:24 +0000973 // Build the alias scopes for annotations first.
974 if (PollyAnnotateAliasScopes)
975 Annotator.buildAliasScopes(S);
976
Johannes Doerfert38262242014-09-10 14:50:23 +0000977 BasicBlock *EnteringBB = simplifyRegion(&S, this);
978 PollyIRBuilder Builder = createPollyIRBuilder(EnteringBB, Annotator);
Johannes Doerfert9744c4a2014-08-12 18:35:54 +0000979
Tobias Grossere3c05582014-11-15 21:32:53 +0000980 IslNodeBuilder NodeBuilder(Builder, Annotator, this, *DL, *LI, *SE, *DT, S);
Tobias Grosser28735942014-08-16 09:09:15 +0000981 NodeBuilder.addParameters(S.getContext());
Johannes Doerfert38262242014-09-10 14:50:23 +0000982
983 Value *RTC = buildRTC(Builder, NodeBuilder.getExprBuilder());
984 BasicBlock *StartBlock = executeScopConditionally(S, this, RTC);
Tobias Grosser28735942014-08-16 09:09:15 +0000985 Builder.SetInsertPoint(StartBlock->begin());
986
Johannes Doerfert7ceb0402015-02-11 17:25:09 +0000987 NodeBuilder.create(AstRoot);
Johannes Doerfert0b169c02015-02-27 17:37:05 +0000988
989 assert(!verifyGeneratedFunction(S, *EnteringBB->getParent()) &&
990 "Verification of generated function failed");
Tobias Grosser8a5bc6e2012-10-02 19:50:43 +0000991 return true;
992 }
993
Johannes Doerfert909a3bf2015-03-01 18:42:08 +0000994 void printScop(raw_ostream &, Scop &) const override {}
Tobias Grosser8a5bc6e2012-10-02 19:50:43 +0000995
Johannes Doerfert909a3bf2015-03-01 18:42:08 +0000996 void getAnalysisUsage(AnalysisUsage &AU) const override {
Tobias Grossere3c05582014-11-15 21:32:53 +0000997 AU.addRequired<DataLayoutPass>();
Tobias Grosser42aff302014-01-13 22:29:56 +0000998 AU.addRequired<DominatorTreeWrapperPass>();
Tobias Grosser8a5bc6e2012-10-02 19:50:43 +0000999 AU.addRequired<IslAstInfo>();
Matt Arsenault8ca36812014-07-19 18:40:17 +00001000 AU.addRequired<RegionInfoPass>();
Tobias Grosser8a5bc6e2012-10-02 19:50:43 +00001001 AU.addRequired<ScalarEvolution>();
1002 AU.addRequired<ScopDetection>();
1003 AU.addRequired<ScopInfo>();
Chandler Carruthf5579872015-01-17 14:16:56 +00001004 AU.addRequired<LoopInfoWrapperPass>();
Tobias Grosser8a5bc6e2012-10-02 19:50:43 +00001005
1006 AU.addPreserved<Dependences>();
1007
Chandler Carruthf5579872015-01-17 14:16:56 +00001008 AU.addPreserved<LoopInfoWrapperPass>();
Tobias Grosser42aff302014-01-13 22:29:56 +00001009 AU.addPreserved<DominatorTreeWrapperPass>();
Tobias Grosser8a5bc6e2012-10-02 19:50:43 +00001010 AU.addPreserved<IslAstInfo>();
1011 AU.addPreserved<ScopDetection>();
1012 AU.addPreserved<ScalarEvolution>();
1013
1014 // FIXME: We do not yet add regions for the newly generated code to the
1015 // region tree.
Matt Arsenault8ca36812014-07-19 18:40:17 +00001016 AU.addPreserved<RegionInfoPass>();
Tobias Grosser8a5bc6e2012-10-02 19:50:43 +00001017 AU.addPreserved<TempScopInfo>();
1018 AU.addPreserved<ScopInfo>();
1019 AU.addPreservedID(IndependentBlocksID);
1020 }
1021};
1022}
1023
1024char IslCodeGeneration::ID = 1;
1025
Tobias Grosser7242ad92013-02-22 08:07:06 +00001026Pass *polly::createIslCodeGenerationPass() { return new IslCodeGeneration(); }
Tobias Grosser8a5bc6e2012-10-02 19:50:43 +00001027
Tobias Grosser7242ad92013-02-22 08:07:06 +00001028INITIALIZE_PASS_BEGIN(IslCodeGeneration, "polly-codegen-isl",
1029 "Polly - Create LLVM-IR from SCoPs", false, false);
1030INITIALIZE_PASS_DEPENDENCY(Dependences);
Tobias Grosser42aff302014-01-13 22:29:56 +00001031INITIALIZE_PASS_DEPENDENCY(DominatorTreeWrapperPass);
Chandler Carruthf5579872015-01-17 14:16:56 +00001032INITIALIZE_PASS_DEPENDENCY(LoopInfoWrapperPass);
Matt Arsenault8ca36812014-07-19 18:40:17 +00001033INITIALIZE_PASS_DEPENDENCY(RegionInfoPass);
Tobias Grosser7242ad92013-02-22 08:07:06 +00001034INITIALIZE_PASS_DEPENDENCY(ScalarEvolution);
1035INITIALIZE_PASS_DEPENDENCY(ScopDetection);
1036INITIALIZE_PASS_END(IslCodeGeneration, "polly-codegen-isl",
1037 "Polly - Create LLVM-IR from SCoPs", false, false)