gpt4 book ai didi

objective-c - 在单个 MTLRenderCommandEncoder : How to Synchronize MTLBuffer? 中使用多个渲染管道

转载 作者:行者123 更新时间:2023-12-03 09:24:49 24 4
gpt4 key购买 nike

中心刊
我在一个渲染命令编码器中有两个渲染管道。第一个管道写入在第二个管道中使用的缓冲区。这似乎不起作用,我希望这是一个同步问题。当我为每个渲染管道使用一个单独的渲染命令编码器时,我得到了想要的结果。这可以用一个单一的渲染命令编码器来解决,还是我需要两个单独的编码器来同步缓冲区?

这是更具体的案例:
第一个管道是非光栅化管道,仅运行顶点着色器以输出到 MTLBuffer收纳MTLDrawPrimitivesIndirectArguments用于 drawPrimitives调用第二个管道,如下所示:

// renderCommandEncoder is MTLRenderCommandEncoder
// firstPipelineState and secondPipelineState are two different MTLRenderPipelineState
// indirectArgumentsBuffer is a MTLBuffer containing MTLDrawPrimitivesIndirectArguments
// numberOfVertices is number of vertices suited for first pipeline

// first pipeline
renderCommandEncoder.setRenderPipelineState(firstPipelineState)
renderCommandEncoder.setVertexBuffer(indirectArgumentsBuffer, offset: 0, index: 0)
renderCommandEncoder.drawPrimitives(type: .point, vertexStart: 0, vertexCount: numberOfVertices)

// second pipeline
renderCommandEncoder.setRenderPipelineState(secondPipelineState)
renderCommandEncoder.setVertexBuffer(secondPipelineBuffer, offset: 0, index: 0)
renderCommandEncoder.drawPrimitives(type: .point, indirectBuffer: indirectArgumentsBuffer, indirectBufferOffset: 0)

renderCommandEncoder.endEncoding()

我如何确保 indirectArgumentsBuffer在发出对 drawPrimitives 的调用时已被第一个管道写入对于第二个管道,它使用并需要 indirectArgumentsBuffer 的内容?

最佳答案

我相信您需要使用单独的编码器。在这个(有点过时)documentation about function writes ,对于绘制调用之间共享的缓冲区,只有原子操作是同步的。

关于objective-c - 在单个 MTLRenderCommandEncoder : How to Synchronize MTLBuffer? 中使用多个渲染管道,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60063522/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com