![]() System : Linux absol.cf 5.4.0-198-generic #218-Ubuntu SMP Fri Sep 27 20:18:53 UTC 2024 x86_64 User : www-data ( 33) PHP Version : 7.4.33 Disable Function : pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare, Directory : /proc/thread-self/root/usr/lib/llvm-6.0/include/polly/ |
Upload File : |
//===------ Simplify.h ------------------------------------------*- C++ -*-===// // // The LLVM Compiler Infrastructure // // This file is distributed under the University of Illinois Open Source // License. See LICENSE.TXT for details. // //===----------------------------------------------------------------------===// // // Simplify a SCoP by removing unnecessary statements and accesses. // //===----------------------------------------------------------------------===// #ifndef POLLY_TRANSFORM_SIMPLIFY_H #define POLLY_TRANSFORM_SIMPLIFY_H #include "llvm/ADT/SmallVector.h" namespace llvm { class PassRegistry; class Pass; } // namespace llvm namespace polly { class MemoryAccess; class ScopStmt; /// Return a vector that contains MemoryAccesses in the order in /// which they are executed. /// /// The order is: /// - Implicit reads (BlockGenerator::generateScalarLoads) /// - Explicit reads and writes (BlockGenerator::generateArrayLoad, /// BlockGenerator::generateArrayStore) /// - In block statements, the accesses are in order in which their /// instructions are executed. /// - In region statements, that order of execution is not predictable at /// compile-time. /// - Implicit writes (BlockGenerator::generateScalarStores) /// The order in which implicit writes are executed relative to each other is /// undefined. llvm::SmallVector<MemoryAccess *, 32> getAccessesInOrder(ScopStmt &Stmt); /// Create a Simplify pass /// /// @param CallNo Disambiguates this instance for when there are multiple /// instances of this pass in the pass manager. It is used only to /// keep the statistics apart and has no influence on the /// simplification itself. /// /// @return The Simplify pass. llvm::Pass *createSimplifyPass(int CallNo = 0); } // namespace polly namespace llvm { void initializeSimplifyPass(llvm::PassRegistry &); } // namespace llvm #endif /* POLLY_TRANSFORM_SIMPLIFY_H */