summaryrefslogtreecommitdiff
path: root/source/slang/slang-check-shader.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'source/slang/slang-check-shader.cpp')
-rw-r--r--source/slang/slang-check-shader.cpp29
1 files changed, 10 insertions, 19 deletions
diff --git a/source/slang/slang-check-shader.cpp b/source/slang/slang-check-shader.cpp
index 3d086b189..a802906a7 100644
--- a/source/slang/slang-check-shader.cpp
+++ b/source/slang/slang-check-shader.cpp
@@ -521,26 +521,15 @@ namespace Slang
targetCaps.join(stageCapabilitySet);
if (targetCaps.isIncompatibleWith(entryPointFuncDecl->inferredCapabilityRequirements))
{
- maybeDiagnose(sink, linkage->m_optionSet, DiagnosticCategory::Capability, entryPointFuncDecl, Diagnostics::entryPointUsesUnavailableCapability, entryPointFuncDecl, entryPointFuncDecl->inferredCapabilityRequirements, targetCaps);
+ // Incompatable means we don't support a set of abstract atoms.
+ // Diagnose that we lack support for 'stage' and 'target' atoms with our provided entry-point
+ auto compileTarget = target->getTargetCaps().getCompileTarget();
+ auto stageTarget = stageCapabilitySet.getTargetStage();
+ maybeDiagnose(sink, linkage->m_optionSet, DiagnosticCategory::Capability, entryPointFuncDecl, Diagnostics::entryPointUsesUnavailableCapability, entryPointFuncDecl, compileTarget, stageTarget);
- // Find out what exactly is incompatible and print out a trace of provenance to
- // help user diagnose their code.
- // TODO: provedence should have a way to filter out for provenance that are missing X capabilitySet from their caps, else in big functions we get junk errors
- // This is specifically a problem for when a function is missing a target but otherwise has identical capabilities.
-
- const auto interredCapConjunctions = entryPointFuncDecl->inferredCapabilityRequirements.getAtomSets();
- const auto compileCaps = targetCaps.getAtomSets();
- if (compileCaps && interredCapConjunctions)
- {
- for (auto inferredAtom : *interredCapConjunctions.begin())
- {
- CapabilityAtom inferredAtomFormatted = asAtom(inferredAtom);
- if (!compileCaps->contains((UInt)inferredAtom))
- {
- diagnoseCapabilityProvenance(linkage->m_optionSet, sink, entryPointFuncDecl, inferredAtomFormatted);
- }
- }
- }
+ // Find out what is incompatible (ancestor missing a super set of 'target+stage')
+ CapabilitySet failedSet({ (CapabilityName)compileTarget, (CapabilityName)stageTarget });
+ diagnoseMissingCapabilityProvenance(linkage->m_optionSet, sink, entryPointFuncDecl, failedSet);
}
else
{
@@ -571,6 +560,8 @@ namespace Slang
entryPointFuncDecl->loc,
Diagnostics::profileImplicitlyUpgraded,
Diagnostics::profileImplicitlyUpgradedRestrictive,
+ entryPointFuncDecl,
+ target->getOptionSet().getProfile().getName(),
addedAtoms.getElements<CapabilityAtom>());
}
}