forked from eden-emu/eden
		
	hle: kernel: Migrate KEvent to KAutoObject.
This commit is contained in:
		
							parent
							
								
									11f9080d2e
								
							
						
					
					
						commit
						949231d69c
					
				
					 37 changed files with 269 additions and 266 deletions
				
			
		|  | @ -53,6 +53,7 @@ ResultVal<Handle> HandleTable::Create(Object* obj) { | ||||||
|     switch (obj->GetHandleType()) { |     switch (obj->GetHandleType()) { | ||||||
|     case HandleType::SharedMemory: |     case HandleType::SharedMemory: | ||||||
|     case HandleType::Thread: |     case HandleType::Thread: | ||||||
|  |     case HandleType::Event: | ||||||
|     case HandleType::Process: { |     case HandleType::Process: { | ||||||
|         Handle handle{}; |         Handle handle{}; | ||||||
|         Add(&handle, reinterpret_cast<KAutoObject*>(obj), {}); |         Add(&handle, reinterpret_cast<KAutoObject*>(obj), {}); | ||||||
|  |  | ||||||
|  | @ -9,6 +9,7 @@ | ||||||
| #include "core/core.h" | #include "core/core.h" | ||||||
| #include "core/hardware_properties.h" | #include "core/hardware_properties.h" | ||||||
| #include "core/hle/kernel/init/init_slab_setup.h" | #include "core/hle/kernel/init/init_slab_setup.h" | ||||||
|  | #include "core/hle/kernel/k_event.h" | ||||||
| #include "core/hle/kernel/k_memory_layout.h" | #include "core/hle/kernel/k_memory_layout.h" | ||||||
| #include "core/hle/kernel/k_memory_manager.h" | #include "core/hle/kernel/k_memory_manager.h" | ||||||
| #include "core/hle/kernel/k_shared_memory.h" | #include "core/hle/kernel/k_shared_memory.h" | ||||||
|  | @ -25,6 +26,7 @@ namespace Kernel::Init { | ||||||
| #define FOREACH_SLAB_TYPE(HANDLER, ...)                                                            \ | #define FOREACH_SLAB_TYPE(HANDLER, ...)                                                            \ | ||||||
|     HANDLER(Process, (SLAB_COUNT(Process)), ##__VA_ARGS__)                                         \ |     HANDLER(Process, (SLAB_COUNT(Process)), ##__VA_ARGS__)                                         \ | ||||||
|     HANDLER(KThread, (SLAB_COUNT(KThread)), ##__VA_ARGS__)                                         \ |     HANDLER(KThread, (SLAB_COUNT(KThread)), ##__VA_ARGS__)                                         \ | ||||||
|  |     HANDLER(KEvent, (SLAB_COUNT(KEvent)), ##__VA_ARGS__)                                           \ | ||||||
|     HANDLER(KSharedMemory, (SLAB_COUNT(KSharedMemory)), ##__VA_ARGS__) |     HANDLER(KSharedMemory, (SLAB_COUNT(KSharedMemory)), ##__VA_ARGS__) | ||||||
| 
 | 
 | ||||||
| namespace { | namespace { | ||||||
|  |  | ||||||
|  | @ -4,29 +4,53 @@ | ||||||
| 
 | 
 | ||||||
| #include "core/hle/kernel/k_event.h" | #include "core/hle/kernel/k_event.h" | ||||||
| #include "core/hle/kernel/k_readable_event.h" | #include "core/hle/kernel/k_readable_event.h" | ||||||
|  | #include "core/hle/kernel/k_resource_limit.h" | ||||||
| #include "core/hle/kernel/k_writable_event.h" | #include "core/hle/kernel/k_writable_event.h" | ||||||
|  | #include "core/hle/kernel/process.h" | ||||||
| 
 | 
 | ||||||
| namespace Kernel { | namespace Kernel { | ||||||
| 
 | 
 | ||||||
| KEvent::KEvent(KernelCore& kernel, std::string&& name) : Object{kernel, std::move(name)} {} | KEvent::KEvent(KernelCore& kernel) : KAutoObjectWithSlabHeapAndContainer{kernel} {} | ||||||
| 
 | 
 | ||||||
| KEvent::~KEvent() = default; | KEvent::~KEvent() = default; | ||||||
| 
 | 
 | ||||||
| std::shared_ptr<KEvent> KEvent::Create(KernelCore& kernel, std::string&& name) { | void KEvent::Initialize(std::string&& name_) { | ||||||
|     return std::make_shared<KEvent>(kernel, std::move(name)); |     // Increment reference count.
 | ||||||
| } |     // Because reference count is one on creation, this will result
 | ||||||
|  |     // in a reference count of two. Thus, when both readable and
 | ||||||
|  |     // writable events are closed this object will be destroyed.
 | ||||||
|  |     Open(); | ||||||
| 
 | 
 | ||||||
| void KEvent::Initialize() { |  | ||||||
|     // Create our sub events.
 |     // Create our sub events.
 | ||||||
|     readable_event = std::make_shared<KReadableEvent>(kernel, GetName() + ":Readable"); |     readable_event = std::make_shared<KReadableEvent>(kernel, name_ + ":Readable"); | ||||||
|     writable_event = std::make_shared<KWritableEvent>(kernel, GetName() + ":Writable"); |     writable_event = std::make_shared<KWritableEvent>(kernel, name_ + ":Writable"); | ||||||
| 
 | 
 | ||||||
|     // Initialize our sub sessions.
 |     // Initialize our sub sessions.
 | ||||||
|     readable_event->Initialize(this); |     readable_event->Initialize(this); | ||||||
|     writable_event->Initialize(this); |     writable_event->Initialize(this); | ||||||
| 
 | 
 | ||||||
|  |     // Set our owner process.
 | ||||||
|  |     owner = kernel.CurrentProcess(); | ||||||
|  |     if (owner) { | ||||||
|  |         owner->Open(); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     // Mark initialized.
 |     // Mark initialized.
 | ||||||
|  |     name = std::move(name_); | ||||||
|     initialized = true; |     initialized = true; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | void KEvent::Finalize() { | ||||||
|  |     KAutoObjectWithSlabHeapAndContainer<KEvent, KAutoObjectWithList>::Finalize(); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | void KEvent::PostDestroy(uintptr_t arg) { | ||||||
|  |     // Release the event count resource the owner process holds.
 | ||||||
|  |     Process* owner = reinterpret_cast<Process*>(arg); | ||||||
|  |     if (owner) { | ||||||
|  |         owner->GetResourceLimit()->Release(LimitableResource::Events, 1); | ||||||
|  |         owner->Close(); | ||||||
|  |     } | ||||||
|  | } | ||||||
|  | 
 | ||||||
| } // namespace Kernel
 | } // namespace Kernel
 | ||||||
|  |  | ||||||
|  | @ -4,24 +4,34 @@ | ||||||
| 
 | 
 | ||||||
| #pragma once | #pragma once | ||||||
| 
 | 
 | ||||||
| #include "core/hle/kernel/object.h" | #include "core/hle/kernel/slab_helpers.h" | ||||||
| 
 | 
 | ||||||
| namespace Kernel { | namespace Kernel { | ||||||
| 
 | 
 | ||||||
| class KernelCore; | class KernelCore; | ||||||
| class KReadableEvent; | class KReadableEvent; | ||||||
| class KWritableEvent; | class KWritableEvent; | ||||||
|  | class Process; | ||||||
|  | 
 | ||||||
|  | class KEvent final : public KAutoObjectWithSlabHeapAndContainer<KEvent, KAutoObjectWithList> { | ||||||
|  |     KERNEL_AUTOOBJECT_TRAITS(KEvent, KAutoObject); | ||||||
| 
 | 
 | ||||||
| class KEvent final : public Object { |  | ||||||
| public: | public: | ||||||
|     explicit KEvent(KernelCore& kernel, std::string&& name); |     explicit KEvent(KernelCore& kernel); | ||||||
|     ~KEvent() override; |     ~KEvent() override; | ||||||
| 
 | 
 | ||||||
|     static std::shared_ptr<KEvent> Create(KernelCore& kernel, std::string&& name); |     void Initialize(std::string&& name); | ||||||
| 
 | 
 | ||||||
|     void Initialize(); |     virtual void Finalize() override; | ||||||
| 
 | 
 | ||||||
|     void Finalize() override {} |     virtual bool IsInitialized() const override { | ||||||
|  |         return initialized; | ||||||
|  |     } | ||||||
|  |     virtual uintptr_t GetPostDestroyArgument() const override { | ||||||
|  |         return reinterpret_cast<uintptr_t>(owner); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     static void PostDestroy(uintptr_t arg); | ||||||
| 
 | 
 | ||||||
|     std::string GetTypeName() const override { |     std::string GetTypeName() const override { | ||||||
|         return "KEvent"; |         return "KEvent"; | ||||||
|  | @ -51,6 +61,7 @@ public: | ||||||
| private: | private: | ||||||
|     std::shared_ptr<KReadableEvent> readable_event; |     std::shared_ptr<KReadableEvent> readable_event; | ||||||
|     std::shared_ptr<KWritableEvent> writable_event; |     std::shared_ptr<KWritableEvent> writable_event; | ||||||
|  |     Process* owner{}; | ||||||
|     bool initialized{}; |     bool initialized{}; | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -71,6 +71,8 @@ protected: | ||||||
| 
 | 
 | ||||||
| private: | private: | ||||||
|     std::atomic<u32> object_id{0}; |     std::atomic<u32> object_id{0}; | ||||||
|  | 
 | ||||||
|  | protected: | ||||||
|     std::string name; |     std::string name; | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -1953,14 +1953,11 @@ static ResultCode CreateEvent(Core::System& system, Handle* out_write, Handle* o | ||||||
|     HandleTable& handle_table = kernel.CurrentProcess()->GetHandleTable(); |     HandleTable& handle_table = kernel.CurrentProcess()->GetHandleTable(); | ||||||
| 
 | 
 | ||||||
|     // Create a new event.
 |     // Create a new event.
 | ||||||
|     const auto event = KEvent::Create(kernel, "CreateEvent"); |     KEvent* event = KEvent::CreateWithKernel(kernel); | ||||||
|     if (!event) { |     R_UNLESS(event != nullptr, ResultOutOfResource); | ||||||
|         LOG_ERROR(Kernel_SVC, "Unable to create new events. Event creation limit reached."); |  | ||||||
|         return ResultOutOfResource; |  | ||||||
|     } |  | ||||||
| 
 | 
 | ||||||
|     // Initialize the event.
 |     // Initialize the event.
 | ||||||
|     event->Initialize(); |     event->Initialize("CreateEvent"); | ||||||
| 
 | 
 | ||||||
|     // Add the writable event to the handle table.
 |     // Add the writable event to the handle table.
 | ||||||
|     const auto write_create_result = handle_table.Create(event->GetWritableEvent().get()); |     const auto write_create_result = handle_table.Create(event->GetWritableEvent().get()); | ||||||
|  |  | ||||||
|  | @ -253,7 +253,8 @@ IDebugFunctions::IDebugFunctions(Core::System& system_) | ||||||
| IDebugFunctions::~IDebugFunctions() = default; | IDebugFunctions::~IDebugFunctions() = default; | ||||||
| 
 | 
 | ||||||
| ISelfController::ISelfController(Core::System& system_, NVFlinger::NVFlinger& nvflinger_) | ISelfController::ISelfController(Core::System& system_, NVFlinger::NVFlinger& nvflinger_) | ||||||
|     : ServiceFramework{system_, "ISelfController"}, nvflinger{nvflinger_} { |     : ServiceFramework{system_, "ISelfController"}, nvflinger{nvflinger_}, | ||||||
|  |       launchable_event{system.Kernel()}, accumulated_suspended_tick_changed_event{system.Kernel()} { | ||||||
|     // clang-format off
 |     // clang-format off
 | ||||||
|     static const FunctionInfo functions[] = { |     static const FunctionInfo functions[] = { | ||||||
|         {0, &ISelfController::Exit, "Exit"}, |         {0, &ISelfController::Exit, "Exit"}, | ||||||
|  | @ -306,19 +307,17 @@ ISelfController::ISelfController(Core::System& system_, NVFlinger::NVFlinger& nv | ||||||
| 
 | 
 | ||||||
|     RegisterHandlers(functions); |     RegisterHandlers(functions); | ||||||
| 
 | 
 | ||||||
|     auto& kernel = system.Kernel(); |     launchable_event.Initialize("ISelfController:LaunchableEvent"); | ||||||
|     launchable_event = Kernel::KEvent::Create(kernel, "ISelfController:LaunchableEvent"); |  | ||||||
|     launchable_event->Initialize(); |  | ||||||
| 
 | 
 | ||||||
|     // This event is created by AM on the first time GetAccumulatedSuspendedTickChangedEvent() is
 |     // This event is created by AM on the first time GetAccumulatedSuspendedTickChangedEvent() is
 | ||||||
|     // called. Yuzu can just create it unconditionally, since it doesn't need to support multiple
 |     // called. Yuzu can just create it unconditionally, since it doesn't need to support multiple
 | ||||||
|     // ISelfControllers. The event is signaled on creation, and on transition from suspended -> not
 |     // ISelfControllers. The event is signaled on creation, and on transition from suspended -> not
 | ||||||
|     // suspended if the event has previously been created by a call to
 |     // suspended if the event has previously been created by a call to
 | ||||||
|     // GetAccumulatedSuspendedTickChangedEvent.
 |     // GetAccumulatedSuspendedTickChangedEvent.
 | ||||||
|     accumulated_suspended_tick_changed_event = | 
 | ||||||
|         Kernel::KEvent::Create(kernel, "ISelfController:AccumulatedSuspendedTickChangedEvent"); |     accumulated_suspended_tick_changed_event.Initialize( | ||||||
|     accumulated_suspended_tick_changed_event->Initialize(); |         "ISelfController:AccumulatedSuspendedTickChangedEvent"); | ||||||
|     accumulated_suspended_tick_changed_event->GetWritableEvent()->Signal(); |     accumulated_suspended_tick_changed_event.GetWritableEvent()->Signal(); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| ISelfController::~ISelfController() = default; | ISelfController::~ISelfController() = default; | ||||||
|  | @ -377,11 +376,11 @@ void ISelfController::LeaveFatalSection(Kernel::HLERequestContext& ctx) { | ||||||
| void ISelfController::GetLibraryAppletLaunchableEvent(Kernel::HLERequestContext& ctx) { | void ISelfController::GetLibraryAppletLaunchableEvent(Kernel::HLERequestContext& ctx) { | ||||||
|     LOG_WARNING(Service_AM, "(STUBBED) called"); |     LOG_WARNING(Service_AM, "(STUBBED) called"); | ||||||
| 
 | 
 | ||||||
|     launchable_event->GetWritableEvent()->Signal(); |     launchable_event.GetWritableEvent()->Signal(); | ||||||
| 
 | 
 | ||||||
|     IPC::ResponseBuilder rb{ctx, 2, 1}; |     IPC::ResponseBuilder rb{ctx, 2, 1}; | ||||||
|     rb.Push(RESULT_SUCCESS); |     rb.Push(RESULT_SUCCESS); | ||||||
|     rb.PushCopyObjects(launchable_event->GetReadableEvent()); |     rb.PushCopyObjects(launchable_event.GetReadableEvent()); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void ISelfController::SetScreenShotPermission(Kernel::HLERequestContext& ctx) { | void ISelfController::SetScreenShotPermission(Kernel::HLERequestContext& ctx) { | ||||||
|  | @ -560,7 +559,7 @@ void ISelfController::GetAccumulatedSuspendedTickChangedEvent(Kernel::HLERequest | ||||||
| 
 | 
 | ||||||
|     IPC::ResponseBuilder rb{ctx, 2, 1}; |     IPC::ResponseBuilder rb{ctx, 2, 1}; | ||||||
|     rb.Push(RESULT_SUCCESS); |     rb.Push(RESULT_SUCCESS); | ||||||
|     rb.PushCopyObjects(accumulated_suspended_tick_changed_event->GetReadableEvent()); |     rb.PushCopyObjects(accumulated_suspended_tick_changed_event.GetReadableEvent()); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void ISelfController::SetAlbumImageTakenNotificationEnabled(Kernel::HLERequestContext& ctx) { | void ISelfController::SetAlbumImageTakenNotificationEnabled(Kernel::HLERequestContext& ctx) { | ||||||
|  | @ -578,38 +577,36 @@ void ISelfController::SetAlbumImageTakenNotificationEnabled(Kernel::HLERequestCo | ||||||
|     rb.Push(RESULT_SUCCESS); |     rb.Push(RESULT_SUCCESS); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| AppletMessageQueue::AppletMessageQueue(Kernel::KernelCore& kernel) { | AppletMessageQueue::AppletMessageQueue(Kernel::KernelCore& kernel) | ||||||
|     on_new_message = Kernel::KEvent::Create(kernel, "AMMessageQueue:OnMessageReceived"); |     : on_new_message{kernel}, on_operation_mode_changed{kernel} { | ||||||
|     on_new_message->Initialize(); |     on_new_message.Initialize("AMMessageQueue:OnMessageReceived"); | ||||||
|     on_operation_mode_changed = |     on_operation_mode_changed.Initialize("AMMessageQueue:OperationModeChanged"); | ||||||
|         Kernel::KEvent::Create(kernel, "AMMessageQueue:OperationModeChanged"); |  | ||||||
|     on_operation_mode_changed->Initialize(); |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| AppletMessageQueue::~AppletMessageQueue() = default; | AppletMessageQueue::~AppletMessageQueue() = default; | ||||||
| 
 | 
 | ||||||
| Kernel::KReadableEvent* AppletMessageQueue::GetMessageReceiveEvent() const { | Kernel::KReadableEvent* AppletMessageQueue::GetMessageReceiveEvent() const { | ||||||
|     return on_new_message->GetReadableEvent(); |     return on_new_message.GetReadableEvent().get(); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| Kernel::KReadableEvent* AppletMessageQueue::GetOperationModeChangedEvent() const { | Kernel::KReadableEvent* AppletMessageQueue::GetOperationModeChangedEvent() const { | ||||||
|     return on_operation_mode_changed->GetReadableEvent(); |     return on_operation_mode_changed.GetReadableEvent().get(); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void AppletMessageQueue::PushMessage(AppletMessage msg) { | void AppletMessageQueue::PushMessage(AppletMessage msg) { | ||||||
|     messages.push(msg); |     messages.push(msg); | ||||||
|     on_new_message->GetWritableEvent()->Signal(); |     on_new_message.GetWritableEvent()->Signal(); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| AppletMessageQueue::AppletMessage AppletMessageQueue::PopMessage() { | AppletMessageQueue::AppletMessage AppletMessageQueue::PopMessage() { | ||||||
|     if (messages.empty()) { |     if (messages.empty()) { | ||||||
|         on_new_message->GetWritableEvent()->Clear(); |         on_new_message.GetWritableEvent()->Clear(); | ||||||
|         return AppletMessage::NoMessage; |         return AppletMessage::NoMessage; | ||||||
|     } |     } | ||||||
|     auto msg = messages.front(); |     auto msg = messages.front(); | ||||||
|     messages.pop(); |     messages.pop(); | ||||||
|     if (messages.empty()) { |     if (messages.empty()) { | ||||||
|         on_new_message->GetWritableEvent()->Clear(); |         on_new_message.GetWritableEvent()->Clear(); | ||||||
|     } |     } | ||||||
|     return msg; |     return msg; | ||||||
| } | } | ||||||
|  | @ -629,7 +626,7 @@ void AppletMessageQueue::FocusStateChanged() { | ||||||
| void AppletMessageQueue::OperationModeChanged() { | void AppletMessageQueue::OperationModeChanged() { | ||||||
|     PushMessage(AppletMessage::OperationModeChanged); |     PushMessage(AppletMessage::OperationModeChanged); | ||||||
|     PushMessage(AppletMessage::PerformanceModeChanged); |     PushMessage(AppletMessage::PerformanceModeChanged); | ||||||
|     on_operation_mode_changed->GetWritableEvent()->Signal(); |     on_operation_mode_changed.GetWritableEvent()->Signal(); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| ICommonStateGetter::ICommonStateGetter(Core::System& system_, | ICommonStateGetter::ICommonStateGetter(Core::System& system_, | ||||||
|  | @ -1212,16 +1209,16 @@ void ILibraryAppletCreator::CreateTransferMemoryStorage(Kernel::HLERequestContex | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     auto transfer_mem = |     auto transfer_mem = | ||||||
|         system.CurrentProcess()->GetHandleTable().Get<Kernel::TransferMemory>(handle); |         system.CurrentProcess()->GetHandleTable().GetObject<Kernel::KTransferMemory>(handle); | ||||||
| 
 | 
 | ||||||
|     if (transfer_mem == nullptr) { |     if (transfer_mem.IsNull()) { | ||||||
|         LOG_ERROR(Service_AM, "transfer_mem is a nullptr for handle={:08X}", handle); |         LOG_ERROR(Service_AM, "transfer_mem is a nullptr for handle={:08X}", handle); | ||||||
|         IPC::ResponseBuilder rb{ctx, 2}; |         IPC::ResponseBuilder rb{ctx, 2}; | ||||||
|         rb.Push(RESULT_UNKNOWN); |         rb.Push(RESULT_UNKNOWN); | ||||||
|         return; |         return; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     const u8* const mem_begin = transfer_mem->GetPointer(); |     const u8* const mem_begin = system.Memory().GetPointer(transfer_mem->GetSourceAddress()); | ||||||
|     const u8* const mem_end = mem_begin + transfer_mem->GetSize(); |     const u8* const mem_end = mem_begin + transfer_mem->GetSize(); | ||||||
|     std::vector<u8> memory{mem_begin, mem_end}; |     std::vector<u8> memory{mem_begin, mem_end}; | ||||||
| 
 | 
 | ||||||
|  | @ -1265,7 +1262,9 @@ void ILibraryAppletCreator::CreateHandleStorage(Kernel::HLERequestContext& ctx) | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| IApplicationFunctions::IApplicationFunctions(Core::System& system_) | IApplicationFunctions::IApplicationFunctions(Core::System& system_) | ||||||
|     : ServiceFramework{system_, "IApplicationFunctions"} { |     : ServiceFramework{system_, "IApplicationFunctions"}, gpu_error_detected_event{system.Kernel()}, | ||||||
|  |       friend_invitation_storage_channel_event{system.Kernel()}, | ||||||
|  |       health_warning_disappeared_system_event{system.Kernel()} { | ||||||
|     // clang-format off
 |     // clang-format off
 | ||||||
|     static const FunctionInfo functions[] = { |     static const FunctionInfo functions[] = { | ||||||
|         {1, &IApplicationFunctions::PopLaunchParameter, "PopLaunchParameter"}, |         {1, &IApplicationFunctions::PopLaunchParameter, "PopLaunchParameter"}, | ||||||
|  | @ -1334,15 +1333,11 @@ IApplicationFunctions::IApplicationFunctions(Core::System& system_) | ||||||
|     RegisterHandlers(functions); |     RegisterHandlers(functions); | ||||||
| 
 | 
 | ||||||
|     auto& kernel = system.Kernel(); |     auto& kernel = system.Kernel(); | ||||||
|     gpu_error_detected_event = |     gpu_error_detected_event.Initialize("IApplicationFunctions:GpuErrorDetectedSystemEvent"); | ||||||
|         Kernel::KEvent::Create(kernel, "IApplicationFunctions:GpuErrorDetectedSystemEvent"); |     friend_invitation_storage_channel_event.Initialize( | ||||||
|     gpu_error_detected_event->Initialize(); |         "IApplicationFunctions:FriendInvitationStorageChannelEvent"); | ||||||
|     friend_invitation_storage_channel_event = |     health_warning_disappeared_system_event.Initialize( | ||||||
|         Kernel::KEvent::Create(kernel, "IApplicationFunctions:FriendInvitationStorageChannelEvent"); |         "IApplicationFunctions:HealthWarningDisappearedSystemEvent"); | ||||||
|     friend_invitation_storage_channel_event->Initialize(); |  | ||||||
|     health_warning_disappeared_system_event = |  | ||||||
|         Kernel::KEvent::Create(kernel, "IApplicationFunctions:HealthWarningDisappearedSystemEvent"); |  | ||||||
|     health_warning_disappeared_system_event->Initialize(); |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| IApplicationFunctions::~IApplicationFunctions() = default; | IApplicationFunctions::~IApplicationFunctions() = default; | ||||||
|  | @ -1739,7 +1734,7 @@ void IApplicationFunctions::GetGpuErrorDetectedSystemEvent(Kernel::HLERequestCon | ||||||
| 
 | 
 | ||||||
|     IPC::ResponseBuilder rb{ctx, 2, 1}; |     IPC::ResponseBuilder rb{ctx, 2, 1}; | ||||||
|     rb.Push(RESULT_SUCCESS); |     rb.Push(RESULT_SUCCESS); | ||||||
|     rb.PushCopyObjects(gpu_error_detected_event->GetReadableEvent()); |     rb.PushCopyObjects(gpu_error_detected_event.GetReadableEvent()); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void IApplicationFunctions::GetFriendInvitationStorageChannelEvent(Kernel::HLERequestContext& ctx) { | void IApplicationFunctions::GetFriendInvitationStorageChannelEvent(Kernel::HLERequestContext& ctx) { | ||||||
|  | @ -1747,7 +1742,7 @@ void IApplicationFunctions::GetFriendInvitationStorageChannelEvent(Kernel::HLERe | ||||||
| 
 | 
 | ||||||
|     IPC::ResponseBuilder rb{ctx, 2, 1}; |     IPC::ResponseBuilder rb{ctx, 2, 1}; | ||||||
|     rb.Push(RESULT_SUCCESS); |     rb.Push(RESULT_SUCCESS); | ||||||
|     rb.PushCopyObjects(friend_invitation_storage_channel_event->GetReadableEvent()); |     rb.PushCopyObjects(friend_invitation_storage_channel_event.GetReadableEvent()); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void IApplicationFunctions::TryPopFromFriendInvitationStorageChannel( | void IApplicationFunctions::TryPopFromFriendInvitationStorageChannel( | ||||||
|  | @ -1763,7 +1758,7 @@ void IApplicationFunctions::GetHealthWarningDisappearedSystemEvent(Kernel::HLERe | ||||||
| 
 | 
 | ||||||
|     IPC::ResponseBuilder rb{ctx, 2, 1}; |     IPC::ResponseBuilder rb{ctx, 2, 1}; | ||||||
|     rb.Push(RESULT_SUCCESS); |     rb.Push(RESULT_SUCCESS); | ||||||
|     rb.PushCopyObjects(health_warning_disappeared_system_event->GetReadableEvent()); |     rb.PushCopyObjects(health_warning_disappeared_system_event.GetReadableEvent()); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void InstallInterfaces(SM::ServiceManager& service_manager, NVFlinger::NVFlinger& nvflinger, | void InstallInterfaces(SM::ServiceManager& service_manager, NVFlinger::NVFlinger& nvflinger, | ||||||
|  | @ -1781,7 +1776,8 @@ void InstallInterfaces(SM::ServiceManager& service_manager, NVFlinger::NVFlinger | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| IHomeMenuFunctions::IHomeMenuFunctions(Core::System& system_) | IHomeMenuFunctions::IHomeMenuFunctions(Core::System& system_) | ||||||
|     : ServiceFramework{system_, "IHomeMenuFunctions"} { |     : ServiceFramework{system_, "IHomeMenuFunctions"}, pop_from_general_channel_event{ | ||||||
|  |                                                            system.Kernel()} { | ||||||
|     // clang-format off
 |     // clang-format off
 | ||||||
|     static const FunctionInfo functions[] = { |     static const FunctionInfo functions[] = { | ||||||
|         {10, &IHomeMenuFunctions::RequestToGetForeground, "RequestToGetForeground"}, |         {10, &IHomeMenuFunctions::RequestToGetForeground, "RequestToGetForeground"}, | ||||||
|  | @ -1802,9 +1798,7 @@ IHomeMenuFunctions::IHomeMenuFunctions(Core::System& system_) | ||||||
| 
 | 
 | ||||||
|     RegisterHandlers(functions); |     RegisterHandlers(functions); | ||||||
| 
 | 
 | ||||||
|     pop_from_general_channel_event = |     pop_from_general_channel_event.Initialize("IHomeMenuFunctions:PopFromGeneralChannelEvent"); | ||||||
|         Kernel::KEvent::Create(system.Kernel(), "IHomeMenuFunctions:PopFromGeneralChannelEvent"); |  | ||||||
|     pop_from_general_channel_event->Initialize(); |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| IHomeMenuFunctions::~IHomeMenuFunctions() = default; | IHomeMenuFunctions::~IHomeMenuFunctions() = default; | ||||||
|  | @ -1821,7 +1815,7 @@ void IHomeMenuFunctions::GetPopFromGeneralChannelEvent(Kernel::HLERequestContext | ||||||
| 
 | 
 | ||||||
|     IPC::ResponseBuilder rb{ctx, 2, 1}; |     IPC::ResponseBuilder rb{ctx, 2, 1}; | ||||||
|     rb.Push(RESULT_SUCCESS); |     rb.Push(RESULT_SUCCESS); | ||||||
|     rb.PushCopyObjects(pop_from_general_channel_event->GetReadableEvent()); |     rb.PushCopyObjects(pop_from_general_channel_event.GetReadableEvent()); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| IGlobalStateController::IGlobalStateController(Core::System& system_) | IGlobalStateController::IGlobalStateController(Core::System& system_) | ||||||
|  |  | ||||||
|  | @ -8,11 +8,11 @@ | ||||||
| #include <memory> | #include <memory> | ||||||
| #include <queue> | #include <queue> | ||||||
| 
 | 
 | ||||||
|  | #include "core/hle/kernel/k_event.h" | ||||||
| #include "core/hle/service/service.h" | #include "core/hle/service/service.h" | ||||||
| 
 | 
 | ||||||
| namespace Kernel { | namespace Kernel { | ||||||
| class KernelCore; | class KernelCore; | ||||||
| class KEvent; |  | ||||||
| class TransferMemory; | class TransferMemory; | ||||||
| } // namespace Kernel
 | } // namespace Kernel
 | ||||||
| 
 | 
 | ||||||
|  | @ -67,8 +67,8 @@ public: | ||||||
| 
 | 
 | ||||||
| private: | private: | ||||||
|     std::queue<AppletMessage> messages; |     std::queue<AppletMessage> messages; | ||||||
|     std::shared_ptr<Kernel::KEvent> on_new_message; |     Kernel::KEvent on_new_message; | ||||||
|     std::shared_ptr<Kernel::KEvent> on_operation_mode_changed; |     Kernel::KEvent on_operation_mode_changed; | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| class IWindowController final : public ServiceFramework<IWindowController> { | class IWindowController final : public ServiceFramework<IWindowController> { | ||||||
|  | @ -156,8 +156,8 @@ private: | ||||||
|     }; |     }; | ||||||
| 
 | 
 | ||||||
|     NVFlinger::NVFlinger& nvflinger; |     NVFlinger::NVFlinger& nvflinger; | ||||||
|     std::shared_ptr<Kernel::KEvent> launchable_event; |     Kernel::KEvent launchable_event; | ||||||
|     std::shared_ptr<Kernel::KEvent> accumulated_suspended_tick_changed_event; |     Kernel::KEvent accumulated_suspended_tick_changed_event; | ||||||
| 
 | 
 | ||||||
|     u32 idle_time_detection_extension = 0; |     u32 idle_time_detection_extension = 0; | ||||||
|     u64 num_fatal_sections_entered = 0; |     u64 num_fatal_sections_entered = 0; | ||||||
|  | @ -300,9 +300,9 @@ private: | ||||||
|     bool launch_popped_application_specific = false; |     bool launch_popped_application_specific = false; | ||||||
|     bool launch_popped_account_preselect = false; |     bool launch_popped_account_preselect = false; | ||||||
|     s32 previous_program_index{-1}; |     s32 previous_program_index{-1}; | ||||||
|     std::shared_ptr<Kernel::KEvent> gpu_error_detected_event; |     Kernel::KEvent gpu_error_detected_event; | ||||||
|     std::shared_ptr<Kernel::KEvent> friend_invitation_storage_channel_event; |     Kernel::KEvent friend_invitation_storage_channel_event; | ||||||
|     std::shared_ptr<Kernel::KEvent> health_warning_disappeared_system_event; |     Kernel::KEvent health_warning_disappeared_system_event; | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| class IHomeMenuFunctions final : public ServiceFramework<IHomeMenuFunctions> { | class IHomeMenuFunctions final : public ServiceFramework<IHomeMenuFunctions> { | ||||||
|  | @ -314,7 +314,7 @@ private: | ||||||
|     void RequestToGetForeground(Kernel::HLERequestContext& ctx); |     void RequestToGetForeground(Kernel::HLERequestContext& ctx); | ||||||
|     void GetPopFromGeneralChannelEvent(Kernel::HLERequestContext& ctx); |     void GetPopFromGeneralChannelEvent(Kernel::HLERequestContext& ctx); | ||||||
| 
 | 
 | ||||||
|     std::shared_ptr<Kernel::KEvent> pop_from_general_channel_event; |     Kernel::KEvent pop_from_general_channel_event; | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| class IGlobalStateController final : public ServiceFramework<IGlobalStateController> { | class IGlobalStateController final : public ServiceFramework<IGlobalStateController> { | ||||||
|  |  | ||||||
|  | @ -12,7 +12,6 @@ | ||||||
| #include "core/frontend/applets/profile_select.h" | #include "core/frontend/applets/profile_select.h" | ||||||
| #include "core/frontend/applets/software_keyboard.h" | #include "core/frontend/applets/software_keyboard.h" | ||||||
| #include "core/frontend/applets/web_browser.h" | #include "core/frontend/applets/web_browser.h" | ||||||
| #include "core/hle/kernel/k_event.h" |  | ||||||
| #include "core/hle/kernel/k_readable_event.h" | #include "core/hle/kernel/k_readable_event.h" | ||||||
| #include "core/hle/kernel/k_writable_event.h" | #include "core/hle/kernel/k_writable_event.h" | ||||||
| #include "core/hle/kernel/server_session.h" | #include "core/hle/kernel/server_session.h" | ||||||
|  | @ -31,16 +30,11 @@ | ||||||
| namespace Service::AM::Applets { | namespace Service::AM::Applets { | ||||||
| 
 | 
 | ||||||
| AppletDataBroker::AppletDataBroker(Core::System& system_, LibraryAppletMode applet_mode_) | AppletDataBroker::AppletDataBroker(Core::System& system_, LibraryAppletMode applet_mode_) | ||||||
|     : system{system_}, applet_mode{applet_mode_} { |     : system{system_}, applet_mode{applet_mode_}, state_changed_event{system.Kernel()}, | ||||||
|     state_changed_event = |       pop_out_data_event{system.Kernel()}, pop_interactive_out_data_event{system.Kernel()} { | ||||||
|         Kernel::KEvent::Create(system.Kernel(), "ILibraryAppletAccessor:StateChangedEvent"); |     state_changed_event.Initialize("ILibraryAppletAccessor:StateChangedEvent"); | ||||||
|     state_changed_event->Initialize(); |     pop_out_data_event.Initialize("ILibraryAppletAccessor:PopDataOutEvent"); | ||||||
|     pop_out_data_event = |     pop_interactive_out_data_event.Initialize("ILibraryAppletAccessor:PopInteractiveDataOutEvent"); | ||||||
|         Kernel::KEvent::Create(system.Kernel(), "ILibraryAppletAccessor:PopDataOutEvent"); |  | ||||||
|     pop_out_data_event->Initialize(); |  | ||||||
|     pop_interactive_out_data_event = Kernel::KEvent::Create( |  | ||||||
|         system.Kernel(), "ILibraryAppletAccessor:PopInteractiveDataOutEvent"); |  | ||||||
|     pop_interactive_out_data_event->Initialize(); |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| AppletDataBroker::~AppletDataBroker() = default; | AppletDataBroker::~AppletDataBroker() = default; | ||||||
|  | @ -67,7 +61,7 @@ std::shared_ptr<IStorage> AppletDataBroker::PopNormalDataToGame() { | ||||||
| 
 | 
 | ||||||
|     auto out = std::move(out_channel.front()); |     auto out = std::move(out_channel.front()); | ||||||
|     out_channel.pop_front(); |     out_channel.pop_front(); | ||||||
|     pop_out_data_event->GetWritableEvent()->Clear(); |     pop_out_data_event.GetWritableEvent()->Clear(); | ||||||
|     return out; |     return out; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | @ -86,7 +80,7 @@ std::shared_ptr<IStorage> AppletDataBroker::PopInteractiveDataToGame() { | ||||||
| 
 | 
 | ||||||
|     auto out = std::move(out_interactive_channel.front()); |     auto out = std::move(out_interactive_channel.front()); | ||||||
|     out_interactive_channel.pop_front(); |     out_interactive_channel.pop_front(); | ||||||
|     pop_interactive_out_data_event->GetWritableEvent()->Clear(); |     pop_interactive_out_data_event.GetWritableEvent()->Clear(); | ||||||
|     return out; |     return out; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | @ -105,7 +99,7 @@ void AppletDataBroker::PushNormalDataFromGame(std::shared_ptr<IStorage>&& storag | ||||||
| 
 | 
 | ||||||
| void AppletDataBroker::PushNormalDataFromApplet(std::shared_ptr<IStorage>&& storage) { | void AppletDataBroker::PushNormalDataFromApplet(std::shared_ptr<IStorage>&& storage) { | ||||||
|     out_channel.emplace_back(std::move(storage)); |     out_channel.emplace_back(std::move(storage)); | ||||||
|     pop_out_data_event->GetWritableEvent()->Signal(); |     pop_out_data_event.GetWritableEvent()->Signal(); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void AppletDataBroker::PushInteractiveDataFromGame(std::shared_ptr<IStorage>&& storage) { | void AppletDataBroker::PushInteractiveDataFromGame(std::shared_ptr<IStorage>&& storage) { | ||||||
|  | @ -114,11 +108,11 @@ void AppletDataBroker::PushInteractiveDataFromGame(std::shared_ptr<IStorage>&& s | ||||||
| 
 | 
 | ||||||
| void AppletDataBroker::PushInteractiveDataFromApplet(std::shared_ptr<IStorage>&& storage) { | void AppletDataBroker::PushInteractiveDataFromApplet(std::shared_ptr<IStorage>&& storage) { | ||||||
|     out_interactive_channel.emplace_back(std::move(storage)); |     out_interactive_channel.emplace_back(std::move(storage)); | ||||||
|     pop_interactive_out_data_event->GetWritableEvent()->Signal(); |     pop_interactive_out_data_event.GetWritableEvent()->Signal(); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void AppletDataBroker::SignalStateChanged() const { | void AppletDataBroker::SignalStateChanged() { | ||||||
|     state_changed_event->GetWritableEvent()->Signal(); |     state_changed_event.GetWritableEvent()->Signal(); | ||||||
| 
 | 
 | ||||||
|     switch (applet_mode) { |     switch (applet_mode) { | ||||||
|     case LibraryAppletMode::AllForeground: |     case LibraryAppletMode::AllForeground: | ||||||
|  | @ -143,15 +137,15 @@ void AppletDataBroker::SignalStateChanged() const { | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| Kernel::KReadableEvent* AppletDataBroker::GetNormalDataEvent() const { | Kernel::KReadableEvent* AppletDataBroker::GetNormalDataEvent() const { | ||||||
|     return pop_out_data_event->GetReadableEvent(); |     return pop_out_data_event.GetReadableEvent().get(); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| Kernel::KReadableEvent* AppletDataBroker::GetInteractiveDataEvent() const { | Kernel::KReadableEvent* AppletDataBroker::GetInteractiveDataEvent() const { | ||||||
|     return pop_interactive_out_data_event->GetReadableEvent(); |     return pop_interactive_out_data_event.GetReadableEvent().get(); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| Kernel::KReadableEvent* AppletDataBroker::GetStateChangedEvent() const { | Kernel::KReadableEvent* AppletDataBroker::GetStateChangedEvent() const { | ||||||
|     return state_changed_event->GetReadableEvent(); |     return state_changed_event.GetReadableEvent().get(); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| Applet::Applet(Core::System& system_, LibraryAppletMode applet_mode_) | Applet::Applet(Core::System& system_, LibraryAppletMode applet_mode_) | ||||||
|  |  | ||||||
|  | @ -8,6 +8,7 @@ | ||||||
| #include <queue> | #include <queue> | ||||||
| 
 | 
 | ||||||
| #include "common/swap.h" | #include "common/swap.h" | ||||||
|  | #include "core/hle/kernel/k_event.h" | ||||||
| #include "core/hle/kernel/object.h" | #include "core/hle/kernel/object.h" | ||||||
| 
 | 
 | ||||||
| union ResultCode; | union ResultCode; | ||||||
|  | @ -119,13 +120,13 @@ private: | ||||||
|     // PopInteractiveDataToGame and PushInteractiveDataFromApplet
 |     // PopInteractiveDataToGame and PushInteractiveDataFromApplet
 | ||||||
|     std::deque<std::shared_ptr<IStorage>> out_interactive_channel; |     std::deque<std::shared_ptr<IStorage>> out_interactive_channel; | ||||||
| 
 | 
 | ||||||
|     std::shared_ptr<Kernel::KEvent> state_changed_event; |     Kernel::KEvent state_changed_event; | ||||||
| 
 | 
 | ||||||
|     // Signaled on PushNormalDataFromApplet
 |     // Signaled on PushNormalDataFromApplet
 | ||||||
|     std::shared_ptr<Kernel::KEvent> pop_out_data_event; |     Kernel::KEvent pop_out_data_event; | ||||||
| 
 | 
 | ||||||
|     // Signaled on PushInteractiveDataFromApplet
 |     // Signaled on PushInteractiveDataFromApplet
 | ||||||
|     std::shared_ptr<Kernel::KEvent> pop_interactive_out_data_event; |     Kernel::KEvent pop_interactive_out_data_event; | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| class Applet { | class Applet { | ||||||
|  |  | ||||||
|  | @ -16,7 +16,6 @@ | ||||||
| #include "core/file_sys/patch_manager.h" | #include "core/file_sys/patch_manager.h" | ||||||
| #include "core/file_sys/registered_cache.h" | #include "core/file_sys/registered_cache.h" | ||||||
| #include "core/hle/ipc_helpers.h" | #include "core/hle/ipc_helpers.h" | ||||||
| #include "core/hle/kernel/k_event.h" |  | ||||||
| #include "core/hle/kernel/k_readable_event.h" | #include "core/hle/kernel/k_readable_event.h" | ||||||
| #include "core/hle/kernel/kernel.h" | #include "core/hle/kernel/kernel.h" | ||||||
| #include "core/hle/kernel/process.h" | #include "core/hle/kernel/process.h" | ||||||
|  | @ -50,7 +49,7 @@ static std::vector<u64> AccumulateAOCTitleIDs(Core::System& system) { | ||||||
| class IPurchaseEventManager final : public ServiceFramework<IPurchaseEventManager> { | class IPurchaseEventManager final : public ServiceFramework<IPurchaseEventManager> { | ||||||
| public: | public: | ||||||
|     explicit IPurchaseEventManager(Core::System& system_) |     explicit IPurchaseEventManager(Core::System& system_) | ||||||
|         : ServiceFramework{system_, "IPurchaseEventManager"} { |         : ServiceFramework{system_, "IPurchaseEventManager"}, purchased_event{system.Kernel()} { | ||||||
|         // clang-format off
 |         // clang-format off
 | ||||||
|         static const FunctionInfo functions[] = { |         static const FunctionInfo functions[] = { | ||||||
|             {0, &IPurchaseEventManager::SetDefaultDeliveryTarget, "SetDefaultDeliveryTarget"}, |             {0, &IPurchaseEventManager::SetDefaultDeliveryTarget, "SetDefaultDeliveryTarget"}, | ||||||
|  | @ -63,9 +62,7 @@ public: | ||||||
| 
 | 
 | ||||||
|         RegisterHandlers(functions); |         RegisterHandlers(functions); | ||||||
| 
 | 
 | ||||||
|         purchased_event = |         purchased_event.Initialize("IPurchaseEventManager:PurchasedEvent"); | ||||||
|             Kernel::KEvent::Create(system.Kernel(), "IPurchaseEventManager:PurchasedEvent"); |  | ||||||
|         purchased_event->Initialize(); |  | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
| private: | private: | ||||||
|  | @ -98,14 +95,15 @@ private: | ||||||
| 
 | 
 | ||||||
|         IPC::ResponseBuilder rb{ctx, 2, 1}; |         IPC::ResponseBuilder rb{ctx, 2, 1}; | ||||||
|         rb.Push(RESULT_SUCCESS); |         rb.Push(RESULT_SUCCESS); | ||||||
|         rb.PushCopyObjects(purchased_event->GetReadableEvent()); |         rb.PushCopyObjects(purchased_event.GetReadableEvent()); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     std::shared_ptr<Kernel::KEvent> purchased_event; |     Kernel::KEvent purchased_event; | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| AOC_U::AOC_U(Core::System& system_) | AOC_U::AOC_U(Core::System& system_) | ||||||
|     : ServiceFramework{system_, "aoc:u"}, add_on_content{AccumulateAOCTitleIDs(system)} { |     : ServiceFramework{system_, "aoc:u"}, add_on_content{AccumulateAOCTitleIDs(system)}, | ||||||
|  |       aoc_change_event{system.Kernel()} { | ||||||
|     // clang-format off
 |     // clang-format off
 | ||||||
|     static const FunctionInfo functions[] = { |     static const FunctionInfo functions[] = { | ||||||
|         {0, nullptr, "CountAddOnContentByApplicationId"}, |         {0, nullptr, "CountAddOnContentByApplicationId"}, | ||||||
|  | @ -127,9 +125,7 @@ AOC_U::AOC_U(Core::System& system_) | ||||||
| 
 | 
 | ||||||
|     RegisterHandlers(functions); |     RegisterHandlers(functions); | ||||||
| 
 | 
 | ||||||
|     auto& kernel = system.Kernel(); |     aoc_change_event.Initialize("GetAddOnContentListChanged:Event"); | ||||||
|     aoc_change_event = Kernel::KEvent::Create(kernel, "GetAddOnContentListChanged:Event"); |  | ||||||
|     aoc_change_event->Initialize(); |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| AOC_U::~AOC_U() = default; | AOC_U::~AOC_U() = default; | ||||||
|  | @ -256,7 +252,7 @@ void AOC_U::GetAddOnContentListChangedEvent(Kernel::HLERequestContext& ctx) { | ||||||
| 
 | 
 | ||||||
|     IPC::ResponseBuilder rb{ctx, 2, 1}; |     IPC::ResponseBuilder rb{ctx, 2, 1}; | ||||||
|     rb.Push(RESULT_SUCCESS); |     rb.Push(RESULT_SUCCESS); | ||||||
|     rb.PushCopyObjects(aoc_change_event->GetReadableEvent()); |     rb.PushCopyObjects(aoc_change_event.GetReadableEvent()); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void AOC_U::CreateEcPurchasedEventManager(Kernel::HLERequestContext& ctx) { | void AOC_U::CreateEcPurchasedEventManager(Kernel::HLERequestContext& ctx) { | ||||||
|  |  | ||||||
|  | @ -4,6 +4,7 @@ | ||||||
| 
 | 
 | ||||||
| #pragma once | #pragma once | ||||||
| 
 | 
 | ||||||
|  | #include "core/hle/kernel/k_event.h" | ||||||
| #include "core/hle/service/service.h" | #include "core/hle/service/service.h" | ||||||
| 
 | 
 | ||||||
| namespace Core { | namespace Core { | ||||||
|  | @ -31,7 +32,7 @@ private: | ||||||
|     void CreatePermanentEcPurchasedEventManager(Kernel::HLERequestContext& ctx); |     void CreatePermanentEcPurchasedEventManager(Kernel::HLERequestContext& ctx); | ||||||
| 
 | 
 | ||||||
|     std::vector<u64> add_on_content; |     std::vector<u64> add_on_content; | ||||||
|     std::shared_ptr<Kernel::KEvent> aoc_change_event; |     Kernel::KEvent aoc_change_event; | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| /// Registers all AOC services with the specified service manager.
 | /// Registers all AOC services with the specified service manager.
 | ||||||
|  |  | ||||||
|  | @ -43,9 +43,9 @@ class IAudioOut final : public ServiceFramework<IAudioOut> { | ||||||
| public: | public: | ||||||
|     IAudioOut(Core::System& system_, AudoutParams audio_params_, AudioCore::AudioOut& audio_core_, |     IAudioOut(Core::System& system_, AudoutParams audio_params_, AudioCore::AudioOut& audio_core_, | ||||||
|               std::string&& device_name_, std::string&& unique_name) |               std::string&& device_name_, std::string&& unique_name) | ||||||
|         : ServiceFramework{system_, "IAudioOut"}, audio_core{audio_core_}, |         : ServiceFramework{system_, "IAudioOut"}, audio_core{audio_core_}, device_name{std::move( | ||||||
|           device_name{std::move(device_name_)}, audio_params{audio_params_}, main_memory{ |                                                                                device_name_)}, | ||||||
|                                                                                  system.Memory()} { |           audio_params{audio_params_}, buffer_event{system.Kernel()}, main_memory{system.Memory()} { | ||||||
|         // clang-format off
 |         // clang-format off
 | ||||||
|         static const FunctionInfo functions[] = { |         static const FunctionInfo functions[] = { | ||||||
|             {0, &IAudioOut::GetAudioOutState, "GetAudioOutState"}, |             {0, &IAudioOut::GetAudioOutState, "GetAudioOutState"}, | ||||||
|  | @ -67,13 +67,12 @@ public: | ||||||
|         RegisterHandlers(functions); |         RegisterHandlers(functions); | ||||||
| 
 | 
 | ||||||
|         // This is the event handle used to check if the audio buffer was released
 |         // This is the event handle used to check if the audio buffer was released
 | ||||||
|         buffer_event = Kernel::KEvent::Create(system.Kernel(), "IAudioOutBufferReleased"); |         buffer_event.Initialize("IAudioOutBufferReleased"); | ||||||
|         buffer_event->Initialize(); |  | ||||||
| 
 | 
 | ||||||
|         stream = audio_core.OpenStream(system.CoreTiming(), audio_params.sample_rate, |         stream = audio_core.OpenStream(system.CoreTiming(), audio_params.sample_rate, | ||||||
|                                        audio_params.channel_count, std::move(unique_name), [this] { |                                        audio_params.channel_count, std::move(unique_name), [this] { | ||||||
|                                            const auto guard = LockService(); |                                            const auto guard = LockService(); | ||||||
|                                            buffer_event->GetWritableEvent()->Signal(); |                                            buffer_event.GetWritableEvent()->Signal(); | ||||||
|                                        }); |                                        }); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  | @ -126,7 +125,7 @@ private: | ||||||
| 
 | 
 | ||||||
|         IPC::ResponseBuilder rb{ctx, 2, 1}; |         IPC::ResponseBuilder rb{ctx, 2, 1}; | ||||||
|         rb.Push(RESULT_SUCCESS); |         rb.Push(RESULT_SUCCESS); | ||||||
|         rb.PushCopyObjects(buffer_event->GetReadableEvent()); |         rb.PushCopyObjects(buffer_event.GetReadableEvent()); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     void AppendAudioOutBufferImpl(Kernel::HLERequestContext& ctx) { |     void AppendAudioOutBufferImpl(Kernel::HLERequestContext& ctx) { | ||||||
|  | @ -220,7 +219,7 @@ private: | ||||||
|     [[maybe_unused]] AudoutParams audio_params{}; |     [[maybe_unused]] AudoutParams audio_params{}; | ||||||
| 
 | 
 | ||||||
|     /// This is the event handle used to check if the audio buffer was released
 |     /// This is the event handle used to check if the audio buffer was released
 | ||||||
|     std::shared_ptr<Kernel::KEvent> buffer_event; |     Kernel::KEvent buffer_event; | ||||||
|     Core::Memory::Memory& main_memory; |     Core::Memory::Memory& main_memory; | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -30,7 +30,7 @@ public: | ||||||
|     explicit IAudioRenderer(Core::System& system_, |     explicit IAudioRenderer(Core::System& system_, | ||||||
|                             const AudioCommon::AudioRendererParameter& audren_params, |                             const AudioCommon::AudioRendererParameter& audren_params, | ||||||
|                             const std::size_t instance_number) |                             const std::size_t instance_number) | ||||||
|         : ServiceFramework{system_, "IAudioRenderer"} { |         : ServiceFramework{system_, "IAudioRenderer"}, system_event{system.Kernel()} { | ||||||
|         // clang-format off
 |         // clang-format off
 | ||||||
|         static const FunctionInfo functions[] = { |         static const FunctionInfo functions[] = { | ||||||
|             {0, &IAudioRenderer::GetSampleRate, "GetSampleRate"}, |             {0, &IAudioRenderer::GetSampleRate, "GetSampleRate"}, | ||||||
|  | @ -49,13 +49,12 @@ public: | ||||||
|         // clang-format on
 |         // clang-format on
 | ||||||
|         RegisterHandlers(functions); |         RegisterHandlers(functions); | ||||||
| 
 | 
 | ||||||
|         system_event = Kernel::KEvent::Create(system.Kernel(), "IAudioRenderer:SystemEvent"); |         system_event.Initialize("IAudioRenderer:SystemEvent"); | ||||||
|         system_event->Initialize(); |  | ||||||
|         renderer = std::make_unique<AudioCore::AudioRenderer>( |         renderer = std::make_unique<AudioCore::AudioRenderer>( | ||||||
|             system.CoreTiming(), system.Memory(), audren_params, |             system.CoreTiming(), system.Memory(), audren_params, | ||||||
|             [this]() { |             [this]() { | ||||||
|                 const auto guard = LockService(); |                 const auto guard = LockService(); | ||||||
|                 system_event->GetWritableEvent()->Signal(); |                 system_event.GetWritableEvent()->Signal(); | ||||||
|             }, |             }, | ||||||
|             instance_number); |             instance_number); | ||||||
|     } |     } | ||||||
|  | @ -128,7 +127,7 @@ private: | ||||||
| 
 | 
 | ||||||
|         IPC::ResponseBuilder rb{ctx, 2, 1}; |         IPC::ResponseBuilder rb{ctx, 2, 1}; | ||||||
|         rb.Push(RESULT_SUCCESS); |         rb.Push(RESULT_SUCCESS); | ||||||
|         rb.PushCopyObjects(system_event->GetReadableEvent()); |         rb.PushCopyObjects(system_event.GetReadableEvent()); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     void SetRenderingTimeLimit(Kernel::HLERequestContext& ctx) { |     void SetRenderingTimeLimit(Kernel::HLERequestContext& ctx) { | ||||||
|  | @ -162,7 +161,7 @@ private: | ||||||
|         rb.Push(ERR_NOT_SUPPORTED); |         rb.Push(ERR_NOT_SUPPORTED); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     std::shared_ptr<Kernel::KEvent> system_event; |     Kernel::KEvent system_event; | ||||||
|     std::unique_ptr<AudioCore::AudioRenderer> renderer; |     std::unique_ptr<AudioCore::AudioRenderer> renderer; | ||||||
|     u32 rendering_time_limit_percent = 100; |     u32 rendering_time_limit_percent = 100; | ||||||
| }; | }; | ||||||
|  | @ -170,7 +169,9 @@ private: | ||||||
| class IAudioDevice final : public ServiceFramework<IAudioDevice> { | class IAudioDevice final : public ServiceFramework<IAudioDevice> { | ||||||
| public: | public: | ||||||
|     explicit IAudioDevice(Core::System& system_, u32_le revision_num) |     explicit IAudioDevice(Core::System& system_, u32_le revision_num) | ||||||
|         : ServiceFramework{system_, "IAudioDevice"}, revision{revision_num} { |         : ServiceFramework{system_, "IAudioDevice"}, revision{revision_num}, | ||||||
|  |           buffer_event{system.Kernel()}, audio_input_device_switch_event{system.Kernel()}, | ||||||
|  |           audio_output_device_switch_event{system.Kernel()} { | ||||||
|         static const FunctionInfo functions[] = { |         static const FunctionInfo functions[] = { | ||||||
|             {0, &IAudioDevice::ListAudioDeviceName, "ListAudioDeviceName"}, |             {0, &IAudioDevice::ListAudioDeviceName, "ListAudioDeviceName"}, | ||||||
|             {1, &IAudioDevice::SetAudioDeviceOutputVolume, "SetAudioDeviceOutputVolume"}, |             {1, &IAudioDevice::SetAudioDeviceOutputVolume, "SetAudioDeviceOutputVolume"}, | ||||||
|  | @ -188,20 +189,14 @@ public: | ||||||
|         }; |         }; | ||||||
|         RegisterHandlers(functions); |         RegisterHandlers(functions); | ||||||
| 
 | 
 | ||||||
|         auto& kernel = system.Kernel(); |         buffer_event.Initialize("IAudioOutBufferReleasedEvent"); | ||||||
|         buffer_event = Kernel::KEvent::Create(kernel, "IAudioOutBufferReleasedEvent"); |  | ||||||
|         buffer_event->Initialize(); |  | ||||||
| 
 | 
 | ||||||
|         // Should be similar to audio_output_device_switch_event
 |         // Should be similar to audio_output_device_switch_event
 | ||||||
|         audio_input_device_switch_event = |         audio_input_device_switch_event.Initialize("IAudioDevice:AudioInputDeviceSwitchedEvent"); | ||||||
|             Kernel::KEvent::Create(kernel, "IAudioDevice:AudioInputDeviceSwitchedEvent"); |  | ||||||
|         audio_input_device_switch_event->Initialize(); |  | ||||||
| 
 | 
 | ||||||
|         // Should only be signalled when an audio output device has been changed, example: speaker
 |         // Should only be signalled when an audio output device has been changed, example: speaker
 | ||||||
|         // to headset
 |         // to headset
 | ||||||
|         audio_output_device_switch_event = |         audio_output_device_switch_event.Initialize("IAudioDevice:AudioOutputDeviceSwitchedEvent"); | ||||||
|             Kernel::KEvent::Create(kernel, "IAudioDevice:AudioOutputDeviceSwitchedEvent"); |  | ||||||
|         audio_output_device_switch_event->Initialize(); |  | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
| private: | private: | ||||||
|  | @ -290,11 +285,11 @@ private: | ||||||
|     void QueryAudioDeviceSystemEvent(Kernel::HLERequestContext& ctx) { |     void QueryAudioDeviceSystemEvent(Kernel::HLERequestContext& ctx) { | ||||||
|         LOG_WARNING(Service_Audio, "(STUBBED) called"); |         LOG_WARNING(Service_Audio, "(STUBBED) called"); | ||||||
| 
 | 
 | ||||||
|         buffer_event->GetWritableEvent()->Signal(); |         buffer_event.GetWritableEvent()->Signal(); | ||||||
| 
 | 
 | ||||||
|         IPC::ResponseBuilder rb{ctx, 2, 1}; |         IPC::ResponseBuilder rb{ctx, 2, 1}; | ||||||
|         rb.Push(RESULT_SUCCESS); |         rb.Push(RESULT_SUCCESS); | ||||||
|         rb.PushCopyObjects(buffer_event->GetReadableEvent()); |         rb.PushCopyObjects(buffer_event.GetReadableEvent()); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     void GetActiveChannelCount(Kernel::HLERequestContext& ctx) { |     void GetActiveChannelCount(Kernel::HLERequestContext& ctx) { | ||||||
|  | @ -311,7 +306,7 @@ private: | ||||||
| 
 | 
 | ||||||
|         IPC::ResponseBuilder rb{ctx, 2, 1}; |         IPC::ResponseBuilder rb{ctx, 2, 1}; | ||||||
|         rb.Push(RESULT_SUCCESS); |         rb.Push(RESULT_SUCCESS); | ||||||
|         rb.PushCopyObjects(audio_input_device_switch_event->GetReadableEvent()); |         rb.PushCopyObjects(audio_input_device_switch_event.GetReadableEvent()); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     void QueryAudioDeviceOutputEvent(Kernel::HLERequestContext& ctx) { |     void QueryAudioDeviceOutputEvent(Kernel::HLERequestContext& ctx) { | ||||||
|  | @ -319,13 +314,13 @@ private: | ||||||
| 
 | 
 | ||||||
|         IPC::ResponseBuilder rb{ctx, 2, 1}; |         IPC::ResponseBuilder rb{ctx, 2, 1}; | ||||||
|         rb.Push(RESULT_SUCCESS); |         rb.Push(RESULT_SUCCESS); | ||||||
|         rb.PushCopyObjects(audio_output_device_switch_event->GetReadableEvent()); |         rb.PushCopyObjects(audio_output_device_switch_event.GetReadableEvent()); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     u32_le revision = 0; |     u32_le revision = 0; | ||||||
|     std::shared_ptr<Kernel::KEvent> buffer_event; |     Kernel::KEvent buffer_event; | ||||||
|     std::shared_ptr<Kernel::KEvent> audio_input_device_switch_event; |     Kernel::KEvent audio_input_device_switch_event; | ||||||
|     std::shared_ptr<Kernel::KEvent> audio_output_device_switch_event; |     Kernel::KEvent audio_output_device_switch_event; | ||||||
| 
 | 
 | ||||||
| }; // namespace Audio
 | }; // namespace Audio
 | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -5,7 +5,6 @@ | ||||||
| #include "common/hex_util.h" | #include "common/hex_util.h" | ||||||
| #include "common/logging/log.h" | #include "common/logging/log.h" | ||||||
| #include "core/core.h" | #include "core/core.h" | ||||||
| #include "core/hle/kernel/k_event.h" |  | ||||||
| #include "core/hle/kernel/k_readable_event.h" | #include "core/hle/kernel/k_readable_event.h" | ||||||
| #include "core/hle/kernel/k_writable_event.h" | #include "core/hle/kernel/k_writable_event.h" | ||||||
| #include "core/hle/lock.h" | #include "core/hle/lock.h" | ||||||
|  | @ -14,14 +13,13 @@ | ||||||
| namespace Service::BCAT { | namespace Service::BCAT { | ||||||
| 
 | 
 | ||||||
| ProgressServiceBackend::ProgressServiceBackend(Kernel::KernelCore& kernel, | ProgressServiceBackend::ProgressServiceBackend(Kernel::KernelCore& kernel, | ||||||
|                                                std::string_view event_name) { |                                                std::string_view event_name) | ||||||
|     event = Kernel::KEvent::Create(kernel, |     : update_event{kernel} { | ||||||
|                                    "ProgressServiceBackend:UpdateEvent:" + std::string(event_name)); |     update_event.Initialize("ProgressServiceBackend:UpdateEvent:" + std::string(event_name)); | ||||||
|     event->Initialize(); |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| std::shared_ptr<Kernel::KReadableEvent> ProgressServiceBackend::GetEvent() const { | std::shared_ptr<Kernel::KReadableEvent> ProgressServiceBackend::GetEvent() const { | ||||||
|     return SharedFrom(event->GetReadableEvent()); |     return update_event.GetReadableEvent(); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| DeliveryCacheProgressImpl& ProgressServiceBackend::GetImpl() { | DeliveryCacheProgressImpl& ProgressServiceBackend::GetImpl() { | ||||||
|  | @ -89,9 +87,9 @@ void ProgressServiceBackend::FinishDownload(ResultCode result) { | ||||||
| void ProgressServiceBackend::SignalUpdate() const { | void ProgressServiceBackend::SignalUpdate() const { | ||||||
|     if (need_hle_lock) { |     if (need_hle_lock) { | ||||||
|         std::lock_guard lock(HLE::g_hle_lock); |         std::lock_guard lock(HLE::g_hle_lock); | ||||||
|         event->GetWritableEvent()->Signal(); |         update_event.GetWritableEvent()->Signal(); | ||||||
|     } else { |     } else { | ||||||
|         event->GetWritableEvent()->Signal(); |         update_event.GetWritableEvent()->Signal(); | ||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -11,6 +11,7 @@ | ||||||
| 
 | 
 | ||||||
| #include "common/common_types.h" | #include "common/common_types.h" | ||||||
| #include "core/file_sys/vfs_types.h" | #include "core/file_sys/vfs_types.h" | ||||||
|  | #include "core/hle/kernel/k_event.h" | ||||||
| #include "core/hle/result.h" | #include "core/hle/result.h" | ||||||
| 
 | 
 | ||||||
| namespace Core { | namespace Core { | ||||||
|  | @ -104,7 +105,7 @@ private: | ||||||
|     void SignalUpdate() const; |     void SignalUpdate() const; | ||||||
| 
 | 
 | ||||||
|     DeliveryCacheProgressImpl impl{}; |     DeliveryCacheProgressImpl impl{}; | ||||||
|     std::shared_ptr<Kernel::KEvent> event; |     Kernel::KEvent update_event; | ||||||
|     bool need_hle_lock = false; |     bool need_hle_lock = false; | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -17,7 +17,8 @@ namespace Service::BtDrv { | ||||||
| 
 | 
 | ||||||
| class Bt final : public ServiceFramework<Bt> { | class Bt final : public ServiceFramework<Bt> { | ||||||
| public: | public: | ||||||
|     explicit Bt(Core::System& system_) : ServiceFramework{system_, "bt"} { |     explicit Bt(Core::System& system_) | ||||||
|  |         : ServiceFramework{system_, "bt"}, register_event{system.Kernel()} { | ||||||
|         // clang-format off
 |         // clang-format off
 | ||||||
|         static const FunctionInfo functions[] = { |         static const FunctionInfo functions[] = { | ||||||
|             {0, nullptr, "LeClientReadCharacteristic"}, |             {0, nullptr, "LeClientReadCharacteristic"}, | ||||||
|  | @ -34,9 +35,7 @@ public: | ||||||
|         // clang-format on
 |         // clang-format on
 | ||||||
|         RegisterHandlers(functions); |         RegisterHandlers(functions); | ||||||
| 
 | 
 | ||||||
|         auto& kernel = system.Kernel(); |         register_event.Initialize("BT:RegisterEvent"); | ||||||
|         register_event = Kernel::KEvent::Create(kernel, "BT:RegisterEvent"); |  | ||||||
|         register_event->Initialize(); |  | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
| private: | private: | ||||||
|  | @ -45,10 +44,10 @@ private: | ||||||
| 
 | 
 | ||||||
|         IPC::ResponseBuilder rb{ctx, 2, 1}; |         IPC::ResponseBuilder rb{ctx, 2, 1}; | ||||||
|         rb.Push(RESULT_SUCCESS); |         rb.Push(RESULT_SUCCESS); | ||||||
|         rb.PushCopyObjects(register_event->GetReadableEvent()); |         rb.PushCopyObjects(register_event.GetReadableEvent()); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     std::shared_ptr<Kernel::KEvent> register_event; |     Kernel::KEvent register_event; | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| class BtDrv final : public ServiceFramework<BtDrv> { | class BtDrv final : public ServiceFramework<BtDrv> { | ||||||
|  |  | ||||||
|  | @ -18,7 +18,10 @@ namespace Service::BTM { | ||||||
| 
 | 
 | ||||||
| class IBtmUserCore final : public ServiceFramework<IBtmUserCore> { | class IBtmUserCore final : public ServiceFramework<IBtmUserCore> { | ||||||
| public: | public: | ||||||
|     explicit IBtmUserCore(Core::System& system_) : ServiceFramework{system_, "IBtmUserCore"} { |     explicit IBtmUserCore(Core::System& system_) | ||||||
|  |         : ServiceFramework{system_, "IBtmUserCore"}, scan_event{system.Kernel()}, | ||||||
|  |           connection_event{system.Kernel()}, service_discovery{system.Kernel()}, | ||||||
|  |           config_event{system.Kernel()} { | ||||||
|         // clang-format off
 |         // clang-format off
 | ||||||
|         static const FunctionInfo functions[] = { |         static const FunctionInfo functions[] = { | ||||||
|             {0, &IBtmUserCore::AcquireBleScanEvent, "AcquireBleScanEvent"}, |             {0, &IBtmUserCore::AcquireBleScanEvent, "AcquireBleScanEvent"}, | ||||||
|  | @ -57,15 +60,10 @@ public: | ||||||
|         // clang-format on
 |         // clang-format on
 | ||||||
|         RegisterHandlers(functions); |         RegisterHandlers(functions); | ||||||
| 
 | 
 | ||||||
|         auto& kernel = system.Kernel(); |         scan_event.Initialize("IBtmUserCore:ScanEvent"); | ||||||
|         scan_event = Kernel::KEvent::Create(kernel, "IBtmUserCore:ScanEvent"); |         connection_event.Initialize("IBtmUserCore:ConnectionEvent"); | ||||||
|         scan_event->Initialize(); |         service_discovery.Initialize("IBtmUserCore:Discovery"); | ||||||
|         connection_event = Kernel::KEvent::Create(kernel, "IBtmUserCore:ConnectionEvent"); |         config_event.Initialize("IBtmUserCore:ConfigEvent"); | ||||||
|         connection_event->Initialize(); |  | ||||||
|         service_discovery = Kernel::KEvent::Create(kernel, "IBtmUserCore:Discovery"); |  | ||||||
|         service_discovery->Initialize(); |  | ||||||
|         config_event = Kernel::KEvent::Create(kernel, "IBtmUserCore:ConfigEvent"); |  | ||||||
|         config_event->Initialize(); |  | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
| private: | private: | ||||||
|  | @ -74,7 +72,7 @@ private: | ||||||
| 
 | 
 | ||||||
|         IPC::ResponseBuilder rb{ctx, 2, 1}; |         IPC::ResponseBuilder rb{ctx, 2, 1}; | ||||||
|         rb.Push(RESULT_SUCCESS); |         rb.Push(RESULT_SUCCESS); | ||||||
|         rb.PushCopyObjects(scan_event->GetReadableEvent()); |         rb.PushCopyObjects(scan_event.GetReadableEvent()); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     void AcquireBleConnectionEvent(Kernel::HLERequestContext& ctx) { |     void AcquireBleConnectionEvent(Kernel::HLERequestContext& ctx) { | ||||||
|  | @ -82,7 +80,7 @@ private: | ||||||
| 
 | 
 | ||||||
|         IPC::ResponseBuilder rb{ctx, 2, 1}; |         IPC::ResponseBuilder rb{ctx, 2, 1}; | ||||||
|         rb.Push(RESULT_SUCCESS); |         rb.Push(RESULT_SUCCESS); | ||||||
|         rb.PushCopyObjects(connection_event->GetReadableEvent()); |         rb.PushCopyObjects(connection_event.GetReadableEvent()); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     void AcquireBleServiceDiscoveryEvent(Kernel::HLERequestContext& ctx) { |     void AcquireBleServiceDiscoveryEvent(Kernel::HLERequestContext& ctx) { | ||||||
|  | @ -90,7 +88,7 @@ private: | ||||||
| 
 | 
 | ||||||
|         IPC::ResponseBuilder rb{ctx, 2, 1}; |         IPC::ResponseBuilder rb{ctx, 2, 1}; | ||||||
|         rb.Push(RESULT_SUCCESS); |         rb.Push(RESULT_SUCCESS); | ||||||
|         rb.PushCopyObjects(service_discovery->GetReadableEvent()); |         rb.PushCopyObjects(service_discovery.GetReadableEvent()); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     void AcquireBleMtuConfigEvent(Kernel::HLERequestContext& ctx) { |     void AcquireBleMtuConfigEvent(Kernel::HLERequestContext& ctx) { | ||||||
|  | @ -98,13 +96,13 @@ private: | ||||||
| 
 | 
 | ||||||
|         IPC::ResponseBuilder rb{ctx, 2, 1}; |         IPC::ResponseBuilder rb{ctx, 2, 1}; | ||||||
|         rb.Push(RESULT_SUCCESS); |         rb.Push(RESULT_SUCCESS); | ||||||
|         rb.PushCopyObjects(config_event->GetReadableEvent()); |         rb.PushCopyObjects(config_event.GetReadableEvent()); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     std::shared_ptr<Kernel::KEvent> scan_event; |     Kernel::KEvent scan_event; | ||||||
|     std::shared_ptr<Kernel::KEvent> connection_event; |     Kernel::KEvent connection_event; | ||||||
|     std::shared_ptr<Kernel::KEvent> service_discovery; |     Kernel::KEvent service_discovery; | ||||||
|     std::shared_ptr<Kernel::KEvent> config_event; |     Kernel::KEvent config_event; | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| class BTM_USR final : public ServiceFramework<BTM_USR> { | class BTM_USR final : public ServiceFramework<BTM_USR> { | ||||||
|  |  | ||||||
|  | @ -185,7 +185,8 @@ private: | ||||||
| class INotificationService final : public ServiceFramework<INotificationService> { | class INotificationService final : public ServiceFramework<INotificationService> { | ||||||
| public: | public: | ||||||
|     explicit INotificationService(Common::UUID uuid_, Core::System& system_) |     explicit INotificationService(Common::UUID uuid_, Core::System& system_) | ||||||
|         : ServiceFramework{system_, "INotificationService"}, uuid{uuid_} { |         : ServiceFramework{system_, "INotificationService"}, uuid{uuid_}, notification_event{ | ||||||
|  |                                                                               system.Kernel()} { | ||||||
|         // clang-format off
 |         // clang-format off
 | ||||||
|         static const FunctionInfo functions[] = { |         static const FunctionInfo functions[] = { | ||||||
|             {0, &INotificationService::GetEvent, "GetEvent"}, |             {0, &INotificationService::GetEvent, "GetEvent"}, | ||||||
|  | @ -196,9 +197,7 @@ public: | ||||||
| 
 | 
 | ||||||
|         RegisterHandlers(functions); |         RegisterHandlers(functions); | ||||||
| 
 | 
 | ||||||
|         notification_event = |         notification_event.Initialize("INotificationService:NotifyEvent"); | ||||||
|             Kernel::KEvent::Create(system.Kernel(), "INotificationService:NotifyEvent"); |  | ||||||
|         notification_event->Initialize(); |  | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
| private: | private: | ||||||
|  | @ -207,7 +206,7 @@ private: | ||||||
| 
 | 
 | ||||||
|         IPC::ResponseBuilder rb{ctx, 2, 1}; |         IPC::ResponseBuilder rb{ctx, 2, 1}; | ||||||
|         rb.Push(RESULT_SUCCESS); |         rb.Push(RESULT_SUCCESS); | ||||||
|         rb.PushCopyObjects(notification_event->GetReadableEvent()); |         rb.PushCopyObjects(notification_event.GetReadableEvent()); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     void Clear(Kernel::HLERequestContext& ctx) { |     void Clear(Kernel::HLERequestContext& ctx) { | ||||||
|  | @ -273,7 +272,7 @@ private: | ||||||
|     }; |     }; | ||||||
| 
 | 
 | ||||||
|     Common::UUID uuid{Common::INVALID_UUID}; |     Common::UUID uuid{Common::INVALID_UUID}; | ||||||
|     std::shared_ptr<Kernel::KEvent> notification_event; |     Kernel::KEvent notification_event; | ||||||
|     std::queue<SizedNotificationInfo> notifications; |     std::queue<SizedNotificationInfo> notifications; | ||||||
|     States states{}; |     States states{}; | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  | @ -253,9 +253,8 @@ void Controller_NPad::InitNewlyAddedController(std::size_t controller_idx) { | ||||||
| void Controller_NPad::OnInit() { | void Controller_NPad::OnInit() { | ||||||
|     auto& kernel = system.Kernel(); |     auto& kernel = system.Kernel(); | ||||||
|     for (std::size_t i = 0; i < styleset_changed_events.size(); ++i) { |     for (std::size_t i = 0; i < styleset_changed_events.size(); ++i) { | ||||||
|         styleset_changed_events[i] = |         styleset_changed_events[i] = std::make_unique<Kernel::KEvent>(kernel); | ||||||
|             Kernel::KEvent::Create(kernel, fmt::format("npad:NpadStyleSetChanged_{}", i)); |         styleset_changed_events[i]->Initialize(fmt::format("npad:NpadStyleSetChanged_{}", i)); | ||||||
|         styleset_changed_events[i]->Initialize(); |  | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     if (!IsControllerActivated()) { |     if (!IsControllerActivated()) { | ||||||
|  |  | ||||||
|  | @ -573,7 +573,7 @@ private: | ||||||
|     NpadHandheldActivationMode handheld_activation_mode{NpadHandheldActivationMode::Dual}; |     NpadHandheldActivationMode handheld_activation_mode{NpadHandheldActivationMode::Dual}; | ||||||
|     NpadCommunicationMode communication_mode{NpadCommunicationMode::Default}; |     NpadCommunicationMode communication_mode{NpadCommunicationMode::Default}; | ||||||
|     // Each controller should have their own styleset changed event
 |     // Each controller should have their own styleset changed event
 | ||||||
|     std::array<std::shared_ptr<Kernel::KEvent>, 10> styleset_changed_events; |     std::array<std::unique_ptr<Kernel::KEvent>, 10> styleset_changed_events; | ||||||
|     std::array<std::array<std::chrono::steady_clock::time_point, 2>, 10> last_vibration_timepoints; |     std::array<std::array<std::chrono::steady_clock::time_point, 2>, 10> last_vibration_timepoints; | ||||||
|     std::array<std::array<VibrationValue, 2>, 10> latest_vibration_values{}; |     std::array<std::array<VibrationValue, 2>, 10> latest_vibration_values{}; | ||||||
|     bool permit_vibration_session_enabled{false}; |     bool permit_vibration_session_enabled{false}; | ||||||
|  |  | ||||||
|  | @ -8,7 +8,6 @@ | ||||||
| #include "common/logging/log.h" | #include "common/logging/log.h" | ||||||
| #include "core/core.h" | #include "core/core.h" | ||||||
| #include "core/hle/ipc_helpers.h" | #include "core/hle/ipc_helpers.h" | ||||||
| #include "core/hle/kernel/k_event.h" |  | ||||||
| #include "core/hle/kernel/k_readable_event.h" | #include "core/hle/kernel/k_readable_event.h" | ||||||
| #include "core/hle/kernel/k_thread.h" | #include "core/hle/kernel/k_thread.h" | ||||||
| #include "core/hle/kernel/k_writable_event.h" | #include "core/hle/kernel/k_writable_event.h" | ||||||
|  | @ -24,10 +23,8 @@ constexpr ResultCode ERR_NO_APPLICATION_AREA(ErrorModule::NFP, 152); | ||||||
| 
 | 
 | ||||||
| Module::Interface::Interface(std::shared_ptr<Module> module_, Core::System& system_, | Module::Interface::Interface(std::shared_ptr<Module> module_, Core::System& system_, | ||||||
|                              const char* name) |                              const char* name) | ||||||
|     : ServiceFramework{system_, name}, module{std::move(module_)} { |     : ServiceFramework{system_, name}, nfc_tag_load{system.Kernel()}, module{std::move(module_)} { | ||||||
|     auto& kernel = system.Kernel(); |     nfc_tag_load.Initialize("IUser:NFCTagDetected"); | ||||||
|     nfc_tag_load = Kernel::KEvent::Create(kernel, "IUser:NFCTagDetected"); |  | ||||||
|     nfc_tag_load->Initialize(); |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| Module::Interface::~Interface() = default; | Module::Interface::~Interface() = default; | ||||||
|  | @ -35,7 +32,8 @@ Module::Interface::~Interface() = default; | ||||||
| class IUser final : public ServiceFramework<IUser> { | class IUser final : public ServiceFramework<IUser> { | ||||||
| public: | public: | ||||||
|     explicit IUser(Module::Interface& nfp_interface_, Core::System& system_) |     explicit IUser(Module::Interface& nfp_interface_, Core::System& system_) | ||||||
|         : ServiceFramework{system_, "NFP::IUser"}, nfp_interface{nfp_interface_} { |         : ServiceFramework{system_, "NFP::IUser"}, nfp_interface{nfp_interface_}, | ||||||
|  |           deactivate_event{system.Kernel()}, availability_change_event{system.Kernel()} { | ||||||
|         static const FunctionInfo functions[] = { |         static const FunctionInfo functions[] = { | ||||||
|             {0, &IUser::Initialize, "Initialize"}, |             {0, &IUser::Initialize, "Initialize"}, | ||||||
|             {1, &IUser::Finalize, "Finalize"}, |             {1, &IUser::Finalize, "Finalize"}, | ||||||
|  | @ -65,11 +63,8 @@ public: | ||||||
|         }; |         }; | ||||||
|         RegisterHandlers(functions); |         RegisterHandlers(functions); | ||||||
| 
 | 
 | ||||||
|         auto& kernel = system.Kernel(); |         deactivate_event.Initialize("IUser:DeactivateEvent"); | ||||||
|         deactivate_event = Kernel::KEvent::Create(kernel, "IUser:DeactivateEvent"); |         availability_change_event.Initialize("IUser:AvailabilityChangeEvent"); | ||||||
|         deactivate_event->Initialize(); |  | ||||||
|         availability_change_event = Kernel::KEvent::Create(kernel, "IUser:AvailabilityChangeEvent"); |  | ||||||
|         availability_change_event->Initialize(); |  | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
| private: | private: | ||||||
|  | @ -167,7 +162,7 @@ private: | ||||||
| 
 | 
 | ||||||
|         IPC::ResponseBuilder rb{ctx, 2, 1}; |         IPC::ResponseBuilder rb{ctx, 2, 1}; | ||||||
|         rb.Push(RESULT_SUCCESS); |         rb.Push(RESULT_SUCCESS); | ||||||
|         rb.PushCopyObjects(deactivate_event->GetReadableEvent()); |         rb.PushCopyObjects(deactivate_event.GetReadableEvent()); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     void StopDetection(Kernel::HLERequestContext& ctx) { |     void StopDetection(Kernel::HLERequestContext& ctx) { | ||||||
|  | @ -176,7 +171,7 @@ private: | ||||||
|         switch (device_state) { |         switch (device_state) { | ||||||
|         case DeviceState::TagFound: |         case DeviceState::TagFound: | ||||||
|         case DeviceState::TagNearby: |         case DeviceState::TagNearby: | ||||||
|             deactivate_event->GetWritableEvent()->Signal(); |             deactivate_event.GetWritableEvent()->Signal(); | ||||||
|             device_state = DeviceState::Initialized; |             device_state = DeviceState::Initialized; | ||||||
|             break; |             break; | ||||||
|         case DeviceState::SearchingForTag: |         case DeviceState::SearchingForTag: | ||||||
|  | @ -265,7 +260,7 @@ private: | ||||||
| 
 | 
 | ||||||
|         IPC::ResponseBuilder rb{ctx, 2, 1}; |         IPC::ResponseBuilder rb{ctx, 2, 1}; | ||||||
|         rb.Push(RESULT_SUCCESS); |         rb.Push(RESULT_SUCCESS); | ||||||
|         rb.PushCopyObjects(availability_change_event->GetReadableEvent()); |         rb.PushCopyObjects(availability_change_event.GetReadableEvent()); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     void GetRegisterInfo(Kernel::HLERequestContext& ctx) { |     void GetRegisterInfo(Kernel::HLERequestContext& ctx) { | ||||||
|  | @ -319,9 +314,9 @@ private: | ||||||
|     const u32 npad_id{0};       // Player 1 controller
 |     const u32 npad_id{0};       // Player 1 controller
 | ||||||
|     State state{State::NonInitialized}; |     State state{State::NonInitialized}; | ||||||
|     DeviceState device_state{DeviceState::Initialized}; |     DeviceState device_state{DeviceState::Initialized}; | ||||||
|     std::shared_ptr<Kernel::KEvent> deactivate_event; |  | ||||||
|     std::shared_ptr<Kernel::KEvent> availability_change_event; |  | ||||||
|     const Module::Interface& nfp_interface; |     const Module::Interface& nfp_interface; | ||||||
|  |     Kernel::KEvent deactivate_event; | ||||||
|  |     Kernel::KEvent availability_change_event; | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| void Module::Interface::CreateUserInterface(Kernel::HLERequestContext& ctx) { | void Module::Interface::CreateUserInterface(Kernel::HLERequestContext& ctx) { | ||||||
|  | @ -339,12 +334,12 @@ bool Module::Interface::LoadAmiibo(const std::vector<u8>& buffer) { | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     std::memcpy(&amiibo, buffer.data(), sizeof(amiibo)); |     std::memcpy(&amiibo, buffer.data(), sizeof(amiibo)); | ||||||
|     nfc_tag_load->GetWritableEvent()->Signal(); |     nfc_tag_load.GetWritableEvent()->Signal(); | ||||||
|     return true; |     return true; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| Kernel::KReadableEvent* Module::Interface::GetNFCEvent() const { | Kernel::KReadableEvent* Module::Interface::GetNFCEvent() const { | ||||||
|     return nfc_tag_load->GetReadableEvent(); |     return nfc_tag_load.GetReadableEvent().get(); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| const Module::Interface::AmiiboFile& Module::Interface::GetAmiiboBuffer() const { | const Module::Interface::AmiiboFile& Module::Interface::GetAmiiboBuffer() const { | ||||||
|  |  | ||||||
|  | @ -7,6 +7,7 @@ | ||||||
| #include <array> | #include <array> | ||||||
| #include <vector> | #include <vector> | ||||||
| 
 | 
 | ||||||
|  | #include "core/hle/kernel/k_event.h" | ||||||
| #include "core/hle/service/service.h" | #include "core/hle/service/service.h" | ||||||
| 
 | 
 | ||||||
| namespace Kernel { | namespace Kernel { | ||||||
|  | @ -42,7 +43,7 @@ public: | ||||||
|         const AmiiboFile& GetAmiiboBuffer() const; |         const AmiiboFile& GetAmiiboBuffer() const; | ||||||
| 
 | 
 | ||||||
|     private: |     private: | ||||||
|         std::shared_ptr<Kernel::KEvent> nfc_tag_load; |         Kernel::KEvent nfc_tag_load; | ||||||
|         AmiiboFile amiibo{}; |         AmiiboFile amiibo{}; | ||||||
| 
 | 
 | ||||||
|     protected: |     protected: | ||||||
|  |  | ||||||
|  | @ -127,7 +127,8 @@ public: | ||||||
| 
 | 
 | ||||||
| class IRequest final : public ServiceFramework<IRequest> { | class IRequest final : public ServiceFramework<IRequest> { | ||||||
| public: | public: | ||||||
|     explicit IRequest(Core::System& system_) : ServiceFramework{system_, "IRequest"} { |     explicit IRequest(Core::System& system_) | ||||||
|  |         : ServiceFramework{system_, "IRequest"}, event1{system.Kernel()}, event2{system.Kernel()} { | ||||||
|         static const FunctionInfo functions[] = { |         static const FunctionInfo functions[] = { | ||||||
|             {0, &IRequest::GetRequestState, "GetRequestState"}, |             {0, &IRequest::GetRequestState, "GetRequestState"}, | ||||||
|             {1, &IRequest::GetResult, "GetResult"}, |             {1, &IRequest::GetResult, "GetResult"}, | ||||||
|  | @ -159,10 +160,8 @@ public: | ||||||
| 
 | 
 | ||||||
|         auto& kernel = system.Kernel(); |         auto& kernel = system.Kernel(); | ||||||
| 
 | 
 | ||||||
|         event1 = Kernel::KEvent::Create(kernel, "IRequest:Event1"); |         event1.Initialize("IRequest:Event1"); | ||||||
|         event1->Initialize(); |         event2.Initialize("IRequest:Event2"); | ||||||
|         event2 = Kernel::KEvent::Create(kernel, "IRequest:Event2"); |  | ||||||
|         event2->Initialize(); |  | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
| private: | private: | ||||||
|  | @ -198,7 +197,7 @@ private: | ||||||
| 
 | 
 | ||||||
|         IPC::ResponseBuilder rb{ctx, 2, 2}; |         IPC::ResponseBuilder rb{ctx, 2, 2}; | ||||||
|         rb.Push(RESULT_SUCCESS); |         rb.Push(RESULT_SUCCESS); | ||||||
|         rb.PushCopyObjects(event1->GetReadableEvent(), event2->GetReadableEvent()); |         rb.PushCopyObjects(event1.GetReadableEvent(), event2.GetReadableEvent()); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     void Cancel(Kernel::HLERequestContext& ctx) { |     void Cancel(Kernel::HLERequestContext& ctx) { | ||||||
|  | @ -229,7 +228,7 @@ private: | ||||||
|         rb.Push<u32>(0); |         rb.Push<u32>(0); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     std::shared_ptr<Kernel::KEvent> event1, event2; |     Kernel::KEvent event1, event2; | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| class INetworkProfile final : public ServiceFramework<INetworkProfile> { | class INetworkProfile final : public ServiceFramework<INetworkProfile> { | ||||||
|  |  | ||||||
|  | @ -300,7 +300,8 @@ class IEnsureNetworkClockAvailabilityService final | ||||||
|     : public ServiceFramework<IEnsureNetworkClockAvailabilityService> { |     : public ServiceFramework<IEnsureNetworkClockAvailabilityService> { | ||||||
| public: | public: | ||||||
|     explicit IEnsureNetworkClockAvailabilityService(Core::System& system_) |     explicit IEnsureNetworkClockAvailabilityService(Core::System& system_) | ||||||
|         : ServiceFramework{system_, "IEnsureNetworkClockAvailabilityService"} { |         : ServiceFramework{system_, "IEnsureNetworkClockAvailabilityService"}, | ||||||
|  |           finished_event{system.Kernel()} { | ||||||
|         static const FunctionInfo functions[] = { |         static const FunctionInfo functions[] = { | ||||||
|             {0, &IEnsureNetworkClockAvailabilityService::StartTask, "StartTask"}, |             {0, &IEnsureNetworkClockAvailabilityService::StartTask, "StartTask"}, | ||||||
|             {1, &IEnsureNetworkClockAvailabilityService::GetFinishNotificationEvent, |             {1, &IEnsureNetworkClockAvailabilityService::GetFinishNotificationEvent, | ||||||
|  | @ -312,19 +313,16 @@ public: | ||||||
|         }; |         }; | ||||||
|         RegisterHandlers(functions); |         RegisterHandlers(functions); | ||||||
| 
 | 
 | ||||||
|         auto& kernel = system.Kernel(); |         finished_event.Initialize("IEnsureNetworkClockAvailabilityService:FinishEvent"); | ||||||
|         finished_event = |  | ||||||
|             Kernel::KEvent::Create(kernel, "IEnsureNetworkClockAvailabilityService:FinishEvent"); |  | ||||||
|         finished_event->Initialize(); |  | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
| private: | private: | ||||||
|     std::shared_ptr<Kernel::KEvent> finished_event; |     Kernel::KEvent finished_event; | ||||||
| 
 | 
 | ||||||
|     void StartTask(Kernel::HLERequestContext& ctx) { |     void StartTask(Kernel::HLERequestContext& ctx) { | ||||||
|         // No need to connect to the internet, just finish the task straight away.
 |         // No need to connect to the internet, just finish the task straight away.
 | ||||||
|         LOG_DEBUG(Service_NIM, "called"); |         LOG_DEBUG(Service_NIM, "called"); | ||||||
|         finished_event->GetWritableEvent()->Signal(); |         finished_event.GetWritableEvent()->Signal(); | ||||||
|         IPC::ResponseBuilder rb{ctx, 2}; |         IPC::ResponseBuilder rb{ctx, 2}; | ||||||
|         rb.Push(RESULT_SUCCESS); |         rb.Push(RESULT_SUCCESS); | ||||||
|     } |     } | ||||||
|  | @ -334,7 +332,7 @@ private: | ||||||
| 
 | 
 | ||||||
|         IPC::ResponseBuilder rb{ctx, 2, 1}; |         IPC::ResponseBuilder rb{ctx, 2, 1}; | ||||||
|         rb.Push(RESULT_SUCCESS); |         rb.Push(RESULT_SUCCESS); | ||||||
|         rb.PushCopyObjects(finished_event->GetReadableEvent()); |         rb.PushCopyObjects(finished_event.GetReadableEvent()); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     void GetResult(Kernel::HLERequestContext& ctx) { |     void GetResult(Kernel::HLERequestContext& ctx) { | ||||||
|  | @ -346,7 +344,7 @@ private: | ||||||
| 
 | 
 | ||||||
|     void Cancel(Kernel::HLERequestContext& ctx) { |     void Cancel(Kernel::HLERequestContext& ctx) { | ||||||
|         LOG_DEBUG(Service_NIM, "called"); |         LOG_DEBUG(Service_NIM, "called"); | ||||||
|         finished_event->GetWritableEvent()->Clear(); |         finished_event.GetWritableEvent()->Clear(); | ||||||
|         IPC::ResponseBuilder rb{ctx, 2}; |         IPC::ResponseBuilder rb{ctx, 2}; | ||||||
|         rb.Push(RESULT_SUCCESS); |         rb.Push(RESULT_SUCCESS); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  | @ -102,7 +102,7 @@ NvResult nvhost_ctrl::IocCtrlEventWait(const std::vector<u8>& input, std::vector | ||||||
|         return NvResult::Success; |         return NvResult::Success; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     auto event = events_interface.events[event_id]; |     auto& event = events_interface.events[event_id]; | ||||||
|     auto& gpu = system.GPU(); |     auto& gpu = system.GPU(); | ||||||
| 
 | 
 | ||||||
|     // This is mostly to take into account unimplemented features. As synced
 |     // This is mostly to take into account unimplemented features. As synced
 | ||||||
|  |  | ||||||
|  | @ -42,9 +42,8 @@ void InstallInterfaces(SM::ServiceManager& service_manager, NVFlinger::NVFlinger | ||||||
| Module::Module(Core::System& system) : syncpoint_manager{system.GPU()} { | Module::Module(Core::System& system) : syncpoint_manager{system.GPU()} { | ||||||
|     auto& kernel = system.Kernel(); |     auto& kernel = system.Kernel(); | ||||||
|     for (u32 i = 0; i < MaxNvEvents; i++) { |     for (u32 i = 0; i < MaxNvEvents; i++) { | ||||||
|         std::string event_label = fmt::format("NVDRV::NvEvent_{}", i); |         events_interface.events[i].event = std::make_unique<Kernel::KEvent>(kernel); | ||||||
|         events_interface.events[i] = {Kernel::KEvent::Create(kernel, std::move(event_label))}; |         events_interface.events[i].event->Initialize(fmt::format("NVDRV::NvEvent_{}", i)); | ||||||
|         events_interface.events[i].event->Initialize(); |  | ||||||
|         events_interface.status[i] = EventState::Free; |         events_interface.status[i] = EventState::Free; | ||||||
|         events_interface.registered[i] = false; |         events_interface.registered[i] = false; | ||||||
|     } |     } | ||||||
|  | @ -64,7 +63,12 @@ Module::Module(Core::System& system) : syncpoint_manager{system.GPU()} { | ||||||
|         std::make_shared<Devices::nvhost_vic>(system, nvmap_dev, syncpoint_manager); |         std::make_shared<Devices::nvhost_vic>(system, nvmap_dev, syncpoint_manager); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| Module::~Module() = default; | Module::~Module() { | ||||||
|  |     for (u32 i = 0; i < MaxNvEvents; i++) { | ||||||
|  |         events_interface.events[i].event->Close(); | ||||||
|  |         events_interface.events[i].event = nullptr; | ||||||
|  |     } | ||||||
|  | } | ||||||
| 
 | 
 | ||||||
| NvResult Module::VerifyFD(DeviceFD fd) const { | NvResult Module::VerifyFD(DeviceFD fd) const { | ||||||
|     if (fd < 0) { |     if (fd < 0) { | ||||||
|  |  | ||||||
|  | @ -35,7 +35,7 @@ class nvdevice; | ||||||
| 
 | 
 | ||||||
| /// Represents an Nvidia event
 | /// Represents an Nvidia event
 | ||||||
| struct NvEvent { | struct NvEvent { | ||||||
|     std::shared_ptr<Kernel::KEvent> event; |     std::unique_ptr<Kernel::KEvent> event; | ||||||
|     Fence fence{}; |     Fence fence{}; | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -7,7 +7,6 @@ | ||||||
| #include "common/assert.h" | #include "common/assert.h" | ||||||
| #include "common/logging/log.h" | #include "common/logging/log.h" | ||||||
| #include "core/core.h" | #include "core/core.h" | ||||||
| #include "core/hle/kernel/k_event.h" |  | ||||||
| #include "core/hle/kernel/k_writable_event.h" | #include "core/hle/kernel/k_writable_event.h" | ||||||
| #include "core/hle/kernel/kernel.h" | #include "core/hle/kernel/kernel.h" | ||||||
| #include "core/hle/service/nvflinger/buffer_queue.h" | #include "core/hle/service/nvflinger/buffer_queue.h" | ||||||
|  | @ -15,9 +14,8 @@ | ||||||
| namespace Service::NVFlinger { | namespace Service::NVFlinger { | ||||||
| 
 | 
 | ||||||
| BufferQueue::BufferQueue(Kernel::KernelCore& kernel, u32 id, u64 layer_id) | BufferQueue::BufferQueue(Kernel::KernelCore& kernel, u32 id, u64 layer_id) | ||||||
|     : id(id), layer_id(layer_id) { |     : id(id), layer_id(layer_id), buffer_wait_event{kernel} { | ||||||
|     buffer_wait_event = Kernel::KEvent::Create(kernel, "BufferQueue:WaitEvent"); |     buffer_wait_event.Initialize("BufferQueue:WaitEvent"); | ||||||
|     buffer_wait_event->Initialize(); |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| BufferQueue::~BufferQueue() = default; | BufferQueue::~BufferQueue() = default; | ||||||
|  | @ -42,7 +40,7 @@ void BufferQueue::SetPreallocatedBuffer(u32 slot, const IGBPBuffer& igbp_buffer) | ||||||
|         .multi_fence = {}, |         .multi_fence = {}, | ||||||
|     }; |     }; | ||||||
| 
 | 
 | ||||||
|     buffer_wait_event->GetWritableEvent()->Signal(); |     buffer_wait_event.GetWritableEvent()->Signal(); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| std::optional<std::pair<u32, Service::Nvidia::MultiFence*>> BufferQueue::DequeueBuffer(u32 width, | std::optional<std::pair<u32, Service::Nvidia::MultiFence*>> BufferQueue::DequeueBuffer(u32 width, | ||||||
|  | @ -120,7 +118,7 @@ void BufferQueue::CancelBuffer(u32 slot, const Service::Nvidia::MultiFence& mult | ||||||
|     } |     } | ||||||
|     free_buffers_condition.notify_one(); |     free_buffers_condition.notify_one(); | ||||||
| 
 | 
 | ||||||
|     buffer_wait_event->GetWritableEvent()->Signal(); |     buffer_wait_event.GetWritableEvent()->Signal(); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| std::optional<std::reference_wrapper<const BufferQueue::Buffer>> BufferQueue::AcquireBuffer() { | std::optional<std::reference_wrapper<const BufferQueue::Buffer>> BufferQueue::AcquireBuffer() { | ||||||
|  | @ -155,7 +153,7 @@ void BufferQueue::ReleaseBuffer(u32 slot) { | ||||||
|     } |     } | ||||||
|     free_buffers_condition.notify_one(); |     free_buffers_condition.notify_one(); | ||||||
| 
 | 
 | ||||||
|     buffer_wait_event->GetWritableEvent()->Signal(); |     buffer_wait_event.GetWritableEvent()->Signal(); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void BufferQueue::Connect() { | void BufferQueue::Connect() { | ||||||
|  | @ -170,7 +168,7 @@ void BufferQueue::Disconnect() { | ||||||
|         std::unique_lock lock{queue_sequence_mutex}; |         std::unique_lock lock{queue_sequence_mutex}; | ||||||
|         queue_sequence.clear(); |         queue_sequence.clear(); | ||||||
|     } |     } | ||||||
|     buffer_wait_event->GetWritableEvent()->Signal(); |     buffer_wait_event.GetWritableEvent()->Signal(); | ||||||
|     is_connect = false; |     is_connect = false; | ||||||
|     free_buffers_condition.notify_one(); |     free_buffers_condition.notify_one(); | ||||||
| } | } | ||||||
|  | @ -190,11 +188,11 @@ u32 BufferQueue::Query(QueryType type) { | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| std::shared_ptr<Kernel::KWritableEvent> BufferQueue::GetWritableBufferWaitEvent() const { | std::shared_ptr<Kernel::KWritableEvent> BufferQueue::GetWritableBufferWaitEvent() const { | ||||||
|     return buffer_wait_event->GetWritableEvent(); |     return buffer_wait_event.GetWritableEvent(); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| std::shared_ptr<Kernel::KReadableEvent> BufferQueue::GetBufferWaitEvent() const { | std::shared_ptr<Kernel::KReadableEvent> BufferQueue::GetBufferWaitEvent() const { | ||||||
|     return SharedFrom(buffer_wait_event->GetReadableEvent()); |     return buffer_wait_event.GetReadableEvent(); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| } // namespace Service::NVFlinger
 | } // namespace Service::NVFlinger
 | ||||||
|  |  | ||||||
|  | @ -13,6 +13,7 @@ | ||||||
| #include "common/common_funcs.h" | #include "common/common_funcs.h" | ||||||
| #include "common/math_util.h" | #include "common/math_util.h" | ||||||
| #include "common/swap.h" | #include "common/swap.h" | ||||||
|  | #include "core/hle/kernel/k_event.h" | ||||||
| #include "core/hle/kernel/k_readable_event.h" | #include "core/hle/kernel/k_readable_event.h" | ||||||
| #include "core/hle/kernel/object.h" | #include "core/hle/kernel/object.h" | ||||||
| #include "core/hle/service/nvdrv/nvdata.h" | #include "core/hle/service/nvdrv/nvdata.h" | ||||||
|  | @ -130,7 +131,7 @@ private: | ||||||
|     std::list<u32> free_buffers; |     std::list<u32> free_buffers; | ||||||
|     std::array<Buffer, buffer_slots> buffers; |     std::array<Buffer, buffer_slots> buffers; | ||||||
|     std::list<u32> queue_sequence; |     std::list<u32> queue_sequence; | ||||||
|     std::shared_ptr<Kernel::KEvent> buffer_wait_event; |     Kernel::KEvent buffer_wait_event; | ||||||
| 
 | 
 | ||||||
|     std::mutex free_buffers_mutex; |     std::mutex free_buffers_mutex; | ||||||
|     std::condition_variable free_buffers_condition; |     std::condition_variable free_buffers_condition; | ||||||
|  |  | ||||||
|  | @ -165,8 +165,8 @@ std::optional<u32> NVFlinger::FindBufferQueueId(u64 display_id, u64 layer_id) co | ||||||
|     return layer->GetBufferQueue().GetId(); |     return layer->GetBufferQueue().GetId(); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| std::shared_ptr<Kernel::KReadableEvent> NVFlinger::FindVsyncEvent(u64 display_id) const { | std::shared_ptr<Kernel::KReadableEvent> NVFlinger::FindVsyncEvent(u64 display_id) { | ||||||
|     const auto lock_guard = Lock(); |         const auto lock_guard = Lock(); | ||||||
|     auto* const display = FindDisplay(display_id); |     auto* const display = FindDisplay(display_id); | ||||||
| 
 | 
 | ||||||
|     if (display == nullptr) { |     if (display == nullptr) { | ||||||
|  |  | ||||||
|  | @ -5,6 +5,7 @@ | ||||||
| #pragma once | #pragma once | ||||||
| 
 | 
 | ||||||
| #include <atomic> | #include <atomic> | ||||||
|  | #include <list> | ||||||
| #include <memory> | #include <memory> | ||||||
| #include <mutex> | #include <mutex> | ||||||
| #include <optional> | #include <optional> | ||||||
|  | @ -72,7 +73,7 @@ public: | ||||||
|     /// Gets the vsync event for the specified display.
 |     /// Gets the vsync event for the specified display.
 | ||||||
|     ///
 |     ///
 | ||||||
|     /// If an invalid display ID is provided, then nullptr is returned.
 |     /// If an invalid display ID is provided, then nullptr is returned.
 | ||||||
|     [[nodiscard]] std::shared_ptr<Kernel::KReadableEvent> FindVsyncEvent(u64 display_id) const; |     [[nodiscard]] std::shared_ptr<Kernel::KReadableEvent> FindVsyncEvent(u64 display_id); | ||||||
| 
 | 
 | ||||||
|     /// Obtains a buffer queue identified by the ID.
 |     /// Obtains a buffer queue identified by the ID.
 | ||||||
|     [[nodiscard]] BufferQueue* FindBufferQueue(u32 id); |     [[nodiscard]] BufferQueue* FindBufferQueue(u32 id); | ||||||
|  | @ -106,7 +107,7 @@ private: | ||||||
| 
 | 
 | ||||||
|     std::shared_ptr<Nvidia::Module> nvdrv; |     std::shared_ptr<Nvidia::Module> nvdrv; | ||||||
| 
 | 
 | ||||||
|     std::vector<VI::Display> displays; |     std::list<VI::Display> displays; | ||||||
|     std::vector<std::unique_ptr<BufferQueue>> buffer_queues; |     std::vector<std::unique_ptr<BufferQueue>> buffer_queues; | ||||||
| 
 | 
 | ||||||
|     /// Id to use for the next layer that is created, this counter is shared among all displays.
 |     /// Id to use for the next layer that is created, this counter is shared among all displays.
 | ||||||
|  |  | ||||||
|  | @ -19,7 +19,8 @@ namespace Service::PSM { | ||||||
| 
 | 
 | ||||||
| class IPsmSession final : public ServiceFramework<IPsmSession> { | class IPsmSession final : public ServiceFramework<IPsmSession> { | ||||||
| public: | public: | ||||||
|     explicit IPsmSession(Core::System& system_) : ServiceFramework{system_, "IPsmSession"} { |     explicit IPsmSession(Core::System& system_) | ||||||
|  |         : ServiceFramework{system_, "IPsmSession"}, state_change_event{system.Kernel()} { | ||||||
|         // clang-format off
 |         // clang-format off
 | ||||||
|         static const FunctionInfo functions[] = { |         static const FunctionInfo functions[] = { | ||||||
|             {0, &IPsmSession::BindStateChangeEvent, "BindStateChangeEvent"}, |             {0, &IPsmSession::BindStateChangeEvent, "BindStateChangeEvent"}, | ||||||
|  | @ -32,28 +33,26 @@ public: | ||||||
| 
 | 
 | ||||||
|         RegisterHandlers(functions); |         RegisterHandlers(functions); | ||||||
| 
 | 
 | ||||||
|         state_change_event = |         state_change_event.Initialize("IPsmSession::state_change_event"); | ||||||
|             Kernel::KEvent::Create(system_.Kernel(), "IPsmSession::state_change_event"); |  | ||||||
|         state_change_event->Initialize(); |  | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     ~IPsmSession() override = default; |     ~IPsmSession() override = default; | ||||||
| 
 | 
 | ||||||
|     void SignalChargerTypeChanged() { |     void SignalChargerTypeChanged() { | ||||||
|         if (should_signal && should_signal_charger_type) { |         if (should_signal && should_signal_charger_type) { | ||||||
|             state_change_event->GetWritableEvent()->Signal(); |             state_change_event.GetWritableEvent()->Signal(); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     void SignalPowerSupplyChanged() { |     void SignalPowerSupplyChanged() { | ||||||
|         if (should_signal && should_signal_power_supply) { |         if (should_signal && should_signal_power_supply) { | ||||||
|             state_change_event->GetWritableEvent()->Signal(); |             state_change_event.GetWritableEvent()->Signal(); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     void SignalBatteryVoltageStateChanged() { |     void SignalBatteryVoltageStateChanged() { | ||||||
|         if (should_signal && should_signal_battery_voltage) { |         if (should_signal && should_signal_battery_voltage) { | ||||||
|             state_change_event->GetWritableEvent()->Signal(); |             state_change_event.GetWritableEvent()->Signal(); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  | @ -65,7 +64,7 @@ private: | ||||||
| 
 | 
 | ||||||
|         IPC::ResponseBuilder rb{ctx, 2, 1}; |         IPC::ResponseBuilder rb{ctx, 2, 1}; | ||||||
|         rb.Push(RESULT_SUCCESS); |         rb.Push(RESULT_SUCCESS); | ||||||
|         rb.PushCopyObjects(state_change_event->GetReadableEvent()); |         rb.PushCopyObjects(state_change_event.GetReadableEvent()); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     void UnbindStateChangeEvent(Kernel::HLERequestContext& ctx) { |     void UnbindStateChangeEvent(Kernel::HLERequestContext& ctx) { | ||||||
|  | @ -114,7 +113,7 @@ private: | ||||||
|     bool should_signal_power_supply{}; |     bool should_signal_power_supply{}; | ||||||
|     bool should_signal_battery_voltage{}; |     bool should_signal_battery_voltage{}; | ||||||
|     bool should_signal{}; |     bool should_signal{}; | ||||||
|     std::shared_ptr<Kernel::KEvent> state_change_event; |     Kernel::KEvent state_change_event; | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| class PSM final : public ServiceFramework<PSM> { | class PSM final : public ServiceFramework<PSM> { | ||||||
|  |  | ||||||
|  | @ -4,7 +4,6 @@ | ||||||
| 
 | 
 | ||||||
| #include "common/assert.h" | #include "common/assert.h" | ||||||
| #include "core/core.h" | #include "core/core.h" | ||||||
| #include "core/hle/kernel/k_event.h" |  | ||||||
| #include "core/hle/service/time/standard_local_system_clock_core.h" | #include "core/hle/service/time/standard_local_system_clock_core.h" | ||||||
| #include "core/hle/service/time/standard_network_system_clock_core.h" | #include "core/hle/service/time/standard_network_system_clock_core.h" | ||||||
| #include "core/hle/service/time/standard_user_system_clock_core.h" | #include "core/hle/service/time/standard_user_system_clock_core.h" | ||||||
|  | @ -17,10 +16,9 @@ StandardUserSystemClockCore::StandardUserSystemClockCore( | ||||||
|     : SystemClockCore(local_system_clock_core.GetSteadyClockCore()), |     : SystemClockCore(local_system_clock_core.GetSteadyClockCore()), | ||||||
|       local_system_clock_core{local_system_clock_core}, |       local_system_clock_core{local_system_clock_core}, | ||||||
|       network_system_clock_core{network_system_clock_core}, auto_correction_enabled{}, |       network_system_clock_core{network_system_clock_core}, auto_correction_enabled{}, | ||||||
|       auto_correction_time{SteadyClockTimePoint::GetRandom()}, |       auto_correction_time{SteadyClockTimePoint::GetRandom()}, auto_correction_event{ | ||||||
|       auto_correction_event{Kernel::KEvent::Create( |                                                                    system.Kernel()} { | ||||||
|           system.Kernel(), "StandardUserSystemClockCore:AutoCorrectionEvent")} { |     auto_correction_event.Initialize("StandardUserSystemClockCore:AutoCorrectionEvent"); | ||||||
|     auto_correction_event->Initialize(); |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| ResultCode StandardUserSystemClockCore::SetAutomaticCorrectionEnabled(Core::System& system, | ResultCode StandardUserSystemClockCore::SetAutomaticCorrectionEnabled(Core::System& system, | ||||||
|  |  | ||||||
|  | @ -4,6 +4,7 @@ | ||||||
| 
 | 
 | ||||||
| #pragma once | #pragma once | ||||||
| 
 | 
 | ||||||
|  | #include "core/hle/kernel/k_event.h" | ||||||
| #include "core/hle/service/time/clock_types.h" | #include "core/hle/service/time/clock_types.h" | ||||||
| #include "core/hle/service/time/system_clock_core.h" | #include "core/hle/service/time/system_clock_core.h" | ||||||
| 
 | 
 | ||||||
|  | @ -54,7 +55,7 @@ private: | ||||||
|     StandardNetworkSystemClockCore& network_system_clock_core; |     StandardNetworkSystemClockCore& network_system_clock_core; | ||||||
|     bool auto_correction_enabled{}; |     bool auto_correction_enabled{}; | ||||||
|     SteadyClockTimePoint auto_correction_time; |     SteadyClockTimePoint auto_correction_time; | ||||||
|     std::shared_ptr<Kernel::KEvent> auto_correction_event; |     Kernel::KEvent auto_correction_event; | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| } // namespace Service::Time::Clock
 | } // namespace Service::Time::Clock
 | ||||||
|  |  | ||||||
|  | @ -17,10 +17,9 @@ | ||||||
| 
 | 
 | ||||||
| namespace Service::VI { | namespace Service::VI { | ||||||
| 
 | 
 | ||||||
| Display::Display(u64 id, std::string name, Core::System& system) : id{id}, name{std::move(name)} { | Display::Display(u64 id, std::string name, Core::System& system) | ||||||
|     auto& kernel = system.Kernel(); |     : id{id}, name{std::move(name)}, vsync_event{system.Kernel()} { | ||||||
|     vsync_event = Kernel::KEvent::Create(kernel, fmt::format("Display VSync Event {}", id)); |     vsync_event.Initialize(fmt::format("Display VSync Event {}", id)); | ||||||
|     vsync_event->Initialize(); |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| Display::~Display() = default; | Display::~Display() = default; | ||||||
|  | @ -34,11 +33,11 @@ const Layer& Display::GetLayer(std::size_t index) const { | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| std::shared_ptr<Kernel::KReadableEvent> Display::GetVSyncEvent() const { | std::shared_ptr<Kernel::KReadableEvent> Display::GetVSyncEvent() const { | ||||||
|     return SharedFrom(vsync_event->GetReadableEvent()); |     return vsync_event.GetReadableEvent(); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void Display::SignalVSyncEvent() { | void Display::SignalVSyncEvent() { | ||||||
|     vsync_event->GetWritableEvent()->Signal(); |     vsync_event.GetWritableEvent()->Signal(); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void Display::CreateLayer(u64 layer_id, NVFlinger::BufferQueue& buffer_queue) { | void Display::CreateLayer(u64 layer_id, NVFlinger::BufferQueue& buffer_queue) { | ||||||
|  |  | ||||||
|  | @ -8,6 +8,7 @@ | ||||||
| #include <string> | #include <string> | ||||||
| #include <vector> | #include <vector> | ||||||
| 
 | 
 | ||||||
|  | #include "common/common_funcs.h" | ||||||
| #include "common/common_types.h" | #include "common/common_types.h" | ||||||
| 
 | 
 | ||||||
| namespace Kernel { | namespace Kernel { | ||||||
|  | @ -24,6 +25,9 @@ class Layer; | ||||||
| 
 | 
 | ||||||
| /// Represents a single display type
 | /// Represents a single display type
 | ||||||
| class Display { | class Display { | ||||||
|  |     NON_COPYABLE(Display); | ||||||
|  |     NON_MOVEABLE(Display); | ||||||
|  | 
 | ||||||
| public: | public: | ||||||
|     /// Constructs a display with a given unique ID and name.
 |     /// Constructs a display with a given unique ID and name.
 | ||||||
|     ///
 |     ///
 | ||||||
|  | @ -33,12 +37,6 @@ public: | ||||||
|     Display(u64 id, std::string name, Core::System& system); |     Display(u64 id, std::string name, Core::System& system); | ||||||
|     ~Display(); |     ~Display(); | ||||||
| 
 | 
 | ||||||
|     Display(const Display&) = delete; |  | ||||||
|     Display& operator=(const Display&) = delete; |  | ||||||
| 
 |  | ||||||
|     Display(Display&&) = default; |  | ||||||
|     Display& operator=(Display&&) = default; |  | ||||||
| 
 |  | ||||||
|     /// Gets the unique ID assigned to this display.
 |     /// Gets the unique ID assigned to this display.
 | ||||||
|     u64 GetID() const { |     u64 GetID() const { | ||||||
|         return id; |         return id; | ||||||
|  | @ -102,7 +100,7 @@ private: | ||||||
|     std::string name; |     std::string name; | ||||||
| 
 | 
 | ||||||
|     std::vector<std::shared_ptr<Layer>> layers; |     std::vector<std::shared_ptr<Layer>> layers; | ||||||
|     std::shared_ptr<Kernel::KEvent> vsync_event; |     Kernel::KEvent vsync_event; | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| } // namespace Service::VI
 | } // namespace Service::VI
 | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 bunnei
						bunnei