From 20ad88e473b23778ee4d106c8b6b70fbae9e96a4 Mon Sep 17 00:00:00 2001 From: Ben Clayton Date: Wed, 14 Mar 2018 17:18:19 +0000 Subject: [PATCH] gles compat: Replace GL_BACK to GL_FRONT for glDrawBuffers() We only render single-buffered at the moment. --- gapis/api/gles/compat.go | 15 +++++++++++++++ 1 file changed, 15 insertions(+) diff --git a/gapis/api/gles/compat.go b/gapis/api/gles/compat.go index 4ce3be2e8d..47b94a2d9f 100644 --- a/gapis/api/gles/compat.go +++ b/gapis/api/gles/compat.go @@ -458,6 +458,21 @@ func compat(ctx context.Context, device *device.Instance, onError onCompatError) } return + case *GlDrawBuffers: + // Currently the default framebuffer for replay is single-buffered + // and so we need to transform any usage of GL_BACK to GL_FRONT. + cmd.Extras().Observations().ApplyReads(s.Memory.ApplicationPool()) + bufs := cmd.Bufs.Slice(0, uint64(cmd.N), s.MemoryLayout).MustRead(ctx, cmd, s, nil) + for i, buf := range bufs { + if buf == GLenum_GL_BACK { + bufs[i] = GLenum_GL_FRONT + } + } + tmp := s.AllocDataOrPanic(ctx, bufs) + out.MutateAndWrite(ctx, id, cb.GlDrawBuffers(cmd.N, tmp.Ptr()).AddRead(tmp.Data())) + tmp.Free() + return + case *GlDrawArrays: if target.vertexArrayObjects == required { if clientVAsBound(c, clientVAs) {