You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
For GPU-AV in the Vulkan Validation Layers, I have times I need to go
%result = OpLoad %1%2
// <----- Inject an if check to make sure this access to something unrelated doesn't blow up when executed
%bad_accsss = OpAccessChain
%bad_load = OpLoad %bad_accsss
%5= OpSampledImage %3%4%result
and my "fix" was using OpCopyObject to pass %result so that spirv-val didn't complain 🤷
I got from @dneto0 at the F2F this was not intended
While here, any suggestions how something like GPU-AV should work around this case?
The text was updated successfully, but these errors were encountered:
I'd suggest we update the validation (and perhaps the spec) in ValidateSampledImage to traverse OpCopyObject. Just turn it into a DFS, but only push more instructions on OpCopyObject. It also appears that we aren't checking the similar rule for loads of images or samplers. So maybe the validator should refactor the code. The correct uses of OpSampledImage should ideally be checked on instruction operands already. So it might be the case the final check can removed.
As for GPU-AV, you could try either sinking or duplicating the load to just before the OpSampledImage. This is something inlining might be running into already. So maybe it would make sense to address it there and use a function in GPU-AV.
There is a
spirv-val
errorbut now learning from @alan-baker in KhronosGroup/SPIRV-Guide#27 we should not be able to side-step with
OpCopyObject
For GPU-AV in the Vulkan Validation Layers, I have times I need to go
and my "fix" was using
OpCopyObject
to pass%result
so thatspirv-val
didn't complain 🤷The text was updated successfully, but these errors were encountered: