2013-04-17 23:29:41 -04:00
|
|
|
// Copyright 2013 Dolphin Emulator Project
|
|
|
|
// Licensed under GPLv2
|
|
|
|
// Refer to the license.txt file included.
|
2008-12-08 05:25:12 +00:00
|
|
|
|
2009-01-30 07:35:47 +00:00
|
|
|
#include "GLUtil.h"
|
2008-12-08 05:25:12 +00:00
|
|
|
#include "x64Emitter.h"
|
2013-02-26 13:49:00 -06:00
|
|
|
#include "x64ABI.h"
|
2008-12-08 05:25:12 +00:00
|
|
|
#include "MemoryUtil.h"
|
2011-11-30 21:00:21 -06:00
|
|
|
#include "ProgramShaderCache.h"
|
2008-12-26 17:33:53 +00:00
|
|
|
#include "VertexShaderGen.h"
|
2008-12-08 05:25:12 +00:00
|
|
|
|
|
|
|
#include "CPMemory.h"
|
|
|
|
#include "NativeVertexFormat.h"
|
2010-11-26 09:25:08 +00:00
|
|
|
#include "VertexManager.h"
|
2008-12-08 05:25:12 +00:00
|
|
|
|
|
|
|
// Here's some global state. We only use this to keep track of what we've sent to the OpenGL state
|
|
|
|
// machine.
|
|
|
|
|
2010-11-26 09:25:08 +00:00
|
|
|
namespace OGL
|
|
|
|
{
|
2008-12-25 15:56:36 +00:00
|
|
|
|
2010-11-26 09:25:08 +00:00
|
|
|
NativeVertexFormat* VertexManager::CreateNativeVertexFormat()
|
2008-12-25 15:56:36 +00:00
|
|
|
{
|
|
|
|
return new GLVertexFormat();
|
|
|
|
}
|
|
|
|
|
|
|
|
GLVertexFormat::GLVertexFormat()
|
2008-12-08 05:25:12 +00:00
|
|
|
{
|
2012-12-15 14:43:01 +01:00
|
|
|
|
2008-12-08 05:25:12 +00:00
|
|
|
}
|
|
|
|
|
2008-12-25 15:56:36 +00:00
|
|
|
GLVertexFormat::~GLVertexFormat()
|
2008-12-08 05:25:12 +00:00
|
|
|
{
|
2012-12-15 17:28:58 +01:00
|
|
|
glDeleteVertexArrays(1, &VAO);
|
2008-12-08 05:25:12 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
inline GLuint VarToGL(VarType t)
|
|
|
|
{
|
2010-01-12 00:08:02 +00:00
|
|
|
static const GLuint lookup[5] = {
|
2014-01-24 14:18:55 +01:00
|
|
|
GL_UNSIGNED_BYTE, GL_BYTE, GL_UNSIGNED_SHORT, GL_SHORT, GL_FLOAT
|
2010-01-12 00:08:02 +00:00
|
|
|
};
|
2008-12-08 05:25:12 +00:00
|
|
|
return lookup[t];
|
|
|
|
}
|
|
|
|
|
2014-01-24 14:46:05 +01:00
|
|
|
static void SetPointer(u32 attrib, u32 stride, const AttributeFormat &format)
|
|
|
|
{
|
|
|
|
if (!format.enable)
|
|
|
|
return;
|
|
|
|
|
|
|
|
glEnableVertexAttribArray(attrib);
|
|
|
|
if (format.integer)
|
|
|
|
glVertexAttribIPointer(attrib, format.components, VarToGL(format.type), stride, (u8*)NULL + format.offset);
|
|
|
|
else
|
|
|
|
glVertexAttribPointer(attrib, format.components, VarToGL(format.type), true, stride, (u8*)NULL + format.offset);
|
|
|
|
}
|
|
|
|
|
2008-12-25 15:56:36 +00:00
|
|
|
void GLVertexFormat::Initialize(const PortableVertexDeclaration &_vtx_decl)
|
2008-12-08 05:25:12 +00:00
|
|
|
{
|
2012-12-15 14:43:01 +01:00
|
|
|
this->vtx_decl = _vtx_decl;
|
|
|
|
vertex_stride = vtx_decl.stride;
|
2008-12-08 05:25:12 +00:00
|
|
|
|
2009-04-03 14:35:49 +00:00
|
|
|
// We will not allow vertex components causing uneven strides.
|
2013-10-29 01:23:17 -04:00
|
|
|
if (vertex_stride & 3)
|
2012-12-15 14:43:01 +01:00
|
|
|
PanicAlert("Uneven vertex stride: %i", vertex_stride);
|
2013-10-29 01:23:17 -04:00
|
|
|
|
2012-12-15 14:43:01 +01:00
|
|
|
VertexManager *vm = (OGL::VertexManager*)g_vertex_manager;
|
2013-10-29 01:23:17 -04:00
|
|
|
|
2012-12-15 17:28:58 +01:00
|
|
|
glGenVertexArrays(1, &VAO);
|
|
|
|
glBindVertexArray(VAO);
|
2013-10-29 01:23:17 -04:00
|
|
|
|
2012-12-15 17:28:58 +01:00
|
|
|
// the element buffer is bound directly to the vao, so we must it set for every vao
|
|
|
|
glBindBuffer(GL_ELEMENT_ARRAY_BUFFER, vm->m_index_buffers);
|
2013-01-14 21:36:31 +01:00
|
|
|
glBindBuffer(GL_ARRAY_BUFFER, vm->m_vertex_buffers);
|
2008-12-08 05:25:12 +00:00
|
|
|
|
2014-01-24 14:46:05 +01:00
|
|
|
SetPointer(SHADER_POSITION_ATTRIB, vertex_stride, vtx_decl.position);
|
2013-10-29 01:23:17 -04:00
|
|
|
|
2013-01-14 22:59:08 +01:00
|
|
|
for (int i = 0; i < 3; i++) {
|
2014-01-24 15:16:52 +01:00
|
|
|
SetPointer(SHADER_NORM0_ATTRIB+i, vertex_stride, vtx_decl.normals[i]);
|
2008-12-08 05:25:12 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
for (int i = 0; i < 2; i++) {
|
2014-01-24 15:23:50 +01:00
|
|
|
SetPointer(SHADER_COLOR0_ATTRIB+i, vertex_stride, vtx_decl.colors[i]);
|
2008-12-08 05:25:12 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
for (int i = 0; i < 8; i++) {
|
|
|
|
if (vtx_decl.texcoord_offset[i] != -1) {
|
2013-01-14 22:59:08 +01:00
|
|
|
glEnableVertexAttribArray(SHADER_TEXTURE0_ATTRIB+i);
|
|
|
|
glVertexAttribPointer(SHADER_TEXTURE0_ATTRIB+i, vtx_decl.texcoord_size[i], VarToGL(vtx_decl.texcoord_gl_type[i]),
|
|
|
|
GL_FALSE, vtx_decl.stride, (u8*)NULL + vtx_decl.texcoord_offset[i]);
|
2008-12-08 05:25:12 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (vtx_decl.posmtx_offset != -1) {
|
2012-12-15 17:28:58 +01:00
|
|
|
glEnableVertexAttribArray(SHADER_POSMTX_ATTRIB);
|
2013-04-24 03:03:52 +02:00
|
|
|
glVertexAttribPointer(SHADER_POSMTX_ATTRIB, 4, GL_UNSIGNED_BYTE, GL_FALSE, vtx_decl.stride, (u8*)NULL + vtx_decl.posmtx_offset);
|
2008-12-08 05:25:12 +00:00
|
|
|
}
|
2008-12-26 17:02:46 +00:00
|
|
|
|
2012-12-15 17:28:58 +01:00
|
|
|
vm->m_last_vao = VAO;
|
2008-12-26 17:02:46 +00:00
|
|
|
}
|
|
|
|
|
2012-12-15 14:43:01 +01:00
|
|
|
void GLVertexFormat::SetupVertexPointers() {
|
2012-10-26 11:34:02 -03:00
|
|
|
}
|
2008-12-26 17:02:46 +00:00
|
|
|
|
|
|
|
}
|