OGL: Fix perf metrics being overcounted when using a non-native internal resolution.

This commit is contained in:
NeoBrainX 2013-03-01 23:12:41 +01:00
parent 4058b4c38a
commit d1acb0a937
2 changed files with 7 additions and 4 deletions

View file

@ -103,6 +103,7 @@ void PerfQuery::FlushOne()
hr = D3D::context->GetData(entry.query, &result, sizeof(result), 0);
}
// NOTE: Reported pixel metrics should be referenced to native resolution
m_results[entry.query_type] += result * EFB_WIDTH * EFB_HEIGHT / g_renderer->GetTargetWidth() / g_renderer->GetTargetHeight();
m_query_read_pos = (m_query_read_pos + 1) % ARRAYSIZE(m_query_buffer);

View file

@ -1,3 +1,4 @@
#include "RenderBase.h"
#include "GLUtil.h"
#include "PerfQuery.h"
@ -61,12 +62,13 @@ bool PerfQuery::IsFlushed() const
void PerfQuery::FlushOne()
{
auto& entry = m_query_buffer[m_query_read_pos];
GLuint result = 0;
glGetQueryObjectuiv(entry.query_id, GL_QUERY_RESULT, &result);
m_results[entry.query_type] += result;
// NOTE: Reported pixel metrics should be referenced to native resolution
m_results[entry.query_type] += result * EFB_WIDTH * EFB_HEIGHT / g_renderer->GetTargetWidth() / g_renderer->GetTargetHeight();
m_query_read_pos = (m_query_read_pos + 1) % ARRAYSIZE(m_query_buffer);
--m_query_count;
}