mirror of
https://github.com/dolphin-emu/dolphin.git
synced 2025-01-27 08:15:33 +01:00
Merge pull request #1720 from Armada651/stereo-msaa
FramebufferManager: Support resolving a multi-layered EFB
This commit is contained in:
commit
f978d141c8
@ -29,7 +29,8 @@ D3DTexture2D* &FramebufferManager::GetResolvedEFBColorTexture()
|
|||||||
{
|
{
|
||||||
if (g_ActiveConfig.iMultisampleMode)
|
if (g_ActiveConfig.iMultisampleMode)
|
||||||
{
|
{
|
||||||
D3D::context->ResolveSubresource(m_efb.resolved_color_tex->GetTex(), 0, m_efb.color_tex->GetTex(), 0, DXGI_FORMAT_R8G8B8A8_UNORM);
|
for (int i = 0; i < m_efb.slices; i++)
|
||||||
|
D3D::context->ResolveSubresource(m_efb.resolved_color_tex->GetTex(), D3D11CalcSubresource(0, i, 1), m_efb.color_tex->GetTex(), D3D11CalcSubresource(0, i, 1), DXGI_FORMAT_R8G8B8A8_UNORM);
|
||||||
return m_efb.resolved_color_tex;
|
return m_efb.resolved_color_tex;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
@ -40,8 +41,9 @@ D3DTexture2D* &FramebufferManager::GetResolvedEFBDepthTexture()
|
|||||||
{
|
{
|
||||||
if (g_ActiveConfig.iMultisampleMode)
|
if (g_ActiveConfig.iMultisampleMode)
|
||||||
{
|
{
|
||||||
D3D::context->ResolveSubresource(m_efb.resolved_color_tex->GetTex(), 0, m_efb.color_tex->GetTex(), 0, DXGI_FORMAT_R8G8B8A8_UNORM);
|
for (int i = 0; i < m_efb.slices; i++)
|
||||||
return m_efb.resolved_color_tex;
|
D3D::context->ResolveSubresource(m_efb.resolved_depth_tex->GetTex(), D3D11CalcSubresource(0, i, 1), m_efb.depth_tex->GetTex(), D3D11CalcSubresource(0, i, 1), DXGI_FORMAT_R8G8B8A8_UNORM);
|
||||||
|
return m_efb.resolved_depth_tex;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
return m_efb.depth_tex;
|
return m_efb.depth_tex;
|
||||||
|
@ -21,14 +21,14 @@ int FramebufferManager::m_targetHeight;
|
|||||||
int FramebufferManager::m_msaaSamples;
|
int FramebufferManager::m_msaaSamples;
|
||||||
|
|
||||||
GLenum FramebufferManager::m_textureType;
|
GLenum FramebufferManager::m_textureType;
|
||||||
GLuint FramebufferManager::m_efbFramebuffer;
|
GLuint* FramebufferManager::m_efbFramebuffer;
|
||||||
GLuint FramebufferManager::m_xfbFramebuffer;
|
GLuint FramebufferManager::m_xfbFramebuffer;
|
||||||
GLuint FramebufferManager::m_efbColor;
|
GLuint FramebufferManager::m_efbColor;
|
||||||
GLuint FramebufferManager::m_efbDepth;
|
GLuint FramebufferManager::m_efbDepth;
|
||||||
GLuint FramebufferManager::m_efbColorSwap; // for hot swap when reinterpreting EFB pixel formats
|
GLuint FramebufferManager::m_efbColorSwap; // for hot swap when reinterpreting EFB pixel formats
|
||||||
|
|
||||||
// Only used in MSAA mode.
|
// Only used in MSAA mode.
|
||||||
GLuint FramebufferManager::m_resolvedFramebuffer;
|
GLuint* FramebufferManager::m_resolvedFramebuffer;
|
||||||
GLuint FramebufferManager::m_resolvedColorTexture;
|
GLuint FramebufferManager::m_resolvedColorTexture;
|
||||||
GLuint FramebufferManager::m_resolvedDepthTexture;
|
GLuint FramebufferManager::m_resolvedDepthTexture;
|
||||||
|
|
||||||
@ -38,12 +38,10 @@ SHADER FramebufferManager::m_pixel_format_shaders[2];
|
|||||||
|
|
||||||
FramebufferManager::FramebufferManager(int targetWidth, int targetHeight, int msaaSamples)
|
FramebufferManager::FramebufferManager(int targetWidth, int targetHeight, int msaaSamples)
|
||||||
{
|
{
|
||||||
m_efbFramebuffer = 0;
|
|
||||||
m_xfbFramebuffer = 0;
|
m_xfbFramebuffer = 0;
|
||||||
m_efbColor = 0;
|
m_efbColor = 0;
|
||||||
m_efbDepth = 0;
|
m_efbDepth = 0;
|
||||||
m_efbColorSwap = 0;
|
m_efbColorSwap = 0;
|
||||||
m_resolvedFramebuffer = 0;
|
|
||||||
m_resolvedColorTexture = 0;
|
m_resolvedColorTexture = 0;
|
||||||
m_resolvedDepthTexture = 0;
|
m_resolvedDepthTexture = 0;
|
||||||
|
|
||||||
@ -72,6 +70,8 @@ FramebufferManager::FramebufferManager(int targetWidth, int targetHeight, int ms
|
|||||||
m_efbColorSwap = glObj[2];
|
m_efbColorSwap = glObj[2];
|
||||||
|
|
||||||
m_EFBLayers = (g_ActiveConfig.iStereoMode > 0) ? 2 : 1;
|
m_EFBLayers = (g_ActiveConfig.iStereoMode > 0) ? 2 : 1;
|
||||||
|
m_efbFramebuffer = new GLuint[m_EFBLayers]();
|
||||||
|
m_resolvedFramebuffer = new GLuint[m_EFBLayers]();
|
||||||
|
|
||||||
// OpenGL MSAA textures are a different kind of texture type and must be allocated
|
// OpenGL MSAA textures are a different kind of texture type and must be allocated
|
||||||
// with a different function, so we create them separately.
|
// with a different function, so we create them separately.
|
||||||
@ -99,9 +99,28 @@ FramebufferManager::FramebufferManager(int targetWidth, int targetHeight, int ms
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
m_textureType = GL_TEXTURE_2D_MULTISAMPLE;
|
|
||||||
GLenum resolvedType = GL_TEXTURE_2D_ARRAY;
|
GLenum resolvedType = GL_TEXTURE_2D_ARRAY;
|
||||||
|
|
||||||
|
// Only use a layered multisample texture if needed. Some drivers
|
||||||
|
// slow down significantly with single-layered multisample textures.
|
||||||
|
if (m_EFBLayers > 1)
|
||||||
|
{
|
||||||
|
m_textureType = GL_TEXTURE_2D_MULTISAMPLE_ARRAY;
|
||||||
|
|
||||||
|
glBindTexture(m_textureType, m_efbColor);
|
||||||
|
glTexImage3DMultisample(m_textureType, m_msaaSamples, GL_RGBA, m_targetWidth, m_targetHeight, m_EFBLayers, false);
|
||||||
|
|
||||||
|
glBindTexture(m_textureType, m_efbDepth);
|
||||||
|
glTexImage3DMultisample(m_textureType, m_msaaSamples, GL_DEPTH_COMPONENT24, m_targetWidth, m_targetHeight, m_EFBLayers, false);
|
||||||
|
|
||||||
|
glBindTexture(m_textureType, m_efbColorSwap);
|
||||||
|
glTexImage3DMultisample(m_textureType, m_msaaSamples, GL_RGBA, m_targetWidth, m_targetHeight, m_EFBLayers, false);
|
||||||
|
glBindTexture(m_textureType, 0);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
m_textureType = GL_TEXTURE_2D_MULTISAMPLE;
|
||||||
|
|
||||||
glBindTexture(m_textureType, m_efbColor);
|
glBindTexture(m_textureType, m_efbColor);
|
||||||
glTexImage2DMultisample(m_textureType, m_msaaSamples, GL_RGBA, m_targetWidth, m_targetHeight, false);
|
glTexImage2DMultisample(m_textureType, m_msaaSamples, GL_RGBA, m_targetWidth, m_targetHeight, false);
|
||||||
|
|
||||||
@ -111,6 +130,7 @@ FramebufferManager::FramebufferManager(int targetWidth, int targetHeight, int ms
|
|||||||
glBindTexture(m_textureType, m_efbColorSwap);
|
glBindTexture(m_textureType, m_efbColorSwap);
|
||||||
glTexImage2DMultisample(m_textureType, m_msaaSamples, GL_RGBA, m_targetWidth, m_targetHeight, false);
|
glTexImage2DMultisample(m_textureType, m_msaaSamples, GL_RGBA, m_targetWidth, m_targetHeight, false);
|
||||||
glBindTexture(m_textureType, 0);
|
glBindTexture(m_textureType, 0);
|
||||||
|
}
|
||||||
|
|
||||||
// Although we are able to access the multisampled texture directly, we don't do it everywhere.
|
// Although we are able to access the multisampled texture directly, we don't do it everywhere.
|
||||||
// The old way is to "resolve" this multisampled texture by copying it into a non-sampled texture.
|
// The old way is to "resolve" this multisampled texture by copying it into a non-sampled texture.
|
||||||
@ -133,21 +153,37 @@ FramebufferManager::FramebufferManager(int targetWidth, int targetHeight, int ms
|
|||||||
glTexImage3D(resolvedType, 0, GL_DEPTH_COMPONENT24, m_targetWidth, m_targetHeight, m_EFBLayers, 0, GL_DEPTH_COMPONENT, GL_UNSIGNED_INT, nullptr);
|
glTexImage3D(resolvedType, 0, GL_DEPTH_COMPONENT24, m_targetWidth, m_targetHeight, m_EFBLayers, 0, GL_DEPTH_COMPONENT, GL_UNSIGNED_INT, nullptr);
|
||||||
|
|
||||||
// Bind resolved textures to resolved framebuffer.
|
// Bind resolved textures to resolved framebuffer.
|
||||||
glGenFramebuffers(1, &m_resolvedFramebuffer);
|
glGenFramebuffers(m_EFBLayers, m_resolvedFramebuffer);
|
||||||
glBindFramebuffer(GL_FRAMEBUFFER, m_resolvedFramebuffer);
|
glBindFramebuffer(GL_FRAMEBUFFER, m_resolvedFramebuffer[0]);
|
||||||
FramebufferTexture(GL_FRAMEBUFFER, GL_COLOR_ATTACHMENT0, resolvedType, m_resolvedColorTexture, 0);
|
FramebufferTexture(GL_FRAMEBUFFER, GL_COLOR_ATTACHMENT0, resolvedType, m_resolvedColorTexture, 0);
|
||||||
FramebufferTexture(GL_FRAMEBUFFER, GL_DEPTH_ATTACHMENT, resolvedType, m_resolvedDepthTexture, 0);
|
FramebufferTexture(GL_FRAMEBUFFER, GL_DEPTH_ATTACHMENT, resolvedType, m_resolvedDepthTexture, 0);
|
||||||
|
|
||||||
|
// Bind all the other layers as separate FBOs for blitting.
|
||||||
|
for (unsigned int i = 1; i < m_EFBLayers; i++)
|
||||||
|
{
|
||||||
|
glBindFramebuffer(GL_FRAMEBUFFER, m_resolvedFramebuffer[i]);
|
||||||
|
glFramebufferTextureLayer(GL_FRAMEBUFFER, GL_COLOR_ATTACHMENT0, m_resolvedColorTexture, 0, i);
|
||||||
|
glFramebufferTextureLayer(GL_FRAMEBUFFER, GL_DEPTH_ATTACHMENT, m_resolvedDepthTexture, 0, i);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Create XFB framebuffer; targets will be created elsewhere.
|
// Create XFB framebuffer; targets will be created elsewhere.
|
||||||
glGenFramebuffers(1, &m_xfbFramebuffer);
|
glGenFramebuffers(1, &m_xfbFramebuffer);
|
||||||
|
|
||||||
// Bind target textures to EFB framebuffer.
|
// Bind target textures to EFB framebuffer.
|
||||||
glGenFramebuffers(1, &m_efbFramebuffer);
|
glGenFramebuffers(m_EFBLayers, m_efbFramebuffer);
|
||||||
glBindFramebuffer(GL_FRAMEBUFFER, m_efbFramebuffer);
|
glBindFramebuffer(GL_FRAMEBUFFER, m_efbFramebuffer[0]);
|
||||||
FramebufferTexture(GL_FRAMEBUFFER, GL_COLOR_ATTACHMENT0, m_textureType, m_efbColor, 0);
|
FramebufferTexture(GL_FRAMEBUFFER, GL_COLOR_ATTACHMENT0, m_textureType, m_efbColor, 0);
|
||||||
FramebufferTexture(GL_FRAMEBUFFER, GL_DEPTH_ATTACHMENT, m_textureType, m_efbDepth, 0);
|
FramebufferTexture(GL_FRAMEBUFFER, GL_DEPTH_ATTACHMENT, m_textureType, m_efbDepth, 0);
|
||||||
|
|
||||||
|
// Bind all the other layers as separate FBOs for blitting.
|
||||||
|
for (unsigned int i = 1; i < m_EFBLayers; i++)
|
||||||
|
{
|
||||||
|
glBindFramebuffer(GL_FRAMEBUFFER, m_efbFramebuffer[i]);
|
||||||
|
glFramebufferTextureLayer(GL_FRAMEBUFFER, GL_COLOR_ATTACHMENT0, m_efbColor, 0, i);
|
||||||
|
glFramebufferTextureLayer(GL_FRAMEBUFFER, GL_DEPTH_ATTACHMENT, m_efbDepth, 0, i);
|
||||||
|
}
|
||||||
|
|
||||||
// EFB framebuffer is currently bound, make sure to clear its alpha value to 1.f
|
// EFB framebuffer is currently bound, make sure to clear its alpha value to 1.f
|
||||||
glViewport(0, 0, m_targetWidth, m_targetHeight);
|
glViewport(0, 0, m_targetWidth, m_targetHeight);
|
||||||
glScissor(0, 0, m_targetWidth, m_targetHeight);
|
glScissor(0, 0, m_targetWidth, m_targetHeight);
|
||||||
@ -180,17 +216,41 @@ FramebufferManager::FramebufferManager(int targetWidth, int targetHeight, int ms
|
|||||||
// msaa + sample shading available, so just fetch the sample
|
// msaa + sample shading available, so just fetch the sample
|
||||||
// This will lead to sample shading, but it's the only way to not loose
|
// This will lead to sample shading, but it's the only way to not loose
|
||||||
// the values of each sample.
|
// the values of each sample.
|
||||||
|
if (m_EFBLayers > 1)
|
||||||
|
{
|
||||||
|
sampler =
|
||||||
|
"SAMPLER_BINDING(9) uniform sampler2DMSArray samp9;\n"
|
||||||
|
"vec4 sampleEFB(ivec2 pos) {\n"
|
||||||
|
" return texelFetch(samp9, ivec3(pos, 0), gl_SampleID);\n"
|
||||||
|
"}\n";
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
sampler =
|
sampler =
|
||||||
"SAMPLER_BINDING(9) uniform sampler2DMS samp9;\n"
|
"SAMPLER_BINDING(9) uniform sampler2DMS samp9;\n"
|
||||||
"vec4 sampleEFB(ivec2 pos) {\n"
|
"vec4 sampleEFB(ivec2 pos) {\n"
|
||||||
" return texelFetch(samp9, pos, gl_SampleID);\n"
|
" return texelFetch(samp9, pos, gl_SampleID);\n"
|
||||||
"}\n";
|
"}\n";
|
||||||
}
|
}
|
||||||
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
// msaa without sample shading: calculate the mean value of the pixel
|
// msaa without sample shading: calculate the mean value of the pixel
|
||||||
std::stringstream samples;
|
std::stringstream samples;
|
||||||
samples << m_msaaSamples;
|
samples << m_msaaSamples;
|
||||||
|
if (m_EFBLayers > 1)
|
||||||
|
{
|
||||||
|
sampler =
|
||||||
|
"SAMPLER_BINDING(9) uniform sampler2DMSArray samp9;\n"
|
||||||
|
"vec4 sampleEFB(ivec2 pos) {\n"
|
||||||
|
" vec4 color = vec4(0.0, 0.0, 0.0, 0.0);\n"
|
||||||
|
" for(int i=0; i<" + samples.str() + "; i++)\n"
|
||||||
|
" color += texelFetch(samp9, ivec3(pos, 0), i);\n"
|
||||||
|
" return color / " + samples.str() + ";\n"
|
||||||
|
"}\n";
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
sampler =
|
sampler =
|
||||||
"SAMPLER_BINDING(9) uniform sampler2DMS samp9;\n"
|
"SAMPLER_BINDING(9) uniform sampler2DMS samp9;\n"
|
||||||
"vec4 sampleEFB(ivec2 pos) {\n"
|
"vec4 sampleEFB(ivec2 pos) {\n"
|
||||||
@ -200,6 +260,7 @@ FramebufferManager::FramebufferManager(int targetWidth, int targetHeight, int ms
|
|||||||
" return color / " + samples.str() + ";\n"
|
" return color / " + samples.str() + ";\n"
|
||||||
"}\n";
|
"}\n";
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
std::string ps_rgba6_to_rgb8 = sampler +
|
std::string ps_rgba6_to_rgb8 = sampler +
|
||||||
"out vec4 ocol0;\n"
|
"out vec4 ocol0;\n"
|
||||||
@ -239,13 +300,15 @@ FramebufferManager::~FramebufferManager()
|
|||||||
|
|
||||||
// Note: OpenGL deletion functions silently ignore parameters of "0".
|
// Note: OpenGL deletion functions silently ignore parameters of "0".
|
||||||
|
|
||||||
glObj[0] = m_efbFramebuffer;
|
glDeleteFramebuffers(m_EFBLayers, m_efbFramebuffer);
|
||||||
glObj[1] = m_xfbFramebuffer;
|
glDeleteFramebuffers(m_EFBLayers, m_resolvedFramebuffer);
|
||||||
glObj[2] = m_resolvedFramebuffer;
|
delete [] m_efbFramebuffer;
|
||||||
glDeleteFramebuffers(3, glObj);
|
delete [] m_resolvedFramebuffer;
|
||||||
m_efbFramebuffer = 0;
|
m_efbFramebuffer = nullptr;
|
||||||
|
m_resolvedFramebuffer = nullptr;
|
||||||
|
|
||||||
|
glDeleteFramebuffers(1, &m_xfbFramebuffer);
|
||||||
m_xfbFramebuffer = 0;
|
m_xfbFramebuffer = 0;
|
||||||
m_resolvedFramebuffer = 0;
|
|
||||||
|
|
||||||
glObj[0] = m_resolvedColorTexture;
|
glObj[0] = m_resolvedColorTexture;
|
||||||
glObj[1] = m_resolvedDepthTexture;
|
glObj[1] = m_resolvedDepthTexture;
|
||||||
@ -281,16 +344,19 @@ GLuint FramebufferManager::GetEFBColorTexture(const EFBRectangle& sourceRc)
|
|||||||
targetRc.ClampLL(0, 0, m_targetWidth, m_targetHeight);
|
targetRc.ClampLL(0, 0, m_targetWidth, m_targetHeight);
|
||||||
|
|
||||||
// Resolve.
|
// Resolve.
|
||||||
glBindFramebuffer(GL_READ_FRAMEBUFFER, m_efbFramebuffer);
|
for (unsigned int i = 0; i < m_EFBLayers; i++)
|
||||||
glBindFramebuffer(GL_DRAW_FRAMEBUFFER, m_resolvedFramebuffer);
|
{
|
||||||
|
glBindFramebuffer(GL_READ_FRAMEBUFFER, m_efbFramebuffer[i]);
|
||||||
|
glBindFramebuffer(GL_DRAW_FRAMEBUFFER, m_resolvedFramebuffer[i]);
|
||||||
glBlitFramebuffer(
|
glBlitFramebuffer(
|
||||||
targetRc.left, targetRc.top, targetRc.right, targetRc.bottom,
|
targetRc.left, targetRc.top, targetRc.right, targetRc.bottom,
|
||||||
targetRc.left, targetRc.top, targetRc.right, targetRc.bottom,
|
targetRc.left, targetRc.top, targetRc.right, targetRc.bottom,
|
||||||
GL_COLOR_BUFFER_BIT, GL_NEAREST
|
GL_COLOR_BUFFER_BIT, GL_NEAREST
|
||||||
);
|
);
|
||||||
|
}
|
||||||
|
|
||||||
// Return to EFB.
|
// Return to EFB.
|
||||||
glBindFramebuffer(GL_FRAMEBUFFER, m_efbFramebuffer);
|
glBindFramebuffer(GL_FRAMEBUFFER, m_efbFramebuffer[0]);
|
||||||
|
|
||||||
return m_resolvedColorTexture;
|
return m_resolvedColorTexture;
|
||||||
}
|
}
|
||||||
@ -310,16 +376,19 @@ GLuint FramebufferManager::GetEFBDepthTexture(const EFBRectangle& sourceRc)
|
|||||||
targetRc.ClampLL(0, 0, m_targetWidth, m_targetHeight);
|
targetRc.ClampLL(0, 0, m_targetWidth, m_targetHeight);
|
||||||
|
|
||||||
// Resolve.
|
// Resolve.
|
||||||
glBindFramebuffer(GL_READ_FRAMEBUFFER, m_efbFramebuffer);
|
for (unsigned int i = 0; i < m_EFBLayers; i++)
|
||||||
glBindFramebuffer(GL_DRAW_FRAMEBUFFER, m_resolvedFramebuffer);
|
{
|
||||||
|
glBindFramebuffer(GL_READ_FRAMEBUFFER, m_efbFramebuffer[i]);
|
||||||
|
glBindFramebuffer(GL_DRAW_FRAMEBUFFER, m_resolvedFramebuffer[i]);
|
||||||
glBlitFramebuffer(
|
glBlitFramebuffer(
|
||||||
targetRc.left, targetRc.top, targetRc.right, targetRc.bottom,
|
targetRc.left, targetRc.top, targetRc.right, targetRc.bottom,
|
||||||
targetRc.left, targetRc.top, targetRc.right, targetRc.bottom,
|
targetRc.left, targetRc.top, targetRc.right, targetRc.bottom,
|
||||||
GL_DEPTH_BUFFER_BIT, GL_NEAREST
|
GL_DEPTH_BUFFER_BIT, GL_NEAREST
|
||||||
);
|
);
|
||||||
|
}
|
||||||
|
|
||||||
// Return to EFB.
|
// Return to EFB.
|
||||||
glBindFramebuffer(GL_FRAMEBUFFER, m_efbFramebuffer);
|
glBindFramebuffer(GL_FRAMEBUFFER, m_efbFramebuffer[0]);
|
||||||
|
|
||||||
return m_resolvedDepthTexture;
|
return m_resolvedDepthTexture;
|
||||||
}
|
}
|
||||||
|
@ -68,11 +68,11 @@ public:
|
|||||||
static GLuint GetEFBColorTexture(const EFBRectangle& sourceRc);
|
static GLuint GetEFBColorTexture(const EFBRectangle& sourceRc);
|
||||||
static GLuint GetEFBDepthTexture(const EFBRectangle& sourceRc);
|
static GLuint GetEFBDepthTexture(const EFBRectangle& sourceRc);
|
||||||
|
|
||||||
static GLuint GetEFBFramebuffer() { return m_efbFramebuffer; }
|
static GLuint GetEFBFramebuffer() { return m_efbFramebuffer[0]; }
|
||||||
static GLuint GetXFBFramebuffer() { return m_xfbFramebuffer; }
|
static GLuint GetXFBFramebuffer() { return m_xfbFramebuffer; }
|
||||||
|
|
||||||
// Resolved framebuffer is only used in MSAA mode.
|
// Resolved framebuffer is only used in MSAA mode.
|
||||||
static GLuint GetResolvedFramebuffer() { return m_resolvedFramebuffer; }
|
static GLuint GetResolvedFramebuffer() { return m_resolvedFramebuffer[0]; }
|
||||||
|
|
||||||
static void SetFramebuffer(GLuint fb);
|
static void SetFramebuffer(GLuint fb);
|
||||||
static void FramebufferTexture(GLenum target, GLenum attachment, GLenum textarget, GLuint texture, GLint level);
|
static void FramebufferTexture(GLenum target, GLenum attachment, GLenum textarget, GLuint texture, GLint level);
|
||||||
@ -102,14 +102,14 @@ private:
|
|||||||
static int m_msaaSamples;
|
static int m_msaaSamples;
|
||||||
|
|
||||||
static GLenum m_textureType;
|
static GLenum m_textureType;
|
||||||
static GLuint m_efbFramebuffer;
|
static GLuint* m_efbFramebuffer;
|
||||||
static GLuint m_xfbFramebuffer;
|
static GLuint m_xfbFramebuffer;
|
||||||
static GLuint m_efbColor;
|
static GLuint m_efbColor;
|
||||||
static GLuint m_efbDepth;
|
static GLuint m_efbDepth;
|
||||||
static GLuint m_efbColorSwap;// will be hot swapped with m_efbColor when reinterpreting EFB pixel formats
|
static GLuint m_efbColorSwap;// will be hot swapped with m_efbColor when reinterpreting EFB pixel formats
|
||||||
|
|
||||||
// Only used in MSAA mode, TODO: try to avoid them
|
// Only used in MSAA mode, TODO: try to avoid them
|
||||||
static GLuint m_resolvedFramebuffer;
|
static GLuint* m_resolvedFramebuffer;
|
||||||
static GLuint m_resolvedColorTexture;
|
static GLuint m_resolvedColorTexture;
|
||||||
static GLuint m_resolvedDepthTexture;
|
static GLuint m_resolvedDepthTexture;
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user