//===- Utils.h - Utility functions for code generation ----------*- C++ -*-===// // // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. // See https://llvm.org/LICENSE.txt for license information. // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception // //===----------------------------------------------------------------------===// // // This file contains utility functions for the code generation. //===----------------------------------------------------------------------===// #ifndef POLLY_CODEGEN_UTILS_H #define POLLY_CODEGEN_UTILS_H #include namespace llvm { class Pass; class Value; class BasicBlock; class DominatorTree; class RegionInfo; class LoopInfo; class BranchInst; } // namespace llvm namespace polly { class Scop; using BBPair = std::pair; /// Execute a Scop conditionally wrt @p RTC. /// /// In the CFG the optimized code of the Scop is generated next to the /// original code. Both the new and the original version of the code remain /// in the CFG. A branch statement decides which version is executed based on /// the runtime value of @p RTC. /// /// Before transformation: /// /// bb0 /// | /// orig_scop /// | /// bb1 /// /// After transformation: /// bb0 /// | /// polly.splitBlock /// / \. /// | startBlock /// | | /// orig_scop new_scop /// \ / /// \ / /// bb1 (joinBlock) /// /// @param S The Scop to execute conditionally. /// @param P A reference to the pass calling this function. /// @param RTC The runtime condition checked before executing the new SCoP. /// /// @return An std::pair: /// - The first element is a BBPair of (StartBlock, EndBlock). /// - The second element is the BranchInst which conditionally /// branches to the SCoP based on the RTC. /// std::pair executeScopConditionally(Scop &S, llvm::Value *RTC, llvm::DominatorTree &DT, llvm::RegionInfo &RI, llvm::LoopInfo &LI); } // namespace polly #endif