mirror of
				https://github.com/yuzu-emu/yuzu-android
				synced 2025-10-25 14:02:26 -07:00 
			
		
		
		
	Merge pull request #12454 from liamwhite/ct-stuff
core_timing: minor refactors
This commit is contained in:
		| @@ -10,15 +10,15 @@ namespace Kernel { | ||||
|  | ||||
| void KHardwareTimer::Initialize() { | ||||
|     // Create the timing callback to register with CoreTiming. | ||||
|     m_event_type = Core::Timing::CreateEvent( | ||||
|         "KHardwareTimer::Callback", [](std::uintptr_t timer_handle, s64, std::chrono::nanoseconds) { | ||||
|             reinterpret_cast<KHardwareTimer*>(timer_handle)->DoTask(); | ||||
|             return std::nullopt; | ||||
|         }); | ||||
|     m_event_type = Core::Timing::CreateEvent("KHardwareTimer::Callback", | ||||
|                                              [this](s64, std::chrono::nanoseconds) { | ||||
|                                                  this->DoTask(); | ||||
|                                                  return std::nullopt; | ||||
|                                              }); | ||||
| } | ||||
|  | ||||
| void KHardwareTimer::Finalize() { | ||||
|     m_kernel.System().CoreTiming().UnscheduleEvent(m_event_type, reinterpret_cast<uintptr_t>(this)); | ||||
|     m_kernel.System().CoreTiming().UnscheduleEvent(m_event_type); | ||||
|     m_wakeup_time = std::numeric_limits<s64>::max(); | ||||
|     m_event_type.reset(); | ||||
| } | ||||
| @@ -57,13 +57,12 @@ void KHardwareTimer::EnableInterrupt(s64 wakeup_time) { | ||||
|  | ||||
|     m_wakeup_time = wakeup_time; | ||||
|     m_kernel.System().CoreTiming().ScheduleEvent(std::chrono::nanoseconds{m_wakeup_time}, | ||||
|                                                  m_event_type, reinterpret_cast<uintptr_t>(this), | ||||
|                                                  true); | ||||
|                                                  m_event_type, true); | ||||
| } | ||||
|  | ||||
| void KHardwareTimer::DisableInterrupt() { | ||||
|     m_kernel.System().CoreTiming().UnscheduleEventWithoutWait(m_event_type, | ||||
|                                                               reinterpret_cast<uintptr_t>(this)); | ||||
|     m_kernel.System().CoreTiming().UnscheduleEvent(m_event_type, | ||||
|                                                    Core::Timing::UnscheduleEventType::NoWait); | ||||
|     m_wakeup_time = std::numeric_limits<s64>::max(); | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -238,7 +238,7 @@ struct KernelCore::Impl { | ||||
|     void InitializePreemption(KernelCore& kernel) { | ||||
|         preemption_event = Core::Timing::CreateEvent( | ||||
|             "PreemptionCallback", | ||||
|             [this, &kernel](std::uintptr_t, s64 time, | ||||
|             [this, &kernel](s64 time, | ||||
|                             std::chrono::nanoseconds) -> std::optional<std::chrono::nanoseconds> { | ||||
|                 { | ||||
|                     KScopedSchedulerLock lock(kernel); | ||||
|   | ||||
| @@ -49,10 +49,10 @@ HidBus::HidBus(Core::System& system_) | ||||
|     // Register update callbacks | ||||
|     hidbus_update_event = Core::Timing::CreateEvent( | ||||
|         "Hidbus::UpdateCallback", | ||||
|         [this](std::uintptr_t user_data, s64 time, | ||||
|         [this](s64 time, | ||||
|                std::chrono::nanoseconds ns_late) -> std::optional<std::chrono::nanoseconds> { | ||||
|             const auto guard = LockService(); | ||||
|             UpdateHidbus(user_data, ns_late); | ||||
|             UpdateHidbus(ns_late); | ||||
|             return std::nullopt; | ||||
|         }); | ||||
|  | ||||
| @@ -61,10 +61,10 @@ HidBus::HidBus(Core::System& system_) | ||||
| } | ||||
|  | ||||
| HidBus::~HidBus() { | ||||
|     system.CoreTiming().UnscheduleEvent(hidbus_update_event, 0); | ||||
|     system.CoreTiming().UnscheduleEvent(hidbus_update_event); | ||||
| } | ||||
|  | ||||
| void HidBus::UpdateHidbus(std::uintptr_t user_data, std::chrono::nanoseconds ns_late) { | ||||
| void HidBus::UpdateHidbus(std::chrono::nanoseconds ns_late) { | ||||
|     if (is_hidbus_enabled) { | ||||
|         for (std::size_t i = 0; i < devices.size(); ++i) { | ||||
|             if (!devices[i].is_device_initializated) { | ||||
|   | ||||
| @@ -108,7 +108,7 @@ private: | ||||
|     void DisableJoyPollingReceiveMode(HLERequestContext& ctx); | ||||
|     void SetStatusManagerType(HLERequestContext& ctx); | ||||
|  | ||||
|     void UpdateHidbus(std::uintptr_t user_data, std::chrono::nanoseconds ns_late); | ||||
|     void UpdateHidbus(std::chrono::nanoseconds ns_late); | ||||
|     std::optional<std::size_t> GetDeviceIndexFromHandle(BusHandle handle) const; | ||||
|  | ||||
|     template <typename T> | ||||
|   | ||||
| @@ -227,8 +227,7 @@ void ResourceManager::EnableTouchScreen(u64 aruid, bool is_enabled) { | ||||
|     applet_resource->EnableTouchScreen(aruid, is_enabled); | ||||
| } | ||||
|  | ||||
| void ResourceManager::UpdateControllers(std::uintptr_t user_data, | ||||
|                                         std::chrono::nanoseconds ns_late) { | ||||
| void ResourceManager::UpdateControllers(std::chrono::nanoseconds ns_late) { | ||||
|     auto& core_timing = system.CoreTiming(); | ||||
|     debug_pad->OnUpdate(core_timing); | ||||
|     digitizer->OnUpdate(core_timing); | ||||
| @@ -241,20 +240,19 @@ void ResourceManager::UpdateControllers(std::uintptr_t user_data, | ||||
|     capture_button->OnUpdate(core_timing); | ||||
| } | ||||
|  | ||||
| void ResourceManager::UpdateNpad(std::uintptr_t user_data, std::chrono::nanoseconds ns_late) { | ||||
| void ResourceManager::UpdateNpad(std::chrono::nanoseconds ns_late) { | ||||
|     auto& core_timing = system.CoreTiming(); | ||||
|     npad->OnUpdate(core_timing); | ||||
| } | ||||
|  | ||||
| void ResourceManager::UpdateMouseKeyboard(std::uintptr_t user_data, | ||||
|                                           std::chrono::nanoseconds ns_late) { | ||||
| void ResourceManager::UpdateMouseKeyboard(std::chrono::nanoseconds ns_late) { | ||||
|     auto& core_timing = system.CoreTiming(); | ||||
|     mouse->OnUpdate(core_timing); | ||||
|     debug_mouse->OnUpdate(core_timing); | ||||
|     keyboard->OnUpdate(core_timing); | ||||
| } | ||||
|  | ||||
| void ResourceManager::UpdateMotion(std::uintptr_t user_data, std::chrono::nanoseconds ns_late) { | ||||
| void ResourceManager::UpdateMotion(std::chrono::nanoseconds ns_late) { | ||||
|     auto& core_timing = system.CoreTiming(); | ||||
|     six_axis->OnUpdate(core_timing); | ||||
|     seven_six_axis->OnUpdate(core_timing); | ||||
| @@ -273,34 +271,34 @@ IAppletResource::IAppletResource(Core::System& system_, std::shared_ptr<Resource | ||||
|     // Register update callbacks | ||||
|     npad_update_event = Core::Timing::CreateEvent( | ||||
|         "HID::UpdatePadCallback", | ||||
|         [this, resource](std::uintptr_t user_data, s64 time, std::chrono::nanoseconds ns_late) | ||||
|             -> std::optional<std::chrono::nanoseconds> { | ||||
|         [this, resource]( | ||||
|             s64 time, std::chrono::nanoseconds ns_late) -> std::optional<std::chrono::nanoseconds> { | ||||
|             const auto guard = LockService(); | ||||
|             resource->UpdateNpad(user_data, ns_late); | ||||
|             resource->UpdateNpad(ns_late); | ||||
|             return std::nullopt; | ||||
|         }); | ||||
|     default_update_event = Core::Timing::CreateEvent( | ||||
|         "HID::UpdateDefaultCallback", | ||||
|         [this, resource](std::uintptr_t user_data, s64 time, std::chrono::nanoseconds ns_late) | ||||
|             -> std::optional<std::chrono::nanoseconds> { | ||||
|         [this, resource]( | ||||
|             s64 time, std::chrono::nanoseconds ns_late) -> std::optional<std::chrono::nanoseconds> { | ||||
|             const auto guard = LockService(); | ||||
|             resource->UpdateControllers(user_data, ns_late); | ||||
|             resource->UpdateControllers(ns_late); | ||||
|             return std::nullopt; | ||||
|         }); | ||||
|     mouse_keyboard_update_event = Core::Timing::CreateEvent( | ||||
|         "HID::UpdateMouseKeyboardCallback", | ||||
|         [this, resource](std::uintptr_t user_data, s64 time, std::chrono::nanoseconds ns_late) | ||||
|             -> std::optional<std::chrono::nanoseconds> { | ||||
|         [this, resource]( | ||||
|             s64 time, std::chrono::nanoseconds ns_late) -> std::optional<std::chrono::nanoseconds> { | ||||
|             const auto guard = LockService(); | ||||
|             resource->UpdateMouseKeyboard(user_data, ns_late); | ||||
|             resource->UpdateMouseKeyboard(ns_late); | ||||
|             return std::nullopt; | ||||
|         }); | ||||
|     motion_update_event = Core::Timing::CreateEvent( | ||||
|         "HID::UpdateMotionCallback", | ||||
|         [this, resource](std::uintptr_t user_data, s64 time, std::chrono::nanoseconds ns_late) | ||||
|             -> std::optional<std::chrono::nanoseconds> { | ||||
|         [this, resource]( | ||||
|             s64 time, std::chrono::nanoseconds ns_late) -> std::optional<std::chrono::nanoseconds> { | ||||
|             const auto guard = LockService(); | ||||
|             resource->UpdateMotion(user_data, ns_late); | ||||
|             resource->UpdateMotion(ns_late); | ||||
|             return std::nullopt; | ||||
|         }); | ||||
|  | ||||
| @@ -314,10 +312,10 @@ IAppletResource::IAppletResource(Core::System& system_, std::shared_ptr<Resource | ||||
| } | ||||
|  | ||||
| IAppletResource::~IAppletResource() { | ||||
|     system.CoreTiming().UnscheduleEvent(npad_update_event, 0); | ||||
|     system.CoreTiming().UnscheduleEvent(default_update_event, 0); | ||||
|     system.CoreTiming().UnscheduleEvent(mouse_keyboard_update_event, 0); | ||||
|     system.CoreTiming().UnscheduleEvent(motion_update_event, 0); | ||||
|     system.CoreTiming().UnscheduleEvent(npad_update_event); | ||||
|     system.CoreTiming().UnscheduleEvent(default_update_event); | ||||
|     system.CoreTiming().UnscheduleEvent(mouse_keyboard_update_event); | ||||
|     system.CoreTiming().UnscheduleEvent(motion_update_event); | ||||
|     resource_manager->FreeAppletResourceId(aruid); | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -81,10 +81,10 @@ public: | ||||
|     void EnablePadInput(u64 aruid, bool is_enabled); | ||||
|     void EnableTouchScreen(u64 aruid, bool is_enabled); | ||||
|  | ||||
|     void UpdateControllers(std::uintptr_t user_data, std::chrono::nanoseconds ns_late); | ||||
|     void UpdateNpad(std::uintptr_t user_data, std::chrono::nanoseconds ns_late); | ||||
|     void UpdateMouseKeyboard(std::uintptr_t user_data, std::chrono::nanoseconds ns_late); | ||||
|     void UpdateMotion(std::uintptr_t user_data, std::chrono::nanoseconds ns_late); | ||||
|     void UpdateControllers(std::chrono::nanoseconds ns_late); | ||||
|     void UpdateNpad(std::chrono::nanoseconds ns_late); | ||||
|     void UpdateMouseKeyboard(std::chrono::nanoseconds ns_late); | ||||
|     void UpdateMotion(std::chrono::nanoseconds ns_late); | ||||
|  | ||||
| private: | ||||
|     Result CreateAppletResourceImpl(u64 aruid); | ||||
|   | ||||
| @@ -67,7 +67,7 @@ Nvnflinger::Nvnflinger(Core::System& system_, HosBinderDriverServer& hos_binder_ | ||||
|     // Schedule the screen composition events | ||||
|     multi_composition_event = Core::Timing::CreateEvent( | ||||
|         "ScreenComposition", | ||||
|         [this](std::uintptr_t, s64 time, | ||||
|         [this](s64 time, | ||||
|                std::chrono::nanoseconds ns_late) -> std::optional<std::chrono::nanoseconds> { | ||||
|             vsync_signal.Set(); | ||||
|             return std::chrono::nanoseconds(GetNextTicks()); | ||||
| @@ -75,7 +75,7 @@ Nvnflinger::Nvnflinger(Core::System& system_, HosBinderDriverServer& hos_binder_ | ||||
|  | ||||
|     single_composition_event = Core::Timing::CreateEvent( | ||||
|         "ScreenComposition", | ||||
|         [this](std::uintptr_t, s64 time, | ||||
|         [this](s64 time, | ||||
|                std::chrono::nanoseconds ns_late) -> std::optional<std::chrono::nanoseconds> { | ||||
|             const auto lock_guard = Lock(); | ||||
|             Compose(); | ||||
| @@ -93,11 +93,11 @@ Nvnflinger::Nvnflinger(Core::System& system_, HosBinderDriverServer& hos_binder_ | ||||
|  | ||||
| Nvnflinger::~Nvnflinger() { | ||||
|     if (system.IsMulticore()) { | ||||
|         system.CoreTiming().UnscheduleEvent(multi_composition_event, {}); | ||||
|         system.CoreTiming().UnscheduleEvent(multi_composition_event); | ||||
|         vsync_thread.request_stop(); | ||||
|         vsync_signal.Set(); | ||||
|     } else { | ||||
|         system.CoreTiming().UnscheduleEvent(single_composition_event, {}); | ||||
|         system.CoreTiming().UnscheduleEvent(single_composition_event); | ||||
|     } | ||||
|  | ||||
|     ShutdownLayers(); | ||||
|   | ||||
		Reference in New Issue
	
	Block a user