diff options
Diffstat (limited to 'src')
| -rw-r--r-- | src/core/hle/service/nvdrv/nvdrv.cpp | 4 | ||||
| -rw-r--r-- | src/core/hle/service/nvflinger/nvflinger.cpp | 8 |
2 files changed, 9 insertions, 3 deletions
diff --git a/src/core/hle/service/nvdrv/nvdrv.cpp b/src/core/hle/service/nvdrv/nvdrv.cpp index 307a7e928..7bfb99e34 100644 --- a/src/core/hle/service/nvdrv/nvdrv.cpp +++ b/src/core/hle/service/nvdrv/nvdrv.cpp | |||
| @@ -40,8 +40,8 @@ Module::Module(Core::System& system) { | |||
| 40 | auto& kernel = system.Kernel(); | 40 | auto& kernel = system.Kernel(); |
| 41 | for (u32 i = 0; i < MaxNvEvents; i++) { | 41 | for (u32 i = 0; i < MaxNvEvents; i++) { |
| 42 | std::string event_label = fmt::format("NVDRV::NvEvent_{}", i); | 42 | std::string event_label = fmt::format("NVDRV::NvEvent_{}", i); |
| 43 | events_interface.events[i] = Kernel::WritableEvent::CreateEventPair( | 43 | events_interface.events[i] = |
| 44 | kernel, Kernel::ResetType::Automatic, event_label); | 44 | Kernel::WritableEvent::CreateEventPair(kernel, Kernel::ResetType::Manual, event_label); |
| 45 | events_interface.status[i] = EventState::Free; | 45 | events_interface.status[i] = EventState::Free; |
| 46 | events_interface.registered[i] = false; | 46 | events_interface.registered[i] = false; |
| 47 | } | 47 | } |
diff --git a/src/core/hle/service/nvflinger/nvflinger.cpp b/src/core/hle/service/nvflinger/nvflinger.cpp index 2e4d707b9..3b251f8c8 100644 --- a/src/core/hle/service/nvflinger/nvflinger.cpp +++ b/src/core/hle/service/nvflinger/nvflinger.cpp | |||
| @@ -170,8 +170,13 @@ const VI::Layer* NVFlinger::FindLayer(u64 display_id, u64 layer_id) const { | |||
| 170 | 170 | ||
| 171 | void NVFlinger::Compose() { | 171 | void NVFlinger::Compose() { |
| 172 | for (auto& display : displays) { | 172 | for (auto& display : displays) { |
| 173 | bool trigger_event = false; | ||
| 173 | // Trigger vsync for this display at the end of drawing | 174 | // Trigger vsync for this display at the end of drawing |
| 174 | SCOPE_EXIT({ display.SignalVSyncEvent(); }); | 175 | SCOPE_EXIT({ |
| 176 | if (trigger_event) { | ||
| 177 | display.SignalVSyncEvent(); | ||
| 178 | } | ||
| 179 | }); | ||
| 175 | 180 | ||
| 176 | // Don't do anything for displays without layers. | 181 | // Don't do anything for displays without layers. |
| 177 | if (!display.HasLayers()) | 182 | if (!display.HasLayers()) |
| @@ -194,6 +199,7 @@ void NVFlinger::Compose() { | |||
| 194 | } | 199 | } |
| 195 | 200 | ||
| 196 | const auto& igbp_buffer = buffer->get().igbp_buffer; | 201 | const auto& igbp_buffer = buffer->get().igbp_buffer; |
| 202 | trigger_event = true; | ||
| 197 | 203 | ||
| 198 | // Now send the buffer to the GPU for drawing. | 204 | // Now send the buffer to the GPU for drawing. |
| 199 | // TODO(Subv): Support more than just disp0. The display device selection is probably based | 205 | // TODO(Subv): Support more than just disp0. The display device selection is probably based |