From ed618fa8cbc32eaef6c0bc8dee0df106b8c3c898 Mon Sep 17 00:00:00 2001 From: Jack Andersen Date: Thu, 4 Jan 2018 17:00:58 -1000 Subject: [PATCH] Metal validation fix --- lib/graphicsdev/Metal.mm | 43 +++++++++++++++++----------------------- 1 file changed, 18 insertions(+), 25 deletions(-) diff --git a/lib/graphicsdev/Metal.mm b/lib/graphicsdev/Metal.mm index 5dbca8d..d3bc94d 100644 --- a/lib/graphicsdev/Metal.mm +++ b/lib/graphicsdev/Metal.mm @@ -857,22 +857,6 @@ static id GetBufferGPUResource(const ObjToken& buf, } } -static id GetBufferGPUResource(const ObjToken& buf, int idx, size_t& strideOut) -{ - if (buf->dynamic()) - { - const MetalGraphicsBufferD* cbuf = buf.cast>(); - strideOut = cbuf->m_stride; - return cbuf->m_bufs[idx]; - } - else - { - const MetalGraphicsBufferS* cbuf = buf.cast(); - strideOut = cbuf->m_stride; - return cbuf->m_buf; - } -} - static id GetTextureGPUResource(const ObjToken& tex, int idx, int bindIdx, bool depth) { switch (tex->type()) @@ -979,16 +963,15 @@ struct MetalShaderDataBinding : GraphicsDataNode { m_pipeline.cast()->bind(enc); - size_t stride; if (m_vbuf) { - id buf = GetBufferGPUResource(m_vbuf, b, stride); - [enc setVertexBuffer:buf offset:stride * m_baseVert atIndex:0]; + id buf = GetBufferGPUResource(m_vbuf, b); + [enc setVertexBuffer:buf offset:0 atIndex:0]; } if (m_instVbo) { - id buf = GetBufferGPUResource(m_instVbo, b, stride); - [enc setVertexBuffer:buf offset:stride * m_baseInst atIndex:1]; + id buf = GetBufferGPUResource(m_instVbo, b); + [enc setVertexBuffer:buf offset:0 atIndex:1]; } if (m_ubufOffs.size()) for (size_t i=0 ; im_baseVert + vertexCount:count]; } void drawIndexed(size_t start, size_t count) @@ -1156,13 +1141,19 @@ struct MetalCommandQueue : IGraphicsCommandQueue indexCount:count indexType:MTLIndexTypeUInt32 indexBuffer:GetBufferGPUResource(m_boundData->m_ibuf, m_fillBuf) - indexBufferOffset:start*4]; + indexBufferOffset:start*4 + instanceCount:1 + baseVertex:m_boundData->m_baseVert + baseInstance:0]; } void drawInstances(size_t start, size_t count, size_t instCount) { [m_enc drawPrimitives:m_currentPrimitive - vertexStart:start vertexCount:count instanceCount:instCount]; + vertexStart:start + m_boundData->m_baseVert + vertexCount:count + instanceCount:instCount + baseInstance:m_boundData->m_baseInst]; } void drawInstancesIndexed(size_t start, size_t count, size_t instCount) @@ -1172,7 +1163,9 @@ struct MetalCommandQueue : IGraphicsCommandQueue indexType:MTLIndexTypeUInt32 indexBuffer:GetBufferGPUResource(m_boundData->m_ibuf, m_fillBuf) indexBufferOffset:start*4 - instanceCount:instCount]; + instanceCount:instCount + baseVertex:m_boundData->m_baseVert + baseInstance:m_boundData->m_baseInst]; } void resolveBindTexture(const ObjToken& texture, const SWindowRect& rect, bool tlOrigin,