blob: b300d4da0b6b37488e5a169d3afecf0ec5c3a075 [file] [log] [blame]
Alkis Evlogimenos534f5452004-02-23 01:25:05 +00001//===-- llvm/CodeGen/PhysRegTracker.h - Physical Register Tracker -*- C++ -*-=//
Alkis Evlogimenos888b1a62004-02-23 00:53:31 +00002//
3// The LLVM Compiler Infrastructure
4//
Chris Lattner4ee451d2007-12-29 20:36:04 +00005// This file is distributed under the University of Illinois Open Source
6// License. See LICENSE.TXT for details.
Alkis Evlogimenos888b1a62004-02-23 00:53:31 +00007//
8//===----------------------------------------------------------------------===//
9//
10// This file implements a physical register tracker. The tracker
Alkis Evlogimenos534f5452004-02-23 01:25:05 +000011// tracks physical register usage through addRegUse and
12// delRegUse. isRegAvail checks if a physical register is available or
13// not taking into consideration register aliases.
Alkis Evlogimenos888b1a62004-02-23 00:53:31 +000014//
15//===----------------------------------------------------------------------===//
16
17#ifndef LLVM_CODEGEN_PHYSREGTRACKER_H
18#define LLVM_CODEGEN_PHYSREGTRACKER_H
19
Alkis Evlogimenos12edc7e2004-02-23 06:10:13 +000020#include "llvm/Target/MRegisterInfo.h"
Alkis Evlogimenos888b1a62004-02-23 00:53:31 +000021
22namespace llvm {
23
24 class PhysRegTracker {
Alkis Evlogimenos888b1a62004-02-23 00:53:31 +000025 const MRegisterInfo* mri_;
26 std::vector<unsigned> regUse_;
27
28 public:
Dan Gohman81975f62007-08-27 14:50:10 +000029 explicit PhysRegTracker(const MRegisterInfo& mri)
Alkis Evlogimenos12edc7e2004-02-23 06:10:13 +000030 : mri_(&mri),
31 regUse_(mri_->getNumRegs(), 0) {
Alkis Evlogimenos888b1a62004-02-23 00:53:31 +000032 }
33
34 PhysRegTracker(const PhysRegTracker& rhs)
35 : mri_(rhs.mri_),
36 regUse_(rhs.regUse_) {
37 }
38
39 const PhysRegTracker& operator=(const PhysRegTracker& rhs) {
40 mri_ = rhs.mri_;
41 regUse_ = rhs.regUse_;
42 return *this;
43 }
44
45 void addRegUse(unsigned physReg) {
46 assert(MRegisterInfo::isPhysicalRegister(physReg) &&
47 "should be physical register!");
48 ++regUse_[physReg];
Alkis Evlogimenos25d9d582004-02-23 01:57:39 +000049 for (const unsigned* as = mri_->getAliasSet(physReg); *as; ++as)
50 ++regUse_[*as];
Alkis Evlogimenos888b1a62004-02-23 00:53:31 +000051 }
52
53 void delRegUse(unsigned physReg) {
54 assert(MRegisterInfo::isPhysicalRegister(physReg) &&
55 "should be physical register!");
56 assert(regUse_[physReg] != 0);
57 --regUse_[physReg];
58 for (const unsigned* as = mri_->getAliasSet(physReg); *as; ++as) {
Alkis Evlogimenos25d9d582004-02-23 01:57:39 +000059 assert(regUse_[*as] != 0);
60 --regUse_[*as];
Alkis Evlogimenos888b1a62004-02-23 00:53:31 +000061 }
62 }
63
Alkis Evlogimenos534f5452004-02-23 01:25:05 +000064 bool isRegAvail(unsigned physReg) const {
Alkis Evlogimenos888b1a62004-02-23 00:53:31 +000065 assert(MRegisterInfo::isPhysicalRegister(physReg) &&
66 "should be physical register!");
67 return regUse_[physReg] == 0;
68 }
69 };
70
71} // End llvm namespace
72
73#endif