#ifndef LLVM_CODEGEN_SCHEDULEDAGILP_H
#define LLVM_CODEGEN_SCHEDULEDAGILP_H
#include "llvm/Support/DataTypes.h"
#include <vector>
namespace llvm {
class raw_ostream;
class ScheduleDAGInstrs;
class SUnit;
struct ILPValue {
unsigned InstrCount;
unsigned Cycles;
ILPValue(): InstrCount(0), Cycles(0) {}
ILPValue(unsigned count, unsigned cycles):
InstrCount(count), Cycles(cycles) {}
bool isValid() const { return Cycles > 0; }
bool operator<(ILPValue RHS) const {
return (uint64_t)InstrCount * RHS.Cycles
< (uint64_t)Cycles * RHS.InstrCount;
}
bool operator>(ILPValue RHS) const {
return RHS < *this;
}
bool operator<=(ILPValue RHS) const {
return (uint64_t)InstrCount * RHS.Cycles
<= (uint64_t)Cycles * RHS.InstrCount;
}
bool operator>=(ILPValue RHS) const {
return RHS <= *this;
}
#if !defined(NDEBUG) || defined(LLVM_ENABLE_DUMP)
void print(raw_ostream &OS) const;
void dump() const;
#endif
};
class ScheduleDAGILP {
bool IsBottomUp;
std::vector<ILPValue> ILPValues;
public:
ScheduleDAGILP(bool IsBU): IsBottomUp(IsBU) {}
void resize(unsigned NumSUnits);
void computeILP(const SUnit *Root);
ILPValue getILP(const SUnit *SU);
};
raw_ostream &operator<<(raw_ostream &OS, const ILPValue &Val);
}
#endif