mirror of
https://git.h3cjp.net/H3cJP/citra.git
synced 2024-11-25 06:32:48 +00:00
Merge pull request #1006 from yuriks/fb-commit-profile
OpenGL: Add a profiler category measuring framebuffer readback
This commit is contained in:
commit
bb7eb5c574
|
@ -7,6 +7,7 @@
|
||||||
|
|
||||||
#include "common/color.h"
|
#include "common/color.h"
|
||||||
#include "common/math_util.h"
|
#include "common/math_util.h"
|
||||||
|
#include "common/profiler.h"
|
||||||
|
|
||||||
#include "core/hw/gpu.h"
|
#include "core/hw/gpu.h"
|
||||||
#include "core/memory.h"
|
#include "core/memory.h"
|
||||||
|
@ -873,11 +874,15 @@ void RasterizerOpenGL::ReloadDepthBuffer() {
|
||||||
state.Apply();
|
state.Apply();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Common::Profiling::TimingCategory buffer_commit_category("Framebuffer Commit");
|
||||||
|
|
||||||
void RasterizerOpenGL::CommitColorBuffer() {
|
void RasterizerOpenGL::CommitColorBuffer() {
|
||||||
if (last_fb_color_addr != 0) {
|
if (last_fb_color_addr != 0) {
|
||||||
u8* color_buffer = Memory::GetPhysicalPointer(last_fb_color_addr);
|
u8* color_buffer = Memory::GetPhysicalPointer(last_fb_color_addr);
|
||||||
|
|
||||||
if (color_buffer != nullptr) {
|
if (color_buffer != nullptr) {
|
||||||
|
Common::Profiling::ScopeTimer timer(buffer_commit_category);
|
||||||
|
|
||||||
u32 bytes_per_pixel = Pica::Regs::BytesPerColorPixel(fb_color_texture.format);
|
u32 bytes_per_pixel = Pica::Regs::BytesPerColorPixel(fb_color_texture.format);
|
||||||
|
|
||||||
std::unique_ptr<u8[]> temp_gl_color_buffer(new u8[fb_color_texture.width * fb_color_texture.height * bytes_per_pixel]);
|
std::unique_ptr<u8[]> temp_gl_color_buffer(new u8[fb_color_texture.width * fb_color_texture.height * bytes_per_pixel]);
|
||||||
|
@ -913,6 +918,8 @@ void RasterizerOpenGL::CommitDepthBuffer() {
|
||||||
u8* depth_buffer = Memory::GetPhysicalPointer(last_fb_depth_addr);
|
u8* depth_buffer = Memory::GetPhysicalPointer(last_fb_depth_addr);
|
||||||
|
|
||||||
if (depth_buffer != nullptr) {
|
if (depth_buffer != nullptr) {
|
||||||
|
Common::Profiling::ScopeTimer timer(buffer_commit_category);
|
||||||
|
|
||||||
u32 bytes_per_pixel = Pica::Regs::BytesPerDepthPixel(fb_depth_texture.format);
|
u32 bytes_per_pixel = Pica::Regs::BytesPerDepthPixel(fb_depth_texture.format);
|
||||||
|
|
||||||
// OpenGL needs 4 bpp alignment for D24
|
// OpenGL needs 4 bpp alignment for D24
|
||||||
|
|
Loading…
Reference in a new issue