diff options
author | Fernando Sahmkow <fsahmkow27@gmail.com> | 2019-06-04 22:10:07 +0200 |
---|---|---|
committer | FernandoS27 <fsahmkow27@gmail.com> | 2019-07-05 21:49:08 +0200 |
commit | ceb5f5079c3efd8046ccf35bbc3507a4c190f355 (patch) | |
tree | dec175c503c14e47d5405808a51bec1fa83f5024 /src/core/hle/service/nvflinger/nvflinger.cpp | |
parent | Merge pull request #2601 from FernandoS27/texture_cache (diff) | |
download | yuzu-ceb5f5079c3efd8046ccf35bbc3507a4c190f355.tar yuzu-ceb5f5079c3efd8046ccf35bbc3507a4c190f355.tar.gz yuzu-ceb5f5079c3efd8046ccf35bbc3507a4c190f355.tar.bz2 yuzu-ceb5f5079c3efd8046ccf35bbc3507a4c190f355.tar.lz yuzu-ceb5f5079c3efd8046ccf35bbc3507a4c190f355.tar.xz yuzu-ceb5f5079c3efd8046ccf35bbc3507a4c190f355.tar.zst yuzu-ceb5f5079c3efd8046ccf35bbc3507a4c190f355.zip |
Diffstat (limited to '')
-rw-r--r-- | src/core/hle/service/nvflinger/nvflinger.cpp | 14 |
1 files changed, 10 insertions, 4 deletions
diff --git a/src/core/hle/service/nvflinger/nvflinger.cpp b/src/core/hle/service/nvflinger/nvflinger.cpp index 3c5c53e24..6d83535e7 100644 --- a/src/core/hle/service/nvflinger/nvflinger.cpp +++ b/src/core/hle/service/nvflinger/nvflinger.cpp @@ -37,15 +37,16 @@ NVFlinger::NVFlinger(Core::Timing::CoreTiming& core_timing) : core_timing{core_t displays.emplace_back(4, "Null"); // Schedule the screen composition events - const auto ticks = Settings::values.force_30fps_mode ? frame_ticks_30fps : frame_ticks; + //const auto ticks = Settings::values.force_30fps_mode ? frame_ticks_30fps : frame_ticks; composition_event = core_timing.RegisterEvent( - "ScreenComposition", [this, ticks](u64 userdata, s64 cycles_late) { + "ScreenComposition", [this](u64 userdata, s64 cycles_late) { Compose(); - this->core_timing.ScheduleEvent(ticks - cycles_late, composition_event); + const auto ticks = GetNextTicks(); + this->core_timing.ScheduleEvent(std::max(0LL,ticks - cycles_late), composition_event); }); - core_timing.ScheduleEvent(ticks, composition_event); + core_timing.ScheduleEvent(frame_ticks, composition_event); } NVFlinger::~NVFlinger() { @@ -206,8 +207,13 @@ void NVFlinger::Compose() { igbp_buffer.width, igbp_buffer.height, igbp_buffer.stride, buffer->get().transform, buffer->get().crop_rect); + swap_interval = buffer->get().swap_interval; buffer_queue.ReleaseBuffer(buffer->get().slot); } } +s64 NVFlinger::GetNextTicks() { + return (Core::Timing::BASE_CLOCK_RATE * (1LL << swap_interval)) / 120; +} + } // namespace Service::NVFlinger |