From 103c5057425ac3a69996863e532244acb8b53f5b Mon Sep 17 00:00:00 2001 From: w3irDv <170813473+w3irDv@users.noreply.github.com> Date: Sun, 16 Jun 2024 15:19:03 +0200 Subject: [PATCH 01/12] - use OSScreen inititalization and ProcUI callbacks from libwhb's console.c --- include/utils/DrawUtils.h | 20 +++++-- include/utils/StateUtils.h | 1 + src/main.cpp | 34 +++++------- src/utils/DrawUtils.cpp | 105 ++++++++++++++++++++++++++++++++----- src/utils/StateUtils.cpp | 18 ++++++- 5 files changed, 138 insertions(+), 40 deletions(-) diff --git a/include/utils/DrawUtils.h b/include/utils/DrawUtils.h index b55ec29..44e829b 100644 --- a/include/utils/DrawUtils.h +++ b/include/utils/DrawUtils.h @@ -35,7 +35,11 @@ class DrawUtils { static bool getRedraw() { return redraw; } - static void initBuffers(void *tvBuffer, uint32_t tvSize, void *drcBuffer, uint32_t drcSize); + static BOOL LogConsoleInit(); + + static void LogConsoleFree(); + + static void initBuffers(void *tvBuffer, void *drcBuffer); static void beginDraw(); @@ -73,12 +77,22 @@ class DrawUtils { static void drawRGB5A3(int x, int y, float scale, uint8_t *fileContent); + static uint32_t ConsoleProcCallbackAcquired(void *context); + + static uint32_t ConsoleProcCallbackReleased(void *context); + + + + private: static bool redraw; static bool isBackBuffer; + static uint8_t *tvBuffer; - static uint32_t tvSize; static uint8_t *drcBuffer; - static uint32_t drcSize; + + static void *sBufferTV, *sBufferDRC; + static uint32_t sBufferSizeTV, sBufferSizeDRC; + static BOOL sConsoleHasForeground; }; diff --git a/include/utils/StateUtils.h b/include/utils/StateUtils.h index e788778..a469b9e 100644 --- a/include/utils/StateUtils.h +++ b/include/utils/StateUtils.h @@ -5,6 +5,7 @@ class State { static void init(); static bool AppRunning(); static void shutdown(); + static void registerProcUICallbacks(); private: static bool aroma; diff --git a/src/main.cpp b/src/main.cpp index 0f54f5b..80c0bfc 100644 --- a/src/main.cpp +++ b/src/main.cpp @@ -386,24 +386,12 @@ static void unloadTitles(Title *titles, int count) { int main() { AXInit(); AXQuit(); - OSScreenInit(); - - uint32_t tvBufferSize = OSScreenGetBufferSizeEx(SCREEN_TV); - uint32_t drcBufferSize = OSScreenGetBufferSizeEx(SCREEN_DRC); - - auto *screenBuffer = (uint8_t *) memalign(0x100, tvBufferSize + drcBufferSize); - if (!screenBuffer) { - OSFatal("Fail to allocate screenBuffer"); + + State::init(); + + if (DrawUtils::LogConsoleInit()) { + OSFatal("Failed to initialize OSSCreen"); } - memset(screenBuffer, 0, tvBufferSize + drcBufferSize); - - OSScreenSetBufferEx(SCREEN_TV, screenBuffer); - OSScreenSetBufferEx(SCREEN_DRC, screenBuffer + tvBufferSize); - - OSScreenEnableEx(SCREEN_TV, TRUE); - OSScreenEnableEx(SCREEN_DRC, TRUE); - - DrawUtils::initBuffers(screenBuffer, tvBufferSize, screenBuffer + tvBufferSize, drcBufferSize); if (!DrawUtils::initFont()) { OSFatal("Failed to init font"); @@ -412,8 +400,8 @@ int main() { WPADInit(); KPADInit(); WPADEnableURCC(1); + loadWiiUTitles(0); - State::init(); int res = romfsInit(); if (res) { @@ -422,20 +410,20 @@ int main() { State::shutdown(); return 0; } - Swkbd_LanguageType systemLanguage = LanguageUtils::getSystemLanguage(); LanguageUtils::loadLanguage(systemLanguage); if (!initFS()) { promptError(LanguageUtils::gettext("initFS failed. Please make sure your MochaPayload is up-to-date")); DrawUtils::endDraw(); - State::shutdown(); + State::shutdown(); return 0; } DrawUtils::beginDraw(); DrawUtils::clear(COLOR_BLACK); DrawUtils::endDraw(); + Title *wiiutitles = loadWiiUTitles(1); Title *wiititles = loadWiiTitles(); getAccountsWiiU(); @@ -445,8 +433,9 @@ int main() { Input input{}; std::unique_ptr state = std::make_unique(wiiutitles, wiititles, wiiuTitlesCount, - vWiiTitlesCount); + vWiiTitlesCount); while (State::AppRunning()) { + input.read(); if (input.get(TRIGGER, PAD_BUTTON_ANY)) @@ -473,12 +462,13 @@ int main() { unloadTitles(wiiutitles, wiiuTitlesCount); unloadTitles(wiititles, vWiiTitlesCount); - shutdownFS(); LanguageUtils::gettextCleanUp(); romfsExit(); DrawUtils::deinitFont(); + DrawUtils::LogConsoleFree(); + State::shutdown(); return 0; } diff --git a/src/utils/DrawUtils.cpp b/src/utils/DrawUtils.cpp index 1b8bdec..9c5681d 100644 --- a/src/utils/DrawUtils.cpp +++ b/src/utils/DrawUtils.cpp @@ -5,22 +5,98 @@ #include #include #include +#include +#include +#include +#include +#include +#include +#include +#include // buffer width #define TV_WIDTH 0x500 #define DRC_WIDTH 0x380 +#define CONSOLE_FRAME_HEAP_TAG (0x000DECAF) + + bool DrawUtils::isBackBuffer; uint8_t *DrawUtils::tvBuffer = nullptr; -uint32_t DrawUtils::tvSize = 0; uint8_t *DrawUtils::drcBuffer = nullptr; -uint32_t DrawUtils::drcSize = 0; +/* +uint32_t DrawUtils::sBufferSizeTV = 0; +uint32_t DrawUtils::sBufferSizeDRC = 0; +*/ static SFT pFont = {}; static Color font_col(0xFFFFFFFF); +void *DrawUtils::sBufferTV = NULL, *DrawUtils::sBufferDRC = NULL; +uint32_t DrawUtils::sBufferSizeTV = 0, DrawUtils::sBufferSizeDRC = 0; +BOOL DrawUtils::sConsoleHasForeground = TRUE; + +uint32_t +DrawUtils::ConsoleProcCallbackAcquired(void *context) +{ + MEMHeapHandle heap = MEMGetBaseHeapHandle(MEM_BASE_HEAP_MEM1); + MEMRecordStateForFrmHeap(heap, CONSOLE_FRAME_HEAP_TAG); + + if (sBufferSizeTV) { + sBufferTV = MEMAllocFromFrmHeapEx(heap, sBufferSizeTV, 4); + } + + if (sBufferSizeDRC) { + sBufferDRC = MEMAllocFromFrmHeapEx(heap, sBufferSizeDRC, 4); + } + + sConsoleHasForeground = TRUE; + DrawUtils::setRedraw(true); + OSScreenSetBufferEx(SCREEN_TV, sBufferTV); + OSScreenSetBufferEx(SCREEN_DRC, sBufferDRC); + return 0; +} + +uint32_t +DrawUtils::ConsoleProcCallbackReleased(void *context) +{ + MEMHeapHandle heap = MEMGetBaseHeapHandle(MEM_BASE_HEAP_MEM1); + MEMFreeByStateToFrmHeap(heap, CONSOLE_FRAME_HEAP_TAG); + sConsoleHasForeground = FALSE; + return 0; +} + + +BOOL +DrawUtils::LogConsoleInit() +{ + OSScreenInit(); + sBufferSizeTV = OSScreenGetBufferSizeEx(SCREEN_TV); + sBufferSizeDRC = OSScreenGetBufferSizeEx(SCREEN_DRC); + + ConsoleProcCallbackAcquired(NULL); + OSScreenEnableEx(SCREEN_TV, 1); + OSScreenEnableEx(SCREEN_DRC, 1); + + State::registerProcUICallbacks(); + + DrawUtils::initBuffers(sBufferTV, sBufferDRC); + + return FALSE; +} + +void +DrawUtils::LogConsoleFree() +{ + if (sConsoleHasForeground) { + OSScreenShutdown(); + ConsoleProcCallbackReleased(NULL); + } +} + + bool DrawUtils::redraw = true; template @@ -32,11 +108,9 @@ void DrawUtils::setRedraw(bool value) { redraw = value; } -void DrawUtils::initBuffers(void *tvBuffer_, uint32_t tvSize_, void *drcBuffer_, uint32_t drcSize_) { - DrawUtils::tvBuffer = (uint8_t *) tvBuffer_; - DrawUtils::tvSize = tvSize_; - DrawUtils::drcBuffer = (uint8_t *) drcBuffer_; - DrawUtils::drcSize = drcSize_; +void DrawUtils::initBuffers(void *sBufferTV_, void *sBufferDRC_) { + DrawUtils::tvBuffer = (uint8_t *) sBufferTV_; + DrawUtils::drcBuffer = (uint8_t *) sBufferDRC_; } void DrawUtils::beginDraw() { @@ -56,8 +130,11 @@ void DrawUtils::beginDraw() { void DrawUtils::endDraw() { // OSScreenFlipBuffersEx already flushes the cache? - // DCFlushRange(tvBuffer, tvSize); - // DCFlushRange(drcBuffer, drcSize); + // DCFlushRange(tvBuffer, sBufferSizeTV); + // DCFlushRange(drcBuffer, sBufferSizeDRC); + + DCFlushRange(sBufferTV, sBufferSizeTV); + DCFlushRange(sBufferDRC, sBufferSizeDRC); OSScreenFlipBuffersEx(SCREEN_DRC); OSScreenFlipBuffersEx(SCREEN_TV); @@ -73,9 +150,9 @@ void DrawUtils::drawPixel(uint32_t x, uint32_t y, uint8_t r, uint8_t g, uint8_t // put pixel in the drc buffer uint32_t i = (x + y * DRC_WIDTH) * 4; - if (i + 3 < drcSize / 2) { + if (i + 3 < sBufferSizeDRC / 2) { if (isBackBuffer) { - i += drcSize / 2; + i += sBufferSizeDRC / 2; } if (a == 0xFF) { drcBuffer[i] = r; @@ -90,7 +167,7 @@ void DrawUtils::drawPixel(uint32_t x, uint32_t y, uint8_t r, uint8_t g, uint8_t uint32_t USED_TV_WIDTH = TV_WIDTH; float scale = 1.5f; - if (DrawUtils::tvSize == 0x00FD2000) { + if (DrawUtils::sBufferSizeTV == 0x00FD2000) { USED_TV_WIDTH = 1920; scale = 2.25f; } @@ -99,9 +176,9 @@ void DrawUtils::drawPixel(uint32_t x, uint32_t y, uint8_t r, uint8_t g, uint8_t for (uint32_t yy = (y * scale); yy < ((y * scale) + (uint32_t) scale); yy++) { for (uint32_t xx = (x * scale); xx < ((x * scale) + (uint32_t) scale); xx++) { uint32_t i = (xx + yy * USED_TV_WIDTH) * 4; - if (i + 3 < tvSize / 2) { + if (i + 3 < sBufferSizeTV / 2) { if (isBackBuffer) { - i += tvSize / 2; + i += sBufferSizeTV / 2; } if (a == 0xFF) { tvBuffer[i] = r; diff --git a/src/utils/StateUtils.cpp b/src/utils/StateUtils.cpp index 9cf4796..6cd1164 100644 --- a/src/utils/StateUtils.cpp +++ b/src/utils/StateUtils.cpp @@ -3,8 +3,14 @@ #include #include #include +#include +#include #include +#include + +#include + bool State::aroma = false; void State::init() { @@ -18,6 +24,14 @@ void State::init() { WHBProcInit(); } + +void State::registerProcUICallbacks() { + if (aroma) { + ProcUIRegisterCallback(PROCUI_CALLBACK_ACQUIRE, DrawUtils::ConsoleProcCallbackAcquired, NULL, 100); + ProcUIRegisterCallback(PROCUI_CALLBACK_RELEASE, DrawUtils::ConsoleProcCallbackReleased, NULL, 100); + } +} + bool State::AppRunning() { if (aroma) { bool app = true; @@ -50,4 +64,6 @@ void State::shutdown() { if (!aroma) WHBProcShutdown(); ProcUIShutdown(); -} \ No newline at end of file +} + + From 8eb1ec300d581beeeabb41de79985f367f864370 Mon Sep 17 00:00:00 2001 From: w3irDv <170813473+w3irDv@users.noreply.github.com> Date: Mon, 29 Jul 2024 09:53:58 +0200 Subject: [PATCH 02/12] fix crash when scanning titles due to duplicate data nand/usb --- src/main.cpp | 11 ++++++----- 1 file changed, 6 insertions(+), 5 deletions(-) diff --git a/src/main.cpp b/src/main.cpp index 80c0bfc..b13c3cf 100644 --- a/src/main.cpp +++ b/src/main.cpp @@ -91,10 +91,11 @@ static Title *loadWiiUTitles(int run) { path = StringUtils::stringFormat("%s/usr/save/%08x/%s/meta/meta.xml", (i == 0) ? getUSB().c_str() : "storage_mlc01:", highIDs[a], data->d_name); if (checkEntry(path.c_str()) == 1) { - for (int i = 0; i < usable; i++) { - if (contains(highIDs, savesl[i].highID) && - (strtoul(data->d_name, nullptr, 16) == savesl[i].lowID)) { - savesl[i].found = true; + for (int ii = 0; ii < usable; ii++) { + if (contains(highIDs, savesl[ii].highID) && + (strtoul(data->d_name, nullptr, 16) == savesl[ii].lowID) && + savesl[ii].dev == i ) { + savesl[ii].found = true; tNoSave--; break; } @@ -109,7 +110,7 @@ static Title *loadWiiUTitles(int run) { } foundCount += tNoSave; - auto *saves = (Saves *) malloc((foundCount + tNoSave) * sizeof(Saves)); + auto *saves = (Saves *) malloc((foundCount) * sizeof(Saves)); if (saves == nullptr) { promptError(LanguageUtils::gettext("Out of memory.")); return nullptr; From a22b7af86d4aadff06da10da8cd88af010587367 Mon Sep 17 00:00:00 2001 From: w3irDv <170813473+w3irDv@users.noreply.github.com> Date: Sat, 3 Aug 2024 13:06:38 +0200 Subject: [PATCH 03/12] fix - no black screen when reentering app --- src/utils/DrawUtils.cpp | 24 ++++++++++++++++++------ 1 file changed, 18 insertions(+), 6 deletions(-) diff --git a/src/utils/DrawUtils.cpp b/src/utils/DrawUtils.cpp index 9c5681d..2cda6b1 100644 --- a/src/utils/DrawUtils.cpp +++ b/src/utils/DrawUtils.cpp @@ -33,6 +33,7 @@ uint32_t DrawUtils::sBufferSizeDRC = 0; static SFT pFont = {}; static Color font_col(0xFFFFFFFF); +static Color black(0x000000FF); void *DrawUtils::sBufferTV = NULL, *DrawUtils::sBufferDRC = NULL; uint32_t DrawUtils::sBufferSizeTV = 0, DrawUtils::sBufferSizeDRC = 0; @@ -52,10 +53,25 @@ DrawUtils::ConsoleProcCallbackAcquired(void *context) sBufferDRC = MEMAllocFromFrmHeapEx(heap, sBufferSizeDRC, 4); } + sConsoleHasForeground = TRUE; - DrawUtils::setRedraw(true); + OSScreenSetBufferEx(SCREEN_TV, sBufferTV); OSScreenSetBufferEx(SCREEN_DRC, sBufferDRC); + DrawUtils::initBuffers(sBufferTV, sBufferDRC); + + OSScreenEnableEx(SCREEN_TV, 1); + OSScreenEnableEx(SCREEN_DRC, 1); + + + for (int i = 0; i<2; i++) // both buffers to black + { + DrawUtils::clear(black); + DrawUtils::endDraw(); + } + + DrawUtils::setRedraw(true); // force a redraw when reentering + return 0; } @@ -77,13 +93,9 @@ DrawUtils::LogConsoleInit() sBufferSizeDRC = OSScreenGetBufferSizeEx(SCREEN_DRC); ConsoleProcCallbackAcquired(NULL); - OSScreenEnableEx(SCREEN_TV, 1); - OSScreenEnableEx(SCREEN_DRC, 1); - + State::registerProcUICallbacks(); - DrawUtils::initBuffers(sBufferTV, sBufferDRC); - return FALSE; } From 7827456236797a53f50d3232393d3b408969b990 Mon Sep 17 00:00:00 2001 From: w3irDv <170813473+w3irDv@users.noreply.github.com> Date: Sun, 4 Aug 2024 16:48:02 +0200 Subject: [PATCH 04/12] fix emptyFolder check --- src/savemng.cpp | 15 ++++++++++----- 1 file changed, 10 insertions(+), 5 deletions(-) diff --git a/src/savemng.cpp b/src/savemng.cpp index 84090e0..39dd4fa 100644 --- a/src/savemng.cpp +++ b/src/savemng.cpp @@ -10,6 +10,7 @@ #include #include + #define __FSAShimSend ((FSError(*)(FSAShimBuffer *, uint32_t))(0x101C400 + 0x042d90)) #define IO_MAX_FILE_BUFFER (1024 * 1024) // 1 MB @@ -202,14 +203,18 @@ static bool folderEmpty(const char *fPath) { if (dir == nullptr) return false; - int c = 0; + bool empty = true; struct dirent *data; - while ((data = readdir(dir)) != nullptr) - if (++c > 2) - break; + while ((data = readdir(dir)) != nullptr) { + // rewritten to work wether ./.. are returned or not + if(strcmp(data->d_name,".") == 0 || strcmp(data->d_name,"..") == 0) + continue; + empty = false; + break; + } closedir(dir); - return c < 3; + return empty; } static bool createFolder(const char *path) { From 4c9b69087fd0a41de7d23fdba6cf602567eec4e8 Mon Sep 17 00:00:00 2001 From: w3irDv <170813473+w3irDv@users.noreply.github.com> Date: Sun, 4 Aug 2024 16:54:42 +0200 Subject: [PATCH 05/12] refactor ProcUI + Colors --- include/savemng.h | 5 ----- include/utils/Colors.h | 6 ++++++ include/utils/DrawUtils.h | 4 ++-- include/utils/StateUtils.h | 2 ++ src/main.cpp | 3 +++ src/menu/WiiUTitleListState.cpp | 1 + src/menu/vWiiTitleListState.cpp | 1 + src/savemng.cpp | 1 + src/utils/DrawUtils.cpp | 22 +++++++++++++--------- src/utils/StateUtils.cpp | 20 ++++++++++++++++++-- 10 files changed, 47 insertions(+), 18 deletions(-) create mode 100644 include/utils/Colors.h diff --git a/include/savemng.h b/include/savemng.h index ccc47a3..9152106 100644 --- a/include/savemng.h +++ b/include/savemng.h @@ -23,11 +23,6 @@ #define M_OFF 1 #define Y_OFF 1 -#define COLOR_WHITE Color(0xffffffff) -#define COLOR_BLACK Color(0, 0, 0, 255) -#define COLOR_BACKGROUND Color(0x00006F00) -#define COLOR_TEXT COLOR_WHITE - struct Title { uint32_t highID; uint32_t lowID; diff --git a/include/utils/Colors.h b/include/utils/Colors.h new file mode 100644 index 0000000..3e24658 --- /dev/null +++ b/include/utils/Colors.h @@ -0,0 +1,6 @@ +#pragma once + +#define COLOR_WHITE Color(0xffffffff) +#define COLOR_BLACK Color(0, 0, 0, 255) +#define COLOR_BACKGROUND Color(0x00006F00) +#define COLOR_TEXT COLOR_WHITE \ No newline at end of file diff --git a/include/utils/DrawUtils.h b/include/utils/DrawUtils.h index 44e829b..10a5bf3 100644 --- a/include/utils/DrawUtils.h +++ b/include/utils/DrawUtils.h @@ -77,9 +77,9 @@ class DrawUtils { static void drawRGB5A3(int x, int y, float scale, uint8_t *fileContent); - static uint32_t ConsoleProcCallbackAcquired(void *context); + static uint32_t initScreen(); - static uint32_t ConsoleProcCallbackReleased(void *context); + static uint32_t deinitScreen(); diff --git a/include/utils/StateUtils.h b/include/utils/StateUtils.h index a469b9e..9891335 100644 --- a/include/utils/StateUtils.h +++ b/include/utils/StateUtils.h @@ -6,6 +6,8 @@ class State { static bool AppRunning(); static void shutdown(); static void registerProcUICallbacks(); + static uint32_t ConsoleProcCallbackAcquired(void *context); + static uint32_t ConsoleProcCallbackReleased(void *context); private: static bool aroma; diff --git a/src/main.cpp b/src/main.cpp index b13c3cf..c2cd2ba 100644 --- a/src/main.cpp +++ b/src/main.cpp @@ -10,6 +10,7 @@ #include #include #include +#include #include #include #include @@ -394,6 +395,8 @@ int main() { OSFatal("Failed to initialize OSSCreen"); } + State::registerProcUICallbacks(); + if (!DrawUtils::initFont()) { OSFatal("Failed to init font"); } diff --git a/src/menu/WiiUTitleListState.cpp b/src/menu/WiiUTitleListState.cpp index f9d8309..d25e93f 100644 --- a/src/menu/WiiUTitleListState.cpp +++ b/src/menu/WiiUTitleListState.cpp @@ -6,6 +6,7 @@ #include #include #include +#include #define MAX_TITLE_SHOW 14 static int cursorPos = 0; diff --git a/src/menu/vWiiTitleListState.cpp b/src/menu/vWiiTitleListState.cpp index 8aa4b8b..0f336ee 100644 --- a/src/menu/vWiiTitleListState.cpp +++ b/src/menu/vWiiTitleListState.cpp @@ -5,6 +5,7 @@ #include #include #include +#include #define MAX_TITLE_SHOW 14 static int cursorPos = 0; diff --git a/src/savemng.cpp b/src/savemng.cpp index 39dd4fa..f7bd7bc 100644 --- a/src/savemng.cpp +++ b/src/savemng.cpp @@ -8,6 +8,7 @@ #include #include #include +#include #include diff --git a/src/utils/DrawUtils.cpp b/src/utils/DrawUtils.cpp index 2cda6b1..16cdfd2 100644 --- a/src/utils/DrawUtils.cpp +++ b/src/utils/DrawUtils.cpp @@ -5,7 +5,7 @@ #include #include #include -#include +#include #include #include @@ -33,14 +33,13 @@ uint32_t DrawUtils::sBufferSizeDRC = 0; static SFT pFont = {}; static Color font_col(0xFFFFFFFF); -static Color black(0x000000FF); void *DrawUtils::sBufferTV = NULL, *DrawUtils::sBufferDRC = NULL; uint32_t DrawUtils::sBufferSizeTV = 0, DrawUtils::sBufferSizeDRC = 0; BOOL DrawUtils::sConsoleHasForeground = TRUE; uint32_t -DrawUtils::ConsoleProcCallbackAcquired(void *context) +DrawUtils::initScreen() { MEMHeapHandle heap = MEMGetBaseHeapHandle(MEM_BASE_HEAP_MEM1); MEMRecordStateForFrmHeap(heap, CONSOLE_FRAME_HEAP_TAG); @@ -66,7 +65,7 @@ DrawUtils::ConsoleProcCallbackAcquired(void *context) for (int i = 0; i<2; i++) // both buffers to black { - DrawUtils::clear(black); + DrawUtils::clear(COLOR_BLACK); DrawUtils::endDraw(); } @@ -76,8 +75,15 @@ DrawUtils::ConsoleProcCallbackAcquired(void *context) } uint32_t -DrawUtils::ConsoleProcCallbackReleased(void *context) +DrawUtils::deinitScreen() { + + for (int i = 0; i<2; i++) // both buffers to black + { + DrawUtils::clear(COLOR_BLACK); + DrawUtils::endDraw(); + } + MEMHeapHandle heap = MEMGetBaseHeapHandle(MEM_BASE_HEAP_MEM1); MEMFreeByStateToFrmHeap(heap, CONSOLE_FRAME_HEAP_TAG); sConsoleHasForeground = FALSE; @@ -92,10 +98,8 @@ DrawUtils::LogConsoleInit() sBufferSizeTV = OSScreenGetBufferSizeEx(SCREEN_TV); sBufferSizeDRC = OSScreenGetBufferSizeEx(SCREEN_DRC); - ConsoleProcCallbackAcquired(NULL); + initScreen(); - State::registerProcUICallbacks(); - return FALSE; } @@ -103,8 +107,8 @@ void DrawUtils::LogConsoleFree() { if (sConsoleHasForeground) { + deinitScreen(); OSScreenShutdown(); - ConsoleProcCallbackReleased(NULL); } } diff --git a/src/utils/StateUtils.cpp b/src/utils/StateUtils.cpp index 6cd1164..738e17e 100644 --- a/src/utils/StateUtils.cpp +++ b/src/utils/StateUtils.cpp @@ -11,6 +11,9 @@ #include +#include +#include + bool State::aroma = false; void State::init() { @@ -25,10 +28,22 @@ void State::init() { } +uint32_t +State::ConsoleProcCallbackAcquired(void *context) +{ + return DrawUtils::initScreen(); +} + +uint32_t +State::ConsoleProcCallbackReleased(void *context) +{ + return DrawUtils::deinitScreen(); +} + void State::registerProcUICallbacks() { if (aroma) { - ProcUIRegisterCallback(PROCUI_CALLBACK_ACQUIRE, DrawUtils::ConsoleProcCallbackAcquired, NULL, 100); - ProcUIRegisterCallback(PROCUI_CALLBACK_RELEASE, DrawUtils::ConsoleProcCallbackReleased, NULL, 100); + ProcUIRegisterCallback(PROCUI_CALLBACK_ACQUIRE, ConsoleProcCallbackAcquired, NULL, 100); + ProcUIRegisterCallback(PROCUI_CALLBACK_RELEASE, ConsoleProcCallbackReleased, NULL, 100); } } @@ -43,6 +58,7 @@ bool State::AppRunning() { break; case PROCUI_STATUS_RELEASE_FOREGROUND: // Free up MEM1 to next foreground app, deinit screen, etc. + WHBLogPrintf("ToProcUIDoneRelease"); ProcUIDrawDoneRelease(); break; case PROCUI_STATUS_IN_FOREGROUND: From f22a1fa801238d99109f182d01df2c4fdd9185ae Mon Sep 17 00:00:00 2001 From: w3irDv <170813473+w3irDv@users.noreply.github.com> Date: Mon, 5 Aug 2024 17:45:38 +0200 Subject: [PATCH 06/12] restore only creates needed folders/quota --- src/savemng.cpp | 9 +++++++-- 1 file changed, 7 insertions(+), 2 deletions(-) diff --git a/src/savemng.cpp b/src/savemng.cpp index f7bd7bc..3cc2970 100644 --- a/src/savemng.cpp +++ b/src/savemng.cpp @@ -1012,19 +1012,24 @@ void restoreSavedata(Title *title, uint8_t slot, int8_t sdusers, int8_t allusers srcPath = getBackupPath(highID, lowID, slot); std::string dstPath = StringUtils::stringFormat("%s/%08x/%08x/%s", path.c_str(), highID, lowID, isWii ? "data" : "user"); createFolderUnlocked(dstPath); - FSAMakeQuotaFromDir(srcPath.c_str(), dstPath.c_str(), title->accountSaveSize); - + if ((sdusers > -1) && !isWii) { if (common) { + FSAMakeQuota(handle, newlibtoFSA(dstPath + "/common").c_str(), 0x666, title->accountSaveSize); if (!copyDir(srcPath + "/common", dstPath + "/common")) promptError(LanguageUtils::gettext("Common save not found.")); } srcPath.append(StringUtils::stringFormat("/%s", sdacc[sdusers].persistentID)); dstPath.append(StringUtils::stringFormat("/%s", wiiuacc[allusers].persistentID)); + FSAMakeQuota(handle, newlibtoFSA(dstPath).c_str(), 0x666, title->accountSaveSize); + } else { + FSAMakeQuotaFromDir(srcPath.c_str(), dstPath.c_str(), title->accountSaveSize); } if (!copyDir(srcPath, dstPath)) promptError(LanguageUtils::gettext("Restore failed.")); + + if (!title->saveInit && !isWii) { std::string userPath = StringUtils::stringFormat("%s/%08x/%08x/user", path.c_str(), highID, lowID); From 6278f36e8d074538249e33f96608a605545673d9 Mon Sep 17 00:00:00 2001 From: w3irDv <170813473+w3irDv@users.noreply.github.com> Date: Mon, 5 Aug 2024 22:58:21 +0200 Subject: [PATCH 07/12] fix copySavedata - allusers and quota --- src/savemng.cpp | 17 ++++++++++++----- 1 file changed, 12 insertions(+), 5 deletions(-) diff --git a/src/savemng.cpp b/src/savemng.cpp index 3cc2970..e7bafc7 100644 --- a/src/savemng.cpp +++ b/src/savemng.cpp @@ -857,16 +857,23 @@ void copySavedata(Title *title, Title *titleb, int8_t allusers, int8_t allusers_ std::string srcPath = StringUtils::stringFormat("%s/%08x/%08x/%s", path.c_str(), highID, lowID, "user"); std::string dstPath = StringUtils::stringFormat("%s/%08x/%08x/%s", pathb.c_str(), highIDb, lowIDb, "user"); createFolderUnlocked(dstPath); - FSAMakeQuotaFromDir(srcPath.c_str(), dstPath.c_str(), titleb->accountSaveSize); - if (allusers > -1) - if (common) + if (allusers > -1) { + if (common) { + FSAMakeQuota(handle, newlibtoFSA(dstPath + "/common").c_str(), 0x666, titleb->accountSaveSize); if (!copyDir(srcPath + "/common", dstPath + "/common")) promptError(LanguageUtils::gettext("Common save not found.")); + } + srcPath.append(StringUtils::stringFormat("/%s", wiiuacc[allusers].persistentID)); + dstPath.append(StringUtils::stringFormat("/%s", wiiuacc[allusers_d].persistentID)); + FSAMakeQuota(handle, newlibtoFSA(dstPath).c_str(), 0x666, titleb->accountSaveSize); + } else { + FSAMakeQuotaFromDir(srcPath.c_str(), dstPath.c_str(), titleb->accountSaveSize); + } - if (!copyDir(srcPath + StringUtils::stringFormat("/%s", wiiuacc[allusers].persistentID), - dstPath + StringUtils::stringFormat("/%s", wiiuacc[allusers_d].persistentID))) + if (!copyDir(srcPath, dstPath)) promptError(LanguageUtils::gettext("Copy failed.")); + if (!titleb->saveInit) { std::string userPath = StringUtils::stringFormat("%s/%08x/%08x/user", pathb.c_str(), highIDb, lowIDb); From dc430897c0f86bee0f940622f29b6a755ef5eaef Mon Sep 17 00:00:00 2001 From: w3irDv <170813473+w3irDv@users.noreply.github.com> Date: Tue, 6 Aug 2024 00:14:41 +0200 Subject: [PATCH 08/12] bump version to 1.6.2 --- include/version.h | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/include/version.h b/include/version.h index d98fc50..c784e46 100644 --- a/include/version.h +++ b/include/version.h @@ -2,4 +2,4 @@ #define VERSION_MAJOR 1 #define VERSION_MINOR 6 -#define VERSION_MICRO 1 +#define VERSION_MICRO 2 From d6dd6b3ab98df43a6148de31ddcf74b6ef059d74 Mon Sep 17 00:00:00 2001 From: w3irDv <170813473+w3irDv@users.noreply.github.com> Date: Tue, 6 Aug 2024 14:36:10 +0200 Subject: [PATCH 09/12] remove WHBLOG in utils/State.h --- src/utils/DrawUtils.cpp | 5 ++--- src/utils/StateUtils.cpp | 3 --- 2 files changed, 2 insertions(+), 6 deletions(-) diff --git a/src/utils/DrawUtils.cpp b/src/utils/DrawUtils.cpp index 16cdfd2..65f3d03 100644 --- a/src/utils/DrawUtils.cpp +++ b/src/utils/DrawUtils.cpp @@ -59,9 +59,8 @@ DrawUtils::initScreen() OSScreenSetBufferEx(SCREEN_DRC, sBufferDRC); DrawUtils::initBuffers(sBufferTV, sBufferDRC); - OSScreenEnableEx(SCREEN_TV, 1); + OSScreenEnableEx(SCREEN_TV, 1); OSScreenEnableEx(SCREEN_DRC, 1); - for (int i = 0; i<2; i++) // both buffers to black { @@ -99,7 +98,7 @@ DrawUtils::LogConsoleInit() sBufferSizeDRC = OSScreenGetBufferSizeEx(SCREEN_DRC); initScreen(); - + return FALSE; } diff --git a/src/utils/StateUtils.cpp b/src/utils/StateUtils.cpp index 738e17e..95048cc 100644 --- a/src/utils/StateUtils.cpp +++ b/src/utils/StateUtils.cpp @@ -11,8 +11,6 @@ #include -#include -#include bool State::aroma = false; @@ -58,7 +56,6 @@ bool State::AppRunning() { break; case PROCUI_STATUS_RELEASE_FOREGROUND: // Free up MEM1 to next foreground app, deinit screen, etc. - WHBLogPrintf("ToProcUIDoneRelease"); ProcUIDrawDoneRelease(); break; case PROCUI_STATUS_IN_FOREGROUND: From 911f3816305a6d59951aa658a85f5efefb7d7b75 Mon Sep 17 00:00:00 2001 From: w3irDv <170813473+w3irDv@users.noreply.github.com> Date: Tue, 6 Aug 2024 19:05:04 +0200 Subject: [PATCH 10/12] reduce calls to OSScreenEnableEx, move it to initScreen --- src/utils/DrawUtils.cpp | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/src/utils/DrawUtils.cpp b/src/utils/DrawUtils.cpp index 65f3d03..9c8085f 100644 --- a/src/utils/DrawUtils.cpp +++ b/src/utils/DrawUtils.cpp @@ -59,9 +59,6 @@ DrawUtils::initScreen() OSScreenSetBufferEx(SCREEN_DRC, sBufferDRC); DrawUtils::initBuffers(sBufferTV, sBufferDRC); - OSScreenEnableEx(SCREEN_TV, 1); - OSScreenEnableEx(SCREEN_DRC, 1); - for (int i = 0; i<2; i++) // both buffers to black { DrawUtils::clear(COLOR_BLACK); @@ -99,6 +96,9 @@ DrawUtils::LogConsoleInit() initScreen(); + OSScreenEnableEx(SCREEN_TV, 1); + OSScreenEnableEx(SCREEN_DRC, 1); + return FALSE; } From 484ea7f246f11ab97c224b070e175c2cbe2a4060 Mon Sep 17 00:00:00 2001 From: w3irDv <170813473+w3irDv@users.noreply.github.com> Date: Wed, 7 Aug 2024 14:52:19 +0200 Subject: [PATCH 11/12] eliminate temp buffer variables/simplify initscreen calls --- include/utils/DrawUtils.h | 3 --- src/utils/DrawUtils.cpp | 46 +++++++++------------------------------ 2 files changed, 10 insertions(+), 39 deletions(-) diff --git a/include/utils/DrawUtils.h b/include/utils/DrawUtils.h index 10a5bf3..725eb76 100644 --- a/include/utils/DrawUtils.h +++ b/include/utils/DrawUtils.h @@ -39,8 +39,6 @@ class DrawUtils { static void LogConsoleFree(); - static void initBuffers(void *tvBuffer, void *drcBuffer); - static void beginDraw(); static void endDraw(); @@ -92,7 +90,6 @@ class DrawUtils { static uint8_t *tvBuffer; static uint8_t *drcBuffer; - static void *sBufferTV, *sBufferDRC; static uint32_t sBufferSizeTV, sBufferSizeDRC; static BOOL sConsoleHasForeground; }; diff --git a/src/utils/DrawUtils.cpp b/src/utils/DrawUtils.cpp index 9c8085f..078b3c9 100644 --- a/src/utils/DrawUtils.cpp +++ b/src/utils/DrawUtils.cpp @@ -26,18 +26,13 @@ bool DrawUtils::isBackBuffer; uint8_t *DrawUtils::tvBuffer = nullptr; uint8_t *DrawUtils::drcBuffer = nullptr; -/* -uint32_t DrawUtils::sBufferSizeTV = 0; -uint32_t DrawUtils::sBufferSizeDRC = 0; -*/ +uint32_t DrawUtils::sBufferSizeTV = 0, DrawUtils::sBufferSizeDRC = 0; +BOOL DrawUtils::sConsoleHasForeground = TRUE; + static SFT pFont = {}; static Color font_col(0xFFFFFFFF); -void *DrawUtils::sBufferTV = NULL, *DrawUtils::sBufferDRC = NULL; -uint32_t DrawUtils::sBufferSizeTV = 0, DrawUtils::sBufferSizeDRC = 0; -BOOL DrawUtils::sConsoleHasForeground = TRUE; - uint32_t DrawUtils::initScreen() { @@ -45,45 +40,36 @@ DrawUtils::initScreen() MEMRecordStateForFrmHeap(heap, CONSOLE_FRAME_HEAP_TAG); if (sBufferSizeTV) { - sBufferTV = MEMAllocFromFrmHeapEx(heap, sBufferSizeTV, 4); + DrawUtils::tvBuffer = static_cast(MEMAllocFromFrmHeapEx(heap, sBufferSizeTV, 4)); } if (sBufferSizeDRC) { - sBufferDRC = MEMAllocFromFrmHeapEx(heap, sBufferSizeDRC, 4); + DrawUtils::drcBuffer = static_cast(MEMAllocFromFrmHeapEx(heap, sBufferSizeDRC, 4)); } sConsoleHasForeground = TRUE; - OSScreenSetBufferEx(SCREEN_TV, sBufferTV); - OSScreenSetBufferEx(SCREEN_DRC, sBufferDRC); - DrawUtils::initBuffers(sBufferTV, sBufferDRC); + OSScreenSetBufferEx(SCREEN_TV, DrawUtils::tvBuffer); + OSScreenSetBufferEx(SCREEN_DRC, DrawUtils::drcBuffer); - for (int i = 0; i<2; i++) // both buffers to black - { - DrawUtils::clear(COLOR_BLACK); - DrawUtils::endDraw(); - } + DrawUtils::endDraw(); // flip buffers DrawUtils::setRedraw(true); // force a redraw when reentering return 0; + } uint32_t DrawUtils::deinitScreen() { - for (int i = 0; i<2; i++) // both buffers to black - { - DrawUtils::clear(COLOR_BLACK); - DrawUtils::endDraw(); - } - MEMHeapHandle heap = MEMGetBaseHeapHandle(MEM_BASE_HEAP_MEM1); MEMFreeByStateToFrmHeap(heap, CONSOLE_FRAME_HEAP_TAG); sConsoleHasForeground = FALSE; return 0; + } @@ -123,11 +109,6 @@ void DrawUtils::setRedraw(bool value) { redraw = value; } -void DrawUtils::initBuffers(void *sBufferTV_, void *sBufferDRC_) { - DrawUtils::tvBuffer = (uint8_t *) sBufferTV_; - DrawUtils::drcBuffer = (uint8_t *) sBufferDRC_; -} - void DrawUtils::beginDraw() { uint32_t pixel = *(uint32_t *) tvBuffer; @@ -144,13 +125,6 @@ void DrawUtils::beginDraw() { } void DrawUtils::endDraw() { - // OSScreenFlipBuffersEx already flushes the cache? - // DCFlushRange(tvBuffer, sBufferSizeTV); - // DCFlushRange(drcBuffer, sBufferSizeDRC); - - DCFlushRange(sBufferTV, sBufferSizeTV); - DCFlushRange(sBufferDRC, sBufferSizeDRC); - OSScreenFlipBuffersEx(SCREEN_DRC); OSScreenFlipBuffersEx(SCREEN_TV); } From 093dcc41ad00205dce3d701379dd923e2d6ebc3b Mon Sep 17 00:00:00 2001 From: w3irDv <170813473+w3irDv@users.noreply.github.com> Date: Wed, 7 Aug 2024 23:39:22 +0200 Subject: [PATCH 12/12] includes housekeeping --- include/utils/StateUtils.h | 2 ++ src/main.cpp | 6 +++--- src/utils/DrawUtils.cpp | 12 +++++------- src/utils/StateUtils.cpp | 7 ++----- 4 files changed, 12 insertions(+), 15 deletions(-) diff --git a/include/utils/StateUtils.h b/include/utils/StateUtils.h index 9891335..4c399fa 100644 --- a/include/utils/StateUtils.h +++ b/include/utils/StateUtils.h @@ -1,5 +1,7 @@ #pragma once +#include + class State { public: static void init(); diff --git a/src/main.cpp b/src/main.cpp index c2cd2ba..fd3deed 100644 --- a/src/main.cpp +++ b/src/main.cpp @@ -1,6 +1,3 @@ -#include -#include -#include #include #include #include @@ -16,6 +13,9 @@ #include #include #include +#include +#include +#include static int wiiuTitlesCount = 0, vWiiTitlesCount = 0; diff --git a/src/utils/DrawUtils.cpp b/src/utils/DrawUtils.cpp index 078b3c9..471de02 100644 --- a/src/utils/DrawUtils.cpp +++ b/src/utils/DrawUtils.cpp @@ -1,16 +1,14 @@ -#include -#include +#include +#include #include #include #include -#include -#include -#include #include +#include #include - -#include #include +#include +#include #include #include #include diff --git a/src/utils/StateUtils.cpp b/src/utils/StateUtils.cpp index 95048cc..da6b270 100644 --- a/src/utils/StateUtils.cpp +++ b/src/utils/StateUtils.cpp @@ -1,16 +1,13 @@ +#include +#include #include #include #include #include -#include -#include -#include #include #include -#include - bool State::aroma = false;