- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我不知道这是API功能(我几乎可以肯定不是)还是GPU细节,但是为什么例如vkCmdWaitEvents
可以记录在渲染过程的内部和外部,而vkCmdResetEvent
却只能记录在外部?其他命令也一样。
最佳答案
特别是在事件设置方面,他们对渲染过程模型与基于图块的渲染器之间的交互方式产生了极大的破坏。
回想the whole point of the complexity of the render pass model is to service the needs of tile-based renderers (TBRs).当TBR遇到一系列复杂的子 channel 时,它想要执行的方式如下。
它为所有子 channel 的所有渲染命令一次完成所有顶点处理阶段,并将结果顶点数据存储在缓冲区中以备后用。然后,对于每个图块,它对与该图块的构建有关的图元上的每个子遍执行光栅化阶段。
请注意,这是理想情况;特定的事情会使它在不同程度上失败,但是即使那样,它也可能成批失败,在这种情况下,您可以执行渲染过程的多个子过程,如下所示。
假设您要在子 channel 中间设置一个事件。好吧...什么时候真正发生?请记住,在所有前面的命令完成之后,set-event命令实际上会设置事件。在TBR中,如果一切都按上述步骤进行,什么时候设置?理想情况下,整个渲染过程的所有顶点处理都应该在任何光栅化之前进行,因此设置事件必须在顶点处理完成后进行。并且所有栅格化处理都是在逐个图块的基础上进行的,无论哪个基元与该图块重叠都进行处理。由于渲染过程是零散的,因此很难知道单个渲染命令何时完成。
因此,只有在整个renderpass完成之后,才可以进行set-event调用。这显然不是很有用。
另一种方法是发出ckCmdSetEvent
调用,从根本上重塑实现如何构建整个渲染过程的方式。将子 channel 分解为事件之前发生的事件和事件之后发生的事件。
但是VkRenderPass
如此大而复杂的原因,VkPipeline
不得不引用渲染过程的特定子 channel 的原因,以及渲染过程中的vkCmdPipelineBarrier
要求您指定子过程自相关性的原因是, TBR实现可以预先知道何时何地必须打破理想的TBR呈现方案。有一个功能可以在没有事先警告的情况下引入这种分解,从而违背了这个想法。
此外,Vulkan的设计方式是,如果必须以非常低效的方式实现某些事情,那么要么直接做不到,要么API确实使它看起来效率很低。无法在TBR硬件上的渲染过程中有效地实现vkCmd(Re)SetEvent
,因此您不能在此期间进行。
请注意vkCmdWaitEvents
不会出现此问题,因为系统知道等待正在等待渲染 channel 之外的内容。因此,这只是一个特定的阶段,必须等待事件完成。如果在等待阶段是一个顶点阶段,那么在该命令的处理开始时设置等待就足够容易了。如果是分段阶段,则只需在所有光栅化处理的开始处插入等待;这不是处理它的最有效方法,但是由于所有顶点处理均已执行,因此到那时设置事件的可能性很好。
对于其他类型的命令,请记住,在渲染过程中发生的所有事情的依赖图都是在VkRenderPass
本身中定义的。子 channel 依赖关系图在那里。您甚至不能在渲染过程中发出普通的vkCmdPipelineBarrier
,除非该子过程在子过程相关性图中具有明确的自相关性,否则就不能这样做。
因此,如果您不能等待在该子 channel 或下一个子 channel 中完成操作,则在子 channel 的中间发出计算着色器分派(dispatch)或内存转移操作有什么好处?如果您不能等待操作结束,则无法使用其结果。而且,如果您不能使用它的结果,则最好在渲染过程之前发布它。
您不能拥有其他依赖项的原因可以追溯到TBR。依赖图是渲染过程的不可分割的部分,以允许TBR预先知道子过程之间的关系是什么。这样一来,他们便可以知道是否可以构建理想的渲染器,以及何时何地可能出现故障。
由于渲染遍历的TBR模型使这种等待变得不切实际,因此没有必要发布这样的命令。
关于vulkan - 为什么有些命令只能在渲染过程之外记录?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56124631/
我想知道为什么可以在 VkPipelineLayoutCreateInfo 中指定多个描述符集布局,因为一个已经包含所有绑定(bind)。 最佳答案 描述符集布局描述了单个描述符集的布局。但是一个管道
我试图了解整个 L1/L2 冲洗是如何工作的。假设我有一个像这样的计算着色器 layout(std430, set = 0, binding = 2) buffer Particles{ Pa
Vulkan 旨在为用户提供精简和明确的内容,但队列是此规则的一个很大异常(exception):队列可能由驱动程序复用,并且使用一个系列的多个队列是否会提高性能并不总是很明显。 在驱动程序更新之一之
来自与 vkCmdPipelineBarrier 相关的规范: If no memory barriers are specified, then the first access scope inc
Vulkan 是否提供绘制基本图元的功能?点、线、矩形、实心矩形、圆角矩形、实心圆角矩形、圆、实心圆等。 ? 我认为没有任何 VkCmdDraw* 命令可以提供此功能。如果这是真的,需要做些什么来绘制
我正在尝试进行一个模拟,该模拟涉及渲染前的两个计算步骤。我目前有一个计算基础物理的计算管道,然后是一个图形管道。我希望能够添加第二个计算着色器以在第一个计算着色器之后运行。 首先,Vulkan 中是否
取消映射后可以刷新内存范围吗? 乍一看好像不对,因为函数叫vkFlushMappedMemoryRanges() ,但是 the documentation似乎暗示内存已准备好刷新,即使在未映射之后:
Vulkan 是否支持保存流水线阶段的顶点输出?我一直在寻找,但找不到任何示例或引用资料,也许其他人不知道? 最佳答案 Transform Feedback 在最初的 Vulkan 版本中没有被削减,
我有多个具有不同纹理/管道构造的网格,例如深度测试/混合函数以使用 vulkan 进行渲染。在性能方面呈现它们的最佳实践是什么。 一种选择是为 n 个网格创建 n 个具有 n 个线程的命令缓冲区,它们
我正在开发一个使用 Vulkan 的 C++ 应用程序。我如何获得支持的扩展集? 像std::set get_supported_extensions()这样的签名会很理想。 最佳答案 vkEnume
我正在开发一个使用 Vulkan 的 C++ 应用程序。我如何获得支持的扩展集? 像std::set get_supported_extensions()这样的签名会很理想。 最佳答案 vkEnume
正在处理 Vulkan 三角形渲染代码,我想将渲染图像保存到文件而不是渲染到窗口。 那么我应该什么时候读取帧缓冲区以及如何编写在文件中。我想需要将原始 RGBA 格式的像素转换为某种已知的 BMP 或
Vulkan 规范(1.0.12)在第 2.4 节介绍了 VkDeviceSize: With few exceptions, Vulkan uses the standard C types for
即使实例在 Vulkan 中创建失败,我是否应该销毁它? 哪个是正确的: 1: VkResult Result = vkCreateInstance( info, NULL, instance );
我开始学习 Vulkan,想知道 VkCreate[...] 函数是否将结构中指向的资源复制到他自己的缓冲区中。 为了澄清我的问题,在这段代码中我加载了 斯皮尔 将着色器放入我自己的 mkShader
Khronos 刚刚发布了他们的新内存模型扩展,但还没有进行非正式讨论、示例实现等,所以我对基本细节感到困惑。 https://www.khronos.org/blog/vulkan-has-just
SubpassInput 由片段着色器隐式寻址。我想用我自己的纹理坐标来处理输入。类似于 texture(sampler, texCoord) 最佳答案 这是不可能的。如果您想在着色器内对图像进行采样
有没有办法从实例中获取对象类型枚举器(vk::ObjectType dor vulkan.hpp 和 VkObjectType for vulkan)? 例如假设我们有 3 个对象: vk::Devi
我的着色器索引到采样器和图像,但是当我从图像中采样时(如果我在着色器中采样,我只会得到错误)我得到一个错误: Descriptor in binding #0 index 0 requires FLO
我想到了以下场景,但我不知道它是否有效: 在程序的开头创建一个VkCommandPool,并从中分配一个VkCommandBuffer。 在渲染循环中,将命令记录到 VkCommandBuffer(隐
我是一名优秀的程序员,十分优秀!