forked from OSchip/llvm-project
[CostModel] Templatize EntryCost::Cost to allow custom cost metrics
We currently use an unsigned value for our CostTblEntry and TypeConversionCostTblEntry cost tables which is limiting depending on how the target wishes to handle various CostKinds etc. For instance, targets might wish to store separate instruction count, latency or throughput values etc. On D46276 we have been investigating storing a code snippet to improve latency/throughput cost calculations. There is a slight problem in that template argument deduction was struggling to match the now templatized Costs[] tables in a ArrayRef constructor - I've added helper wrappers for CostTableLookup/ConvertCostTableLookup which avoids us having to update all existing calls with a template hint. Differential Revision: https://reviews.llvm.org/D106351
This commit is contained in:
parent
d62bbbebbf
commit
4ffc3c3726
|
@ -21,16 +21,19 @@
|
||||||
namespace llvm {
|
namespace llvm {
|
||||||
|
|
||||||
/// Cost Table Entry
|
/// Cost Table Entry
|
||||||
struct CostTblEntry {
|
template <typename CostType>
|
||||||
|
struct CostTblEntryT {
|
||||||
int ISD;
|
int ISD;
|
||||||
MVT::SimpleValueType Type;
|
MVT::SimpleValueType Type;
|
||||||
unsigned Cost;
|
CostType Cost;
|
||||||
};
|
};
|
||||||
|
using CostTblEntry = CostTblEntryT<unsigned>;
|
||||||
|
|
||||||
/// Find in cost table, TypeTy must be comparable to CompareTy by ==
|
/// Find in cost table.
|
||||||
inline const CostTblEntry *CostTableLookup(ArrayRef<CostTblEntry> Tbl,
|
template <class CostType>
|
||||||
int ISD, MVT Ty) {
|
inline const CostTblEntryT<CostType> *
|
||||||
auto I = find_if(Tbl, [=](const CostTblEntry &Entry) {
|
CostTableLookup(ArrayRef<CostTblEntryT<CostType>> Tbl, int ISD, MVT Ty) {
|
||||||
|
auto I = find_if(Tbl, [=](const CostTblEntryT<CostType> &Entry) {
|
||||||
return ISD == Entry.ISD && Ty == Entry.Type;
|
return ISD == Entry.ISD && Ty == Entry.Type;
|
||||||
});
|
});
|
||||||
if (I != Tbl.end())
|
if (I != Tbl.end())
|
||||||
|
@ -40,20 +43,30 @@ inline const CostTblEntry *CostTableLookup(ArrayRef<CostTblEntry> Tbl,
|
||||||
return nullptr;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
template <size_t N, class CostType>
|
||||||
|
inline const CostTblEntryT<CostType> *
|
||||||
|
CostTableLookup(const CostTblEntryT<CostType> (&Table)[N], int ISD, MVT Ty) {
|
||||||
|
// Wrapper to fix template argument deduction failures.
|
||||||
|
return CostTableLookup<CostType>(makeArrayRef(Table), ISD, Ty);
|
||||||
|
}
|
||||||
|
|
||||||
/// Type Conversion Cost Table
|
/// Type Conversion Cost Table
|
||||||
struct TypeConversionCostTblEntry {
|
template <typename CostType>
|
||||||
|
struct TypeConversionCostTblEntryT {
|
||||||
int ISD;
|
int ISD;
|
||||||
MVT::SimpleValueType Dst;
|
MVT::SimpleValueType Dst;
|
||||||
MVT::SimpleValueType Src;
|
MVT::SimpleValueType Src;
|
||||||
unsigned Cost;
|
CostType Cost;
|
||||||
};
|
};
|
||||||
|
using TypeConversionCostTblEntry = TypeConversionCostTblEntryT<unsigned>;
|
||||||
|
|
||||||
/// Find in type conversion cost table, TypeTy must be comparable to CompareTy
|
/// Find in type conversion cost table.
|
||||||
/// by ==
|
template <class CostType>
|
||||||
inline const TypeConversionCostTblEntry *
|
inline const TypeConversionCostTblEntryT<CostType> *
|
||||||
ConvertCostTableLookup(ArrayRef<TypeConversionCostTblEntry> Tbl,
|
ConvertCostTableLookup(ArrayRef<TypeConversionCostTblEntryT<CostType>> Tbl,
|
||||||
int ISD, MVT Dst, MVT Src) {
|
int ISD, MVT Dst, MVT Src) {
|
||||||
auto I = find_if(Tbl, [=](const TypeConversionCostTblEntry &Entry) {
|
auto I =
|
||||||
|
find_if(Tbl, [=](const TypeConversionCostTblEntryT<CostType> &Entry) {
|
||||||
return ISD == Entry.ISD && Src == Entry.Src && Dst == Entry.Dst;
|
return ISD == Entry.ISD && Src == Entry.Src && Dst == Entry.Dst;
|
||||||
});
|
});
|
||||||
if (I != Tbl.end())
|
if (I != Tbl.end())
|
||||||
|
@ -63,6 +76,14 @@ ConvertCostTableLookup(ArrayRef<TypeConversionCostTblEntry> Tbl,
|
||||||
return nullptr;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
template <size_t N, class CostType>
|
||||||
|
inline const TypeConversionCostTblEntryT<CostType> *
|
||||||
|
ConvertCostTableLookup(const TypeConversionCostTblEntryT<CostType> (&Table)[N],
|
||||||
|
int ISD, MVT Dst, MVT Src) {
|
||||||
|
// Wrapper to fix template argument deduction failures.
|
||||||
|
return ConvertCostTableLookup<CostType>(makeArrayRef(Table), ISD, Dst, Src);
|
||||||
|
}
|
||||||
|
|
||||||
} // namespace llvm
|
} // namespace llvm
|
||||||
|
|
||||||
#endif /* LLVM_CODEGEN_COSTTABLE_H_ */
|
#endif /* LLVM_CODEGEN_COSTTABLE_H_ */
|
||||||
|
|
Loading…
Reference in New Issue