mirror of
https://github.com/capstone-engine/llvm-capstone.git
synced 2025-01-13 19:32:41 +00:00
[IslNodeBuilder] Directly use the insert location of our Builder
... instead of adding instructions at the end of the basic block the builder is currently at. This makes it easier to reason about where IR is generated, as with the IRBuilder there is just a single location that specificies where IR is generated. llvm-svn: 278013
This commit is contained in:
parent
4fbc3f4a37
commit
000db70754
@ -1222,7 +1222,20 @@ void IslNodeBuilder::addParameters(__isl_take isl_set *Context) {
|
||||
}
|
||||
|
||||
Value *IslNodeBuilder::generateSCEV(const SCEV *Expr) {
|
||||
Instruction *InsertLocation = &*--(Builder.GetInsertBlock()->end());
|
||||
/// We pass the insert location of our Builder, as Polly ensures during IR
|
||||
/// generation that there is always a valid CFG into which instructions are
|
||||
/// inserted. As a result, the insertpoint is known to be always followed by a
|
||||
/// terminator instruction. This means the insert point may be specified by a
|
||||
/// terminator instruction, but it can never point to an ->end() iterator
|
||||
/// which does not have a corresponding instruction. Hence, dereferencing
|
||||
/// the insertpoint to obtain an instruction is known to be save.
|
||||
///
|
||||
/// We also do not need to update the Builder here, as new instructions are
|
||||
/// always inserted _before_ the given InsertLocation. As a result, the
|
||||
/// insert location remains valid.
|
||||
assert(Builder.GetInsertBlock()->end() != Builder.getInsertPoint() &&
|
||||
"Insert location points after last valid instruction");
|
||||
Instruction *InsertLocation = &*Builder.GetInsertPoint();
|
||||
return expandCodeFor(S, SE, DL, "polly", Expr, Expr->getType(),
|
||||
InsertLocation, &ValueMap);
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user