reg_alloc: Move implementations out of header

This commit is contained in:
MerryMage 2017-02-26 23:16:41 +00:00
parent 184db36caf
commit 135346eb2e
2 changed files with 57 additions and 36 deletions

View file

@ -71,6 +71,53 @@ static void EmitExchange(BlockOfCode* code, HostLoc a, HostLoc b) {
}
}
bool HostLocInfo::IsLocked() const {
return is_being_used;
}
bool HostLocInfo::IsEmpty() const {
return !is_being_used && values.empty();
}
bool HostLocInfo::IsLastUse() const {
return !is_being_used && std::all_of(values.begin(), values.end(), [](const auto& inst) { return !inst->HasUses(); });
}
bool HostLocInfo::ContainsValue(const IR::Inst* inst) const {
return std::find(values.begin(), values.end(), inst) != values.end();
}
void HostLocInfo::ReadLock() {
ASSERT(!is_scratch);
is_being_used = true;
}
void HostLocInfo::WriteLock() {
ASSERT(!is_being_used);
is_being_used = true;
is_scratch = true;
}
void HostLocInfo::AddValue(IR::Inst* inst) {
values.push_back(inst);
}
void HostLocInfo::EndOfAllocScope() {
const auto to_erase = std::remove_if(values.begin(), values.end(), [](const auto& inst) { return !inst->HasUses(); });
values.erase(to_erase, values.end());
is_being_used = false;
is_scratch = false;
}
IR::Type Argument::GetType() const {
return value.GetType();
}
bool Argument::IsImmediate() const {
return value.IsImmediate();
}
bool Argument::GetImmediateU1() const {
return value.GetU1();
}

View file

@ -26,40 +26,18 @@ class RegAlloc;
struct HostLocInfo {
public:
bool IsLocked() const {
return is_being_used;
}
bool IsEmpty() const {
return !is_being_used && values.empty();
}
bool IsLastUse() const {
return !is_being_used && std::all_of(values.begin(), values.end(), [](const auto& inst) { return !inst->HasUses(); });
}
bool IsLocked() const;
bool IsEmpty() const;
bool IsLastUse() const;
bool ContainsValue(const IR::Inst* inst) const {
return std::find(values.begin(), values.end(), inst) != values.end();
}
bool ContainsValue(const IR::Inst* inst) const;
void ReadLock() {
ASSERT(!is_scratch);
is_being_used = true;
}
void WriteLock() {
ASSERT(!is_being_used);
is_being_used = true;
is_scratch = true;
}
void AddValue(IR::Inst* inst) {
values.push_back(inst);
}
void ReadLock();
void WriteLock();
void EndOfAllocScope() {
const auto to_erase = std::remove_if(values.begin(), values.end(), [](const auto& inst){ return !inst->HasUses(); });
values.erase(to_erase, values.end());
void AddValue(IR::Inst* inst);
is_being_used = false;
is_scratch = false;
}
void EndOfAllocScope();
private:
std::vector<IR::Inst*> values;
@ -69,12 +47,8 @@ private:
struct Argument {
public:
IR::Type GetType() const {
return value.GetType();
}
bool IsImmediate() const {
return value.IsImmediate();
}
IR::Type GetType() const;
bool IsImmediate() const;
bool GetImmediateU1() const;
u8 GetImmediateU8() const;