LLVM
8.0.1
|
#include "HexagonInstrInfo.h"
#include "HexagonRegisterInfo.h"
#include "HexagonSubtarget.h"
#include "llvm/ADT/SmallVector.h"
#include "llvm/CodeGen/MachineDominators.h"
#include "llvm/CodeGen/MachineFunctionPass.h"
#include "llvm/CodeGen/MachineInstrBuilder.h"
#include "llvm/CodeGen/MachineRegisterInfo.h"
#include "llvm/Support/CommandLine.h"
#include "llvm/Support/raw_ostream.h"
#include "llvm/Pass.h"
#include <map>
#include <set>
#include <utility>
#include <vector>
Go to the source code of this file.
Namespaces | |
llvm | |
This class represents lattice values for constants. | |
Macros | |
#define | DEBUG_TYPE "hexagon-cext-opt" |
Functions | |
void | llvm::initializeHexagonConstExtendersPass (PassRegistry &) |
FunctionPass * | llvm::createHexagonConstExtenders () |
static int32_t | adjustUp (int32_t V, uint8_t A, uint8_t O) |
static int32_t | adjustDown (int32_t V, uint8_t A, uint8_t O) |
INITIALIZE_PASS_BEGIN (HexagonConstExtenders, "hexagon-cext-opt", "Hexagon constant-extender optimization", false, false) INITIALIZE_PASS_END(HexagonConstExtenders | |
Variables | |
static cl::opt< unsigned > | CountThreshold ("hexagon-cext-threshold", cl::init(3), cl::Hidden, cl::ZeroOrMore, cl::desc("Minimum number of extenders to trigger replacement")) |
static cl::opt< unsigned > | ReplaceLimit ("hexagon-cext-limit", cl::init(0), cl::Hidden, cl::ZeroOrMore, cl::desc("Maximum number of replacements")) |
hexagon cext | opt |
hexagon cext Hexagon constant extender | optimization |
hexagon cext Hexagon constant extender | false |
hexagon cext Hexagon constant extender static false unsigned | ReplaceCounter = 0 |
#define DEBUG_TYPE "hexagon-cext-opt" |
Definition at line 26 of file HexagonConstExtenders.cpp.
|
static |
Definition at line 48 of file HexagonConstExtenders.cpp.
References adjustUp(), llvm::AMDGPU::HSAMD::Kernel::Arg::Key::Align, assert(), contains(), D, llvm::empty(), H, intersect(), llvm::isPowerOf2_32(), llvm::max(), llvm::RISCVFenceField::O, llvm::operator!=(), llvm::operator<(), llvm::operator==(), and std::swap().
|
static |
Definition at line 42 of file HexagonConstExtenders.cpp.
References assert(), and llvm::isPowerOf2_32().
Referenced by adjustDown().
INITIALIZE_PASS_BEGIN | ( | HexagonConstExtenders | , |
"hexagon-cext-opt" | , | ||
"Hexagon constant-extender optimization" | , | ||
false | , | ||
false | |||
) |
|
static |
hexagon cext Hexagon constant extender false |
Definition at line 571 of file HexagonConstExtenders.cpp.
hexagon cext opt |
Definition at line 571 of file HexagonConstExtenders.cpp.
Referenced by llvm::lto::backend(), and LLVMCreateTargetMachine().
hexagon cext Hexagon constant extender optimization |
Definition at line 571 of file HexagonConstExtenders.cpp.
Definition at line 574 of file HexagonConstExtenders.cpp.