mirror of https://github.com/mgba-emu/mgba.git
GL: Fix VAO semantics
This commit is contained in:
parent
eb5a795101
commit
a0af0ce141
|
@ -571,6 +571,7 @@ static void _compileShader(struct GBAVideoGLRenderer* glRenderer, struct GBAVide
|
||||||
glBindVertexArray(shader->vao);
|
glBindVertexArray(shader->vao);
|
||||||
glBindBuffer(GL_ARRAY_BUFFER, glRenderer->vbo);
|
glBindBuffer(GL_ARRAY_BUFFER, glRenderer->vbo);
|
||||||
GLuint positionLocation = glGetAttribLocation(program, "position");
|
GLuint positionLocation = glGetAttribLocation(program, "position");
|
||||||
|
glEnableVertexAttribArray(positionLocation);
|
||||||
glVertexAttribPointer(positionLocation, 2, GL_INT, GL_FALSE, 0, NULL);
|
glVertexAttribPointer(positionLocation, 2, GL_INT, GL_FALSE, 0, NULL);
|
||||||
|
|
||||||
size_t i;
|
size_t i;
|
||||||
|
@ -1131,12 +1132,12 @@ void GBAVideoGLRendererDrawScanline(struct GBAVideoRenderer* renderer, int y) {
|
||||||
void GBAVideoGLRendererFinishFrame(struct GBAVideoRenderer* renderer) {
|
void GBAVideoGLRendererFinishFrame(struct GBAVideoRenderer* renderer) {
|
||||||
struct GBAVideoGLRenderer* glRenderer = (struct GBAVideoGLRenderer*) renderer;
|
struct GBAVideoGLRenderer* glRenderer = (struct GBAVideoGLRenderer*) renderer;
|
||||||
_finalizeLayers(glRenderer);
|
_finalizeLayers(glRenderer);
|
||||||
|
glBindVertexArray(0);
|
||||||
glRenderer->firstAffine = -1;
|
glRenderer->firstAffine = -1;
|
||||||
glRenderer->bg[2].affine[0].sx = glRenderer->bg[2].refx;
|
glRenderer->bg[2].affine[0].sx = glRenderer->bg[2].refx;
|
||||||
glRenderer->bg[2].affine[0].sy = glRenderer->bg[2].refy;
|
glRenderer->bg[2].affine[0].sy = glRenderer->bg[2].refy;
|
||||||
glRenderer->bg[3].affine[0].sx = glRenderer->bg[3].refx;
|
glRenderer->bg[3].affine[0].sx = glRenderer->bg[3].refx;
|
||||||
glRenderer->bg[3].affine[0].sy = glRenderer->bg[3].refy;
|
glRenderer->bg[3].affine[0].sy = glRenderer->bg[3].refy;
|
||||||
glFlush();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void GBAVideoGLRendererGetPixels(struct GBAVideoRenderer* renderer, size_t* stride, const void** pixels) {
|
void GBAVideoGLRendererGetPixels(struct GBAVideoRenderer* renderer, size_t* stride, const void** pixels) {
|
||||||
|
@ -1273,7 +1274,6 @@ void _finalizeLayers(struct GBAVideoGLRenderer* renderer) {
|
||||||
glUniform1i(uniforms[GBA_GL_FINALIZE_WINDOW], 0);
|
glUniform1i(uniforms[GBA_GL_FINALIZE_WINDOW], 0);
|
||||||
glUniform1i(uniforms[GBA_GL_FINALIZE_BACKDROP], 11);
|
glUniform1i(uniforms[GBA_GL_FINALIZE_BACKDROP], 11);
|
||||||
glUniform1i(uniforms[GBA_GL_FINALIZE_BACKDROPFLAGS], 12);
|
glUniform1i(uniforms[GBA_GL_FINALIZE_BACKDROPFLAGS], 12);
|
||||||
glEnableVertexAttribArray(0);
|
|
||||||
glDrawArrays(GL_TRIANGLE_FAN, 0, 4);
|
glDrawArrays(GL_TRIANGLE_FAN, 0, 4);
|
||||||
glBindFramebuffer(GL_FRAMEBUFFER, 0);
|
glBindFramebuffer(GL_FRAMEBUFFER, 0);
|
||||||
}
|
}
|
||||||
|
@ -1353,7 +1353,6 @@ void GBAVideoGLRendererDrawSprite(struct GBAVideoGLRenderer* renderer, struct GB
|
||||||
} else {
|
} else {
|
||||||
glUniform4i(uniforms[GBA_GL_OBJ_MOSAIC], 0, 0, 0, 0);
|
glUniform4i(uniforms[GBA_GL_OBJ_MOSAIC], 0, 0, 0, 0);
|
||||||
}
|
}
|
||||||
glEnableVertexAttribArray(0);
|
|
||||||
glDrawArrays(GL_TRIANGLE_FAN, 0, 4);
|
glDrawArrays(GL_TRIANGLE_FAN, 0, 4);
|
||||||
glDrawBuffers(1, (GLenum[]) { GL_COLOR_ATTACHMENT0 });
|
glDrawBuffers(1, (GLenum[]) { GL_COLOR_ATTACHMENT0 });
|
||||||
}
|
}
|
||||||
|
@ -1399,7 +1398,6 @@ void GBAVideoGLRendererDrawBackgroundMode0(struct GBAVideoGLRenderer* renderer,
|
||||||
glUniform1i(uniforms[GBA_GL_BG_CHARBASE], background->charBase);
|
glUniform1i(uniforms[GBA_GL_BG_CHARBASE], background->charBase);
|
||||||
glUniform1i(uniforms[GBA_GL_BG_SIZE], background->size);
|
glUniform1i(uniforms[GBA_GL_BG_SIZE], background->size);
|
||||||
glUniform2i(uniforms[GBA_GL_BG_OFFSET], background->x, yBase - y);
|
glUniform2i(uniforms[GBA_GL_BG_OFFSET], background->x, yBase - y);
|
||||||
glEnableVertexAttribArray(0);
|
|
||||||
glDrawArrays(GL_TRIANGLE_FAN, 0, 4);
|
glDrawArrays(GL_TRIANGLE_FAN, 0, 4);
|
||||||
glDrawBuffers(1, (GLenum[]) { GL_COLOR_ATTACHMENT0 });
|
glDrawBuffers(1, (GLenum[]) { GL_COLOR_ATTACHMENT0 });
|
||||||
}
|
}
|
||||||
|
@ -1475,7 +1473,6 @@ void GBAVideoGLRendererDrawBackgroundMode2(struct GBAVideoGLRenderer* renderer,
|
||||||
glUniform1i(uniforms[GBA_GL_BG_SCREENBASE], background->screenBase);
|
glUniform1i(uniforms[GBA_GL_BG_SCREENBASE], background->screenBase);
|
||||||
glUniform1i(uniforms[GBA_GL_BG_CHARBASE], background->charBase);
|
glUniform1i(uniforms[GBA_GL_BG_CHARBASE], background->charBase);
|
||||||
glUniform1i(uniforms[GBA_GL_BG_SIZE], background->size);
|
glUniform1i(uniforms[GBA_GL_BG_SIZE], background->size);
|
||||||
glEnableVertexAttribArray(0);
|
|
||||||
glDrawArrays(GL_TRIANGLE_FAN, 0, 4);
|
glDrawArrays(GL_TRIANGLE_FAN, 0, 4);
|
||||||
glDrawBuffers(1, (GLenum[]) { GL_COLOR_ATTACHMENT0 });
|
glDrawBuffers(1, (GLenum[]) { GL_COLOR_ATTACHMENT0 });
|
||||||
}
|
}
|
||||||
|
@ -1490,7 +1487,6 @@ void GBAVideoGLRendererDrawBackgroundMode3(struct GBAVideoGLRenderer* renderer,
|
||||||
_prepareTransform(renderer, background, uniforms, y);
|
_prepareTransform(renderer, background, uniforms, y);
|
||||||
glUniform1i(uniforms[GBA_GL_BG_CHARBASE], 0);
|
glUniform1i(uniforms[GBA_GL_BG_CHARBASE], 0);
|
||||||
glUniform2i(uniforms[GBA_GL_BG_SIZE], GBA_VIDEO_HORIZONTAL_PIXELS, GBA_VIDEO_VERTICAL_PIXELS);
|
glUniform2i(uniforms[GBA_GL_BG_SIZE], GBA_VIDEO_HORIZONTAL_PIXELS, GBA_VIDEO_VERTICAL_PIXELS);
|
||||||
glEnableVertexAttribArray(0);
|
|
||||||
glDrawArrays(GL_TRIANGLE_FAN, 0, 4);
|
glDrawArrays(GL_TRIANGLE_FAN, 0, 4);
|
||||||
glDrawBuffers(1, (GLenum[]) { GL_COLOR_ATTACHMENT0 });
|
glDrawBuffers(1, (GLenum[]) { GL_COLOR_ATTACHMENT0 });
|
||||||
}
|
}
|
||||||
|
@ -1505,7 +1501,6 @@ void GBAVideoGLRendererDrawBackgroundMode4(struct GBAVideoGLRenderer* renderer,
|
||||||
_prepareTransform(renderer, background, uniforms, y);
|
_prepareTransform(renderer, background, uniforms, y);
|
||||||
glUniform1i(uniforms[GBA_GL_BG_CHARBASE], GBARegisterDISPCNTIsFrameSelect(renderer->dispcnt) ? 0xA000 : 0);
|
glUniform1i(uniforms[GBA_GL_BG_CHARBASE], GBARegisterDISPCNTIsFrameSelect(renderer->dispcnt) ? 0xA000 : 0);
|
||||||
glUniform2i(uniforms[GBA_GL_BG_SIZE], GBA_VIDEO_HORIZONTAL_PIXELS, GBA_VIDEO_VERTICAL_PIXELS);
|
glUniform2i(uniforms[GBA_GL_BG_SIZE], GBA_VIDEO_HORIZONTAL_PIXELS, GBA_VIDEO_VERTICAL_PIXELS);
|
||||||
glEnableVertexAttribArray(0);
|
|
||||||
glDrawArrays(GL_TRIANGLE_FAN, 0, 4);
|
glDrawArrays(GL_TRIANGLE_FAN, 0, 4);
|
||||||
glDrawBuffers(1, (GLenum[]) { GL_COLOR_ATTACHMENT0 });
|
glDrawBuffers(1, (GLenum[]) { GL_COLOR_ATTACHMENT0 });
|
||||||
}
|
}
|
||||||
|
@ -1520,7 +1515,6 @@ void GBAVideoGLRendererDrawBackgroundMode5(struct GBAVideoGLRenderer* renderer,
|
||||||
_prepareTransform(renderer, background, uniforms, y);
|
_prepareTransform(renderer, background, uniforms, y);
|
||||||
glUniform1i(uniforms[GBA_GL_BG_CHARBASE], GBARegisterDISPCNTIsFrameSelect(renderer->dispcnt) ? 0x5000 : 0);
|
glUniform1i(uniforms[GBA_GL_BG_CHARBASE], GBARegisterDISPCNTIsFrameSelect(renderer->dispcnt) ? 0x5000 : 0);
|
||||||
glUniform2i(uniforms[GBA_GL_BG_SIZE], 160, 128);
|
glUniform2i(uniforms[GBA_GL_BG_SIZE], 160, 128);
|
||||||
glEnableVertexAttribArray(0);
|
|
||||||
glDrawArrays(GL_TRIANGLE_FAN, 0, 4);
|
glDrawArrays(GL_TRIANGLE_FAN, 0, 4);
|
||||||
glDrawBuffers(1, (GLenum[]) { GL_COLOR_ATTACHMENT0 });
|
glDrawBuffers(1, (GLenum[]) { GL_COLOR_ATTACHMENT0 });
|
||||||
}
|
}
|
||||||
|
|
|
@ -136,9 +136,11 @@ static void mGLES2ContextInit(struct VideoBackend* v, WHandle handle) {
|
||||||
|
|
||||||
glBindVertexArray(context->initialShader.vao);
|
glBindVertexArray(context->initialShader.vao);
|
||||||
glBindBuffer(GL_ARRAY_BUFFER, context->vbo);
|
glBindBuffer(GL_ARRAY_BUFFER, context->vbo);
|
||||||
|
glEnableVertexAttribArray(context->initialShader.positionLocation);
|
||||||
glVertexAttribPointer(context->initialShader.positionLocation, 2, GL_FLOAT, GL_FALSE, 0, NULL);
|
glVertexAttribPointer(context->initialShader.positionLocation, 2, GL_FLOAT, GL_FALSE, 0, NULL);
|
||||||
glBindVertexArray(context->finalShader.vao);
|
glBindVertexArray(context->finalShader.vao);
|
||||||
glBindBuffer(GL_ARRAY_BUFFER, context->vbo);
|
glBindBuffer(GL_ARRAY_BUFFER, context->vbo);
|
||||||
|
glEnableVertexAttribArray(context->finalShader.positionLocation);
|
||||||
glVertexAttribPointer(context->finalShader.positionLocation, 2, GL_FLOAT, GL_FALSE, 0, NULL);
|
glVertexAttribPointer(context->finalShader.positionLocation, 2, GL_FLOAT, GL_FALSE, 0, NULL);
|
||||||
glBindVertexArray(0);
|
glBindVertexArray(0);
|
||||||
|
|
||||||
|
@ -303,7 +305,6 @@ void _drawShader(struct mGLES2Context* context, struct mGLES2Shader* shader) {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
glEnableVertexAttribArray(shader->positionLocation);
|
|
||||||
glDrawArrays(GL_TRIANGLE_FAN, 0, 4);
|
glDrawArrays(GL_TRIANGLE_FAN, 0, 4);
|
||||||
glBindTexture(GL_TEXTURE_2D, shader->tex);
|
glBindTexture(GL_TEXTURE_2D, shader->tex);
|
||||||
}
|
}
|
||||||
|
@ -327,6 +328,7 @@ void mGLES2ContextDrawFrame(struct VideoBackend* v) {
|
||||||
_drawShader(context, &context->finalShader);
|
_drawShader(context, &context->finalShader);
|
||||||
glBindFramebuffer(GL_FRAMEBUFFER, 0);
|
glBindFramebuffer(GL_FRAMEBUFFER, 0);
|
||||||
glUseProgram(0);
|
glUseProgram(0);
|
||||||
|
glBindVertexArray(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
void mGLES2ContextPostFrame(struct VideoBackend* v, const void* frame) {
|
void mGLES2ContextPostFrame(struct VideoBackend* v, const void* frame) {
|
||||||
|
@ -463,8 +465,8 @@ void mGLES2ShaderAttach(struct mGLES2Context* context, struct mGLES2Shader* shad
|
||||||
|
|
||||||
glBindVertexArray(context->shaders[i].vao);
|
glBindVertexArray(context->shaders[i].vao);
|
||||||
glBindBuffer(GL_ARRAY_BUFFER, context->vbo);
|
glBindBuffer(GL_ARRAY_BUFFER, context->vbo);
|
||||||
glVertexAttribPointer(context->shaders[i].positionLocation, 2, GL_FLOAT, GL_FALSE, 0, NULL);
|
|
||||||
glEnableVertexAttribArray(context->shaders[i].positionLocation);
|
glEnableVertexAttribArray(context->shaders[i].positionLocation);
|
||||||
|
glVertexAttribPointer(context->shaders[i].positionLocation, 2, GL_FLOAT, GL_FALSE, 0, NULL);
|
||||||
}
|
}
|
||||||
glBindVertexArray(0);
|
glBindVertexArray(0);
|
||||||
glBindFramebuffer(GL_FRAMEBUFFER, 0);
|
glBindFramebuffer(GL_FRAMEBUFFER, 0);
|
||||||
|
|
Loading…
Reference in New Issue