From 3b67b91bb2c4c44af7e187670e54895ede6e4b30 Mon Sep 17 00:00:00 2001 From: Hajime Hoshi Date: Sat, 19 Aug 2023 17:15:45 +0900 Subject: [PATCH] internal/graphicscommand: remove redundant buffers Now there are two command queues, uint32sBuffer doesn't have to have two buffers. --- internal/graphicscommand/command.go | 14 ++++---------- 1 file changed, 4 insertions(+), 10 deletions(-) diff --git a/internal/graphicscommand/command.go b/internal/graphicscommand/command.go index 2a56fa4b1..004ad79c6 100644 --- a/internal/graphicscommand/command.go +++ b/internal/graphicscommand/command.go @@ -761,25 +761,19 @@ func (q *commandQueue) prependPreservedUniforms(uniforms []uint32, shader *Shade // uint32sBuffer is a reusable buffer to allocate []uint32. type uint32sBuffer struct { - buf [2][]uint32 - - // index is switched at the end of the frame, - // and the buffer of the original index is kept until the next frame ends. - index int + buf []uint32 } func (b *uint32sBuffer) alloc(n int) []uint32 { - buf := b.buf[b.index] + buf := b.buf if len(buf)+n > cap(buf) { buf = make([]uint32, 0, max(roundUpPower2(len(buf)+n), 16)) } s := buf[len(buf) : len(buf)+n] - b.buf[b.index] = buf[:len(buf)+n] + b.buf = buf[:len(buf)+n] return s } func (b *uint32sBuffer) reset() { - b.buf[b.index] = b.buf[b.index][:0] - b.index++ - b.index %= len(b.buf) + b.buf = b.buf[:0] }