mirror of
				https://git.zaroz.cloud/nintendo-back-up/yuzu/yuzu.git
				synced 2025-05-12 00:45:25 +00:00 
			
		
		
		
	Implemented NTC & IEnsureNetworkClockAvailabilityService
Needed because of the recent nim fixes
This commit is contained in:
		
							parent
							
								
									0432af5ad1
								
							
						
					
					
						commit
						335e9d18ae
					
				@ -2,6 +2,10 @@
 | 
				
			|||||||
// Licensed under GPLv2 or any later version
 | 
					// Licensed under GPLv2 or any later version
 | 
				
			||||||
// Refer to the license.txt file included.
 | 
					// Refer to the license.txt file included.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#include <chrono>
 | 
				
			||||||
 | 
					#include <ctime>
 | 
				
			||||||
 | 
					#include "core/hle/ipc_helpers.h"
 | 
				
			||||||
 | 
					#include "core/hle/kernel/event.h"
 | 
				
			||||||
#include "core/hle/service/nim/nim.h"
 | 
					#include "core/hle/service/nim/nim.h"
 | 
				
			||||||
#include "core/hle/service/service.h"
 | 
					#include "core/hle/service/service.h"
 | 
				
			||||||
#include "core/hle/service/sm/sm.h"
 | 
					#include "core/hle/service/sm/sm.h"
 | 
				
			||||||
@ -100,19 +104,112 @@ public:
 | 
				
			|||||||
    }
 | 
					    }
 | 
				
			||||||
};
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					class IEnsureNetworkClockAvailabilityService final
 | 
				
			||||||
 | 
					    : public ServiceFramework<IEnsureNetworkClockAvailabilityService> {
 | 
				
			||||||
 | 
					public:
 | 
				
			||||||
 | 
					    IEnsureNetworkClockAvailabilityService()
 | 
				
			||||||
 | 
					        : ServiceFramework("IEnsureNetworkClockAvailabilityService") {
 | 
				
			||||||
 | 
					        static const FunctionInfo functions[] = {
 | 
				
			||||||
 | 
					            {0, &IEnsureNetworkClockAvailabilityService::StartTask, "StartTask"},
 | 
				
			||||||
 | 
					            {1, &IEnsureNetworkClockAvailabilityService::GetFinishNotificationEvent,
 | 
				
			||||||
 | 
					             "GetFinishNotificationEvent"},
 | 
				
			||||||
 | 
					            {2, &IEnsureNetworkClockAvailabilityService::GetResult, "GetResult"},
 | 
				
			||||||
 | 
					            {3, &IEnsureNetworkClockAvailabilityService::Cancel, "Cancel"},
 | 
				
			||||||
 | 
					            {4, &IEnsureNetworkClockAvailabilityService::IsProcessing, "IsProcessing"},
 | 
				
			||||||
 | 
					            {5, &IEnsureNetworkClockAvailabilityService::GetServerTime, "GetServerTime"},
 | 
				
			||||||
 | 
					        };
 | 
				
			||||||
 | 
					        RegisterHandlers(functions);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        auto& kernel = Core::System::GetInstance().Kernel();
 | 
				
			||||||
 | 
					        finished_event =
 | 
				
			||||||
 | 
					            Kernel::Event::Create(kernel, Kernel::ResetType::OneShot,
 | 
				
			||||||
 | 
					                                  "IEnsureNetworkClockAvailabilityService:FinishEvent");
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					private:
 | 
				
			||||||
 | 
					    Kernel::SharedPtr<Kernel::Event> finished_event;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    void StartTask(Kernel::HLERequestContext& ctx) {
 | 
				
			||||||
 | 
					        // No need to connect to the internet, just finish the task straight away.
 | 
				
			||||||
 | 
					        finished_event->Signal();
 | 
				
			||||||
 | 
					        IPC::ResponseBuilder rb{ctx, 2};
 | 
				
			||||||
 | 
					        rb.Push(RESULT_SUCCESS);
 | 
				
			||||||
 | 
					        LOG_DEBUG(Service_NIM, "called");
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    void GetFinishNotificationEvent(Kernel::HLERequestContext& ctx) {
 | 
				
			||||||
 | 
					        IPC::ResponseBuilder rb{ctx, 2, 1};
 | 
				
			||||||
 | 
					        rb.Push(RESULT_SUCCESS);
 | 
				
			||||||
 | 
					        rb.PushCopyObjects(finished_event);
 | 
				
			||||||
 | 
					        LOG_DEBUG(Service_NIM, "called");
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    void GetResult(Kernel::HLERequestContext& ctx) {
 | 
				
			||||||
 | 
					        finished_event->Clear();
 | 
				
			||||||
 | 
					        IPC::ResponseBuilder rb{ctx, 2};
 | 
				
			||||||
 | 
					        rb.Push(RESULT_SUCCESS);
 | 
				
			||||||
 | 
					        LOG_DEBUG(Service_NIM, "called");
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    void Cancel(Kernel::HLERequestContext& ctx) {
 | 
				
			||||||
 | 
					        finished_event->Clear();
 | 
				
			||||||
 | 
					        IPC::ResponseBuilder rb{ctx, 2};
 | 
				
			||||||
 | 
					        rb.Push(RESULT_SUCCESS);
 | 
				
			||||||
 | 
					        LOG_DEBUG(Service_NIM, "called");
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    void IsProcessing(Kernel::HLERequestContext& ctx) {
 | 
				
			||||||
 | 
					        IPC::ResponseBuilder rb{ctx, 3};
 | 
				
			||||||
 | 
					        rb.Push(RESULT_SUCCESS);
 | 
				
			||||||
 | 
					        rb.PushRaw<u32>(0); // We instantly process the request
 | 
				
			||||||
 | 
					        LOG_DEBUG(Service_NIM, "called");
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    void GetServerTime(Kernel::HLERequestContext& ctx) {
 | 
				
			||||||
 | 
					        const s64 server_time{std::chrono::duration_cast<std::chrono::seconds>(
 | 
				
			||||||
 | 
					                                  std::chrono::system_clock::now().time_since_epoch())
 | 
				
			||||||
 | 
					                                  .count()};
 | 
				
			||||||
 | 
					        IPC::ResponseBuilder rb{ctx, 4};
 | 
				
			||||||
 | 
					        rb.Push(RESULT_SUCCESS);
 | 
				
			||||||
 | 
					        rb.PushRaw<s64>(server_time);
 | 
				
			||||||
 | 
					        LOG_DEBUG(Service_NIM, "called");
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
class NTC final : public ServiceFramework<NTC> {
 | 
					class NTC final : public ServiceFramework<NTC> {
 | 
				
			||||||
public:
 | 
					public:
 | 
				
			||||||
    explicit NTC() : ServiceFramework{"ntc"} {
 | 
					    explicit NTC() : ServiceFramework{"ntc"} {
 | 
				
			||||||
        // clang-format off
 | 
					        // clang-format off
 | 
				
			||||||
        static const FunctionInfo functions[] = {
 | 
					        static const FunctionInfo functions[] = {
 | 
				
			||||||
            {0, nullptr, "OpenEnsureNetworkClockAvailabilityService"},
 | 
					            {0, &NTC::OpenEnsureNetworkClockAvailabilityService, "OpenEnsureNetworkClockAvailabilityService"},
 | 
				
			||||||
            {100, nullptr, "SuspendAutonomicTimeCorrection"},
 | 
					            {100, &NTC::SuspendAutonomicTimeCorrection, "SuspendAutonomicTimeCorrection"},
 | 
				
			||||||
            {101, nullptr, "ResumeAutonomicTimeCorrection"},
 | 
					            {101, &NTC::ResumeAutonomicTimeCorrection, "ResumeAutonomicTimeCorrection"},
 | 
				
			||||||
        };
 | 
					        };
 | 
				
			||||||
        // clang-format on
 | 
					        // clang-format on
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        RegisterHandlers(functions);
 | 
					        RegisterHandlers(functions);
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					private:
 | 
				
			||||||
 | 
					    void OpenEnsureNetworkClockAvailabilityService(Kernel::HLERequestContext& ctx) {
 | 
				
			||||||
 | 
					        IPC::ResponseBuilder rb{ctx, 2, 0, 1};
 | 
				
			||||||
 | 
					        rb.Push(RESULT_SUCCESS);
 | 
				
			||||||
 | 
					        rb.PushIpcInterface<IEnsureNetworkClockAvailabilityService>();
 | 
				
			||||||
 | 
					        LOG_DEBUG(Service_NIM, "called");
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    // TODO(ogniK): Do we need these?
 | 
				
			||||||
 | 
					    void SuspendAutonomicTimeCorrection(Kernel::HLERequestContext& ctx) {
 | 
				
			||||||
 | 
					        IPC::ResponseBuilder rb{ctx, 2};
 | 
				
			||||||
 | 
					        rb.Push(RESULT_SUCCESS);
 | 
				
			||||||
 | 
					        LOG_WARNING(Service_NIM, "(STUBBED) called");
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    void ResumeAutonomicTimeCorrection(Kernel::HLERequestContext& ctx) {
 | 
				
			||||||
 | 
					        IPC::ResponseBuilder rb{ctx, 2};
 | 
				
			||||||
 | 
					        rb.Push(RESULT_SUCCESS);
 | 
				
			||||||
 | 
					        LOG_WARNING(Service_NIM, "(STUBBED) called");
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
};
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
void InstallInterfaces(SM::ServiceManager& sm) {
 | 
					void InstallInterfaces(SM::ServiceManager& sm) {
 | 
				
			||||||
 | 
				
			|||||||
		Loading…
	
		Reference in New Issue
	
	Block a user