DxilCompType.cpp 9.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360
  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/DXIL/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. uint8_t CompType::GetSizeInBits() const {
  35. switch (m_Kind) {
  36. case Kind::Invalid:
  37. return 0;
  38. case Kind::I1:
  39. return 1;
  40. case Kind::SNormF16:
  41. case Kind::UNormF16:
  42. case Kind::I16:
  43. case Kind::F16:
  44. case Kind::U16:
  45. return 16;
  46. case Kind::SNormF32:
  47. case Kind::UNormF32:
  48. case Kind::I32:
  49. case Kind::U32:
  50. case Kind::F32:
  51. case Kind::PackedS8x32:
  52. case Kind::PackedU8x32:
  53. return 32;
  54. case Kind::I64:
  55. case Kind::U64:
  56. case Kind::SNormF64:
  57. case Kind::UNormF64:
  58. case Kind::F64:
  59. return 64;
  60. default:
  61. DXASSERT(false, "invalid type kind");
  62. }
  63. return 0;
  64. }
  65. CompType CompType::getInvalid() {
  66. return CompType();
  67. }
  68. CompType CompType::getF16() {
  69. return CompType(Kind::F16);
  70. }
  71. CompType CompType::getF32() {
  72. return CompType(Kind::F32);
  73. }
  74. CompType CompType::getF64() {
  75. return CompType(Kind::F64);
  76. }
  77. CompType CompType::getI16() {
  78. return CompType(Kind::I16);
  79. }
  80. CompType CompType::getI32() {
  81. return CompType(Kind::I32);
  82. }
  83. CompType CompType::getI64() {
  84. return CompType(Kind::I64);
  85. }
  86. CompType CompType::getU16() {
  87. return CompType(Kind::U16);
  88. }
  89. CompType CompType::getU32() {
  90. return CompType(Kind::U32);
  91. }
  92. CompType CompType::getU64() {
  93. return CompType(Kind::U64);
  94. }
  95. CompType CompType::getI1() {
  96. return CompType(Kind::I1);
  97. }
  98. CompType CompType::getSNormF16() {
  99. return CompType(Kind::SNormF16);
  100. }
  101. CompType CompType::getUNormF16() {
  102. return CompType(Kind::UNormF16);
  103. }
  104. CompType CompType::getSNormF32() {
  105. return CompType(Kind::SNormF32);
  106. }
  107. CompType CompType::getUNormF32() {
  108. return CompType(Kind::UNormF32);
  109. }
  110. CompType CompType::getSNormF64() {
  111. return CompType(Kind::SNormF64);
  112. }
  113. CompType CompType::getUNormF64() {
  114. return CompType(Kind::UNormF64);
  115. }
  116. bool CompType::IsInvalid() const {
  117. return m_Kind == Kind::Invalid;
  118. }
  119. bool CompType::IsFloatTy() const {
  120. return m_Kind == Kind::F16 || m_Kind == Kind::F32 || m_Kind == Kind::F64;
  121. }
  122. bool CompType::IsIntTy() const {
  123. return IsSIntTy() || IsUIntTy();
  124. }
  125. bool CompType::IsSIntTy() const {
  126. return m_Kind == Kind::I16 || m_Kind == Kind::I32 || m_Kind == Kind::I64;
  127. }
  128. bool CompType::IsUIntTy() const {
  129. return m_Kind == Kind::U16 || m_Kind == Kind::U32 || m_Kind == Kind::U64 ||
  130. m_Kind == Kind::PackedS8x32 || m_Kind == Kind::PackedU8x32;
  131. }
  132. bool CompType::IsBoolTy() const {
  133. return m_Kind == Kind::I1;
  134. }
  135. bool CompType::IsSNorm() const {
  136. return m_Kind == Kind::SNormF16 || m_Kind == Kind::SNormF32 || m_Kind == Kind::SNormF64;
  137. }
  138. bool CompType::IsUNorm() const {
  139. return m_Kind == Kind::UNormF16 || m_Kind == Kind::UNormF32 || m_Kind == Kind::UNormF64;
  140. }
  141. bool CompType::Is64Bit() const {
  142. switch (m_Kind) {
  143. case DXIL::ComponentType::F64:
  144. case DXIL::ComponentType::SNormF64:
  145. case DXIL::ComponentType::UNormF64:
  146. case DXIL::ComponentType::I64:
  147. case DXIL::ComponentType::U64:
  148. return true;
  149. default:
  150. return false;
  151. }
  152. }
  153. bool CompType::Is16Bit() const {
  154. switch (m_Kind) {
  155. case DXIL::ComponentType::F16:
  156. case DXIL::ComponentType::I16:
  157. case DXIL::ComponentType::SNormF16:
  158. case DXIL::ComponentType::UNormF16:
  159. case DXIL::ComponentType::U16:
  160. return true;
  161. default:
  162. return false;
  163. }
  164. }
  165. CompType CompType::GetBaseCompType() const {
  166. switch (m_Kind) {
  167. case Kind::I1: return CompType(Kind::I1);
  168. case Kind::I16: __fallthrough;
  169. case Kind::PackedS8x32: __fallthrough;
  170. case Kind::PackedU8x32: __fallthrough;
  171. case Kind::I32: return CompType(Kind::I32);
  172. case Kind::I64: return CompType(Kind::I64);
  173. case Kind::U16: __fallthrough;
  174. case Kind::U32: return CompType(Kind::U32);
  175. case Kind::U64: return CompType(Kind::U64);
  176. case Kind::SNormF16: __fallthrough;
  177. case Kind::UNormF16: __fallthrough;
  178. case Kind::F16: __fallthrough;
  179. case Kind::SNormF32: __fallthrough;
  180. case Kind::UNormF32: __fallthrough;
  181. case Kind::F32: return CompType(Kind::F32);
  182. case Kind::SNormF64: __fallthrough;
  183. case Kind::UNormF64: __fallthrough;
  184. case Kind::F64: return CompType(Kind::F64);
  185. default:
  186. DXASSERT(false, "invalid type kind");
  187. }
  188. return CompType();
  189. }
  190. bool CompType::HasMinPrec() const {
  191. switch (m_Kind) {
  192. case Kind::I16:
  193. case Kind::U16:
  194. case Kind::F16:
  195. case Kind::SNormF16:
  196. case Kind::UNormF16:
  197. return true;
  198. case Kind::I1:
  199. case Kind::PackedS8x32:
  200. case Kind::PackedU8x32:
  201. case Kind::I32:
  202. case Kind::U32:
  203. case Kind::I64:
  204. case Kind::U64:
  205. case Kind::F32:
  206. case Kind::F64:
  207. case Kind::SNormF32:
  208. case Kind::UNormF32:
  209. case Kind::SNormF64:
  210. case Kind::UNormF64:
  211. break;
  212. default:
  213. DXASSERT(false, "invalid comp type");
  214. }
  215. return false;
  216. }
  217. Type *CompType::GetLLVMType(LLVMContext &Ctx) const {
  218. switch (m_Kind) {
  219. case Kind::I1: return (Type*)Type::getInt1Ty(Ctx);
  220. case Kind::I16:
  221. case Kind::U16: return (Type*)Type::getInt16Ty(Ctx);
  222. case Kind::PackedS8x32:
  223. case Kind::PackedU8x32:
  224. case Kind::I32:
  225. case Kind::U32: return (Type*)Type::getInt32Ty(Ctx);
  226. case Kind::I64:
  227. case Kind::U64: return (Type*)Type::getInt64Ty(Ctx);
  228. case Kind::SNormF16:
  229. case Kind::UNormF16:
  230. case Kind::F16: return Type::getHalfTy(Ctx);
  231. case Kind::SNormF32:
  232. case Kind::UNormF32:
  233. case Kind::F32: return Type::getFloatTy(Ctx);
  234. case Kind::SNormF64:
  235. case Kind::UNormF64:
  236. case Kind::F64: return Type::getDoubleTy(Ctx);
  237. default:
  238. DXASSERT(false, "invalid type kind");
  239. }
  240. return nullptr;
  241. }
  242. PointerType *CompType::GetLLVMPtrType(LLVMContext &Ctx, const unsigned AddrSpace) const {
  243. switch (m_Kind) {
  244. case Kind::I1: return Type::getInt1PtrTy (Ctx, AddrSpace);
  245. case Kind::I16:
  246. case Kind::U16: return Type::getInt16PtrTy (Ctx, AddrSpace);
  247. case Kind::PackedS8x32:
  248. case Kind::PackedU8x32:
  249. case Kind::I32:
  250. case Kind::U32: return Type::getInt32PtrTy (Ctx, AddrSpace);
  251. case Kind::I64:
  252. case Kind::U64: return Type::getInt64PtrTy (Ctx, AddrSpace);
  253. case Kind::SNormF16:
  254. case Kind::UNormF16:
  255. case Kind::F16: return Type::getHalfPtrTy (Ctx, AddrSpace);
  256. case Kind::SNormF32:
  257. case Kind::UNormF32:
  258. case Kind::F32: return Type::getFloatPtrTy (Ctx, AddrSpace);
  259. case Kind::SNormF64:
  260. case Kind::UNormF64:
  261. case Kind::F64: return Type::getDoublePtrTy(Ctx, AddrSpace);
  262. default:
  263. DXASSERT(false, "invalid type kind");
  264. }
  265. return nullptr;
  266. }
  267. Type *CompType::GetLLVMBaseType(llvm::LLVMContext &Ctx) const {
  268. return GetBaseCompType().GetLLVMType(Ctx);
  269. }
  270. CompType CompType::GetCompType(Type *type) {
  271. LLVMContext &Ctx = type->getContext();
  272. if (type == Type::getInt1Ty(Ctx)) return CompType(Kind::I1);
  273. if (type == Type::getInt16Ty(Ctx)) return CompType(Kind::I16);
  274. if (type == Type::getInt32Ty(Ctx)) return CompType(Kind::I32);
  275. if (type == Type::getInt64Ty(Ctx)) return CompType(Kind::I64);
  276. if (type == Type::getHalfTy(Ctx)) return CompType(Kind::F16);
  277. if (type == Type::getFloatTy(Ctx)) return CompType(Kind::F32);
  278. if (type == Type::getDoubleTy(Ctx)) return CompType(Kind::F64);
  279. DXASSERT(false, "invalid type kind");
  280. return CompType();
  281. }
  282. static const char *s_TypeKindNames[(unsigned)CompType::Kind::LastEntry] = {
  283. "invalid",
  284. "i1", "i16", "u16", "i32", "u32", "i64", "u64",
  285. "f16", "f32", "f64",
  286. "snorm_f16", "unorm_f16", "snorm_f32", "unorm_f32", "snorm_f64", "unorm_f64",
  287. "p32i8", "p32u8",
  288. };
  289. const char *CompType::GetName() const {
  290. return s_TypeKindNames[(unsigned)m_Kind];
  291. }
  292. static const char *s_TypeKindHLSLNames[(unsigned)CompType::Kind::LastEntry] = {
  293. "unknown",
  294. "bool", "int16_t", "uint16_t", "int", "uint", "int64_t", "uint64_t",
  295. "half", "float", "double",
  296. "snorm_half", "unorm_half", "snorm_float", "unorm_float", "snorm_double", "unorm_double",
  297. "int8_t_packed", "uint8_t_packed",
  298. };
  299. static const char *s_TypeKindHLSLNamesMinPrecision[(unsigned)CompType::Kind::LastEntry] = {
  300. "unknown",
  301. "bool", "min16i", "min16ui", "int", "uint", "int64_t", "uint64_t",
  302. "min16float", "float", "double",
  303. "snorm_min16f", "unorm_min16f", "snorm_float", "unorm_float", "snorm_double", "unorm_double",
  304. "int8_t_packed", "uint8_t_packed",
  305. };
  306. const char *CompType::GetHLSLName(bool MinPrecision) const {
  307. return MinPrecision ? s_TypeKindHLSLNamesMinPrecision[(unsigned)m_Kind] : s_TypeKindHLSLNames[(unsigned)m_Kind];
  308. }
  309. } // namespace hlsl