Add vsync_interval option

This commit is contained in:
Margen67 2021-12-16 13:57:56 -08:00 committed by Gliniak
parent 485812632a
commit 64b336805e
3 changed files with 9 additions and 1 deletions

View File

@ -20,6 +20,9 @@ DEFINE_path(
DEFINE_bool(vsync, true, "Enable VSYNC.", "GPU"); DEFINE_bool(vsync, true, "Enable VSYNC.", "GPU");
DEFINE_uint64(vsync_interval, 16,
"VSYNC interval. Value is frametime in milliseconds.", "GPU");
DEFINE_bool( DEFINE_bool(
gpu_allow_invalid_fetch_constants, false, gpu_allow_invalid_fetch_constants, false,
"Allow texture and vertex fetch constants with invalid type - generally " "Allow texture and vertex fetch constants with invalid type - generally "

View File

@ -18,6 +18,8 @@ DECLARE_path(dump_shaders);
DECLARE_bool(vsync); DECLARE_bool(vsync);
DECLARE_uint64(vsync_interval);
DECLARE_bool(gpu_allow_invalid_fetch_constants); DECLARE_bool(gpu_allow_invalid_fetch_constants);
DECLARE_bool(half_pixel_offset); DECLARE_bool(half_pixel_offset);

View File

@ -7,6 +7,8 @@
****************************************************************************** ******************************************************************************
*/ */
#include <algorithm>
#include "xenia/gpu/graphics_system.h" #include "xenia/gpu/graphics_system.h"
#include <cstdint> #include <cstdint>
@ -98,7 +100,8 @@ X_STATUS GraphicsSystem::Setup(cpu::Processor* processor,
vsync_worker_running_ = true; vsync_worker_running_ = true;
vsync_worker_thread_ = kernel::object_ref<kernel::XHostThread>( vsync_worker_thread_ = kernel::object_ref<kernel::XHostThread>(
new kernel::XHostThread(kernel_state_, 128 * 1024, 0, [this]() { new kernel::XHostThread(kernel_state_, 128 * 1024, 0, [this]() {
uint64_t vsync_duration = cvars::vsync ? 16 : 1; uint64_t vsync_duration =
cvars::vsync ? std::max<uint64_t>(5, cvars::vsync_interval) : 1;
uint64_t last_frame_time = Clock::QueryGuestTickCount(); uint64_t last_frame_time = Clock::QueryGuestTickCount();
while (vsync_worker_running_) { while (vsync_worker_running_) {
uint64_t current_time = Clock::QueryGuestTickCount(); uint64_t current_time = Clock::QueryGuestTickCount();