- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我已经阅读了几篇关于 CPU-GPU(使用栅栏)和 GPU-GPU(使用信号量)同步机制的文章,但仍然无法理解我应该如何实现一个简单的渲染循环。
请看简单的render()
下面的功能。如果我猜对了,最低要求是我们确保 vkAcquireNextImageKHR
之间的 GPU-GPU 同步。 , vkQueueSubmit
和 vkQueuePresentKHR
通过一组信号量image_available
和 rendering_finished
正如我在下面的示例代码中所做的那样。
然而,这真的省了吗?所有操作都是异步的。那么,“重用”image_available
真的安全吗?在后续调用 render()
中的信号量即使之前调用的信号请求还没有触发?我认为不是,但是另一方面,我们使用相同的队列(不知道图形和表示队列实际上是否相同是否重要)并且队列内的操作应该按顺序使用.. .但如果我做对了,它们可能不会“作为一个整体”被消耗,并且可以重新排序......
第二件事是(同样,除非我遗漏了什么)我显然应该为每个交换链图像使用一个栅栏,以确保对图像的操作对应于 image_index
调用render()
已完成。但这是否意味着我一定需要做一个
if (vkWaitForFences(device(), 1, &fence[image_index_of_last_call], VK_FALSE, std::numeric_limits<std::uint64_t>::max()) != VK_SUCCESS)
throw std::runtime_error("vkWaitForFences");
vkResetFences(device(), 1, &fence[image_index_of_last_call]);
在我调用
vkAcquireNextImageKHR
之前?那么我需要专门的
image_available
吗?和
rendering_finished
每个交换链图像的信号量?或者也许每帧?或者也许每个命令缓冲区/池?我真的很困惑...
void render()
{
std::uint32_t image_index;
switch (vkAcquireNextImageKHR(device(), swap_chain().handle(),
std::numeric_limits<std::uint64_t>::max(), m_image_available, VK_NULL_HANDLE, &image_index))
{
case VK_SUBOPTIMAL_KHR:
case VK_SUCCESS:
break;
case VK_ERROR_OUT_OF_DATE_KHR:
on_resized();
return;
default:
throw std::runtime_error("vkAcquireNextImageKHR");
}
static VkPipelineStageFlags constexpr wait_destination_stage_mask = VK_PIPELINE_STAGE_COLOR_ATTACHMENT_OUTPUT_BIT;
VkSubmitInfo submit_info{};
submit_info.sType = VK_STRUCTURE_TYPE_SUBMIT_INFO;
submit_info.waitSemaphoreCount = 1;
submit_info.pWaitSemaphores = &m_image_available;
submit_info.signalSemaphoreCount = 1;
submit_info.pSignalSemaphores = &m_rendering_finished;
submit_info.pWaitDstStageMask = &wait_destination_stage_mask;
if (vkQueueSubmit(graphics_queue().handle, 1, &submit_info, VK_NULL_HANDLE) != VK_SUCCESS)
throw std::runtime_error("vkQueueSubmit");
VkPresentInfoKHR present_info{};
present_info.sType = VK_STRUCTURE_TYPE_PRESENT_INFO_KHR;
present_info.waitSemaphoreCount = 1;
present_info.pWaitSemaphores = &m_rendering_finished;
present_info.swapchainCount = 1;
present_info.pSwapchains = &swap_chain().handle();
present_info.pImageIndices = &image_index;
switch (vkQueuePresentKHR(presentation_queue().handle, &present_info))
{
case VK_SUCCESS:
break;
case VK_ERROR_OUT_OF_DATE_KHR:
case VK_SUBOPTIMAL_KHR:
on_resized();
return;
default:
throw std::runtime_error("vkQueuePresentKHR");
}
}
编辑 :正如以下答案中所建议的,假设我们有
k
“飞行中的帧”,因此
k
上面代码中使用的信号量和栅栏的实例,我将用
m_image_available[i]
表示,
m_rendering_finished[i]
和
m_fence[i]
对于
i = 0, ..., k - 1
.让
i
表示飞行中帧的当前索引,增加
1
每次调用
render()
之后, 和
j
表示
render()
的调用次数, 从
j = 0
开始.
j = 0
,然后 i = 0
飞行中的第一帧正在使用交换链图像 0
j = a
,然后 i = a
和 a
飞行中的第 1 帧正在使用交换链图像 a
, 对于 a= 2, 3
j = 3
,然后 i = 3
,但由于交换链图像只有三个图像,所以第四帧正在使用交换链图像0
再次。我想知道这是否有问题。我猜不是,因为等待/信号信号量 m_image_available[3]
/m_rendering_finished[3]
, 用于 vkAcquireNextImageKHR
的调用, vkQueueSubmit
和 vkQueuePresentKHR
在这个 render()
的调用中, 专用于飞行中的这个特定帧。 j = k
,然后 i = 0
再次,因为只有 k
飞行中的帧。现在我们可能在 render()
的开头等待, 如果调用 vkQueuePresentKHR
从 i = 0
的第一次调用 ( render()
)未发出信号m_fence[0]
然而。 k
尽可能大?我理论上可以想象的是,如果我们以比 GPU 能够消耗的更快的方式向 GPU 提交工作,则使用的队列可能会不断增长并最终溢出(队列中是否存在某种“最大命令“限制?)。
最佳答案
If I got it right, the minimal requirement is that we ensure the GPU-GPU synchronization between vkAcquireNextImageKHR, vkQueueSubmit and vkQueuePresentKHR by a single set of semaphores image_available and rendering_finished as I've done in the example code below.
vkAcquireNextImageKHR
提交了获得要渲染的新图像的愿望。 .演示引擎将发出
m_image_available
的信号。一旦要渲染的图像可用,就可以使用信号量。但是您已经提交了指令。
submit_info
向图形队列提交一些命令。 . IE。它们也已经提交给 GPU 并在那里等到
m_image_available
信号量接收它的信号。
submit_info
的依赖关系。 - 命令已通过等待
m_rendering_finished
完成信号。
render()
功能和重复使用相同的
m_image_available
和
m_rendering_finished
信号量,它只有在你非常幸运的情况下才会起作用,即如果所有信号量在你再次使用它们之前已经发出信号。
vkAcquireNextImageKHR
的规范说明如下:
If semaphore is not VK_NULL_HANDLE it must not have any uncompleted signal or wait operations pending
the act of waiting for a binary semaphore also unsignals that semaphore.
vkAcquireNextImageKHR
使用相同的
m_image_available
信号量已完成。
vkQueueSubmit
的东西使用栅栏。 .如果您不在 CPU 上进行同步,您将把更多的工作推给 GPU(这是一个问题),并且您正在重复使用的信号量可能无法及时正确地取消信号(这是一个问题)。
关于c++ - 在 Vulkan 中,每个交换链图像、每个帧或每个命令池是否需要专用的栅栏/信号量?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/65054157/
我试图让通用链接在我的应用程序中作为 URL 方案的替代品工作,因为从 iOS 9 开始,系统看起来每次从 Safari 调用应用程序时都会显示一个警告对话框。我希望在使用通用链接时替换关联域中注册
对于给定的常量Map val ctt = Map("a" -> 1, "b" -> 2) 如何定义一个String插值器c在哪里 c"a" 交付List(1)? 注意已考虑String Interpo
最近,我强化了我的 Keycloak 部署以使用专用的 Infinispan 集群作为 remote-store为 Keycloak 的各种缓存提供额外的持久层。更改本身进行得相当顺利,尽管在进行此更
我有一个非常明确的问题: //.h file @property (nonatomic, retain)NSMutableString * retainString; @property (nonat
我倾向于厌恶代码中的重复,所以当我遇到唯一不同的是类型的问题时,我倾向于使用泛型。来自 C++ 背景,我发现 vb.net 的版本相当令人沮丧,我知道 C++ 有模板特化,我猜 vb.net 没有所以
问题:如何确认我的“专属服务器”是否正常运行? 背景:我正在努力获得在独立 Linux 系统上运行的“专用 CoreNLP 服务器”。该系统是运行 CentOS 7 的笔记本电脑。选择该操作系统是因为
我一直在痛苦地寻找公平的电话,说 Clouding 把这个和那个给了管理层。到目前为止,无论我在同一个专用/或共享网络托管中找到什么,但云计算如何在软件行业产生巨大影响? 我一直在寻找关于什么是云托管
关闭。这个问题是opinion-based 。目前不接受答案。 想要改进这个问题吗?更新问题,以便 editing this post 可以用事实和引文来回答它。 . 已关闭 5 年前。 此帖子已于
我没有网络背景。我是数据平台解决方案架构和数据/人工智能工程师。由于分布式数据处理和使用容器进行横向扩展已经进入我的世界,我决定硬着头皮学习 IP 基础知识,以便我可以构建集群。 我一直在做大量的培训
我是 Prototype 的长期用户,总体上非常满意。我最近改用 jQuery 是因为得到了庞大的社区支持,基本上可以说是一致的选择和事实上的行业标准。从那以后我就没那么开心了。是的,我已经阅读了比较
我的应用程序使用各种繁重的库和数据文件,需要在启动时加载/与本地存储同步。由于此操作需要一些时间,因此我正在考虑为此目的创建一个专门的 Activity 。此 Activity 将是应用程序的入口点,
我有一个正在开发的 C++ 程序,它处理许多不同类型的对象,这些对象需要在启动时从文件中检索。总文件大小略小于 1GB。该程序必须至少在 Windows 7 和 Linux 上运行。 我的目标是提供读
我正在为我的页面制作适合移动设备的样式表。有没有一种简单的方法让它向 iPhone/Android 用户显示该样式表?或者我是否必须拉出用户代理并以这种方式解决 - 我该怎么做? 还有 - 有什么工具
我发现各种元素非常困惑。几乎每个元素似乎都有一个与之关联的“部分”,我不确定它们是如何粘合在一起的。 工作簿工作簿部分工作表工作表部分 我也对 DocumentFormat.OpenXml.Packa
我有一个由多个 Zend Framework 应用程序组成的服务器。 我想知道将 Zend Library 上传到服务器并在所有应用程序之间共享而不是按应用程序上传是否是个好主意。 例如,如果多个应用
我们有一个简单的表,需要转换为 XML Declare @Person TABLE ( [BusinessEntityID] [int] NOT NULL, [PersonType] [
当我重新部署容器组时,私有(private) IP 地址发生变化。它通常是三个地址之一。因此,我认识到我的负载均衡器只能拥有所有这三个名称,并且似乎知道哪一个当前实际上处于事件状态,但我更希望能够让负
我目前正在尝试通过我的私有(private) aks 集群部署我的 Helm Chart。但是,我无法执行任何操作,因为它找不到本地目录的路径。 这是我正在运行的命令: az aks command
我已为 Azure 存储帐户设置专用终结点。现在,这一切都为我创建了专用端点和专用链接。此外,我还可以直接从同一事件中的虚拟机访问我的存储帐户(storageaccountA)。 现在,从我的虚拟机进
我们的组织拥有 Azure Synapse 专用池实例。我正在尝试向 Azure Purview 注册 Azure Synapse 专用池并想要扫描 Synapse DB。但是,我每次都会收到以下错误
我是一名优秀的程序员,十分优秀!