diff options
| author | bunnei <bunneidev@gmail.com> | 2018-08-14 21:47:07 -0400 | 
|---|---|---|
| committer | GitHub <noreply@github.com> | 2018-08-14 21:47:07 -0400 | 
| commit | 409d2e07c22a2adfedb22087fafec76110acce3a (patch) | |
| tree | 656cd16e65882edf86a093aafe731c678724ae13 | |
| parent | 8dc440758682e04f1a9443f2eced23388a988f1d (diff) | |
| parent | b6c47b578f2945c0909728e26b1c3dd6982a59a5 (diff) | |
Merge pull request #1056 from lioncash/mm
mm_u: Move interface class into the cpp file
| -rw-r--r-- | src/core/hle/service/mm/mm_u.cpp | 83 | ||||
| -rw-r--r-- | src/core/hle/service/mm/mm_u.h | 15 | 
2 files changed, 52 insertions, 46 deletions
| diff --git a/src/core/hle/service/mm/mm_u.cpp b/src/core/hle/service/mm/mm_u.cpp index 08f45b78a..7b91bb258 100644 --- a/src/core/hle/service/mm/mm_u.cpp +++ b/src/core/hle/service/mm/mm_u.cpp @@ -9,42 +9,63 @@  namespace Service::MM { -void InstallInterfaces(SM::ServiceManager& service_manager) { -    std::make_shared<MM_U>()->InstallAsService(service_manager); -} +class MM_U final : public ServiceFramework<MM_U> { +public: +    explicit MM_U() : ServiceFramework{"mm:u"} { +        // clang-format off +        static const FunctionInfo functions[] = { +            {0, &MM_U::Initialize, "InitializeOld"}, +            {1, &MM_U::Finalize, "FinalizeOld"}, +            {2, &MM_U::SetAndWait, "SetAndWaitOld"}, +            {3, &MM_U::Get, "GetOld"}, +            {4, &MM_U::Initialize, "Initialize"}, +            {5, &MM_U::Finalize, "Finalize"}, +            {6, &MM_U::SetAndWait, "SetAndWait"}, +            {7, &MM_U::Get, "Get"}, +        }; +        // clang-format on -void MM_U::Initialize(Kernel::HLERequestContext& ctx) { -    LOG_WARNING(Service_MM, "(STUBBED) called"); -    IPC::ResponseBuilder rb{ctx, 2}; -    rb.Push(RESULT_SUCCESS); -} +        RegisterHandlers(functions); +    } -void MM_U::SetAndWait(Kernel::HLERequestContext& ctx) { -    IPC::RequestParser rp{ctx}; -    min = rp.Pop<u32>(); -    max = rp.Pop<u32>(); -    current = min; +private: +    void Initialize(Kernel::HLERequestContext& ctx) { +        LOG_WARNING(Service_MM, "(STUBBED) called"); +        IPC::ResponseBuilder rb{ctx, 2}; +        rb.Push(RESULT_SUCCESS); +    } -    LOG_WARNING(Service_MM, "(STUBBED) called, min=0x{:X}, max=0x{:X}", min, max); -    IPC::ResponseBuilder rb{ctx, 2}; -    rb.Push(RESULT_SUCCESS); -} +    void Finalize(Kernel::HLERequestContext& ctx) { +        LOG_WARNING(Service_MM, "(STUBBED) called"); +        IPC::ResponseBuilder rb{ctx, 2}; +        rb.Push(RESULT_SUCCESS); +    } -void MM_U::Get(Kernel::HLERequestContext& ctx) { -    LOG_WARNING(Service_MM, "(STUBBED) called"); -    IPC::ResponseBuilder rb{ctx, 3}; -    rb.Push(RESULT_SUCCESS); -    rb.Push(current); -} +    void SetAndWait(Kernel::HLERequestContext& ctx) { +        IPC::RequestParser rp{ctx}; +        min = rp.Pop<u32>(); +        max = rp.Pop<u32>(); +        current = min; -MM_U::MM_U() : ServiceFramework("mm:u") { -    static const FunctionInfo functions[] = { -        {0, nullptr, "InitializeOld"},        {1, nullptr, "FinalizeOld"}, -        {2, nullptr, "SetAndWaitOld"},        {3, nullptr, "GetOld"}, -        {4, &MM_U::Initialize, "Initialize"}, {5, nullptr, "Finalize"}, -        {6, &MM_U::SetAndWait, "SetAndWait"}, {7, &MM_U::Get, "Get"}, -    }; -    RegisterHandlers(functions); +        LOG_WARNING(Service_MM, "(STUBBED) called, min=0x{:X}, max=0x{:X}", min, max); +        IPC::ResponseBuilder rb{ctx, 2}; +        rb.Push(RESULT_SUCCESS); +    } + +    void Get(Kernel::HLERequestContext& ctx) { +        LOG_WARNING(Service_MM, "(STUBBED) called"); +        IPC::ResponseBuilder rb{ctx, 3}; +        rb.Push(RESULT_SUCCESS); +        rb.Push(current); +    } + +    u32 min{0}; +    u32 max{0}; +    u32 current{0}; +}; + +void InstallInterfaces(SM::ServiceManager& service_manager) { +    std::make_shared<MM_U>()->InstallAsService(service_manager);  }  } // namespace Service::MM diff --git a/src/core/hle/service/mm/mm_u.h b/src/core/hle/service/mm/mm_u.h index 79eeedf9c..5439fa653 100644 --- a/src/core/hle/service/mm/mm_u.h +++ b/src/core/hle/service/mm/mm_u.h @@ -8,21 +8,6 @@  namespace Service::MM { -class MM_U final : public ServiceFramework<MM_U> { -public: -    MM_U(); -    ~MM_U() = default; - -private: -    void Initialize(Kernel::HLERequestContext& ctx); -    void SetAndWait(Kernel::HLERequestContext& ctx); -    void Get(Kernel::HLERequestContext& ctx); - -    u32 min{0}; -    u32 max{0}; -    u32 current{0}; -}; -  /// Registers all MM services with the specified service manager.  void InstallInterfaces(SM::ServiceManager& service_manager); | 
