| //===-- PTXRegAlloc.cpp - PTX Register Allocator --------------------------===// |
| // |
| // The LLVM Compiler Infrastructure |
| // |
| // This file is distributed under the University of Illinois Open Source |
| // License. See LICENSE.TXT for details. |
| // |
| //===----------------------------------------------------------------------===// |
| // |
| // This file contains a register allocator for PTX code. |
| // |
| //===----------------------------------------------------------------------===// |
| |
| #define DEBUG_TYPE "ptx-reg-alloc" |
| |
| #include "PTX.h" |
| #include "llvm/CodeGen/MachineFunctionPass.h" |
| #include "llvm/CodeGen/RegAllocRegistry.h" |
| |
| using namespace llvm; |
| |
| namespace { |
| // Special register allocator for PTX. |
| class PTXRegAlloc : public MachineFunctionPass { |
| public: |
| static char ID; |
| PTXRegAlloc() : MachineFunctionPass(ID) { |
| initializePHIEliminationPass(*PassRegistry::getPassRegistry()); |
| initializeTwoAddressInstructionPassPass(*PassRegistry::getPassRegistry()); |
| } |
| |
| virtual const char* getPassName() const { |
| return "PTX Register Allocator"; |
| } |
| |
| virtual void getAnalysisUsage(AnalysisUsage &AU) const { |
| AU.setPreservesCFG(); |
| AU.addRequiredID(PHIEliminationID); |
| AU.addRequiredID(TwoAddressInstructionPassID); |
| MachineFunctionPass::getAnalysisUsage(AU); |
| } |
| |
| virtual bool runOnMachineFunction(MachineFunction &MF) { |
| // We do not actually do anything (at least not yet). |
| return false; |
| } |
| }; |
| |
| char PTXRegAlloc::ID = 0; |
| |
| static RegisterRegAlloc |
| ptxRegAlloc("ptx", "PTX register allocator", createPTXRegisterAllocator); |
| } |
| |
| FunctionPass *llvm::createPTXRegisterAllocator() { |
| return new PTXRegAlloc(); |
| } |
| |