1.5.1
This commit is contained in:
@@ -1,176 +1,242 @@
|
||||
diff --git a/.gitignore b/.gitignore
|
||||
index 3e35c18..6b42bc5 100644
|
||||
--- a/.gitignore
|
||||
+++ b/.gitignore
|
||||
@@ -8,3 +8,4 @@ build/
|
||||
*.nacp
|
||||
|
||||
*.nro
|
||||
+*.DS_Store
|
||||
diff --git a/Overlay/Makefile b/Overlay/Makefile
|
||||
index f881ed9..7184bb0 100644
|
||||
index 5a2c2af..140130b 100644
|
||||
--- a/Overlay/Makefile
|
||||
+++ b/Overlay/Makefile
|
||||
@@ -38,7 +38,7 @@ include $(DEVKITPRO)/libnx/switch_rules
|
||||
# NACP building is skipped as well.
|
||||
#---------------------------------------------------------------------------------
|
||||
APP_TITLE := ReverseNX-RT
|
||||
-APP_VERSION := 1.0.1
|
||||
+APP_VERSION := 1.0.2-OC
|
||||
|
||||
-APP_VERSION := 1.0.2
|
||||
+APP_VERSION := 1.1.0-OC
|
||||
|
||||
TARGET := ReverseNX-RT-ovl
|
||||
BUILD := build
|
||||
@@ -53,7 +53,7 @@ NO_ICON := 1
|
||||
#---------------------------------------------------------------------------------
|
||||
ARCH := -march=armv8-a+crc+crypto -mtune=cortex-a57 -mtp=soft -fPIE
|
||||
|
||||
-CFLAGS := -g -Wall -Os -ffunction-sections \
|
||||
+CFLAGS := -g -Wall -O2 -ffunction-sections \
|
||||
$(ARCH) $(DEFINES)
|
||||
|
||||
CFLAGS += $(INCLUDE) -D__SWITCH__ -DAPP_VERSION="\"$(APP_VERSION)\""
|
||||
diff --git a/Overlay/libs/Atmosphere-libs b/Overlay/libs/Atmosphere-libs
|
||||
index 2d522dc..c4d0335 160000
|
||||
index 2d522dc..af0d008 160000
|
||||
--- a/Overlay/libs/Atmosphere-libs
|
||||
+++ b/Overlay/libs/Atmosphere-libs
|
||||
@@ -1 +1 @@
|
||||
-Subproject commit 2d522dc6a12b2eb5eb3f103a8c5b5126ca301b1a
|
||||
+Subproject commit c4d0335b79da7207b49abf1988f45b0168b692f0
|
||||
diff --git a/Overlay/libs/libtesla b/Overlay/libs/libtesla
|
||||
index 6628524..640629f 160000
|
||||
--- a/Overlay/libs/libtesla
|
||||
+++ b/Overlay/libs/libtesla
|
||||
@@ -1 +1 @@
|
||||
-Subproject commit 66285245361a02e5480c7bb7dac9ef6449ae6181
|
||||
+Subproject commit 640629f49f9e8997ef0769b21b26f4fc177c736f
|
||||
+Subproject commit af0d008900128d8679b80569f69fe562ed7d6681
|
||||
diff --git a/Overlay/source/main.cpp b/Overlay/source/main.cpp
|
||||
index cec060c..13818bb 100644
|
||||
index 810295c..87b6685 100644
|
||||
--- a/Overlay/source/main.cpp
|
||||
+++ b/Overlay/source/main.cpp
|
||||
@@ -1,9 +1,12 @@
|
||||
@@ -1,7 +1,196 @@
|
||||
#define TESLA_INIT_IMPL // If you have more than one file using the tesla header, only define this in the main one
|
||||
#include <tesla.hpp> // The Tesla Header
|
||||
+#include <atomic>
|
||||
#include "dmntcht.h"
|
||||
|
||||
bool def = true;
|
||||
+bool defChanged = false;
|
||||
bool isDocked = false;
|
||||
+bool isDockedChanged = false;
|
||||
bool PluginRunning = false;
|
||||
bool closed = false;
|
||||
Handle debug;
|
||||
@@ -20,6 +23,11 @@ bool plugin = false;
|
||||
#include "SaltyNX.h"
|
||||
|
||||
+class ModeSync {
|
||||
+public:
|
||||
+ enum ReverseNXMode {
|
||||
+ ReverseNX_NotValid = 0,
|
||||
+ ReverseNX_SystemDefault = 0,
|
||||
+ ReverseNX_Handheld,
|
||||
+ ReverseNX_Docked,
|
||||
+ ReverseNX_Undefined,
|
||||
+ };
|
||||
+
|
||||
+ void SetMode(bool isDefault, bool setDock, char* descBuf, size_t bufSize) {
|
||||
+ auto changeHandler = [this](ReverseNXMode newMode) {
|
||||
+ if (this->currentMode == ReverseNX_Undefined || this->currentMode != newMode) {
|
||||
+ if (R_FAILED(this->ipc->SetMode(newMode))) {
|
||||
+ this->ipc->ipcStatus = Ipc::IpcStatus_ConnectFailed;
|
||||
+ return;
|
||||
+ }
|
||||
+ this->currentMode = newMode;
|
||||
+ }
|
||||
+ };
|
||||
+
|
||||
+ tsl::hlp::ScopeGuard updateBufGuard([&] { this->ipc->UpdateStatusDesc(descBuf, bufSize); });
|
||||
+
|
||||
+ if (isDefault) {
|
||||
+ changeHandler(ReverseNX_SystemDefault);
|
||||
+ return;
|
||||
+ }
|
||||
+
|
||||
+ changeHandler(setDock ? ReverseNX_Docked : ReverseNX_Handheld);
|
||||
+ }
|
||||
+
|
||||
+ ModeSync() {
|
||||
+ this->ipc = new Ipc;
|
||||
+ this->ipc->Init();
|
||||
+ }
|
||||
+
|
||||
+ ~ModeSync() {
|
||||
+ this->ipc->Exit();
|
||||
+ delete this->ipc;
|
||||
+ }
|
||||
+
|
||||
+protected:
|
||||
+ struct Ipc {
|
||||
+ #define API_VER 2
|
||||
+ #define SERVICE_NAME "sysclkOC"
|
||||
+
|
||||
+ enum SysClkIpcCmd {
|
||||
+ SysClkIpcCmd_GetApiVersion = 0,
|
||||
+ SysClkIpcCmd_GetConfigValues = 9,
|
||||
+ SysClkIpcCmd_SetReverseNXRTMode = 11,
|
||||
+ };
|
||||
+
|
||||
+ enum SysClkConfigValue {
|
||||
+ SysClkConfigValue_SyncReverseNXMode = 4,
|
||||
+ SysClkConfigValue_EnumMax = 8,
|
||||
+ };
|
||||
+
|
||||
+ struct SysClkConfigValueList {
|
||||
+ uint64_t values[SysClkConfigValue_EnumMax];
|
||||
+ };
|
||||
+
|
||||
+ enum IpcStatus {
|
||||
+ IpcStatus_OK,
|
||||
+
|
||||
+ IpcStatus_Unknown,
|
||||
+ IpcStatus_NotRunning,
|
||||
+ IpcStatus_InitFailed,
|
||||
+ IpcStatus_ConnectFailed,
|
||||
+ IpcStatus_UnsupportedVer,
|
||||
+
|
||||
+ IpcStatus_Count,
|
||||
+ };
|
||||
+
|
||||
+ static constexpr const char* IpcStatusStr[IpcStatus_Count] = {
|
||||
+ "",
|
||||
+
|
||||
+ "Unknown",
|
||||
+ "Err: Not running",
|
||||
+ "Err: Failed to init",
|
||||
+ "Err: Failed to connect",
|
||||
+ "Err: Unsupported version",
|
||||
+ };
|
||||
+
|
||||
+ Result Init() {
|
||||
+ Result rc = 0;
|
||||
+ refCnt++;
|
||||
+
|
||||
+ if (serviceIsActive(&service))
|
||||
+ return 0;
|
||||
+
|
||||
+ rc = smGetService(&service, SERVICE_NAME);
|
||||
+
|
||||
+ if (R_FAILED(rc)) {
|
||||
+ this->Exit();
|
||||
+ return rc;
|
||||
+ }
|
||||
+
|
||||
+ rc = GetStatus();
|
||||
+ return rc;
|
||||
+ }
|
||||
+
|
||||
+ void Exit() {
|
||||
+ if (--refCnt == 0)
|
||||
+ serviceClose(&service);
|
||||
+ }
|
||||
+
|
||||
+ bool IsServiceRunning() {
|
||||
+ Handle handle;
|
||||
+ SmServiceName name = smEncodeName(SERVICE_NAME);
|
||||
+ if (R_FAILED(smRegisterService(&handle, name, false, 1))) {
|
||||
+ return true;
|
||||
+ }
|
||||
+ svcCloseHandle(handle);
|
||||
+ smUnregisterService(name);
|
||||
+ return false;
|
||||
+ }
|
||||
+
|
||||
+ Result GetApiVersion(u32* outVer) {
|
||||
+ return serviceDispatchOut(&service, SysClkIpcCmd_GetApiVersion, *outVer);
|
||||
+ }
|
||||
+
|
||||
+ Result GetConfigValues(SysClkConfigValueList* outConfigValues) {
|
||||
+ return serviceDispatchOut(&service, SysClkIpcCmd_GetConfigValues, *outConfigValues);
|
||||
+ }
|
||||
+
|
||||
+ Result SetMode(ReverseNXMode mode) {
|
||||
+ return serviceDispatchIn(&service, SysClkIpcCmd_SetReverseNXRTMode, mode);
|
||||
+ }
|
||||
+
|
||||
+ Result GetStatus() {
|
||||
+ if (!IsServiceRunning()) {
|
||||
+ this->ipcStatus = IpcStatus_NotRunning;
|
||||
+ return this->ipcStatus;
|
||||
+ }
|
||||
+
|
||||
+ if (R_FAILED(this->Init())) {
|
||||
+ this->ipcStatus = IpcStatus_InitFailed;
|
||||
+ return this->ipcStatus;
|
||||
+ }
|
||||
+
|
||||
+ tsl::hlp::ScopeGuard exitSrvGuard([&] { this->Exit(); });
|
||||
+
|
||||
+ uint32_t api_ver;
|
||||
+ if (R_FAILED(GetApiVersion(&api_ver))) {
|
||||
+ this->ipcStatus = IpcStatus_ConnectFailed;
|
||||
+ return this->ipcStatus;
|
||||
+ }
|
||||
+
|
||||
+ if (api_ver != API_VER) {
|
||||
+ this->ipcStatus = IpcStatus_UnsupportedVer;
|
||||
+ return this->ipcStatus;
|
||||
+ }
|
||||
+
|
||||
+ SysClkConfigValueList* list = new SysClkConfigValueList;
|
||||
+ tsl::hlp::ScopeGuard listGuard([&] { delete list; });
|
||||
+
|
||||
+ if (R_FAILED(GetConfigValues(list))) {
|
||||
+ this->ipcStatus = IpcStatus_ConnectFailed;
|
||||
+ return this->ipcStatus;
|
||||
+ }
|
||||
+
|
||||
+ exitSrvGuard.dismiss();
|
||||
+
|
||||
+ shouldSync = bool(list->values[SysClkConfigValue_SyncReverseNXMode]);
|
||||
+ this->ipcStatus = IpcStatus_OK;
|
||||
+ return this->ipcStatus;
|
||||
+ }
|
||||
+
|
||||
+ void UpdateStatusDesc(char* buffer, size_t size) {
|
||||
+ snprintf(buffer, size,
|
||||
+ "Mode Sync: %s%s",
|
||||
+ IpcStatusStr[ipcStatus],
|
||||
+ (ipcStatus == IpcStatus_OK) ? (
|
||||
+ shouldSync ? "ON" : "OFF"
|
||||
+ ) : ""
|
||||
+ );
|
||||
+ }
|
||||
+
|
||||
+ Service service;
|
||||
+ std::atomic<std::size_t> refCnt;
|
||||
+ IpcStatus ipcStatus = IpcStatus_Unknown;
|
||||
+ bool shouldSync;
|
||||
+ };
|
||||
+
|
||||
+ Ipc* ipc = nullptr;
|
||||
+ ReverseNXMode currentMode = ReverseNX_Undefined;
|
||||
+};
|
||||
+
|
||||
bool* def = 0;
|
||||
bool* isDocked = 0;
|
||||
bool* pluginActive = 0;
|
||||
@@ -17,6 +206,7 @@ bool plugin = false;
|
||||
char DockedChar[32];
|
||||
char SystemChar[32];
|
||||
char PluginChar[36];
|
||||
+char SysclkChar[36];
|
||||
+static Service g_sysclkSrv;
|
||||
+static std::atomic<std::size_t> g_refCnt;
|
||||
+bool sysclkComm = false;
|
||||
+bool sysclkSync = false;
|
||||
|
||||
bool CheckPort () {
|
||||
Handle saltysd;
|
||||
@@ -43,17 +51,84 @@ bool CheckPort () {
|
||||
return false;
|
||||
}
|
||||
|
||||
-bool isServiceRunning(const char *serviceName) {
|
||||
- Handle handle;
|
||||
- SmServiceName service_name = smEncodeName(serviceName);
|
||||
+bool isServiceRunning(const char *serviceName) {
|
||||
+ Handle handle;
|
||||
+ SmServiceName service_name = smEncodeName(serviceName);
|
||||
if (R_FAILED(smRegisterService(&handle, service_name, false, 1))) return true;
|
||||
else {
|
||||
- svcCloseHandle(handle);
|
||||
+ svcCloseHandle(handle);
|
||||
smUnregisterService(service_name);
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
+#define SYSCLK_IPC_API_VERSION 1
|
||||
+#define SYSCLK_IPC_SERVICE_NAME "sysclkOC"
|
||||
+
|
||||
+enum SysClkIpcCmd
|
||||
+{
|
||||
+ SysClkIpcCmd_GetApiVersion = 0,
|
||||
+ SysClkIpcCmd_GetConfigValues = 9,
|
||||
+ SysClkIpcCmd_SetReverseNXRTMode = 11,
|
||||
+};
|
||||
+
|
||||
+enum SysClkConfigValue
|
||||
+{
|
||||
+ SysClkConfigValue_SyncReverseNXMode = 4,
|
||||
+ SysClkConfigValue_EnumMax = 8,
|
||||
+};
|
||||
+
|
||||
+enum ReverseNXMode
|
||||
+{
|
||||
+ ReverseNX_NotValid = 0,
|
||||
+ ReverseNX_SystemDefault = 0,
|
||||
+ ReverseNX_Handheld,
|
||||
+ ReverseNX_Docked,
|
||||
+};
|
||||
+
|
||||
+struct SysClkConfigValueList
|
||||
+{
|
||||
+ uint64_t values[SysClkConfigValue_EnumMax];
|
||||
+};
|
||||
+
|
||||
+void sysclkIpcExit(void)
|
||||
+{
|
||||
+ if (--g_refCnt == 0)
|
||||
+ serviceClose(&g_sysclkSrv);
|
||||
+}
|
||||
+
|
||||
+Result sysclkIpcInitialize(void)
|
||||
+{
|
||||
+ Result rc = 0;
|
||||
+
|
||||
+ g_refCnt++;
|
||||
+
|
||||
+ if (serviceIsActive(&g_sysclkSrv))
|
||||
+ return 0;
|
||||
+
|
||||
+ rc = smGetService(&g_sysclkSrv, SYSCLK_IPC_SERVICE_NAME);
|
||||
+
|
||||
+ if (R_FAILED(rc))
|
||||
+ sysclkIpcExit();
|
||||
+
|
||||
+ return rc;
|
||||
+}
|
||||
+
|
||||
+Result sysclkIpcGetAPIVersion(u32* out_ver)
|
||||
+{
|
||||
+ return serviceDispatchOut(&g_sysclkSrv, SysClkIpcCmd_GetApiVersion, *out_ver);
|
||||
+}
|
||||
+
|
||||
+Result sysclkIpcGetConfigValues(SysClkConfigValueList* out_configValues)
|
||||
+{
|
||||
+ return serviceDispatchOut(&g_sysclkSrv, SysClkIpcCmd_GetConfigValues, *out_configValues);
|
||||
+}
|
||||
+
|
||||
+Result sysclkIpcSetReverseNXRTMode(ReverseNXMode mode)
|
||||
+{
|
||||
+ return serviceDispatchIn(&g_sysclkSrv, SysClkIpcCmd_SetReverseNXRTMode, mode);
|
||||
+}
|
||||
+
|
||||
+char SysclkChar[0x40];
|
||||
uint64_t PID = 0;
|
||||
Handle remoteSharedMemory = 1;
|
||||
SharedMemory _sharedmemory = {};
|
||||
@@ -73,7 +263,7 @@ bool CheckPort () {
|
||||
|
||||
class GuiTest : public tsl::Gui {
|
||||
public:
|
||||
GuiTest(u8 arg1, u8 arg2, bool arg3) { }
|
||||
@@ -67,7 +142,7 @@ public:
|
||||
|
||||
// A list that can contain sub elements and handles scrolling
|
||||
auto list = new tsl::elm::List();
|
||||
-
|
||||
+
|
||||
list->addItem(new tsl::elm::CustomDrawer([](tsl::gfx::Renderer *renderer, s32 x, s32 y, s32 w, s32 h) {
|
||||
if (SaltySD == false) renderer->drawString("SaltyNX is not working!", false, x, y+50, 20, renderer->a(0xF33F));
|
||||
else if (plugin == false) renderer->drawString("Can't detect ReverseNX-RT plugin!", false, x, y+50, 20, renderer->a(0xF33F));
|
||||
@@ -88,16 +163,18 @@ public:
|
||||
- GuiTest(u8 arg1, u8 arg2, bool arg3) { }
|
||||
+ GuiTest(ModeSync* p) : modeSync(p) { }
|
||||
|
||||
// Called when this Gui gets loaded to create the UI
|
||||
// Allocate all elements on the heap. libtesla will make sure to clean them up when not needed anymore
|
||||
@@ -112,6 +302,7 @@ public:
|
||||
else {
|
||||
renderer->drawString(SystemChar, false, x, y+40, 20, renderer->a(0xFFFF));
|
||||
renderer->drawString(DockedChar, false, x, y+60, 20, renderer->a(0xFFFF));
|
||||
@@ -178,186 +244,47 @@ index cec060c..13818bb 100644
|
||||
}
|
||||
}
|
||||
}), 100);
|
||||
|
||||
if (MAGIC == 0x06BA7E39) {
|
||||
auto *clickableListItem = new tsl::elm::ListItem("Change system control");
|
||||
- clickableListItem->setClickListener([](u64 keys) {
|
||||
- if (keys & KEY_A) {
|
||||
+ clickableListItem->setClickListener([](u64 keys) {
|
||||
+ if (keys & HidNpadButton_A) {
|
||||
if (PluginRunning == true) {
|
||||
def = !def;
|
||||
+ defChanged = true;
|
||||
if (dmntcht == true) {
|
||||
dmntchtWriteCheatProcessMemory(def_address, &def, 0x1);
|
||||
dmntchtReadCheatProcessMemory(def_address, &def, 0x1);
|
||||
@@ -117,12 +194,13 @@ public:
|
||||
});
|
||||
|
||||
list->addItem(clickableListItem);
|
||||
-
|
||||
@@ -190,6 +381,8 @@ public:
|
||||
|
||||
if (_def) sprintf(SystemChar, "Controlled by system: Yes");
|
||||
else sprintf(SystemChar, "Controlled by system: No");
|
||||
+
|
||||
auto *clickableListItem2 = new tsl::elm::ListItem("Change mode");
|
||||
- clickableListItem2->setClickListener([](u64 keys) {
|
||||
- if (keys & KEY_A) {
|
||||
+ clickableListItem2->setClickListener([](u64 keys) {
|
||||
+ if (keys & HidNpadButton_A) {
|
||||
if (PluginRunning == true && def == false) {
|
||||
isDocked =! isDocked;
|
||||
+ isDockedChanged = true;
|
||||
if (dmntcht == true) {
|
||||
dmntchtWriteCheatProcessMemory(docked_address, &isDocked, 0x1);
|
||||
dmntchtReadCheatProcessMemory(docked_address, &isDocked, 0x1);
|
||||
@@ -137,15 +215,15 @@ public:
|
||||
}
|
||||
else return false;
|
||||
}
|
||||
-
|
||||
+
|
||||
return false;
|
||||
});
|
||||
list->addItem(clickableListItem2);
|
||||
}
|
||||
else if (SaltySD == true && plugin == true && check == false) {
|
||||
auto *clickableListItem = new tsl::elm::ListItem("(De)activate plugin");
|
||||
- clickableListItem->setClickListener([](u64 keys) {
|
||||
- if (keys & KEY_A) {
|
||||
+ clickableListItem->setClickListener([](u64 keys) {
|
||||
+ if (keys & HidNpadButton_A) {
|
||||
if (bak == false) {
|
||||
rename("sdmc:/SaltySD/plugins/ReverseNX-RT.elf", "sdmc:/SaltySD/plugins/ReverseNX-RT.elf.bak");
|
||||
bak = true;
|
||||
@@ -156,7 +234,7 @@ public:
|
||||
}
|
||||
return true;
|
||||
}
|
||||
-
|
||||
+
|
||||
return false;
|
||||
});
|
||||
list->addItem(clickableListItem);
|
||||
@@ -164,7 +242,7 @@ public:
|
||||
|
||||
// Add the list to the frame for it to be drawn
|
||||
frame->setContent(list);
|
||||
-
|
||||
+
|
||||
// Return the frame to have it become the top level element of this Gui
|
||||
return frame;
|
||||
}
|
||||
@@ -179,30 +257,39 @@ public:
|
||||
closed = true;
|
||||
}
|
||||
if (PluginRunning == true) {
|
||||
- if (i > 59) {
|
||||
+ if (i > 29) {
|
||||
if (dmntcht == true) dmntchtReadCheatProcessMemory(docked_address, &isDocked, 0x1);
|
||||
else if (R_SUCCEEDED(svcDebugActiveProcess(&debug, PID))) {
|
||||
svcReadDebugProcessMemory(&isDocked, debug, docked_address, 0x1);
|
||||
svcCloseHandle(debug);
|
||||
}
|
||||
+ if (sysclkComm && !bak) {
|
||||
+ if (!def && isDockedChanged) {
|
||||
+ isDockedChanged = false;
|
||||
+ sysclkIpcSetReverseNXRTMode(isDocked ? ReverseNX_Docked : ReverseNX_Handheld);
|
||||
+ }
|
||||
+ if (def && defChanged) {
|
||||
+ defChanged = false;
|
||||
+ sysclkIpcSetReverseNXRTMode(ReverseNX_SystemDefault);
|
||||
+ }
|
||||
+ }
|
||||
i = 0;
|
||||
+ modeSync->SetMode(_def, _isDocked, SysclkChar, sizeof(SysclkChar));
|
||||
}
|
||||
else i++;
|
||||
}
|
||||
-
|
||||
+
|
||||
if (isDocked == true) sprintf(DockedChar, "Mode: Docked");
|
||||
else sprintf(DockedChar, "Mode: Handheld");
|
||||
-
|
||||
+
|
||||
if (def == true) sprintf(SystemChar, "Controlled by system: Yes");
|
||||
else sprintf(SystemChar, "Controlled by system: No");
|
||||
-
|
||||
+
|
||||
if (bak == false) sprintf(PluginChar, "ReverseNX-RT plugin is activated.");
|
||||
else sprintf(PluginChar, "ReverseNX-RT plugin is deactivated.");
|
||||
-
|
||||
}
|
||||
|
||||
// Called once every frame to handle inputs not handled by other UI elements
|
||||
- virtual bool handleInput(u64 keysDown, u64 keysHeld, touchPosition touchInput, JoystickPosition leftJoyStick, JoystickPosition rightJoyStick) override {
|
||||
+ virtual bool handleInput(u64 keysDown, u64 keysHeld, const HidTouchState &touchPos, HidAnalogStickState joyStickPosLeft, HidAnalogStickState joyStickPosRight) override {
|
||||
@@ -200,6 +393,8 @@ public:
|
||||
virtual bool handleInput(u64 keysDown, u64 keysHeld, const HidTouchState &touchPos, HidAnalogStickState joyStickPosLeft, HidAnalogStickState joyStickPosRight) override {
|
||||
return false; // Return true here to singal the inputs have been consumed
|
||||
}
|
||||
+
|
||||
+ ModeSync* modeSync;
|
||||
};
|
||||
@@ -213,10 +300,10 @@ public:
|
||||
virtual void initServices() override {
|
||||
smInitialize();
|
||||
fsdevMountSdmc();
|
||||
-
|
||||
+
|
||||
SaltySD = CheckPort();
|
||||
if (SaltySD == false) return;
|
||||
-
|
||||
+
|
||||
FILE* temp = fopen("sdmc:/SaltySD/plugins/ReverseNX-RT.elf", "r");
|
||||
if (temp != NULL) {
|
||||
fclose(temp);
|
||||
@@ -234,6 +321,20 @@ public:
|
||||
else return;
|
||||
}
|
||||
|
||||
+ sysclkComm = false;
|
||||
+ sysclkSync = false;
|
||||
+ if (isServiceRunning(SYSCLK_IPC_SERVICE_NAME)) {
|
||||
+ uint32_t apiVer;
|
||||
+ if (R_SUCCEEDED(sysclkIpcInitialize()) && R_SUCCEEDED(sysclkIpcGetAPIVersion(&apiVer)) && apiVer == SYSCLK_IPC_API_VERSION) {
|
||||
+ sysclkComm = true;
|
||||
+
|
||||
+ SysClkConfigValueList* list = new SysClkConfigValueList;
|
||||
+ if (R_SUCCEEDED(sysclkIpcGetConfigValues(list)))
|
||||
+ sysclkSync = bool(list->values[SysClkConfigValue_SyncReverseNXMode]);
|
||||
+ delete list;
|
||||
+ }
|
||||
+ }
|
||||
+
|
||||
if (R_FAILED(pmdmntGetApplicationProcessId(&PID))) remove("sdmc:/SaltySD/ReverseNX-RT.hex");
|
||||
else {
|
||||
check = true;
|
||||
@@ -244,9 +345,9 @@ public:
|
||||
fread(&def_address, 0x5, 1, offset);
|
||||
fread(&MAGIC_address, 0x5, 1, offset);
|
||||
fclose(offset);
|
||||
-
|
||||
+
|
||||
dmntcht = isServiceRunning("dmnt:cht");
|
||||
-
|
||||
+
|
||||
if (dmntcht == true) {
|
||||
if (R_SUCCEEDED(dmntchtInitialize())) {
|
||||
bool out = false;
|
||||
@@ -272,16 +373,19 @@ public:
|
||||
}
|
||||
|
||||
class OverlayTest : public tsl::Overlay {
|
||||
@@ -247,10 +442,12 @@ public:
|
||||
}
|
||||
}
|
||||
-
|
||||
+
|
||||
if (isDocked == true) sprintf(DockedChar, "Mode: Docked");
|
||||
else sprintf(DockedChar, "Mode: Handheld");
|
||||
-
|
||||
+
|
||||
if (def == true) sprintf(SystemChar, "Controlled by system: Yes");
|
||||
else sprintf(SystemChar, "Controlled by system: No");
|
||||
-
|
||||
+
|
||||
+ sprintf(SysclkChar, "Sys-clk-OC Sync: %s", sysclkComm ? (sysclkSync ? "ON" : "OFF") : "UNAVAILABLE");
|
||||
|
||||
});
|
||||
-
|
||||
+
|
||||
+ modeSync = new ModeSync;
|
||||
} // Called at the start to initialize all services necessary for this Overlay
|
||||
-
|
||||
+
|
||||
|
||||
virtual void exitServices() override {
|
||||
+ sysclkIpcExit();
|
||||
dmntchtExit();
|
||||
if (dmntcht == false) svcCloseHandle(debug);
|
||||
+ delete modeSync;
|
||||
shmemClose(&_sharedmemory);
|
||||
fsdevUnmountDevice("sdmc");
|
||||
} // Callet at the end to clean up all services previously initialized
|
||||
@@ -260,8 +457,10 @@ public:
|
||||
virtual void onHide() override {} // Called before overlay wants to change from visible to invisible state
|
||||
|
||||
virtual std::unique_ptr<tsl::Gui> loadInitialGui() override {
|
||||
- return initially<GuiTest>(1, 2, true); // Initial Gui to load. It's possible to pass arguments to it's constructor like this
|
||||
+ return initially<GuiTest>(modeSync); // Initial Gui to load. It's possible to pass arguments to it's constructor like this
|
||||
}
|
||||
+
|
||||
+ ModeSync* modeSync = nullptr;
|
||||
};
|
||||
|
||||
int main(int argc, char **argv) {
|
||||
|
||||
Reference in New Issue
Block a user