DxilCompType.cpp 7.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293
  1. ///////////////////////////////////////////////////////////////////////////////
  2. // //
  3. // DxilCompType.cpp //
  4. // Copyright (C) Microsoft Corporation. All rights reserved. //
  5. // This file is distributed under the University of Illinois Open Source //
  6. // License. See LICENSE.TXT for details. //
  7. // //
  8. ///////////////////////////////////////////////////////////////////////////////
  9. #include "dxc/HLSL/DxilCompType.h"
  10. #include "dxc/Support/Global.h"
  11. #include "llvm/IR/LLVMContext.h"
  12. #include "llvm/IR/Type.h"
  13. #include "llvm/IR/DerivedTypes.h"
  14. using namespace llvm;
  15. namespace hlsl {
  16. //------------------------------------------------------------------------------
  17. //
  18. // CompType class methods.
  19. //
  20. CompType::CompType()
  21. : m_Kind(Kind::Invalid) {
  22. }
  23. CompType::CompType(Kind K)
  24. : m_Kind(K) {
  25. DXASSERT(m_Kind >= Kind::Invalid && m_Kind < Kind::LastEntry, "otherwise the caller passed out-of-range value");
  26. }
  27. CompType::CompType(unsigned int K) : CompType((Kind)K) {}
  28. bool CompType::operator==(const CompType &o) const {
  29. return m_Kind == o.m_Kind;
  30. }
  31. CompType::Kind CompType::GetKind() const {
  32. return m_Kind;
  33. }
  34. CompType CompType::getInvalid() {
  35. return CompType();
  36. }
  37. CompType CompType::getF16() {
  38. return CompType(Kind::F16);
  39. }
  40. CompType CompType::getF32() {
  41. return CompType(Kind::F32);
  42. }
  43. CompType CompType::getF64() {
  44. return CompType(Kind::F64);
  45. }
  46. CompType CompType::getI16() {
  47. return CompType(Kind::I16);
  48. }
  49. CompType CompType::getI32() {
  50. return CompType(Kind::I32);
  51. }
  52. CompType CompType::getI64() {
  53. return CompType(Kind::I64);
  54. }
  55. CompType CompType::getU16() {
  56. return CompType(Kind::U16);
  57. }
  58. CompType CompType::getU32() {
  59. return CompType(Kind::U32);
  60. }
  61. CompType CompType::getU64() {
  62. return CompType(Kind::U64);
  63. }
  64. CompType CompType::getI1() {
  65. return CompType(Kind::I1);
  66. }
  67. CompType CompType::getSNormF16() {
  68. return CompType(Kind::SNormF16);
  69. }
  70. CompType CompType::getUNormF16() {
  71. return CompType(Kind::UNormF16);
  72. }
  73. CompType CompType::getSNormF32() {
  74. return CompType(Kind::SNormF32);
  75. }
  76. CompType CompType::getUNormF32() {
  77. return CompType(Kind::UNormF32);
  78. }
  79. CompType CompType::getSNormF64() {
  80. return CompType(Kind::SNormF64);
  81. }
  82. CompType CompType::getUNormF64() {
  83. return CompType(Kind::UNormF64);
  84. }
  85. bool CompType::IsInvalid() const {
  86. return m_Kind == Kind::Invalid;
  87. }
  88. bool CompType::IsFloatTy() const {
  89. return m_Kind == Kind::F16 || m_Kind == Kind::F32 || m_Kind == Kind::F64;
  90. }
  91. bool CompType::IsIntTy() const {
  92. return IsSIntTy() || IsUIntTy();
  93. }
  94. bool CompType::IsSIntTy() const {
  95. return m_Kind == Kind::I16 || m_Kind == Kind::I32 || m_Kind == Kind::I64;
  96. }
  97. bool CompType::IsUIntTy() const {
  98. return m_Kind == Kind::U16 || m_Kind == Kind::U32 || m_Kind == Kind::U64;
  99. }
  100. bool CompType::IsBoolTy() const {
  101. return m_Kind == Kind::I1;
  102. }
  103. bool CompType::IsSNorm() const {
  104. return m_Kind == Kind::SNormF16 || m_Kind == Kind::SNormF32 || m_Kind == Kind::SNormF64;
  105. }
  106. bool CompType::IsUNorm() const {
  107. return m_Kind == Kind::UNormF16 || m_Kind == Kind::UNormF32 || m_Kind == Kind::UNormF64;
  108. }
  109. bool CompType::Is64Bit() const {
  110. switch (m_Kind) {
  111. case DXIL::ComponentType::F64:
  112. case DXIL::ComponentType::SNormF64:
  113. case DXIL::ComponentType::UNormF64:
  114. case DXIL::ComponentType::I64:
  115. case DXIL::ComponentType::U64:
  116. return true;
  117. default:
  118. return false;
  119. }
  120. }
  121. CompType CompType::GetBaseCompType() const {
  122. switch (m_Kind) {
  123. case Kind::I1: return CompType(Kind::I1);
  124. case Kind::I16: __fallthrough;
  125. case Kind::I32: return CompType(Kind::I32);
  126. case Kind::I64: return CompType(Kind::I64);
  127. case Kind::U16: __fallthrough;
  128. case Kind::U32: return CompType(Kind::U32);
  129. case Kind::U64: return CompType(Kind::U64);
  130. case Kind::SNormF16: __fallthrough;
  131. case Kind::UNormF16: __fallthrough;
  132. case Kind::F16: __fallthrough;
  133. case Kind::SNormF32: __fallthrough;
  134. case Kind::UNormF32: __fallthrough;
  135. case Kind::F32: return CompType(Kind::F32);
  136. case Kind::SNormF64: __fallthrough;
  137. case Kind::UNormF64: __fallthrough;
  138. case Kind::F64: return CompType(Kind::F64);
  139. }
  140. DXASSERT(false, "invalid type kind");
  141. return CompType();
  142. }
  143. bool CompType::HasMinPrec() const {
  144. switch (m_Kind) {
  145. case Kind::I16:
  146. case Kind::U16:
  147. case Kind::F16:
  148. case Kind::SNormF16:
  149. case Kind::UNormF16:
  150. return true;
  151. case Kind::I1:
  152. case Kind::I32:
  153. case Kind::U32:
  154. case Kind::I64:
  155. case Kind::U64:
  156. case Kind::F32:
  157. case Kind::F64:
  158. case Kind::SNormF32:
  159. case Kind::UNormF32:
  160. case Kind::SNormF64:
  161. case Kind::UNormF64:
  162. break;
  163. default:
  164. DXASSERT(false, "invalid comp type");
  165. }
  166. return false;
  167. }
  168. Type *CompType::GetLLVMType(LLVMContext &Ctx) const {
  169. switch (m_Kind) {
  170. case Kind::I1: return (Type*)Type::getInt1Ty(Ctx);
  171. case Kind::I16:
  172. case Kind::U16: return (Type*)Type::getInt16Ty(Ctx);
  173. case Kind::I32:
  174. case Kind::U32: return (Type*)Type::getInt32Ty(Ctx);
  175. case Kind::I64:
  176. case Kind::U64: return (Type*)Type::getInt64Ty(Ctx);
  177. case Kind::SNormF16:
  178. case Kind::UNormF16:
  179. case Kind::F16: return Type::getHalfTy(Ctx);
  180. case Kind::SNormF32:
  181. case Kind::UNormF32:
  182. case Kind::F32: return Type::getFloatTy(Ctx);
  183. case Kind::SNormF64:
  184. case Kind::UNormF64:
  185. case Kind::F64: return Type::getDoubleTy(Ctx);
  186. }
  187. DXASSERT(false, "invalid type kind");
  188. return nullptr;
  189. }
  190. PointerType *CompType::GetLLVMPtrType(LLVMContext &Ctx, const unsigned AddrSpace) const {
  191. switch (m_Kind) {
  192. case Kind::I1: return Type::getInt1PtrTy (Ctx, AddrSpace);
  193. case Kind::I16:
  194. case Kind::U16: return Type::getInt16PtrTy (Ctx, AddrSpace);
  195. case Kind::I32:
  196. case Kind::U32: return Type::getInt32PtrTy (Ctx, AddrSpace);
  197. case Kind::I64:
  198. case Kind::U64: return Type::getInt64PtrTy (Ctx, AddrSpace);
  199. case Kind::SNormF16:
  200. case Kind::UNormF16:
  201. case Kind::F16: return Type::getHalfPtrTy (Ctx, AddrSpace);
  202. case Kind::SNormF32:
  203. case Kind::UNormF32:
  204. case Kind::F32: return Type::getFloatPtrTy (Ctx, AddrSpace);
  205. case Kind::SNormF64:
  206. case Kind::UNormF64:
  207. case Kind::F64: return Type::getDoublePtrTy(Ctx, AddrSpace);
  208. }
  209. DXASSERT(false, "invalid type kind");
  210. return nullptr;
  211. }
  212. Type *CompType::GetLLVMBaseType(llvm::LLVMContext &Ctx) const {
  213. return GetBaseCompType().GetLLVMType(Ctx);
  214. }
  215. CompType CompType::GetCompType(Type *type) {
  216. LLVMContext &Ctx = type->getContext();
  217. if (type == Type::getInt1Ty(Ctx)) return CompType(Kind::I1);
  218. if (type == Type::getInt16Ty(Ctx)) return CompType(Kind::I16);
  219. if (type == Type::getInt32Ty(Ctx)) return CompType(Kind::I32);
  220. if (type == Type::getInt64Ty(Ctx)) return CompType(Kind::I64);
  221. if (type == Type::getHalfTy(Ctx)) return CompType(Kind::F16);
  222. if (type == Type::getFloatTy(Ctx)) return CompType(Kind::F32);
  223. if (type == Type::getDoubleTy(Ctx)) return CompType(Kind::F64);
  224. DXASSERT(false, "invalid type kind");
  225. return CompType();
  226. }
  227. static const char *s_TypeKindNames[(unsigned)CompType::Kind::LastEntry] = {
  228. "invalid",
  229. "i1", "i16", "u16", "i32", "u32", "i64", "u64",
  230. "f16", "f32", "f64",
  231. "snorm_f16", "unorm_f16", "snorm_f32", "unorm_f32", "snorm_f64", "unorm_f64",
  232. };
  233. const char *CompType::GetName() const {
  234. return s_TypeKindNames[(unsigned)m_Kind];
  235. }
  236. static const char *s_TypeKindHLSLNames[(unsigned)CompType::Kind::LastEntry] = {
  237. "unknown",
  238. "bool", "min16i", "min16ui", "int", "uint", "int64_t", "uint64_t",
  239. "min16f", "float", "double",
  240. "snorm_min16f", "unorm_min16f", "snorm_float", "unorm_float", "snorm_double", "unorm_double",
  241. };
  242. const char *CompType::GetHLSLName() const {
  243. return s_TypeKindHLSLNames[(unsigned)m_Kind];
  244. }
  245. } // namespace hlsl