| 
									
										
										
										
											2022-04-23 04:59:50 -04:00
										 |  |  | // SPDX-FileCopyrightText: Copyright 2018 yuzu Emulator Project
 | 
					
						
							|  |  |  | // SPDX-License-Identifier: GPL-2.0-or-later
 | 
					
						
							| 
									
										
										
										
											2018-07-26 01:16:08 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | #include <memory>
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-08-07 23:54:51 +02:00
										 |  |  | #include "core/core.h"
 | 
					
						
							| 
									
										
										
										
											2018-07-26 01:16:08 -04:00
										 |  |  | #include "core/hle/service/ldn/ldn.h"
 | 
					
						
							| 
									
										
										
										
											2022-08-07 23:54:51 +02:00
										 |  |  | #include "core/internal_network/network.h"
 | 
					
						
							|  |  |  | #include "core/internal_network/network_interface.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #undef CreateEvent
 | 
					
						
							| 
									
										
										
										
											2018-07-26 01:16:08 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | namespace Service::LDN { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class IMonitorService final : public ServiceFramework<IMonitorService> { | 
					
						
							|  |  |  | public: | 
					
						
							| 
									
										
										
										
											2020-11-26 15:19:08 -05:00
										 |  |  |     explicit IMonitorService(Core::System& system_) : ServiceFramework{system_, "IMonitorService"} { | 
					
						
							| 
									
										
										
										
											2018-07-26 01:16:08 -04:00
										 |  |  |         // clang-format off
 | 
					
						
							|  |  |  |         static const FunctionInfo functions[] = { | 
					
						
							|  |  |  |             {0, nullptr, "GetStateForMonitor"}, | 
					
						
							|  |  |  |             {1, nullptr, "GetNetworkInfoForMonitor"}, | 
					
						
							|  |  |  |             {2, nullptr, "GetIpv4AddressForMonitor"}, | 
					
						
							|  |  |  |             {3, nullptr, "GetDisconnectReasonForMonitor"}, | 
					
						
							|  |  |  |             {4, nullptr, "GetSecurityParameterForMonitor"}, | 
					
						
							|  |  |  |             {5, nullptr, "GetNetworkConfigForMonitor"}, | 
					
						
							|  |  |  |             {100, nullptr, "InitializeMonitor"}, | 
					
						
							|  |  |  |             {101, nullptr, "FinalizeMonitor"}, | 
					
						
							|  |  |  |         }; | 
					
						
							|  |  |  |         // clang-format on
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         RegisterHandlers(functions); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class LDNM final : public ServiceFramework<LDNM> { | 
					
						
							|  |  |  | public: | 
					
						
							| 
									
										
										
										
											2020-11-26 15:19:08 -05:00
										 |  |  |     explicit LDNM(Core::System& system_) : ServiceFramework{system_, "ldn:m"} { | 
					
						
							| 
									
										
										
										
											2018-07-26 01:16:08 -04:00
										 |  |  |         // clang-format off
 | 
					
						
							|  |  |  |         static const FunctionInfo functions[] = { | 
					
						
							|  |  |  |             {0, &LDNM::CreateMonitorService, "CreateMonitorService"} | 
					
						
							|  |  |  |         }; | 
					
						
							|  |  |  |         // clang-format on
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         RegisterHandlers(functions); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     void CreateMonitorService(Kernel::HLERequestContext& ctx) { | 
					
						
							| 
									
										
										
										
											2018-11-26 17:06:13 +11:00
										 |  |  |         LOG_DEBUG(Service_LDN, "called"); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-26 01:16:08 -04:00
										 |  |  |         IPC::ResponseBuilder rb{ctx, 2, 0, 1}; | 
					
						
							| 
									
										
										
										
											2021-05-21 01:05:04 -04:00
										 |  |  |         rb.Push(ResultSuccess); | 
					
						
							| 
									
										
										
										
											2020-11-26 15:19:08 -05:00
										 |  |  |         rb.PushIpcInterface<IMonitorService>(system); | 
					
						
							| 
									
										
										
										
											2018-07-26 01:16:08 -04:00
										 |  |  |     } | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-10 14:48:37 -04:00
										 |  |  | class ISystemLocalCommunicationService final | 
					
						
							|  |  |  |     : public ServiceFramework<ISystemLocalCommunicationService> { | 
					
						
							| 
									
										
										
										
											2018-07-26 01:16:08 -04:00
										 |  |  | public: | 
					
						
							| 
									
										
										
										
											2020-11-26 15:19:08 -05:00
										 |  |  |     explicit ISystemLocalCommunicationService(Core::System& system_) | 
					
						
							|  |  |  |         : ServiceFramework{system_, "ISystemLocalCommunicationService"} { | 
					
						
							| 
									
										
										
										
											2018-07-26 01:16:08 -04:00
										 |  |  |         // clang-format off
 | 
					
						
							|  |  |  |         static const FunctionInfo functions[] = { | 
					
						
							|  |  |  |             {0, nullptr, "GetState"}, | 
					
						
							|  |  |  |             {1, nullptr, "GetNetworkInfo"}, | 
					
						
							|  |  |  |             {2, nullptr, "GetIpv4Address"}, | 
					
						
							|  |  |  |             {3, nullptr, "GetDisconnectReason"}, | 
					
						
							|  |  |  |             {4, nullptr, "GetSecurityParameter"}, | 
					
						
							|  |  |  |             {5, nullptr, "GetNetworkConfig"}, | 
					
						
							|  |  |  |             {100, nullptr, "AttachStateChangeEvent"}, | 
					
						
							|  |  |  |             {101, nullptr, "GetNetworkInfoLatestUpdate"}, | 
					
						
							|  |  |  |             {102, nullptr, "Scan"}, | 
					
						
							|  |  |  |             {103, nullptr, "ScanPrivate"}, | 
					
						
							| 
									
										
										
										
											2020-06-27 12:50:56 +02:00
										 |  |  |             {104, nullptr, "SetWirelessControllerRestriction"}, | 
					
						
							| 
									
										
										
										
											2018-07-26 01:16:08 -04:00
										 |  |  |             {200, nullptr, "OpenAccessPoint"}, | 
					
						
							|  |  |  |             {201, nullptr, "CloseAccessPoint"}, | 
					
						
							|  |  |  |             {202, nullptr, "CreateNetwork"}, | 
					
						
							|  |  |  |             {203, nullptr, "CreateNetworkPrivate"}, | 
					
						
							|  |  |  |             {204, nullptr, "DestroyNetwork"}, | 
					
						
							|  |  |  |             {205, nullptr, "Reject"}, | 
					
						
							|  |  |  |             {206, nullptr, "SetAdvertiseData"}, | 
					
						
							|  |  |  |             {207, nullptr, "SetStationAcceptPolicy"}, | 
					
						
							|  |  |  |             {208, nullptr, "AddAcceptFilterEntry"}, | 
					
						
							|  |  |  |             {209, nullptr, "ClearAcceptFilter"}, | 
					
						
							|  |  |  |             {300, nullptr, "OpenStation"}, | 
					
						
							|  |  |  |             {301, nullptr, "CloseStation"}, | 
					
						
							|  |  |  |             {302, nullptr, "Connect"}, | 
					
						
							|  |  |  |             {303, nullptr, "ConnectPrivate"}, | 
					
						
							|  |  |  |             {304, nullptr, "Disconnect"}, | 
					
						
							|  |  |  |             {400, nullptr, "InitializeSystem"}, | 
					
						
							|  |  |  |             {401, nullptr, "FinalizeSystem"}, | 
					
						
							| 
									
										
										
										
											2019-04-10 14:48:37 -04:00
										 |  |  |             {402, nullptr, "SetOperationMode"}, | 
					
						
							|  |  |  |             {403, nullptr, "InitializeSystem2"}, | 
					
						
							|  |  |  |         }; | 
					
						
							|  |  |  |         // clang-format on
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         RegisterHandlers(functions); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-08-07 23:54:51 +02:00
										 |  |  | IUserLocalCommunicationService::IUserLocalCommunicationService(Core::System& system_) | 
					
						
							|  |  |  |     : ServiceFramework{system_, "IUserLocalCommunicationService", ServiceThreadType::CreateNew}, | 
					
						
							|  |  |  |       service_context{system, "IUserLocalCommunicationService"}, room_network{ | 
					
						
							|  |  |  |                                                                      system_.GetRoomNetwork()} { | 
					
						
							|  |  |  |     // clang-format off
 | 
					
						
							| 
									
										
										
										
											2019-04-10 14:48:37 -04:00
										 |  |  |         static const FunctionInfo functions[] = { | 
					
						
							| 
									
										
										
										
											2021-02-13 21:45:09 -08:00
										 |  |  |             {0, &IUserLocalCommunicationService::GetState, "GetState"}, | 
					
						
							| 
									
										
										
										
											2022-08-07 23:54:51 +02:00
										 |  |  |             {1, &IUserLocalCommunicationService::GetNetworkInfo, "GetNetworkInfo"}, | 
					
						
							| 
									
										
										
										
											2019-04-10 14:48:37 -04:00
										 |  |  |             {2, nullptr, "GetIpv4Address"}, | 
					
						
							| 
									
										
										
										
											2022-08-07 23:54:51 +02:00
										 |  |  |             {3, &IUserLocalCommunicationService::GetDisconnectReason, "GetDisconnectReason"}, | 
					
						
							|  |  |  |             {4, &IUserLocalCommunicationService::GetSecurityParameter, "GetSecurityParameter"}, | 
					
						
							|  |  |  |             {5, &IUserLocalCommunicationService::GetNetworkConfig, "GetNetworkConfig"}, | 
					
						
							|  |  |  |             {100, &IUserLocalCommunicationService::AttachStateChangeEvent, "AttachStateChangeEvent"}, | 
					
						
							|  |  |  |             {101, &IUserLocalCommunicationService::GetNetworkInfoLatestUpdate, "GetNetworkInfoLatestUpdate"}, | 
					
						
							|  |  |  |             {102, &IUserLocalCommunicationService::Scan, "Scan"}, | 
					
						
							|  |  |  |             {103, &IUserLocalCommunicationService::ScanPrivate, "ScanPrivate"}, | 
					
						
							| 
									
										
										
										
											2019-04-10 14:48:37 -04:00
										 |  |  |             {104, nullptr, "SetWirelessControllerRestriction"}, | 
					
						
							| 
									
										
										
										
											2022-08-07 23:54:51 +02:00
										 |  |  |             {200, &IUserLocalCommunicationService::OpenAccessPoint, "OpenAccessPoint"}, | 
					
						
							|  |  |  |             {201, &IUserLocalCommunicationService::CloseAccessPoint, "CloseAccessPoint"}, | 
					
						
							|  |  |  |             {202, &IUserLocalCommunicationService::CreateNetwork, "CreateNetwork"}, | 
					
						
							|  |  |  |             {203, &IUserLocalCommunicationService::CreateNetworkPrivate, "CreateNetworkPrivate"}, | 
					
						
							|  |  |  |             {204, &IUserLocalCommunicationService::DestroyNetwork, "DestroyNetwork"}, | 
					
						
							| 
									
										
										
										
											2019-04-10 14:48:37 -04:00
										 |  |  |             {205, nullptr, "Reject"}, | 
					
						
							| 
									
										
										
										
											2022-08-07 23:54:51 +02:00
										 |  |  |             {206, &IUserLocalCommunicationService::SetAdvertiseData, "SetAdvertiseData"}, | 
					
						
							|  |  |  |             {207, &IUserLocalCommunicationService::SetStationAcceptPolicy, "SetStationAcceptPolicy"}, | 
					
						
							|  |  |  |             {208, &IUserLocalCommunicationService::AddAcceptFilterEntry, "AddAcceptFilterEntry"}, | 
					
						
							| 
									
										
										
										
											2019-04-10 14:48:37 -04:00
										 |  |  |             {209, nullptr, "ClearAcceptFilter"}, | 
					
						
							| 
									
										
										
										
											2022-08-07 23:54:51 +02:00
										 |  |  |             {300, &IUserLocalCommunicationService::OpenStation, "OpenStation"}, | 
					
						
							|  |  |  |             {301, &IUserLocalCommunicationService::CloseStation, "CloseStation"}, | 
					
						
							|  |  |  |             {302, &IUserLocalCommunicationService::Connect, "Connect"}, | 
					
						
							| 
									
										
										
										
											2019-04-10 14:48:37 -04:00
										 |  |  |             {303, nullptr, "ConnectPrivate"}, | 
					
						
							| 
									
										
										
										
											2022-08-07 23:54:51 +02:00
										 |  |  |             {304, &IUserLocalCommunicationService::Disconnect, "Disconnect"}, | 
					
						
							|  |  |  |             {400, &IUserLocalCommunicationService::Initialize, "Initialize"}, | 
					
						
							|  |  |  |             {401, &IUserLocalCommunicationService::Finalize, "Finalize"}, | 
					
						
							|  |  |  |             {402, &IUserLocalCommunicationService::Initialize2, "Initialize2"}, | 
					
						
							| 
									
										
										
										
											2018-07-26 01:16:08 -04:00
										 |  |  |         }; | 
					
						
							| 
									
										
										
										
											2022-08-07 23:54:51 +02:00
										 |  |  |     // clang-format on
 | 
					
						
							| 
									
										
										
										
											2018-07-26 01:16:08 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-08-07 23:54:51 +02:00
										 |  |  |     RegisterHandlers(functions); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     state_change_event = | 
					
						
							|  |  |  |         service_context.CreateEvent("IUserLocalCommunicationService:StateChangeEvent"); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | IUserLocalCommunicationService::~IUserLocalCommunicationService() { | 
					
						
							|  |  |  |     service_context.CloseEvent(state_change_event); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void IUserLocalCommunicationService::OnEventFired() { | 
					
						
							|  |  |  |     state_change_event->GetWritableEvent().Signal(); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void IUserLocalCommunicationService::GetState(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |     State state = State::Error; | 
					
						
							|  |  |  |     LOG_WARNING(Service_LDN, "(STUBBED) called, state = {}", state); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     IPC::ResponseBuilder rb{ctx, 3}; | 
					
						
							|  |  |  |     rb.Push(ResultSuccess); | 
					
						
							|  |  |  |     rb.PushEnum(state); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void IUserLocalCommunicationService::GetNetworkInfo(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |     const auto write_buffer_size = ctx.GetWriteBufferSize(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (write_buffer_size != sizeof(NetworkInfo)) { | 
					
						
							|  |  |  |         LOG_ERROR(Service_LDN, "Invalid buffer size {}", write_buffer_size); | 
					
						
							|  |  |  |         IPC::ResponseBuilder rb{ctx, 2}; | 
					
						
							|  |  |  |         rb.Push(ResultBadInput); | 
					
						
							|  |  |  |         return; | 
					
						
							| 
									
										
										
										
											2018-07-26 01:16:08 -04:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2020-02-16 13:24:34 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-08-07 23:54:51 +02:00
										 |  |  |     NetworkInfo networkInfo{}; | 
					
						
							|  |  |  |     const auto rc = ResultSuccess; | 
					
						
							|  |  |  |     if (rc.IsError()) { | 
					
						
							|  |  |  |         LOG_ERROR(Service_LDN, "NetworkInfo is not valid {}", rc.raw); | 
					
						
							|  |  |  |         IPC::ResponseBuilder rb{ctx, 2}; | 
					
						
							|  |  |  |         rb.Push(rc); | 
					
						
							|  |  |  |         return; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2021-02-13 02:32:13 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-08-07 23:54:51 +02:00
										 |  |  |     LOG_WARNING(Service_LDN, "(STUBBED) called, ssid='{}', nodes={}", | 
					
						
							|  |  |  |                 networkInfo.common.ssid.GetStringValue(), networkInfo.ldn.node_count); | 
					
						
							| 
									
										
										
										
											2021-02-13 21:45:09 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-08-07 23:54:51 +02:00
										 |  |  |     ctx.WriteBuffer<NetworkInfo>(networkInfo); | 
					
						
							|  |  |  |     IPC::ResponseBuilder rb{ctx, 2}; | 
					
						
							|  |  |  |     rb.Push(rc); | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2021-02-13 21:45:09 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-08-07 23:54:51 +02:00
										 |  |  | void IUserLocalCommunicationService::GetDisconnectReason(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |     const auto disconnect_reason = DisconnectReason::None; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     LOG_WARNING(Service_LDN, "(STUBBED) called, disconnect_reason={}", disconnect_reason); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     IPC::ResponseBuilder rb{ctx, 3}; | 
					
						
							|  |  |  |     rb.Push(ResultSuccess); | 
					
						
							|  |  |  |     rb.PushEnum(disconnect_reason); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void IUserLocalCommunicationService::GetSecurityParameter(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |     SecurityParameter security_parameter; | 
					
						
							|  |  |  |     NetworkInfo info; | 
					
						
							|  |  |  |     const Result rc = ResultSuccess; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (rc.IsError()) { | 
					
						
							|  |  |  |         LOG_ERROR(Service_LDN, "NetworkInfo is not valid {}", rc.raw); | 
					
						
							|  |  |  |         IPC::ResponseBuilder rb{ctx, 2}; | 
					
						
							|  |  |  |         rb.Push(rc); | 
					
						
							|  |  |  |         return; | 
					
						
							| 
									
										
										
										
											2021-02-13 21:45:09 -08:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-08-07 23:54:51 +02:00
										 |  |  |     security_parameter.session_id = info.network_id.session_id; | 
					
						
							|  |  |  |     std::memcpy(security_parameter.data.data(), info.ldn.security_parameter.data(), | 
					
						
							|  |  |  |                 sizeof(SecurityParameter::data)); | 
					
						
							| 
									
										
										
										
											2021-02-13 21:45:09 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-08-07 23:54:51 +02:00
										 |  |  |     LOG_WARNING(Service_LDN, "(STUBBED) called"); | 
					
						
							| 
									
										
										
										
											2021-02-13 21:45:09 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-08-07 23:54:51 +02:00
										 |  |  |     IPC::ResponseBuilder rb{ctx, 10}; | 
					
						
							|  |  |  |     rb.Push(rc); | 
					
						
							|  |  |  |     rb.PushRaw<SecurityParameter>(security_parameter); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void IUserLocalCommunicationService::GetNetworkConfig(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |     NetworkConfig config; | 
					
						
							|  |  |  |     NetworkInfo info; | 
					
						
							|  |  |  |     const Result rc = ResultSuccess; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (rc.IsError()) { | 
					
						
							|  |  |  |         LOG_ERROR(Service_LDN, "NetworkConfig is not valid {}", rc.raw); | 
					
						
							| 
									
										
										
										
											2020-02-16 13:24:34 +07:00
										 |  |  |         IPC::ResponseBuilder rb{ctx, 2}; | 
					
						
							| 
									
										
										
										
											2022-08-07 23:54:51 +02:00
										 |  |  |         rb.Push(rc); | 
					
						
							|  |  |  |         return; | 
					
						
							| 
									
										
										
										
											2020-02-16 13:24:34 +07:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2021-02-13 21:45:09 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-08-07 23:54:51 +02:00
										 |  |  |     config.intent_id = info.network_id.intent_id; | 
					
						
							|  |  |  |     config.channel = info.common.channel; | 
					
						
							|  |  |  |     config.node_count_max = info.ldn.node_count_max; | 
					
						
							|  |  |  |     config.local_communication_version = info.ldn.nodes[0].local_communication_version; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     LOG_WARNING(Service_LDN, | 
					
						
							|  |  |  |                 "(STUBBED) called, intent_id={}/{}, channel={}, node_count_max={}, " | 
					
						
							|  |  |  |                 "local_communication_version={}", | 
					
						
							|  |  |  |                 config.intent_id.local_communication_id, config.intent_id.scene_id, config.channel, | 
					
						
							|  |  |  |                 config.node_count_max, config.local_communication_version); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     IPC::ResponseBuilder rb{ctx, 10}; | 
					
						
							|  |  |  |     rb.Push(rc); | 
					
						
							|  |  |  |     rb.PushRaw<NetworkConfig>(config); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void IUserLocalCommunicationService::AttachStateChangeEvent(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |     LOG_INFO(Service_LDN, "called"); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     IPC::ResponseBuilder rb{ctx, 2, 1}; | 
					
						
							|  |  |  |     rb.Push(ResultSuccess); | 
					
						
							|  |  |  |     rb.PushCopyObjects(state_change_event->GetReadableEvent()); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void IUserLocalCommunicationService::GetNetworkInfoLatestUpdate(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |     const std::size_t network_buffer_size = ctx.GetWriteBufferSize(0); | 
					
						
							|  |  |  |     const std::size_t node_buffer_count = ctx.GetWriteBufferSize(1) / sizeof(NodeLatestUpdate); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (node_buffer_count == 0 || network_buffer_size != sizeof(NetworkInfo)) { | 
					
						
							|  |  |  |         LOG_ERROR(Service_LDN, "Invalid buffer size {}, {}", network_buffer_size, | 
					
						
							|  |  |  |                   node_buffer_count); | 
					
						
							|  |  |  |         IPC::ResponseBuilder rb{ctx, 2}; | 
					
						
							|  |  |  |         rb.Push(ResultBadInput); | 
					
						
							|  |  |  |         return; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     NetworkInfo info; | 
					
						
							|  |  |  |     std::vector<NodeLatestUpdate> latest_update{}; | 
					
						
							|  |  |  |     latest_update.resize(node_buffer_count); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     const auto rc = ResultSuccess; | 
					
						
							|  |  |  |     if (rc.IsError()) { | 
					
						
							|  |  |  |         LOG_ERROR(Service_LDN, "NetworkInfo is not valid {}", rc.raw); | 
					
						
							|  |  |  |         IPC::ResponseBuilder rb{ctx, 2}; | 
					
						
							|  |  |  |         rb.Push(rc); | 
					
						
							|  |  |  |         return; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     LOG_WARNING(Service_LDN, "(STUBBED) called, ssid='{}', nodes={}", | 
					
						
							|  |  |  |                 info.common.ssid.GetStringValue(), info.ldn.node_count); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     ctx.WriteBuffer(info, 0); | 
					
						
							|  |  |  |     ctx.WriteBuffer(latest_update, 1); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     IPC::ResponseBuilder rb{ctx, 2}; | 
					
						
							|  |  |  |     rb.Push(ResultSuccess); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void IUserLocalCommunicationService::Scan(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |     ScanImpl(ctx); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void IUserLocalCommunicationService::ScanPrivate(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |     ScanImpl(ctx, true); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void IUserLocalCommunicationService::ScanImpl(Kernel::HLERequestContext& ctx, bool is_private) { | 
					
						
							|  |  |  |     IPC::RequestParser rp{ctx}; | 
					
						
							|  |  |  |     const auto channel{rp.PopEnum<WifiChannel>()}; | 
					
						
							|  |  |  |     const auto scan_filter{rp.PopRaw<ScanFilter>()}; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     const std::size_t network_info_size = ctx.GetWriteBufferSize() / sizeof(NetworkInfo); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (network_info_size == 0) { | 
					
						
							|  |  |  |         LOG_ERROR(Service_LDN, "Invalid buffer size {}", network_info_size); | 
					
						
							|  |  |  |         IPC::ResponseBuilder rb{ctx, 2}; | 
					
						
							|  |  |  |         rb.Push(ResultBadInput); | 
					
						
							|  |  |  |         return; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     u16 count = 0; | 
					
						
							|  |  |  |     std::vector<NetworkInfo> networks_info{}; | 
					
						
							|  |  |  |     networks_info.resize(network_info_size); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     LOG_WARNING(Service_LDN, | 
					
						
							|  |  |  |                 "(STUBBED) called, channel={}, filter_scan_flag={}, filter_network_type={}", | 
					
						
							|  |  |  |                 channel, scan_filter.flag, scan_filter.network_type); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     ctx.WriteBuffer(networks_info); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     IPC::ResponseBuilder rb{ctx, 3}; | 
					
						
							|  |  |  |     rb.Push(ResultSuccess); | 
					
						
							|  |  |  |     rb.Push<u32>(count); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void IUserLocalCommunicationService::OpenAccessPoint(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |     LOG_WARNING(Service_LDN, "(STUBBED) called"); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     IPC::ResponseBuilder rb{ctx, 2}; | 
					
						
							|  |  |  |     rb.Push(ResultSuccess); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void IUserLocalCommunicationService::CloseAccessPoint(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |     LOG_WARNING(Service_LDN, "(STUBBED) called"); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     IPC::ResponseBuilder rb{ctx, 2}; | 
					
						
							|  |  |  |     rb.Push(ResultSuccess); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void IUserLocalCommunicationService::CreateNetwork(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |     LOG_WARNING(Service_LDN, "(STUBBED) called"); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     CreateNetworkImpl(ctx, false); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void IUserLocalCommunicationService::CreateNetworkPrivate(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |     LOG_WARNING(Service_LDN, "(STUBBED) called"); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     CreateNetworkImpl(ctx, true); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void IUserLocalCommunicationService::CreateNetworkImpl(Kernel::HLERequestContext& ctx, | 
					
						
							|  |  |  |                                                        bool is_private) { | 
					
						
							|  |  |  |     IPC::RequestParser rp{ctx}; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     const auto security_config{rp.PopRaw<SecurityConfig>()}; | 
					
						
							|  |  |  |     [[maybe_unused]] const auto security_parameter{is_private ? rp.PopRaw<SecurityParameter>() | 
					
						
							|  |  |  |                                                               : SecurityParameter{}}; | 
					
						
							|  |  |  |     const auto user_config{rp.PopRaw<UserConfig>()}; | 
					
						
							|  |  |  |     rp.Pop<u32>(); // Padding
 | 
					
						
							|  |  |  |     const auto network_Config{rp.PopRaw<NetworkConfig>()}; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     IPC::ResponseBuilder rb{ctx, 2}; | 
					
						
							|  |  |  |     rb.Push(ResultSuccess); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | void IUserLocalCommunicationService::DestroyNetwork(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |     LOG_WARNING(Service_LDN, "(STUBBED) called"); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     IPC::ResponseBuilder rb{ctx, 2}; | 
					
						
							|  |  |  |     rb.Push(ResultSuccess); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void IUserLocalCommunicationService::SetAdvertiseData(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |     std::vector<u8> read_buffer = ctx.ReadBuffer(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     LOG_WARNING(Service_LDN, "(STUBBED) called, size {}", read_buffer.size()); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     IPC::ResponseBuilder rb{ctx, 2}; | 
					
						
							|  |  |  |     rb.Push(ResultSuccess); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void IUserLocalCommunicationService::SetStationAcceptPolicy(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |     LOG_WARNING(Service_LDN, "(STUBBED) called"); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     IPC::ResponseBuilder rb{ctx, 2}; | 
					
						
							|  |  |  |     rb.Push(ResultSuccess); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void IUserLocalCommunicationService::AddAcceptFilterEntry(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |     LOG_WARNING(Service_LDN, "(STUBBED) called"); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     IPC::ResponseBuilder rb{ctx, 2}; | 
					
						
							|  |  |  |     rb.Push(ResultSuccess); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void IUserLocalCommunicationService::OpenStation(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |     LOG_WARNING(Service_LDN, "(STUBBED) called"); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     IPC::ResponseBuilder rb{ctx, 2}; | 
					
						
							|  |  |  |     rb.Push(ResultSuccess); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void IUserLocalCommunicationService::CloseStation(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |     LOG_WARNING(Service_LDN, "(STUBBED) called"); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     IPC::ResponseBuilder rb{ctx, 2}; | 
					
						
							|  |  |  |     rb.Push(ResultSuccess); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void IUserLocalCommunicationService::Connect(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |     LOG_WARNING(Service_LDN, "(STUBBED) called"); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     IPC::RequestParser rp{ctx}; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     [[maybe_unused]] const auto securityConfig{rp.PopRaw<SecurityConfig>()}; | 
					
						
							|  |  |  |     const auto user_config{rp.PopRaw<UserConfig>()}; | 
					
						
							|  |  |  |     const auto local_communication_version{rp.Pop<u32>()}; | 
					
						
							|  |  |  |     [[maybe_unused]] const auto option{rp.Pop<u32>()}; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     std::vector<u8> read_buffer = ctx.ReadBuffer(); | 
					
						
							|  |  |  |     NetworkInfo networkInfo{}; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (read_buffer.size() != sizeof(NetworkInfo)) { | 
					
						
							|  |  |  |         LOG_ERROR(Frontend, "NetworkInfo doesn't match read_buffer size!"); | 
					
						
							|  |  |  |         IPC::ResponseBuilder rb{ctx, 2}; | 
					
						
							|  |  |  |         rb.Push(ResultBadInput); | 
					
						
							|  |  |  |         return; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     std::memcpy(&networkInfo, read_buffer.data(), read_buffer.size()); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     IPC::ResponseBuilder rb{ctx, 2}; | 
					
						
							|  |  |  |     rb.Push(ResultSuccess); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void IUserLocalCommunicationService::Disconnect(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |     LOG_WARNING(Service_LDN, "(STUBBED) called"); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     IPC::ResponseBuilder rb{ctx, 2}; | 
					
						
							|  |  |  |     rb.Push(ResultSuccess); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | void IUserLocalCommunicationService::Initialize(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |     LOG_WARNING(Service_LDN, "(STUBBED) called"); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     const auto rc = InitializeImpl(ctx); | 
					
						
							|  |  |  |     if (rc.IsError()) { | 
					
						
							|  |  |  |         LOG_ERROR(Service_LDN, "Network isn't initialized, rc={}", rc.raw); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     IPC::ResponseBuilder rb{ctx, 2}; | 
					
						
							|  |  |  |     rb.Push(rc); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void IUserLocalCommunicationService::Finalize(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |     LOG_WARNING(Service_LDN, "(STUBBED) called"); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     is_initialized = false; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     IPC::ResponseBuilder rb{ctx, 2}; | 
					
						
							|  |  |  |     rb.Push(ResultSuccess); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void IUserLocalCommunicationService::Initialize2(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |     LOG_WARNING(Service_LDN, "(STUBBED) called"); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     const auto rc = InitializeImpl(ctx); | 
					
						
							|  |  |  |     if (rc.IsError()) { | 
					
						
							|  |  |  |         LOG_ERROR(Service_LDN, "Network isn't initialized, rc={}", rc.raw); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     IPC::ResponseBuilder rb{ctx, 2}; | 
					
						
							|  |  |  |     rb.Push(rc); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Result IUserLocalCommunicationService::InitializeImpl(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |     const auto network_interface = Network::GetSelectedNetworkInterface(); | 
					
						
							|  |  |  |     if (!network_interface) { | 
					
						
							|  |  |  |         return ResultAirplaneModeEnabled; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     is_initialized = true; | 
					
						
							|  |  |  |     // TODO (flTobi): Change this to ResultSuccess when LDN is fully implemented
 | 
					
						
							|  |  |  |     return ResultAirplaneModeEnabled; | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2018-07-26 01:16:08 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | class LDNS final : public ServiceFramework<LDNS> { | 
					
						
							|  |  |  | public: | 
					
						
							| 
									
										
										
										
											2020-11-26 15:19:08 -05:00
										 |  |  |     explicit LDNS(Core::System& system_) : ServiceFramework{system_, "ldn:s"} { | 
					
						
							| 
									
										
										
										
											2018-07-26 01:16:08 -04:00
										 |  |  |         // clang-format off
 | 
					
						
							|  |  |  |         static const FunctionInfo functions[] = { | 
					
						
							|  |  |  |             {0, &LDNS::CreateSystemLocalCommunicationService, "CreateSystemLocalCommunicationService"}, | 
					
						
							|  |  |  |         }; | 
					
						
							|  |  |  |         // clang-format on
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         RegisterHandlers(functions); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     void CreateSystemLocalCommunicationService(Kernel::HLERequestContext& ctx) { | 
					
						
							| 
									
										
										
										
											2018-11-26 17:06:13 +11:00
										 |  |  |         LOG_DEBUG(Service_LDN, "called"); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-26 01:16:08 -04:00
										 |  |  |         IPC::ResponseBuilder rb{ctx, 2, 0, 1}; | 
					
						
							| 
									
										
										
										
											2021-05-21 01:05:04 -04:00
										 |  |  |         rb.Push(ResultSuccess); | 
					
						
							| 
									
										
										
										
											2020-11-26 15:19:08 -05:00
										 |  |  |         rb.PushIpcInterface<ISystemLocalCommunicationService>(system); | 
					
						
							| 
									
										
										
										
											2018-07-26 01:16:08 -04:00
										 |  |  |     } | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class LDNU final : public ServiceFramework<LDNU> { | 
					
						
							|  |  |  | public: | 
					
						
							| 
									
										
										
										
											2020-11-26 15:19:08 -05:00
										 |  |  |     explicit LDNU(Core::System& system_) : ServiceFramework{system_, "ldn:u"} { | 
					
						
							| 
									
										
										
										
											2018-07-26 01:16:08 -04:00
										 |  |  |         // clang-format off
 | 
					
						
							|  |  |  |         static const FunctionInfo functions[] = { | 
					
						
							|  |  |  |             {0, &LDNU::CreateUserLocalCommunicationService, "CreateUserLocalCommunicationService"}, | 
					
						
							|  |  |  |         }; | 
					
						
							|  |  |  |         // clang-format on
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         RegisterHandlers(functions); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     void CreateUserLocalCommunicationService(Kernel::HLERequestContext& ctx) { | 
					
						
							| 
									
										
										
										
											2018-11-26 17:06:13 +11:00
										 |  |  |         LOG_DEBUG(Service_LDN, "called"); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-26 01:16:08 -04:00
										 |  |  |         IPC::ResponseBuilder rb{ctx, 2, 0, 1}; | 
					
						
							| 
									
										
										
										
											2021-05-21 01:05:04 -04:00
										 |  |  |         rb.Push(ResultSuccess); | 
					
						
							| 
									
										
										
										
											2020-11-26 15:19:08 -05:00
										 |  |  |         rb.PushIpcInterface<IUserLocalCommunicationService>(system); | 
					
						
							| 
									
										
										
										
											2018-07-26 01:16:08 -04:00
										 |  |  |     } | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-26 08:42:57 -05:00
										 |  |  | class INetworkService final : public ServiceFramework<INetworkService> { | 
					
						
							|  |  |  | public: | 
					
						
							|  |  |  |     explicit INetworkService(Core::System& system_) : ServiceFramework{system_, "INetworkService"} { | 
					
						
							|  |  |  |         // clang-format off
 | 
					
						
							|  |  |  |         static const FunctionInfo functions[] = { | 
					
						
							|  |  |  |             {0, nullptr, "Initialize"}, | 
					
						
							|  |  |  |             {256, nullptr, "AttachNetworkInterfaceStateChangeEvent"}, | 
					
						
							|  |  |  |             {264, nullptr, "GetNetworkInterfaceLastError"}, | 
					
						
							|  |  |  |             {272, nullptr, "GetRole"}, | 
					
						
							|  |  |  |             {280, nullptr, "GetAdvertiseData"}, | 
					
						
							|  |  |  |             {288, nullptr, "GetGroupInfo"}, | 
					
						
							|  |  |  |             {296, nullptr, "GetGroupInfo2"}, | 
					
						
							|  |  |  |             {304, nullptr, "GetGroupOwner"}, | 
					
						
							|  |  |  |             {312, nullptr, "GetIpConfig"}, | 
					
						
							|  |  |  |             {320, nullptr, "GetLinkLevel"}, | 
					
						
							|  |  |  |             {512, nullptr, "Scan"}, | 
					
						
							|  |  |  |             {768, nullptr, "CreateGroup"}, | 
					
						
							|  |  |  |             {776, nullptr, "DestroyGroup"}, | 
					
						
							|  |  |  |             {784, nullptr, "SetAdvertiseData"}, | 
					
						
							|  |  |  |             {1536, nullptr, "SendToOtherGroup"}, | 
					
						
							|  |  |  |             {1544, nullptr, "RecvFromOtherGroup"}, | 
					
						
							|  |  |  |             {1552, nullptr, "AddAcceptableGroupId"}, | 
					
						
							|  |  |  |             {1560, nullptr, "ClearAcceptableGroupId"}, | 
					
						
							|  |  |  |         }; | 
					
						
							|  |  |  |         // clang-format on
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         RegisterHandlers(functions); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class INetworkServiceMonitor final : public ServiceFramework<INetworkServiceMonitor> { | 
					
						
							|  |  |  | public: | 
					
						
							|  |  |  |     explicit INetworkServiceMonitor(Core::System& system_) | 
					
						
							|  |  |  |         : ServiceFramework{system_, "INetworkServiceMonitor"} { | 
					
						
							|  |  |  |         // clang-format off
 | 
					
						
							|  |  |  |         static const FunctionInfo functions[] = { | 
					
						
							|  |  |  |             {0, &INetworkServiceMonitor::Initialize, "Initialize"}, | 
					
						
							|  |  |  |             {256, nullptr, "AttachNetworkInterfaceStateChangeEvent"}, | 
					
						
							|  |  |  |             {264, nullptr, "GetNetworkInterfaceLastError"}, | 
					
						
							|  |  |  |             {272, nullptr, "GetRole"}, | 
					
						
							|  |  |  |             {280, nullptr, "GetAdvertiseData"}, | 
					
						
							|  |  |  |             {281, nullptr, "GetAdvertiseData2"}, | 
					
						
							|  |  |  |             {288, nullptr, "GetGroupInfo"}, | 
					
						
							|  |  |  |             {296, nullptr, "GetGroupInfo2"}, | 
					
						
							|  |  |  |             {304, nullptr, "GetGroupOwner"}, | 
					
						
							|  |  |  |             {312, nullptr, "GetIpConfig"}, | 
					
						
							|  |  |  |             {320, nullptr, "GetLinkLevel"}, | 
					
						
							|  |  |  |             {328, nullptr, "AttachJoinEvent"}, | 
					
						
							|  |  |  |             {336, nullptr, "GetMembers"}, | 
					
						
							|  |  |  |         }; | 
					
						
							|  |  |  |         // clang-format on
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         RegisterHandlers(functions); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     void Initialize(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |         LOG_WARNING(Service_LDN, "(STUBBED) called"); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         IPC::ResponseBuilder rb{ctx, 2}; | 
					
						
							| 
									
										
										
										
											2022-08-07 23:54:51 +02:00
										 |  |  |         rb.Push(ResultDisabled); | 
					
						
							| 
									
										
										
										
											2021-05-26 08:42:57 -05:00
										 |  |  |     } | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class LP2PAPP final : public ServiceFramework<LP2PAPP> { | 
					
						
							|  |  |  | public: | 
					
						
							|  |  |  |     explicit LP2PAPP(Core::System& system_) : ServiceFramework{system_, "lp2p:app"} { | 
					
						
							|  |  |  |         // clang-format off
 | 
					
						
							|  |  |  |         static const FunctionInfo functions[] = { | 
					
						
							|  |  |  |             {0, &LP2PAPP::CreateMonitorService, "CreateNetworkService"}, | 
					
						
							|  |  |  |             {8, &LP2PAPP::CreateMonitorService, "CreateNetworkServiceMonitor"}, | 
					
						
							|  |  |  |         }; | 
					
						
							|  |  |  |         // clang-format on
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         RegisterHandlers(functions); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     void CreateNetworkervice(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |         IPC::RequestParser rp{ctx}; | 
					
						
							|  |  |  |         const u64 reserved_input = rp.Pop<u64>(); | 
					
						
							|  |  |  |         const u32 input = rp.Pop<u32>(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         LOG_WARNING(Service_LDN, "(STUBBED) called reserved_input={} input={}", reserved_input, | 
					
						
							|  |  |  |                     input); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         IPC::ResponseBuilder rb{ctx, 2, 0, 1}; | 
					
						
							| 
									
										
										
										
											2021-05-21 01:05:04 -04:00
										 |  |  |         rb.Push(ResultSuccess); | 
					
						
							| 
									
										
										
										
											2021-05-26 08:42:57 -05:00
										 |  |  |         rb.PushIpcInterface<INetworkService>(system); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     void CreateMonitorService(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |         IPC::RequestParser rp{ctx}; | 
					
						
							|  |  |  |         const u64 reserved_input = rp.Pop<u64>(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         LOG_WARNING(Service_LDN, "(STUBBED) called reserved_input={}", reserved_input); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         IPC::ResponseBuilder rb{ctx, 2, 0, 1}; | 
					
						
							| 
									
										
										
										
											2021-05-21 01:05:04 -04:00
										 |  |  |         rb.Push(ResultSuccess); | 
					
						
							| 
									
										
										
										
											2021-05-26 08:42:57 -05:00
										 |  |  |         rb.PushIpcInterface<INetworkServiceMonitor>(system); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class LP2PSYS final : public ServiceFramework<LP2PSYS> { | 
					
						
							|  |  |  | public: | 
					
						
							|  |  |  |     explicit LP2PSYS(Core::System& system_) : ServiceFramework{system_, "lp2p:sys"} { | 
					
						
							|  |  |  |         // clang-format off
 | 
					
						
							|  |  |  |         static const FunctionInfo functions[] = { | 
					
						
							|  |  |  |             {0, &LP2PSYS::CreateMonitorService, "CreateNetworkService"}, | 
					
						
							|  |  |  |             {8, &LP2PSYS::CreateMonitorService, "CreateNetworkServiceMonitor"}, | 
					
						
							|  |  |  |         }; | 
					
						
							|  |  |  |         // clang-format on
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         RegisterHandlers(functions); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     void CreateNetworkervice(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |         IPC::RequestParser rp{ctx}; | 
					
						
							|  |  |  |         const u64 reserved_input = rp.Pop<u64>(); | 
					
						
							|  |  |  |         const u32 input = rp.Pop<u32>(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         LOG_WARNING(Service_LDN, "(STUBBED) called reserved_input={} input={}", reserved_input, | 
					
						
							|  |  |  |                     input); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         IPC::ResponseBuilder rb{ctx, 2, 0, 1}; | 
					
						
							| 
									
										
										
										
											2021-05-21 01:05:04 -04:00
										 |  |  |         rb.Push(ResultSuccess); | 
					
						
							| 
									
										
										
										
											2021-05-26 08:42:57 -05:00
										 |  |  |         rb.PushIpcInterface<INetworkService>(system); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     void CreateMonitorService(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |         IPC::RequestParser rp{ctx}; | 
					
						
							|  |  |  |         const u64 reserved_input = rp.Pop<u64>(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         LOG_WARNING(Service_LDN, "(STUBBED) called reserved_input={}", reserved_input); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         IPC::ResponseBuilder rb{ctx, 2, 0, 1}; | 
					
						
							| 
									
										
										
										
											2021-05-21 01:05:04 -04:00
										 |  |  |         rb.Push(ResultSuccess); | 
					
						
							| 
									
										
										
										
											2021-05-26 08:42:57 -05:00
										 |  |  |         rb.PushIpcInterface<INetworkServiceMonitor>(system); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-11-26 15:19:08 -05:00
										 |  |  | void InstallInterfaces(SM::ServiceManager& sm, Core::System& system) { | 
					
						
							|  |  |  |     std::make_shared<LDNM>(system)->InstallAsService(sm); | 
					
						
							|  |  |  |     std::make_shared<LDNS>(system)->InstallAsService(sm); | 
					
						
							|  |  |  |     std::make_shared<LDNU>(system)->InstallAsService(sm); | 
					
						
							| 
									
										
										
										
											2021-05-26 08:42:57 -05:00
										 |  |  |     std::make_shared<LP2PAPP>(system)->InstallAsService(sm); | 
					
						
							|  |  |  |     std::make_shared<LP2PSYS>(system)->InstallAsService(sm); | 
					
						
							| 
									
										
										
										
											2018-07-26 01:16:08 -04:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | } // namespace Service::LDN
 |