21#include <system_error>
27static_assert((uint64_t)dxbc::FeatureFlags::NextUnusedBit <= 1ull << 63,
28 "Shader flag bits exceed enum size.");
31#define SHADER_FEATURE_FLAG(Num, DxilModuleNum, Val, Str) \
32 Val = (FlagData & (uint64_t)dxbc::FeatureFlags::Val) > 0;
33#include "llvm/BinaryFormat/DXContainerConstants.def"
46 auto Table = *TableOrErr;
56 for (
const auto &R : Table.Ranges) {
59 R.OffsetInDescriptorsFromTableStart;
65 "Invalid value for descriptor range type");
67 if constexpr (std::is_same_v<T, dxbc::RTS0::v2::DescriptorRange>) {
69#define DESCRIPTOR_RANGE_FLAG(Num, Enum, Flag) \
71 (R.Flags & llvm::to_underlying(dxbc::DescriptorRangeFlags::Enum)) != 0;
72#include "llvm/BinaryFormat/DXContainerConstants.def"
74 TableYaml.
Ranges.push_back(NewR);
98 "Invalid value for parameter type");
101 Header.Offset = PH.ParameterOffset;
105 "Invalid value for shader visibility");
110 Data.getParameter(PH);
121 auto Constants = *ConstantsOrErr;
130 }
else if (
auto *RDV =
136 auto Descriptor = *DescriptorOrErr;
145#define ROOT_DESCRIPTOR_FLAG(Num, Enum, Flag) \
146 YamlDescriptor.Enum = \
147 (Descriptor.Flags & \
148 llvm::to_underlying(dxbc::RootDescriptorFlags::Enum)) > 0;
149#include "llvm/BinaryFormat/DXContainerConstants.def"
151 }
else if (
auto *DTV =
155 Header, RootSigDesc, DTV))
159 Header, RootSigDesc, DTV))
166 for (
const auto &S :
Data.samplers()) {
169 "Invalid value for static sampler filter");
173 "Invalid value for static sampler AddressU");
177 "Invalid value for static sampler AddressV");
181 "Invalid value for static sampler AddressW");
185 std::errc::invalid_argument,
186 "Invalid value for static sampler ComparisonFunc");
190 "Invalid value for static sampler BorderColor");
194 std::errc::invalid_argument,
195 "Invalid value for static sampler ShaderVisibility");
213#define STATIC_SAMPLER_FLAG(Num, Enum, Flag) \
214 NewS.Enum = (S.Flags & llvm::to_underlying(dxbc::StaticSamplerFlags::Enum));
215#include "llvm/BinaryFormat/DXContainerConstants.def"
220#define ROOT_SIGNATURE_FLAG(Num, Val) \
221 RootSigDesc.Val = (Flags & llvm::to_underlying(dxbc::RootFlags::Val)) > 0;
222#include "llvm/BinaryFormat/DXContainerConstants.def"
228#define ROOT_DESCRIPTOR_FLAG(Num, Enum, Flag) \
230 Flags |= (uint32_t)dxbc::RootDescriptorFlags::Enum;
231#include "llvm/BinaryFormat/DXContainerConstants.def"
237#define ROOT_SIGNATURE_FLAG(Num, Val) \
239 Flag |= (uint32_t)dxbc::RootFlags::Val;
240#include "llvm/BinaryFormat/DXContainerConstants.def"
246#define DESCRIPTOR_RANGE_FLAG(Num, Enum, Flag) \
248 Flags |= (uint32_t)dxbc::DescriptorRangeFlags::Enum;
249#include "llvm/BinaryFormat/DXContainerConstants.def"
255#define STATIC_SAMPLER_FLAG(Num, Enum, Flag) \
257 Flags |= (uint32_t)dxbc::StaticSamplerFlags::Enum;
258#include "llvm/BinaryFormat/DXContainerConstants.def"
264#define SHADER_FEATURE_FLAG(Num, DxilModuleNum, Val, Str) \
266 Flag |= (uint64_t)dxbc::FeatureFlags::Val;
267#include "llvm/BinaryFormat/DXContainerConstants.def"
288 assert(Stage < std::numeric_limits<uint8_t>::max() &&
289 "Stage should be a very small number");
312 P->EntryNameOffset)) {
319void MappingTraits<DXContainerYAML::VersionTuple>::mapping(
321 IO.mapRequired(
"Major",
Version.Major);
322 IO.mapRequired(
"Minor",
Version.Minor);
325void MappingTraits<DXContainerYAML::FileHeader>::mapping(
327 IO.mapRequired(
"Hash", Header.Hash);
328 IO.mapRequired(
"Version", Header.Version);
329 IO.mapOptional(
"FileSize", Header.FileSize);
330 IO.mapRequired(
"PartCount", Header.PartCount);
331 IO.mapOptional(
"PartOffsets", Header.PartOffsets);
334void MappingTraits<DXContainerYAML::DXILProgram>::mapping(
335 IO &IO, DXContainerYAML::DXILProgram &Program) {
336 IO.mapRequired(
"MajorVersion", Program.MajorVersion);
337 IO.mapRequired(
"MinorVersion", Program.MinorVersion);
338 IO.mapRequired(
"ShaderKind", Program.ShaderKind);
339 IO.mapOptional(
"Size", Program.Size);
340 IO.mapRequired(
"DXILMajorVersion", Program.DXILMajorVersion);
341 IO.mapRequired(
"DXILMinorVersion", Program.DXILMinorVersion);
342 IO.mapOptional(
"DXILSize", Program.DXILSize);
343 IO.mapOptional(
"DXIL", Program.DXIL);
346void MappingTraits<DXContainerYAML::ShaderFeatureFlags>::mapping(
347 IO &IO, DXContainerYAML::ShaderFeatureFlags &Flags) {
348#define SHADER_FEATURE_FLAG(Num, DxilModuleNum, Val, Str) \
349 IO.mapRequired(#Val, Flags.Val);
350#include "llvm/BinaryFormat/DXContainerConstants.def"
353void MappingTraits<DXContainerYAML::ShaderHash>::mapping(
354 IO &IO, DXContainerYAML::ShaderHash &Hash) {
355 IO.mapRequired(
"IncludesSource", Hash.IncludesSource);
356 IO.mapRequired(
"Digest", Hash.Digest);
359void MappingTraits<DXContainerYAML::PSVInfo>::mapping(
360 IO &IO, DXContainerYAML::PSVInfo &PSV) {
361 IO.mapRequired(
"Version", PSV.Version);
364 void *OldContext = IO.getContext();
365 uint32_t
Version = PSV.Version;
366 IO.setContext(&Version);
373 IO.mapRequired(
"ShaderStage", PSV.Info.ShaderStage);
374 PSV.mapInfoForVersion(IO);
376 IO.mapRequired(
"ResourceStride", PSV.ResourceStride);
377 if (PSV.Version > 0) {
378 IO.mapOptional(
"RuntimeInfoSize", PSV.RuntimeInfoSize);
379 IO.mapOptional(
"StringTable", PSV.StringTable);
381 IO.mapRequired(
"Resources", PSV.Resources);
382 if (PSV.Version == 0)
384 IO.mapRequired(
"SigInputElements", PSV.SigInputElements);
385 IO.mapRequired(
"SigOutputElements", PSV.SigOutputElements);
386 IO.mapRequired(
"SigPatchOrPrimElements", PSV.SigPatchOrPrimElements);
388 Triple::EnvironmentType Stage = dxbc::getShaderStage(PSV.Info.ShaderStage);
389 if (PSV.Info.UsesViewID) {
390 MutableArrayRef<SmallVector<llvm::yaml::Hex32>> MutableOutMasks(
391 PSV.OutputVectorMasks);
392 IO.mapRequired(
"OutputVectorMasks", MutableOutMasks);
393 if (Stage == Triple::EnvironmentType::Hull)
394 IO.mapRequired(
"PatchOrPrimMasks", PSV.PatchOrPrimMasks);
396 MutableArrayRef<SmallVector<llvm::yaml::Hex32>> MutableIOMap(
398 IO.mapRequired(
"InputOutputMap", MutableIOMap);
400 if (Stage == Triple::EnvironmentType::Hull)
401 IO.mapRequired(
"InputPatchMap", PSV.InputPatchMap);
403 if (Stage == Triple::EnvironmentType::Domain)
404 IO.mapRequired(
"PatchOutputMap", PSV.PatchOutputMap);
407void MappingTraits<DXContainerYAML::SignatureParameter>::mapping(
408 IO &IO, DXContainerYAML::SignatureParameter &S) {
409 IO.mapRequired(
"Stream", S.Stream);
410 IO.mapRequired(
"Name", S.Name);
411 IO.mapRequired(
"Index", S.Index);
412 IO.mapRequired(
"SystemValue", S.SystemValue);
413 IO.mapRequired(
"CompType", S.CompType);
414 IO.mapRequired(
"Register", S.Register);
415 IO.mapRequired(
"Mask", S.Mask);
416 IO.mapRequired(
"ExclusiveMask", S.ExclusiveMask);
417 IO.mapRequired(
"MinPrecision", S.MinPrecision);
420void MappingTraits<DXContainerYAML::Signature>::mapping(
421 IO &IO, DXContainerYAML::Signature &S) {
422 IO.mapRequired(
"Parameters", S.Parameters);
425void MappingTraits<DXContainerYAML::RootSignatureYamlDesc>::mapping(
426 IO &IO, DXContainerYAML::RootSignatureYamlDesc &S) {
427 IO.mapRequired(
"Version", S.Version);
428 IO.mapRequired(
"NumRootParameters", S.NumRootParameters);
429 IO.mapOptional(
"RootParametersOffset", S.RootParametersOffset, std::nullopt);
430 IO.mapRequired(
"NumStaticSamplers", S.NumStaticSamplers);
431 IO.mapOptional(
"StaticSamplersOffset", S.StaticSamplersOffset, std::nullopt);
432 IO.mapRequired(
"Parameters", S.Parameters.Locations, S);
433 IO.mapOptional(
"Samplers", S.StaticSamplers);
434#define ROOT_SIGNATURE_FLAG(Num, Val) IO.mapOptional(#Val, S.Val, false);
435#include "llvm/BinaryFormat/DXContainerConstants.def"
438void MappingTraits<llvm::DXContainerYAML::DescriptorRangeYaml>::mapping(
439 IO &IO, llvm::DXContainerYAML::DescriptorRangeYaml &R) {
440 IO.mapRequired(
"RangeType",
R.RangeType);
442 if (IO.outputting()) {
443 if (
R.NumDescriptors == UINT_MAX) {
445 IO.mapRequired(
"NumDescriptors", NegOne);
447 IO.mapRequired(
"NumDescriptors",
R.NumDescriptors);
449 int32_t TmpNumDesc = 0;
450 IO.mapRequired(
"NumDescriptors", TmpNumDesc);
451 R.NumDescriptors =
static_cast<uint32_t
>(TmpNumDesc);
454 IO.mapRequired(
"BaseShaderRegister",
R.BaseShaderRegister);
455 IO.mapRequired(
"RegisterSpace",
R.RegisterSpace);
456 IO.mapRequired(
"OffsetInDescriptorsFromTableStart",
457 R.OffsetInDescriptorsFromTableStart);
458#define DESCRIPTOR_RANGE_FLAG(Num, Enum, Flag) \
459 IO.mapOptional(#Flag, R.Enum, false);
460#include "llvm/BinaryFormat/DXContainerConstants.def"
463void MappingTraits<llvm::DXContainerYAML::DescriptorTableYaml>::mapping(
464 IO &IO, llvm::DXContainerYAML::DescriptorTableYaml &
T) {
465 IO.mapRequired(
"NumRanges",
T.NumRanges);
466 IO.mapOptional(
"RangesOffset",
T.RangesOffset);
467 IO.mapRequired(
"Ranges",
T.Ranges);
470void MappingContextTraits<DXContainerYAML::RootParameterLocationYaml,
471 DXContainerYAML::RootSignatureYamlDesc>::
472 mapping(IO &IO, DXContainerYAML::RootParameterLocationYaml &L,
473 DXContainerYAML::RootSignatureYamlDesc &S) {
474 IO.mapRequired(
"ParameterType",
L.Header.Type);
475 IO.mapRequired(
"ShaderVisibility",
L.Header.Visibility);
477 switch (
L.Header.Type) {
478 case dxbc::RootParameterType::Constants32Bit: {
479 DXContainerYAML::RootConstantsYaml &
Constants =
480 S.Parameters.getOrInsertConstants(L);
481 IO.mapRequired(
"Constants", Constants);
484 case dxbc::RootParameterType::CBV:
485 case dxbc::RootParameterType::SRV:
486 case dxbc::RootParameterType::UAV: {
487 DXContainerYAML::RootDescriptorYaml &Descriptor =
488 S.Parameters.getOrInsertDescriptor(L);
489 IO.mapRequired(
"Descriptor", Descriptor);
492 case dxbc::RootParameterType::DescriptorTable: {
493 DXContainerYAML::DescriptorTableYaml &Table =
494 S.Parameters.getOrInsertTable(L);
495 IO.mapRequired(
"Table", Table);
501void MappingTraits<llvm::DXContainerYAML::RootConstantsYaml>::mapping(
502 IO &IO, llvm::DXContainerYAML::RootConstantsYaml &
C) {
503 IO.mapRequired(
"Num32BitValues",
C.Num32BitValues);
504 IO.mapRequired(
"RegisterSpace",
C.RegisterSpace);
505 IO.mapRequired(
"ShaderRegister",
C.ShaderRegister);
508void MappingTraits<llvm::DXContainerYAML::RootDescriptorYaml>::mapping(
509 IO &IO, llvm::DXContainerYAML::RootDescriptorYaml &
D) {
510 IO.mapRequired(
"RegisterSpace",
D.RegisterSpace);
511 IO.mapRequired(
"ShaderRegister",
D.ShaderRegister);
512#define ROOT_DESCRIPTOR_FLAG(Num, Enum, Flag) \
513 IO.mapOptional(#Flag, D.Enum, false);
514#include "llvm/BinaryFormat/DXContainerConstants.def"
517void MappingTraits<llvm::DXContainerYAML::StaticSamplerYamlDesc>::mapping(
518 IO &IO, llvm::DXContainerYAML::StaticSamplerYamlDesc &S) {
520 IO.mapOptional(
"Filter", S.
Filter);
521 IO.mapOptional(
"AddressU", S.
AddressU);
522 IO.mapOptional(
"AddressV", S.
AddressV);
523 IO.mapOptional(
"AddressW", S.
AddressW);
528 IO.mapOptional(
"MinLOD", S.
MinLOD);
529 IO.mapOptional(
"MaxLOD", S.
MaxLOD);
533#define STATIC_SAMPLER_FLAG(Num, Enum, Flag) \
534 IO.mapOptional(#Flag, S.Enum, false);
535#include "llvm/BinaryFormat/DXContainerConstants.def"
538void MappingTraits<DXContainerYAML::DebugName>::mapping(
539 IO &IO, DXContainerYAML::DebugName &DebugName) {
540 IO.mapOptional(
"Flags", DebugName.Flags);
541 IO.mapOptional(
"NameLength", DebugName.NameLength);
542 IO.mapRequired(
"DebugName", DebugName.Filename);
545void MappingTraits<DXContainerYAML::CompilerVersion>::mapping(
546 IO &IO, DXContainerYAML::CompilerVersion &CompilerVersion) {
547 IO.mapOptional(
"Major", CompilerVersion.Major);
548 IO.mapOptional(
"Minor", CompilerVersion.Minor);
549 IO.mapOptional(
"IsDebugBuild", CompilerVersion.IsDebugBuild);
550 IO.mapOptional(
"IsValidated", CompilerVersion.IsValidated);
551 IO.mapOptional(
"CommitCount", CompilerVersion.CommitCount);
552 IO.mapOptional(
"ContentSizeInBytes", CompilerVersion.ContentSizeInBytes);
553 IO.mapOptional(
"CommitSha", CompilerVersion.CommitSha);
554 IO.mapOptional(
"CustomVersionString", CompilerVersion.CustomVersionString);
557void MappingTraits<DXContainerYAML::Part>::mapping(IO &IO,
558 DXContainerYAML::Part &
P) {
559 IO.mapRequired(
"Name",
P.Name);
560 IO.mapRequired(
"Size",
P.Size);
561 IO.mapOptional(
"Program",
P.Program);
562 IO.mapOptional(
"Flags",
P.Flags);
563 IO.mapOptional(
"Hash",
P.Hash);
564 IO.mapOptional(
"PSVInfo",
P.Info);
565 IO.mapOptional(
"Signature",
P.Signature);
566 IO.mapOptional(
"RootSignature",
P.RootSignature);
567 IO.mapOptional(
"DebugName",
P.DebugName);
568 IO.mapOptional(
"CompilerVersion",
P.CompilerVersion);
569 IO.mapOptional(
"SourceInfo",
P.SourceInfo);
572void MappingTraits<DXContainerYAML::Object>::mapping(
573 IO &IO, DXContainerYAML::Object &Obj) {
574 IO.mapTag(
"!dxcontainer",
true);
575 IO.mapRequired(
"Header",
Obj.Header);
576 IO.mapRequired(
"Parts",
Obj.Parts);
579void MappingTraits<DXContainerYAML::ResourceFlags>::mapping(
580 IO &IO, DXContainerYAML::ResourceFlags &Flags) {
581#define RESOURCE_FLAG(FlagIndex, Enum) IO.mapRequired(#Enum, Flags.Bits.Enum);
582#include "llvm/BinaryFormat/DXContainerConstants.def"
585void MappingTraits<DXContainerYAML::ResourceBindInfo>::mapping(
586 IO &IO, DXContainerYAML::ResourceBindInfo &Res) {
587 IO.mapRequired(
"Type", Res.Type);
588 IO.mapRequired(
"Space", Res.Space);
589 IO.mapRequired(
"LowerBound", Res.LowerBound);
590 IO.mapRequired(
"UpperBound", Res.UpperBound);
592 const uint32_t *PSVVersion =
static_cast<uint32_t *
>(IO.getContext());
596 IO.mapRequired(
"Kind", Res.Kind);
597 IO.mapRequired(
"Flags", Res.Flags);
600void MappingTraits<DXContainerYAML::SignatureElement>::mapping(
601 IO &IO, DXContainerYAML::SignatureElement &El) {
602 IO.mapRequired(
"Name", El.Name);
603 IO.mapRequired(
"Indices", El.Indices);
604 IO.mapRequired(
"StartRow", El.StartRow);
605 IO.mapRequired(
"Cols", El.Cols);
606 IO.mapRequired(
"StartCol", El.StartCol);
607 IO.mapRequired(
"Allocated", El.Allocated);
608 IO.mapRequired(
"Kind", El.Kind);
609 IO.mapRequired(
"ComponentType", El.Type);
610 IO.mapRequired(
"Interpolation", El.Mode);
611 IO.mapRequired(
"DynamicMask", El.DynamicMask);
612 IO.mapRequired(
"Stream", El.Stream);
615void MappingTraits<DXContainerYAML::StringTableEntry>::mapping(
616 IO &IO, DXContainerYAML::StringTableEntry &
E) {
617 IO.mapRequired(
"String",
E.String);
618 IO.mapRequired(
"Offset",
E.Offset);
621void ScalarEnumerationTraits<dxbc::PSV::SemanticKind>::enumeration(
622 IO &IO, dxbc::PSV::SemanticKind &
Value) {
623 for (
const auto &
E : dxbc::PSV::getSemanticKinds())
624 IO.enumCase(
Value,
E.Name,
E.Value);
627void ScalarEnumerationTraits<dxbc::PSV::ComponentType>::enumeration(
628 IO &IO, dxbc::PSV::ComponentType &
Value) {
629 for (
const auto &
E : dxbc::PSV::getComponentTypes())
630 IO.enumCase(
Value,
E.Name,
E.Value);
633void ScalarEnumerationTraits<dxbc::PSV::InterpolationMode>::enumeration(
634 IO &IO, dxbc::PSV::InterpolationMode &
Value) {
635 for (
const auto &
E : dxbc::PSV::getInterpolationModes())
636 IO.enumCase(
Value,
E.Name,
E.Value);
639void ScalarEnumerationTraits<dxbc::PSV::ResourceType>::enumeration(
640 IO &IO, dxbc::PSV::ResourceType &
Value) {
641 for (
const auto &
E : dxbc::PSV::getResourceTypes())
642 IO.enumCase(
Value,
E.Name,
E.Value);
645void ScalarEnumerationTraits<dxbc::PSV::ResourceKind>::enumeration(
646 IO &IO, dxbc::PSV::ResourceKind &
Value) {
647 for (
const auto &
E : dxbc::PSV::getResourceKinds())
648 IO.enumCase(
Value,
E.Name,
E.Value);
651void ScalarEnumerationTraits<dxbc::D3DSystemValue>::enumeration(
652 IO &IO, dxbc::D3DSystemValue &
Value) {
653 for (
const auto &
E : dxbc::getD3DSystemValues())
654 IO.enumCase(
Value,
E.Name,
E.Value);
657void ScalarEnumerationTraits<dxbc::SigMinPrecision>::enumeration(
658 IO &IO, dxbc::SigMinPrecision &
Value) {
659 for (
const auto &
E : dxbc::getSigMinPrecisions())
660 IO.enumCase(
Value,
E.Name,
E.Value);
663void ScalarEnumerationTraits<dxbc::SigComponentType>::enumeration(
664 IO &IO, dxbc::SigComponentType &
Value) {
665 for (
const auto &
E : dxbc::getSigComponentTypes())
666 IO.enumCase(
Value,
E.Name,
E.Value);
669void ScalarEnumerationTraits<dxbc::RootParameterType>::enumeration(
670 IO &IO, dxbc::RootParameterType &
Value) {
671 for (
const auto &
E : dxbc::getRootParameterTypes())
672 IO.enumCase(
Value,
E.Name,
E.Value);
675void ScalarEnumerationTraits<dxil::ResourceClass>::enumeration(
676 IO &IO, dxil::ResourceClass &
Value) {
677 const EnumEntry<dxil::ResourceClass> ResourceClasses[] = {
678 {
"CBuffer", dxil::ResourceClass::CBuffer},
679 {
"SRV", dxil::ResourceClass::SRV},
680 {
"UAV", dxil::ResourceClass::UAV},
681 {
"Sampler", dxil::ResourceClass::Sampler},
684 for (
const auto &
E : ResourceClasses)
685 IO.enumCase(
Value,
E.Name,
E.Value);
688void ScalarEnumerationTraits<dxbc::SamplerFilter>::enumeration(
689 IO &IO, dxbc::SamplerFilter &
Value) {
690 for (
const auto &
E : dxbc::getSamplerFilters())
691 IO.enumCase(
Value,
E.Name,
E.Value);
694void ScalarEnumerationTraits<dxbc::StaticBorderColor>::enumeration(
695 IO &IO, dxbc::StaticBorderColor &
Value) {
696 for (
const auto &
E : dxbc::getStaticBorderColors())
697 IO.enumCase(
Value,
E.Name,
E.Value);
700void ScalarEnumerationTraits<dxbc::TextureAddressMode>::enumeration(
701 IO &IO, dxbc::TextureAddressMode &
Value) {
702 for (
const auto &
E : dxbc::getTextureAddressModes())
703 IO.enumCase(
Value,
E.Name,
E.Value);
706void ScalarEnumerationTraits<dxbc::ShaderVisibility>::enumeration(
707 IO &IO, dxbc::ShaderVisibility &
Value) {
708 for (
const auto &
E : dxbc::getShaderVisibility())
709 IO.enumCase(
Value,
E.Name,
E.Value);
712void ScalarEnumerationTraits<dxbc::ComparisonFunc>::enumeration(
713 IO &IO, dxbc::ComparisonFunc &
Value) {
714 for (
const auto &
E : dxbc::getComparisonFuncs())
715 IO.enumCase(
Value,
E.Name,
E.Value);
718void ScalarEnumerationTraits<llvm::dxbc::SourceInfo::SectionType>::enumeration(
720 for (
const auto &
E : dxbc::SourceInfo::getSectionTypes())
721 IO.enumCase(
Value,
E.Name,
E.Value);
724void ScalarEnumerationTraits<
728 for (
const auto &
E : dxbc::SourceInfo::Contents::getCompressionTypes())
729 IO.enumCase(
Value,
E.Name,
E.Value);
732void MappingTraits<llvm::DXContainerYAML::SourceInfo::Header>::mapping(
733 IO &IO, llvm::DXContainerYAML::SourceInfo::Header &
H) {
734 IO.mapOptional(
"AlignedSizeInBytes",
H.AlignedSizeInBytes);
735 IO.mapOptional(
"Flags",
H.Flags);
736 IO.mapOptional(
"SectionCount",
H.SectionCount);
739void MappingTraits<llvm::DXContainerYAML::SourceInfo::SectionHeader>::mapping(
740 IO &IO, llvm::DXContainerYAML::SourceInfo::SectionHeader &
H) {
741 IO.mapOptional(
"AlignedSizeInBytes",
H.AlignedSizeInBytes);
742 IO.mapOptional(
"Flags",
H.Flags);
743 IO.mapOptional(
"Type",
H.Type);
746void MappingTraits<llvm::DXContainerYAML::SourceInfo::SourceNames::Header>::
747 mapping(IO &IO, llvm::DXContainerYAML::SourceInfo::SourceNames::Header &
H) {
748 IO.mapOptional(
"Flags",
H.Flags);
749 IO.mapOptional(
"Count",
H.Count);
750 IO.mapOptional(
"EntriesSizeInBytes",
H.EntriesSizeInBytes);
753void MappingTraits<llvm::DXContainerYAML::SourceInfo::SourceNames::Entry>::
754 mapping(IO &IO, llvm::DXContainerYAML::SourceInfo::SourceNames::Entry &
E) {
755 IO.mapOptional(
"AlignedSizeInBytes",
E.AlignedSizeInBytes);
756 IO.mapOptional(
"Flags",
E.Flags);
757 IO.mapOptional(
"NameSizeInBytes",
E.NameSizeInBytes);
758 IO.mapOptional(
"ContentSizeInBytes",
E.ContentSizeInBytes);
759 IO.mapRequired(
"FileName",
E.FileName);
762void MappingTraits<llvm::DXContainerYAML::SourceInfo::SourceNames>::mapping(
763 IO &IO, llvm::DXContainerYAML::SourceInfo::SourceNames &S) {
766 IO.mapRequired(
"Entries", S.
Entries);
769void MappingTraits<llvm::DXContainerYAML::SourceInfo::SourceContents::Header>::
771 llvm::DXContainerYAML::SourceInfo::SourceContents::Header &
H) {
772 IO.mapOptional(
"AlignedSizeInBytes",
H.AlignedSizeInBytes);
773 IO.mapOptional(
"Flags",
H.Flags);
774 IO.mapRequired(
"Type",
H.Type);
775 IO.mapOptional(
"EntriesSizeInBytes",
H.EntriesSizeInBytes);
776 IO.mapOptional(
"UncompressedEntriesSizeInBytes",
777 H.UncompressedEntriesSizeInBytes);
778 IO.mapOptional(
"Count",
H.Count);
781void MappingTraits<llvm::DXContainerYAML::SourceInfo::SourceContents::Entry>::
783 llvm::DXContainerYAML::SourceInfo::SourceContents::Entry &
E) {
784 IO.mapOptional(
"AlignedSizeInBytes",
E.AlignedSizeInBytes);
785 IO.mapOptional(
"Flags",
E.Flags);
786 IO.mapOptional(
"ContentSizeInBytes",
E.ContentSizeInBytes);
787 IO.mapRequired(
"FileContent",
E.FileContent);
790void MappingTraits<llvm::DXContainerYAML::SourceInfo::SourceContents>::mapping(
791 IO &IO, llvm::DXContainerYAML::SourceInfo::SourceContents &S) {
794 IO.mapRequired(
"Entries", S.
Entries);
797void MappingTraits<llvm::DXContainerYAML::SourceInfo::ProgramArgs::Header>::
798 mapping(IO &IO, llvm::DXContainerYAML::SourceInfo::ProgramArgs::Header &
H) {
799 IO.mapOptional(
"Flags",
H.Flags);
800 IO.mapOptional(
"SizeInBytes",
H.SizeInBytes);
801 IO.mapOptional(
"Count",
H.Count);
804void MappingTraits<mcdxbc::SourceInfo::ProgramArgs::Entry>::mapping(
805 IO &IO, mcdxbc::SourceInfo::ProgramArgs::Entry &
E) {
806 IO.mapRequired(
"Arg",
E.first);
807 IO.mapRequired(
"Value",
E.second);
810void MappingTraits<llvm::DXContainerYAML::SourceInfo::ProgramArgs>::mapping(
811 IO &IO, llvm::DXContainerYAML::SourceInfo::ProgramArgs &S) {
814 IO.mapRequired(
"Args", S.
Args);
817void MappingTraits<llvm::DXContainerYAML::SourceInfo>::mapping(
818 IO &IO, llvm::DXContainerYAML::SourceInfo &S) {
820 IO.mapRequired(
"Names", S.
Names);
821 IO.mapRequired(
"Contents", S.
Contents);
822 IO.mapRequired(
"Args", S.
Args);
862 IO.
mapRequired(
"GroupSharedBytesDependentOnViewID",
890 Info.GeomData.SigPatchConstOrPrimVectors);
893 IO.
mapRequired(
"SigPrimVectors",
Info.GeomData.MeshInfo.SigPrimVectors);
895 Info.GeomData.MeshInfo.MeshOutputTopology);
921 for (
auto Param : Sig)
923 Param.Stream, Sig.
getName(Param.NameOffset).
str(), Param.Index,
924 Param.SystemValue, Param.CompType, Param.Register, Param.Mask,
925 Param.ExclusiveMask, Param.MinPrecision});
931 Dst.AlignedSizeInBytes = Src.AlignedSizeInBytes;
932 Dst.Flags = Src.Flags;
936Expected<std::unique_ptr<DXContainerYAML::Object>>
938 std::unique_ptr<DXContainerYAML::Object> Obj =
939 std::make_unique<DXContainerYAML::Object>();
942 Obj->Header.Hash.push_back(Byte);
948 Obj->Header.PartOffsets = std::vector<uint32_t>();
949 for (
const auto P : Container) {
950 Obj->Header.PartOffsets->push_back(
P.Offset);
951 Obj->Parts.push_back(
956 case dxbc::PartType::DXIL:
957 case dxbc::PartType::ILDB: {
958 std::optional<object::DXContainer::DXILData> DXIL =
960 assert(DXIL &&
"Since we are iterating and found a DXIL/ILDB part, "
961 "this should never not have a value");
963 DXIL->first.getMajorVersion(),
964 DXIL->first.getMinorVersion(),
965 DXIL->first.ShaderKind,
967 DXIL->first.Bitcode.MajorVersion,
968 DXIL->first.Bitcode.MinorVersion,
969 DXIL->first.Bitcode.Offset,
970 DXIL->first.Bitcode.Size,
971 std::vector<llvm::yaml::Hex8>(
972 DXIL->second, DXIL->second + DXIL->first.Bitcode.Size)};
975 case dxbc::PartType::ILDN: {
977 assert(
DebugName &&
"Since we are iterating and found a ILDN part, this "
978 "should never not have a value");
984 case dxbc::PartType::SFI0: {
987 if (Flags && *Flags > 0)
991 case dxbc::PartType::HASH: {
992 std::optional<dxbc::ShaderHash> Hash = Container.
getShaderHash();
993 if (Hash && Hash->isPopulated())
997 case dxbc::PartType::PSV0: {
1002 std::get_if<dxbc::PSV::v0::RuntimeInfo>(&
PSVInfo->getInfo())) {
1003 std::optional<uint16_t> ShaderKind = Container.
getShaderKind();
1007 }
else if (
const auto *
P = std::get_if<dxbc::PSV::v1::RuntimeInfo>(
1010 else if (
const auto *
P =
1011 std::get_if<dxbc::PSV::v2::RuntimeInfo>(&
PSVInfo->getInfo()))
1013 else if (
const auto *
P =
1014 std::get_if<dxbc::PSV::v3::RuntimeInfo>(&
PSVInfo->getInfo()))
1016 NewPart.
Info->ResourceStride =
PSVInfo->getResourceStride();
1017 NewPart.
Info->RuntimeInfoSize =
PSVInfo->getSize();
1018 if (
PSVInfo->getVersion() > 0) {
1021 while (Pos < ST.size()) {
1022 size_t End = ST.find(
'\0', Pos);
1026 NewPart.
Info->StringTable.push_back(
1027 {ST.slice(Pos, End),
static_cast<uint32_t>(Pos)});
1031 for (
auto Res :
PSVInfo->getResources())
1032 NewPart.
Info->Resources.push_back(Res);
1034 for (
auto El :
PSVInfo->getSigInputElements())
1035 NewPart.
Info->SigInputElements.push_back(
1037 El,
PSVInfo->getStringTable(),
1038 PSVInfo->getSemanticIndexTable()));
1039 for (
auto El :
PSVInfo->getSigOutputElements())
1040 NewPart.
Info->SigOutputElements.push_back(
1042 El,
PSVInfo->getStringTable(),
1043 PSVInfo->getSemanticIndexTable()));
1044 for (
auto El :
PSVInfo->getSigPatchOrPrimElements())
1045 NewPart.
Info->SigPatchOrPrimElements.push_back(
1047 El,
PSVInfo->getStringTable(),
1048 PSVInfo->getSemanticIndexTable()));
1051 for (
int I = 0;
I < 4; ++
I)
1052 for (
auto Mask :
PSVInfo->getOutputVectorMasks(
I))
1053 NewPart.
Info->OutputVectorMasks[
I].push_back(Mask);
1054 for (
auto Mask :
PSVInfo->getPatchOrPrimMasks())
1055 NewPart.
Info->PatchOrPrimMasks.push_back(Mask);
1058 for (
int I = 0;
I < 4; ++
I)
1059 for (
auto Mask :
PSVInfo->getInputOutputMap(
I))
1060 NewPart.
Info->InputOutputMap[
I].push_back(Mask);
1062 for (
auto Mask :
PSVInfo->getInputPatchMap())
1063 NewPart.
Info->InputPatchMap.push_back(Mask);
1065 for (
auto Mask :
PSVInfo->getPatchOutputMap())
1066 NewPart.
Info->PatchOutputMap.push_back(Mask);
1070 case dxbc::PartType::ISG1:
1073 case dxbc::PartType::OSG1:
1076 case dxbc::PartType::PSG1:
1081 case dxbc::PartType::RTS0: {
1082 std::optional<object::DirectX::RootSignature> RS =
1084 if (RS.has_value()) {
1085 auto RootSigDescOrErr =
1087 if (
Error E = RootSigDescOrErr.takeError())
1088 return std::move(
E);
1093 case dxbc::PartType::SRCI: {
1096 "should never not have a value");
1097 auto &SourceInfoYAML = NewPart.
SourceInfo.emplace();
1098 SourceInfoYAML.Parameters.AlignedSizeInBytes =
1101 SourceInfoYAML.Parameters.SectionCount =
1104 auto &NamesYAML = SourceInfoYAML.Names;
1107 NamesYAML.Parameters.Flags = Names.Parameters.Flags;
1108 NamesYAML.Parameters.Count = Names.Parameters.Count;
1109 NamesYAML.Parameters.EntriesSizeInBytes =
1110 Names.Parameters.EntriesSizeInBytes;
1111 NamesYAML.Entries.reserve(Names.Entries.size());
1112 for (
const auto &NameEntry : Names.Entries) {
1115 NameEntry.Parameters.AlignedSizeInBytes;
1116 NameEntryYAML.
Flags = NameEntry.Parameters.Flags;
1119 NameEntry.Parameters.ContentSizeInBytes;
1120 NameEntryYAML.
FileName = NameEntry.FileName;
1121 NamesYAML.Entries.emplace_back(NameEntryYAML);
1124 auto &ContentsYAML = SourceInfoYAML.Contents;
1126 assign(ContentsYAML.GenericHeader, Contents.GenericHeader);
1127 ContentsYAML.Parameters.AlignedSizeInBytes =
1128 Contents.Parameters.AlignedSizeInBytes;
1129 ContentsYAML.Parameters.Flags = Contents.Parameters.Flags;
1130 ContentsYAML.Parameters.Type = Contents.Parameters.Type;
1131 ContentsYAML.Parameters.EntriesSizeInBytes =
1132 Contents.Parameters.EntriesSizeInBytes;
1133 ContentsYAML.Parameters.UncompressedEntriesSizeInBytes =
1134 Contents.Parameters.UncompressedEntriesSizeInBytes;
1135 ContentsYAML.Parameters.Count = Contents.Parameters.Count;
1136 ContentsYAML.Entries.reserve(Contents.Entries.size());
1137 for (
const auto &ContentEntry : Contents.Entries) {
1140 ContentEntry.Parameters.AlignedSizeInBytes;
1141 ContentEntryYAML.
Flags = ContentEntry.Parameters.Flags;
1143 ContentEntry.Parameters.ContentSizeInBytes;
1144 ContentEntryYAML.
FileContent = ContentEntry.FileContent;
1145 ContentsYAML.Entries.emplace_back(ContentEntryYAML);
1148 auto &ArgsYAML = SourceInfoYAML.Args;
1150 assign(ArgsYAML.GenericHeader, Args.GenericHeader);
1151 ArgsYAML.Parameters.Flags = Args.Parameters.Flags;
1152 ArgsYAML.Parameters.SizeInBytes = Args.Parameters.SizeInBytes;
1153 ArgsYAML.Parameters.Count = Args.Parameters.Count;
1154 ArgsYAML.Args = Args.Args;
1157 case dxbc::PartType::VERS: {
1158 std::optional<mcdxbc::CompilerVersion>
Version =
1160 assert(
Version &&
"Since we are iterating and found a VERS part, this "
1161 "should never not have a value");
1164 !!(
Version->Parameters.Flags & dxbc::CompilerVersionFlags::Debug),
1165 !!(
Version->Parameters.Flags & dxbc::CompilerVersionFlags::Internal),
1166 Version->Parameters.CommitCount,
1167 Version->Parameters.ContentSizeInBytes,
Version->CommitSha.str(),
1168 Version->CustomVersionString.str()});
1173 return std::move(Obj);
assert(UImm &&(UImm !=~static_cast< T >(0)) &&"Invalid immediate!")
static GCRegistry::Add< ShadowStackGC > C("shadow-stack", "Very portable GC for uncooperative code generators")
static GCRegistry::Add< StatepointGC > D("statepoint-example", "an example strategy for statepoint")
static GCRegistry::Add< CoreCLRGC > E("coreclr", "CoreCLR-compatible GC")
This file declares classes for handling the YAML representation of DXContainer.
This file contains library features backported from future STL versions.
This file defines the make_scope_exit function, which executes user-defined cleanup logic at scope ex...
static StringRef substr(StringRef Str, uint64_t Len)
Lightweight error class with error context and mandatory checking.
static ErrorSuccess success()
Create a success value.
Tagged union holding either a T or a Error.
Error takeError()
Take ownership of the stored error.
reference get()
Returns a reference to the stored T value.
Represent a mutable reference to an array (0 or more elements consecutively in memory),...
Represent a constant reference to a string, i.e.
static constexpr size_t npos
std::string str() const
Get the contents as an std::string.
const std::optional< DXILData > & getDXIL(bool Debug) const
std::optional< uint64_t > getShaderFeatureFlags() const
const std::optional< DirectX::PSVRuntimeInfo > & getPSVInfo() const
const std::optional< mcdxbc::SourceInfo > & getSourceInfo() const
const std::optional< mcdxbc::CompilerVersion > & getCompilerVersionInfo() const
std::optional< uint16_t > getShaderKind() const
const dxbc::Header & getHeader() const
const DirectX::Signature & getInputSignature() const
std::optional< DirectX::RootSignature > getRootSignature() const
const std::optional< mcdxbc::DebugName > getDebugName() const
std::optional< dxbc::ShaderHash > getShaderHash() const
const DirectX::Signature & getOutputSignature() const
const DirectX::Signature & getPatchConstantSignature() const
StringRef getName(uint32_t Offset) const
void mapRequired(StringRef Key, T &Val)
#define llvm_unreachable(msg)
Marks that the current location is not supposed to be reachable.
LLVM_ABI Expected< std::unique_ptr< DXContainerYAML::Object > > fromDXContainer(object::DXContainer &DXC)
bool isValidShaderVisibility(uint32_t V)
LLVM_ABI PartType parsePartType(StringRef S)
bool isValidSamplerFilter(uint32_t V)
Triple::EnvironmentType getShaderStage(uint32_t Kind)
bool isDebugProgramPart(PartType PT)
bool isValidBorderColor(uint32_t V)
bool isValidComparisonFunc(uint32_t V)
LLVM_ABI_FOR_TEST bool isValidParameterType(uint32_t V)
bool isValidAddress(uint32_t V)
bool isValidRangeType(uint32_t V)
This is an optimization pass for GlobalISel generic memory operations.
auto find(R &&Range, const T &Val)
Provide wrappers to std::find which take ranges instead of having to pass begin/end explicitly.
static DXContainerYAML::Signature dumpSignature(const object::DirectX::Signature &Sig)
decltype(auto) dyn_cast(const From &Val)
dyn_cast<X> - Return the argument parameter cast to the specified type.
scope_exit(Callable) -> scope_exit< Callable >
static void assign(DXContainerYAML::SourceInfo::SectionHeader &Dst, const dxbc::SourceInfo::SectionHeader &Src)
Error createStringError(std::error_code EC, char const *Fmt, const Ts &... Vals)
Create formatted StringError object.
FunctionAddr VTableAddr uintptr_t uintptr_t Version
static llvm::Error readDescriptorRanges(DXContainerYAML::RootParameterHeaderYaml &Header, DXContainerYAML::RootSignatureYamlDesc &RootSigDesc, object::DirectX::DescriptorTableView *DTV)
FunctionAddr VTableAddr uintptr_t uintptr_t Data
std::optional< uint16_t > NameLength
std::optional< uint16_t > Flags
uint32_t OffsetInDescriptorsFromTableStart
uint32_t BaseShaderRegister
LLVM_ABI uint32_t getEncodedFlags() const
dxil::ResourceClass RangeType
SmallVector< DescriptorRangeYaml > Ranges
SmallVector< StringTableEntry > StringTable
LLVM_ABI void mapInfoForVersion(yaml::IO &IO)
dxbc::PSV::v3::RuntimeInfo Info
std::optional< PSVInfo > Info
std::optional< DXContainerYAML::RootSignatureYamlDesc > RootSignature
std::optional< DXILProgram > Program
std::optional< DXContainerYAML::Signature > Signature
std::optional< ShaderHash > Hash
std::optional< DXContainerYAML::CompilerVersion > CompilerVersion
std::optional< DXContainerYAML::DebugName > DebugName
std::optional< ShaderFeatureFlags > Flags
std::optional< DXContainerYAML::SourceInfo > SourceInfo
LLVM_ABI uint32_t getEncodedFlags() const
RootDescriptorYaml & getOrInsertDescriptor(RootParameterLocationYaml &ParamDesc)
RootConstantsYaml & getOrInsertConstants(RootParameterLocationYaml &ParamDesc)
void insertLocation(RootParameterLocationYaml &Location)
DescriptorTableYaml & getOrInsertTable(RootParameterLocationYaml &ParamDesc)
uint32_t NumRootParameters
uint32_t NumStaticSamplers
SmallVector< StaticSamplerYamlDesc > StaticSamplers
std::optional< uint32_t > RootParametersOffset
RootSignatureYamlDesc()=default
LLVM_ABI uint32_t getEncodedFlags()
static LLVM_ABI llvm::Expected< DXContainerYAML::RootSignatureYamlDesc > create(const object::DirectX::RootSignature &Data)
RootParameterYamlDesc Parameters
std::optional< uint32_t > StaticSamplersOffset
ShaderFeatureFlags()=default
LLVM_ABI uint64_t getEncodedFlags()
std::vector< llvm::yaml::Hex8 > Digest
SmallVector< mcdxbc::SourceInfo::ProgramArgs::Entry > Args
SectionHeader GenericHeader
std::optional< uint32_t > Flags
std::optional< uint32_t > ContentSizeInBytes
std::optional< uint32_t > AlignedSizeInBytes
SmallVector< Entry > Entries
std::optional< uint32_t > AlignedSizeInBytes
std::optional< uint32_t > NameSizeInBytes
std::optional< uint32_t > Flags
std::optional< uint32_t > ContentSizeInBytes
SmallVector< Entry > Entries
dxbc::StaticBorderColor BorderColor
dxbc::ShaderVisibility ShaderVisibility
dxbc::TextureAddressMode AddressU
dxbc::SamplerFilter Filter
dxbc::ComparisonFunc ComparisonFunc
dxbc::TextureAddressMode AddressV
LLVM_ABI uint32_t getEncodedFlags() const
dxbc::TextureAddressMode AddressW
uint32_t PayloadSizeInBytes
uint32_t InputControlPointCount
uint32_t TessellatorDomain
uint8_t OutputPositionPresent
uint8_t OutputPositionPresent
uint32_t OutputStreamMask
uint32_t TessellatorOutputPrimitive
uint32_t OutputControlPointCount
uint32_t InputControlPointCount
uint32_t TessellatorDomain
uint32_t PayloadSizeInBytes
uint16_t MaxOutputVertices
uint16_t MaxOutputPrimitives
uint32_t GroupSharedBytesDependentOnViewID
uint32_t GroupSharedBytesUsed
uint8_t OutputPositionPresent
llvm::Expected< DescriptorTable< T > > read()