File indexing completed on 2026-05-10 08:43:29
0001
0002
0003
0004
0005
0006
0007
0008
0009
0010
0011
0012
0013
0014 #ifndef LLVM_CODEGEN_LINKALLCODEGENCOMPONENTS_H
0015 #define LLVM_CODEGEN_LINKALLCODEGENCOMPONENTS_H
0016
0017 #include "llvm/CodeGen/Passes.h"
0018 #include "llvm/CodeGen/SchedulerRegistry.h"
0019 #include "llvm/Target/TargetMachine.h"
0020 #include <cstdlib>
0021
0022 namespace {
0023 struct ForceCodegenLinking {
0024 ForceCodegenLinking() {
0025
0026
0027
0028
0029
0030
0031
0032 if (std::getenv("bar") != (char*) -1)
0033 return;
0034
0035 (void) llvm::createFastRegisterAllocator();
0036 (void) llvm::createBasicRegisterAllocator();
0037 (void) llvm::createGreedyRegisterAllocator();
0038 (void) llvm::createDefaultPBQPRegisterAllocator();
0039
0040 (void)llvm::createBURRListDAGScheduler(nullptr,
0041 llvm::CodeGenOptLevel::Default);
0042 (void)llvm::createSourceListDAGScheduler(nullptr,
0043 llvm::CodeGenOptLevel::Default);
0044 (void)llvm::createHybridListDAGScheduler(nullptr,
0045 llvm::CodeGenOptLevel::Default);
0046 (void)llvm::createFastDAGScheduler(nullptr,
0047 llvm::CodeGenOptLevel::Default);
0048 (void)llvm::createDefaultScheduler(nullptr,
0049 llvm::CodeGenOptLevel::Default);
0050 (void)llvm::createVLIWDAGScheduler(nullptr,
0051 llvm::CodeGenOptLevel::Default);
0052 }
0053 } ForceCodegenLinking;
0054 }
0055
0056 #endif