//===-- llvm/CodeGen/VirtRegMap.cpp - Virtual Register Map ----------------===// // // The LLVM Compiler Infrastructure // // This file was developed by the LLVM research group and is distributed under // the University of Illinois Open Source License. See LICENSE.TXT for details. // //===----------------------------------------------------------------------===// // // This file implements the virtual register map. // //===----------------------------------------------------------------------===// #include "VirtRegMap.h" #include "llvm/CodeGen/MachineFrameInfo.h" #include "llvm/Target/TargetMachine.h" #include "Support/Statistic.h" #include using namespace llvm; namespace { Statistic<> numSpills("ra-linearscan", "Number of register spills"); } int VirtRegMap::assignVirt2StackSlot(unsigned virtReg) { assert(MRegisterInfo::isVirtualRegister(virtReg)); assert(v2ssMap_[toIndex(virtReg)] == NO_STACK_SLOT && "attempt to assign stack slot to already spilled register"); const TargetRegisterClass* rc = mf_->getSSARegMap()->getRegClass(virtReg); int frameIndex = mf_->getFrameInfo()->CreateStackObject(rc); v2ssMap_[toIndex(virtReg)] = frameIndex; ++numSpills; return frameIndex; } std::ostream& llvm::operator<<(std::ostream& os, const VirtRegMap& vrm) { const MRegisterInfo* mri = vrm.mf_->getTarget().getRegisterInfo(); std::cerr << "********** REGISTER MAP **********\n"; for (unsigned i = 0, e = vrm.v2pMap_.size(); i != e; ++i) { if (vrm.v2pMap_[i] != VirtRegMap::NO_PHYS_REG) std::cerr << "[reg" << VirtRegMap::fromIndex(i) << " -> " << mri->getName(vrm.v2pMap_[i]) << "]\n"; } for (unsigned i = 0, e = vrm.v2ssMap_.size(); i != e; ++i) { if (vrm.v2ssMap_[i] != VirtRegMap::NO_STACK_SLOT) std::cerr << "[reg" << VirtRegMap::fromIndex(i) << " -> fi#" << vrm.v2ssMap_[i] << "]\n"; } return std::cerr << '\n'; }