diff options
| author | Liam <byteslice@airmail.cc> | 2022-04-06 14:46:21 -0400 | 
|---|---|---|
| committer | Liam <byteslice@airmail.cc> | 2022-04-06 20:07:01 -0400 | 
| commit | 0cfcee95c7d13d6ea2d7c73c6f1b64a17ceb2aca (patch) | |
| tree | 635c360c4efe908dc0e2187b054b3aa0fbd8d5f6 /src/core/hle | |
| parent | 37199c5f90728f21f5475e409e2ec93901f2f73b (diff) | |
service: jit: stub JIT service
Diffstat (limited to 'src/core/hle')
| -rw-r--r-- | src/core/hle/service/am/am.cpp | 9 | ||||
| -rw-r--r-- | src/core/hle/service/am/am.h | 1 | ||||
| -rw-r--r-- | src/core/hle/service/jit/jit.cpp | 53 | ||||
| -rw-r--r-- | src/core/hle/service/jit/jit.h | 20 | ||||
| -rw-r--r-- | src/core/hle/service/service.cpp | 2 | 
5 files changed, 84 insertions, 1 deletions
| diff --git a/src/core/hle/service/am/am.cpp b/src/core/hle/service/am/am.cpp index 420de3c54..4d7e5ecd3 100644 --- a/src/core/hle/service/am/am.cpp +++ b/src/core/hle/service/am/am.cpp @@ -1337,7 +1337,7 @@ IApplicationFunctions::IApplicationFunctions(Core::System& system_)          {200, nullptr, "GetLastApplicationExitReason"},          {500, nullptr, "StartContinuousRecordingFlushForDebug"},          {1000, nullptr, "CreateMovieMaker"}, -        {1001, nullptr, "PrepareForJit"}, +        {1001, &IApplicationFunctions::PrepareForJit, "PrepareForJit"},      };      // clang-format on @@ -1787,6 +1787,13 @@ void IApplicationFunctions::GetHealthWarningDisappearedSystemEvent(Kernel::HLERe      rb.PushCopyObjects(health_warning_disappeared_system_event->GetReadableEvent());  } +void IApplicationFunctions::PrepareForJit(Kernel::HLERequestContext& ctx) { +    LOG_WARNING(Service_AM, "(STUBBED) called"); + +    IPC::ResponseBuilder rb{ctx, 2}; +    rb.Push(ResultSuccess); +} +  void InstallInterfaces(SM::ServiceManager& service_manager, NVFlinger::NVFlinger& nvflinger,                         Core::System& system) {      auto message_queue = std::make_shared<AppletMessageQueue>(system); diff --git a/src/core/hle/service/am/am.h b/src/core/hle/service/am/am.h index fdd937b82..11a3c0459 100644 --- a/src/core/hle/service/am/am.h +++ b/src/core/hle/service/am/am.h @@ -336,6 +336,7 @@ private:      void TryPopFromFriendInvitationStorageChannel(Kernel::HLERequestContext& ctx);      void GetNotificationStorageChannelEvent(Kernel::HLERequestContext& ctx);      void GetHealthWarningDisappearedSystemEvent(Kernel::HLERequestContext& ctx); +    void PrepareForJit(Kernel::HLERequestContext& ctx);      KernelHelpers::ServiceContext service_context; diff --git a/src/core/hle/service/jit/jit.cpp b/src/core/hle/service/jit/jit.cpp new file mode 100644 index 000000000..c8ebd2e3f --- /dev/null +++ b/src/core/hle/service/jit/jit.cpp @@ -0,0 +1,53 @@ +// Copyright 2022 yuzu Emulator Project +// Licensed under GPLv2 or any later version +// Refer to the license.txt file included. + +#include "core/hle/ipc_helpers.h" +#include "core/hle/result.h" +#include "core/hle/service/jit/jit.h" +#include "core/hle/service/service.h" + +namespace Service::JIT { + +class IJitEnvironment final : public ServiceFramework<IJitEnvironment> { +public: +    explicit IJitEnvironment(Core::System& system_) : ServiceFramework{system_, "IJitEnvironment"} { +        // clang-format off +        static const FunctionInfo functions[] = { +            {0, nullptr, "GenerateCode"}, +            {1, nullptr, "Control"}, +            {1000, nullptr, "LoadPlugin"}, +            {1001, nullptr, "GetCodeAddress"}, +        }; +        // clang-format on + +        RegisterHandlers(functions); +    } +}; + +class JITU final : public ServiceFramework<JITU> { +public: +    explicit JITU(Core::System& system_) : ServiceFramework{system_, "jit:u"} { +        // clang-format off +        static const FunctionInfo functions[] = { +            {0, &JITU::CreateJitEnvironment, "CreateJitEnvironment"}, +        }; +        // clang-format on + +        RegisterHandlers(functions); +    } + +    void CreateJitEnvironment(Kernel::HLERequestContext& ctx) { +        LOG_DEBUG(Service_JIT, "called"); + +        IPC::ResponseBuilder rb{ctx, 2, 0, 1}; +        rb.Push(ResultSuccess); +        rb.PushIpcInterface<IJitEnvironment>(system); +    } +}; + +void InstallInterfaces(SM::ServiceManager& sm, Core::System& system) { +    std::make_shared<JITU>(system)->InstallAsService(sm); +} + +} // namespace Service::JIT diff --git a/src/core/hle/service/jit/jit.h b/src/core/hle/service/jit/jit.h new file mode 100644 index 000000000..8fbf504a1 --- /dev/null +++ b/src/core/hle/service/jit/jit.h @@ -0,0 +1,20 @@ +// Copyright 2022 yuzu Emulator Project +// Licensed under GPLv2 or any later version +// Refer to the license.txt file included. + +#pragma once + +namespace Core { +class System; +} + +namespace Service::SM { +class ServiceManager; +} + +namespace Service::JIT { + +/// Registers all JIT services with the specified service manager. +void InstallInterfaces(SM::ServiceManager& sm, Core::System& system); + +} // namespace Service::JIT diff --git a/src/core/hle/service/service.cpp b/src/core/hle/service/service.cpp index ab3286db9..edf69e33f 100644 --- a/src/core/hle/service/service.cpp +++ b/src/core/hle/service/service.cpp @@ -32,6 +32,7 @@  #include "core/hle/service/glue/glue.h"  #include "core/hle/service/grc/grc.h"  #include "core/hle/service/hid/hid.h" +#include "core/hle/service/jit/jit.h"  #include "core/hle/service/lbl/lbl.h"  #include "core/hle/service/ldn/ldn.h"  #include "core/hle/service/ldr/ldr.h" @@ -261,6 +262,7 @@ Services::Services(std::shared_ptr<SM::ServiceManager>& sm, Core::System& system      Glue::InstallInterfaces(system);      GRC::InstallInterfaces(*sm, system);      HID::InstallInterfaces(*sm, system); +    JIT::InstallInterfaces(*sm, system);      LBL::InstallInterfaces(*sm, system);      LDN::InstallInterfaces(*sm, system);      LDR::InstallInterfaces(*sm, system); | 
