diff options
| -rw-r--r-- | src/common/logging/backend.cpp | 1 | ||||
| -rw-r--r-- | src/common/logging/log.h | 1 | ||||
| -rw-r--r-- | src/core/CMakeLists.txt | 4 | ||||
| -rw-r--r-- | src/core/hle/service/btdrv/btdrv.cpp | 72 | ||||
| -rw-r--r-- | src/core/hle/service/btdrv/btdrv.h | 16 | ||||
| -rw-r--r-- | src/core/hle/service/lbl/lbl.cpp | 90 | ||||
| -rw-r--r-- | src/core/hle/service/lbl/lbl.h | 15 | ||||
| -rw-r--r-- | src/core/hle/service/service.cpp | 6 | ||||
| -rw-r--r-- | src/yuzu/main.cpp | 16 | 
9 files changed, 220 insertions, 1 deletions
diff --git a/src/common/logging/backend.cpp b/src/common/logging/backend.cpp index bcdb69321..30537b27b 100644 --- a/src/common/logging/backend.cpp +++ b/src/common/logging/backend.cpp @@ -173,6 +173,7 @@ void FileBackend::Write(const Entry& entry) {      SUB(Service, Friend)                                                                           \      SUB(Service, FS)                                                                               \      SUB(Service, HID)                                                                              \ +    SUB(Service, LBL)                                                                              \      SUB(Service, LDN)                                                                              \      SUB(Service, LM)                                                                               \      SUB(Service, MM)                                                                               \ diff --git a/src/common/logging/log.h b/src/common/logging/log.h index 3a61c7531..805f82d2f 100644 --- a/src/common/logging/log.h +++ b/src/common/logging/log.h @@ -60,6 +60,7 @@ enum class Class : ClassType {      Service_Friend,    ///< The friend service      Service_FS,        ///< The FS (Filesystem) service      Service_HID,       ///< The HID (Human interface device) service +    Service_LBL,       ///< The LBL (LCD backlight) service      Service_LDN,       ///< The LDN (Local domain network) service      Service_LM,        ///< The LM (Logger) service      Service_MM,        ///< The MM (Multimedia) service diff --git a/src/core/CMakeLists.txt b/src/core/CMakeLists.txt index 6fb1a4c7c..b367c2a27 100644 --- a/src/core/CMakeLists.txt +++ b/src/core/CMakeLists.txt @@ -136,6 +136,8 @@ add_library(core STATIC      hle/service/bcat/bcat.h      hle/service/bcat/module.cpp      hle/service/bcat/module.h +    hle/service/btdrv/btdrv.cpp +    hle/service/btdrv/btdrv.h      hle/service/erpt/erpt.cpp      hle/service/erpt/erpt.h      hle/service/es/es.cpp @@ -164,6 +166,8 @@ add_library(core STATIC      hle/service/hid/irs.h      hle/service/hid/xcd.cpp      hle/service/hid/xcd.h +    hle/service/lbl/lbl.cpp +    hle/service/lbl/lbl.h      hle/service/ldn/ldn.cpp      hle/service/ldn/ldn.h      hle/service/ldr/ldr.cpp diff --git a/src/core/hle/service/btdrv/btdrv.cpp b/src/core/hle/service/btdrv/btdrv.cpp new file mode 100644 index 000000000..d0a15cc4c --- /dev/null +++ b/src/core/hle/service/btdrv/btdrv.cpp @@ -0,0 +1,72 @@ +// Copyright 2018 yuzu emulator team +// Licensed under GPLv2 or any later version +// Refer to the license.txt file included. + +#include "core/hle/service/btdrv/btdrv.h" +#include "core/hle/service/service.h" +#include "core/hle/service/sm/sm.h" + +namespace Service::BtDrv { + +class BtDrv final : public ServiceFramework<BtDrv> { +public: +    explicit BtDrv() : ServiceFramework{"btdrv"} { +        // clang-format off +        static const FunctionInfo functions[] = { +            {0, nullptr, "Unknown"}, +            {1, nullptr, "Init"}, +            {2, nullptr, "Enable"}, +            {3, nullptr, "Disable"}, +            {4, nullptr, "CleanupAndShutdown"}, +            {5, nullptr, "GetAdapterProperties"}, +            {6, nullptr, "GetAdapterProperty"}, +            {7, nullptr, "SetAdapterProperty"}, +            {8, nullptr, "StartDiscovery"}, +            {9, nullptr, "CancelDiscovery"}, +            {10, nullptr, "CreateBond"}, +            {11, nullptr, "RemoveBond"}, +            {12, nullptr, "CancelBond"}, +            {13, nullptr, "PinReply"}, +            {14, nullptr, "SspReply"}, +            {15, nullptr, "Unknown2"}, +            {16, nullptr, "InitInterfaces"}, +            {17, nullptr, "HidHostInterface_Connect"}, +            {18, nullptr, "HidHostInterface_Disconnect"}, +            {19, nullptr, "HidHostInterface_SendData"}, +            {20, nullptr, "HidHostInterface_SendData2"}, +            {21, nullptr, "HidHostInterface_SetReport"}, +            {22, nullptr, "HidHostInterface_GetReport"}, +            {23, nullptr, "HidHostInterface_WakeController"}, +            {24, nullptr, "HidHostInterface_AddPairedDevice"}, +            {25, nullptr, "HidHostInterface_GetPairedDevice"}, +            {26, nullptr, "HidHostInterface_CleanupAndShutdown"}, +            {27, nullptr, "Unknown3"}, +            {28, nullptr, "ExtInterface_SetTSI"}, +            {29, nullptr, "ExtInterface_SetBurstMode"}, +            {30, nullptr, "ExtInterface_SetZeroRetran"}, +            {31, nullptr, "ExtInterface_SetMcMode"}, +            {32, nullptr, "ExtInterface_StartLlrMode"}, +            {33, nullptr, "ExtInterface_ExitLlrMode"}, +            {34, nullptr, "ExtInterface_SetRadio"}, +            {35, nullptr, "ExtInterface_SetVisibility"}, +            {36, nullptr, "Unknown4"}, +            {37, nullptr, "Unknown5"}, +            {38, nullptr, "HidHostInterface_GetLatestPlr"}, +            {39, nullptr, "ExtInterface_GetPendingConnections"}, +            {40, nullptr, "HidHostInterface_GetChannelMap"}, +            {41, nullptr, "SetIsBluetoothBoostEnabled"}, +            {42, nullptr, "GetIsBluetoothBoostEnabled"}, +            {43, nullptr, "SetIsBluetoothAfhEnabled"}, +            {44, nullptr, "GetIsBluetoothAfhEnabled"}, +        }; +        // clang-format on + +        RegisterHandlers(functions); +    } +}; + +void InstallInterfaces(SM::ServiceManager& sm) { +    std::make_shared<BtDrv>()->InstallAsService(sm); +} + +} // namespace Service::BtDrv diff --git a/src/core/hle/service/btdrv/btdrv.h b/src/core/hle/service/btdrv/btdrv.h new file mode 100644 index 000000000..164e56f43 --- /dev/null +++ b/src/core/hle/service/btdrv/btdrv.h @@ -0,0 +1,16 @@ +// Copyright 2018 yuzu emulator team +// Licensed under GPLv2 or any later version +// Refer to the license.txt file included. + +#pragma once + +namespace Service::SM { +class ServiceManager; +} + +namespace Service::BtDrv { + +/// Registers all BtDrv services with the specified service manager. +void InstallInterfaces(SM::ServiceManager& sm); + +} // namespace Service::BtDrv diff --git a/src/core/hle/service/lbl/lbl.cpp b/src/core/hle/service/lbl/lbl.cpp new file mode 100644 index 000000000..8fc8b1057 --- /dev/null +++ b/src/core/hle/service/lbl/lbl.cpp @@ -0,0 +1,90 @@ +// Copyright 2018 yuzu emulator team +// Licensed under GPLv2 or any later version +// Refer to the license.txt file included. + +#include <memory> + +#include "common/logging/log.h" +#include "core/hle/ipc_helpers.h" +#include "core/hle/kernel/hle_ipc.h" +#include "core/hle/service/lbl/lbl.h" +#include "core/hle/service/service.h" +#include "core/hle/service/sm/sm.h" + +namespace Service::LBL { + +class LBL final : public ServiceFramework<LBL> { +public: +    explicit LBL() : ServiceFramework{"lbl"} { +        // clang-format off +        static const FunctionInfo functions[] = { +            {0, nullptr, "Unknown1"}, +            {1, nullptr, "Unknown2"}, +            {2, nullptr, "Unknown3"}, +            {3, nullptr, "Unknown4"}, +            {4, nullptr, "Unknown5"}, +            {5, nullptr, "Unknown6"}, +            {6, nullptr, "TurnOffBacklight"}, +            {7, nullptr, "TurnOnBacklight"}, +            {8, nullptr, "GetBacklightStatus"}, +            {9, nullptr, "Unknown7"}, +            {10, nullptr, "Unknown8"}, +            {11, nullptr, "Unknown9"}, +            {12, nullptr, "Unknown10"}, +            {13, nullptr, "Unknown11"}, +            {14, nullptr, "Unknown12"}, +            {15, nullptr, "Unknown13"}, +            {16, nullptr, "ReadRawLightSensor"}, +            {17, nullptr, "Unknown14"}, +            {18, nullptr, "Unknown15"}, +            {19, nullptr, "Unknown16"}, +            {20, nullptr, "Unknown17"}, +            {21, nullptr, "Unknown18"}, +            {22, nullptr, "Unknown19"}, +            {23, nullptr, "Unknown20"}, +            {24, nullptr, "Unknown21"}, +            {25, nullptr, "Unknown22"}, +            {26, &LBL::EnableVrMode, "EnableVrMode"}, +            {27, &LBL::DisableVrMode, "DisableVrMode"}, +            {28, &LBL::GetVrMode, "GetVrMode"}, +        }; +        // clang-format on + +        RegisterHandlers(functions); +    } + +private: +    void EnableVrMode(Kernel::HLERequestContext& ctx) { +        IPC::ResponseBuilder rb{ctx, 2}; +        rb.Push(RESULT_SUCCESS); + +        vr_mode_enabled = true; + +        LOG_DEBUG(Service_LBL, "called"); +    } + +    void DisableVrMode(Kernel::HLERequestContext& ctx) { +        IPC::ResponseBuilder rb{ctx, 2}; +        rb.Push(RESULT_SUCCESS); + +        vr_mode_enabled = false; + +        LOG_DEBUG(Service_LBL, "called"); +    } + +    void GetVrMode(Kernel::HLERequestContext& ctx) { +        IPC::ResponseBuilder rb{ctx, 3}; +        rb.Push(RESULT_SUCCESS); +        rb.Push(vr_mode_enabled); + +        LOG_DEBUG(Service_LBL, "called"); +    } + +    bool vr_mode_enabled = false; +}; + +void InstallInterfaces(SM::ServiceManager& sm) { +    std::make_shared<LBL>()->InstallAsService(sm); +} + +} // namespace Service::LBL diff --git a/src/core/hle/service/lbl/lbl.h b/src/core/hle/service/lbl/lbl.h new file mode 100644 index 000000000..bf6f400f8 --- /dev/null +++ b/src/core/hle/service/lbl/lbl.h @@ -0,0 +1,15 @@ +// Copyright 2018 yuzu emulator team +// Licensed under GPLv2 or any later version +// Refer to the license.txt file included. + +#pragma once + +namespace Service::SM { +class ServiceManager; +} + +namespace Service::LBL { + +void InstallInterfaces(SM::ServiceManager& sm); + +} // namespace Service::LBL diff --git a/src/core/hle/service/service.cpp b/src/core/hle/service/service.cpp index 443ab5857..8026d27a7 100644 --- a/src/core/hle/service/service.cpp +++ b/src/core/hle/service/service.cpp @@ -21,6 +21,7 @@  #include "core/hle/service/apm/apm.h"  #include "core/hle/service/audio/audio.h"  #include "core/hle/service/bcat/bcat.h" +#include "core/hle/service/btdrv/btdrv.h"  #include "core/hle/service/erpt/erpt.h"  #include "core/hle/service/es/es.h"  #include "core/hle/service/eupld/eupld.h" @@ -29,6 +30,7 @@  #include "core/hle/service/friend/friend.h"  #include "core/hle/service/grc/grc.h"  #include "core/hle/service/hid/hid.h" +#include "core/hle/service/lbl/lbl.h"  #include "core/hle/service/ldn/ldn.h"  #include "core/hle/service/ldr/ldr.h"  #include "core/hle/service/lm/lm.h" @@ -194,8 +196,9 @@ void Init(std::shared_ptr<SM::ServiceManager>& sm) {      AM::InstallInterfaces(*sm, nv_flinger);      AOC::InstallInterfaces(*sm);      APM::InstallInterfaces(*sm); -    BCAT::InstallInterfaces(*sm);      Audio::InstallInterfaces(*sm); +    BCAT::InstallInterfaces(*sm); +    BtDrv::InstallInterfaces(*sm);      ERPT::InstallInterfaces(*sm);      ES::InstallInterfaces(*sm);      EUPLD::InstallInterfaces(*sm); @@ -204,6 +207,7 @@ void Init(std::shared_ptr<SM::ServiceManager>& sm) {      Friend::InstallInterfaces(*sm);      GRC::InstallInterfaces(*sm);      HID::InstallInterfaces(*sm); +    LBL::InstallInterfaces(*sm);      LDN::InstallInterfaces(*sm);      LDR::InstallInterfaces(*sm);      LM::InstallInterfaces(*sm); diff --git a/src/yuzu/main.cpp b/src/yuzu/main.cpp index 97273f967..96998643e 100644 --- a/src/yuzu/main.cpp +++ b/src/yuzu/main.cpp @@ -207,15 +207,27 @@ void GMainWindow::InitializeRecentFileMenuActions() {  void GMainWindow::InitializeHotkeys() {      RegisterHotkey("Main Window", "Load File", QKeySequence::Open);      RegisterHotkey("Main Window", "Start Emulation"); +    RegisterHotkey("Main Window", "Continue/Pause", QKeySequence(Qt::Key_F4));      RegisterHotkey("Main Window", "Fullscreen", QKeySequence::FullScreen);      RegisterHotkey("Main Window", "Exit Fullscreen", QKeySequence(Qt::Key_Escape),                     Qt::ApplicationShortcut); +    RegisterHotkey("Main Window", "Toggle Speed Limit", QKeySequence("CTRL+Z"), +                   Qt::ApplicationShortcut);      LoadHotkeys();      connect(GetHotkey("Main Window", "Load File", this), &QShortcut::activated, this,              &GMainWindow::OnMenuLoadFile);      connect(GetHotkey("Main Window", "Start Emulation", this), &QShortcut::activated, this,              &GMainWindow::OnStartGame); +    connect(GetHotkey("Main Window", "Continue/Pause", this), &QShortcut::activated, this, [&] { +        if (emulation_running) { +            if (emu_thread->IsRunning()) { +                OnPauseGame(); +            } else { +                OnStartGame(); +            } +        } +    });      connect(GetHotkey("Main Window", "Fullscreen", render_window), &QShortcut::activated,              ui.action_Fullscreen, &QAction::trigger);      connect(GetHotkey("Main Window", "Fullscreen", render_window), &QShortcut::activatedAmbiguously, @@ -226,6 +238,10 @@ void GMainWindow::InitializeHotkeys() {              ToggleFullscreen();          }      }); +    connect(GetHotkey("Main Window", "Toggle Speed Limit", this), &QShortcut::activated, this, [&] { +        Settings::values.toggle_framelimit = !Settings::values.toggle_framelimit; +        UpdateStatusBar(); +    });  }  void GMainWindow::SetDefaultUIGeometry() {  | 
