Fix home button exit on all PoCs.

This commit is contained in:
Pablo Curiel 2022-02-19 06:03:06 +01:00
parent c99f6776a7
commit fabb15bbe4
7 changed files with 113 additions and 30 deletions

View file

@ -75,7 +75,7 @@ static void consolePrint(const char *text, ...);
static u32 menuGetElementCount(const Menu *menu); static u32 menuGetElementCount(const Menu *menu);
static bool waitForGameCard(void); static bool waitForGameCard(void);
static void waitForUsb(void); static bool waitForUsb(void);
static void generateDumpTxt(void); static void generateDumpTxt(void);
static bool saveDumpTxt(void); static bool saveDumpTxt(void);
@ -211,6 +211,8 @@ static CondVar g_readCondvar = 0, g_writeCondvar = 0;
static char path[FS_MAX_PATH] = {0}, txt_info[FS_MAX_PATH] = {0}; static char path[FS_MAX_PATH] = {0}, txt_info[FS_MAX_PATH] = {0};
static bool g_appletStatus = true;
static void utilsScanPads(void) static void utilsScanPads(void)
{ {
padUpdate(&g_padState); padUpdate(&g_padState);
@ -295,13 +297,16 @@ int main(int argc, char *argv[])
consoleUpdate(NULL); consoleUpdate(NULL);
u64 btn_down = 0, btn_held = 0; u64 btn_down = 0, btn_held = 0;
while(!btn_down && !btn_held) while((g_appletStatus = appletMainLoop()))
{ {
utilsScanPads(); utilsScanPads();
btn_down = utilsGetButtonsDown(); btn_down = utilsGetButtonsDown();
btn_held = utilsGetButtonsHeld(); btn_held = utilsGetButtonsHeld();
if (btn_down || btn_held) break;
} }
if (!g_appletStatus) break;
if (btn_down & HidNpadButton_A) if (btn_down & HidNpadButton_A)
{ {
Menu *child_menu = (Menu*)selected_element->child_menu; Menu *child_menu = (Menu*)selected_element->child_menu;
@ -315,10 +320,14 @@ int main(int argc, char *argv[])
if (selected_element->task_func) if (selected_element->task_func)
{ {
/* Wait for gamecard. */ /* Wait for gamecard. */
if (!waitForGameCard()) continue; if (!waitForGameCard())
{
if (g_appletStatus) continue;
break;
}
/* Wait for USB session. */ /* Wait for USB session. */
if (g_useUsbHost) waitForUsb(); if (g_useUsbHost && !waitForUsb()) break;
/* Generate dump text. */ /* Generate dump text. */
generateDumpTxt(); generateDumpTxt();
@ -426,7 +435,14 @@ static bool waitForGameCard(void)
consolePrint("waiting for gamecard...\n"); consolePrint("waiting for gamecard...\n");
u8 status = GameCardStatus_NotInserted; u8 status = GameCardStatus_NotInserted;
while(status <= GameCardStatus_Processing) status = gamecardGetStatus();
while((g_appletStatus = appletMainLoop()))
{
status = gamecardGetStatus();
if (status <= GameCardStatus_Processing) break;
}
if (!g_appletStatus) return false;
switch(status) switch(status)
{ {
@ -453,16 +469,18 @@ static bool waitForGameCard(void)
return true; return true;
} }
static void waitForUsb(void) static bool waitForUsb(void)
{ {
if (usbIsReady()) return; if (usbIsReady()) return true;
consolePrint("waiting for usb session...\n"); consolePrint("waiting for usb session...\n");
while(true) while((g_appletStatus = appletMainLoop()))
{ {
if (usbIsReady()) break; if (usbIsReady()) break;
} }
return g_appletStatus;
} }
static void generateDumpTxt(void) static void generateDumpTxt(void)

View file

@ -847,6 +847,8 @@ int main(int argc, char *argv[])
char device_total_fs_size_str[36] = {0}, device_free_fs_size_str[32] = {0}, device_info[0x300] = {0}; char device_total_fs_size_str[36] = {0}, device_free_fs_size_str[32] = {0}, device_info[0x300] = {0};
bool device_retrieved_size = false, device_retrieved_info = false; bool device_retrieved_size = false, device_retrieved_info = false;
bool applet_status = true;
app_metadata = titleGetApplicationMetadataEntries(false, &app_count); app_metadata = titleGetApplicationMetadataEntries(false, &app_count);
if (!app_metadata || !app_count) if (!app_metadata || !app_count)
{ {
@ -860,7 +862,7 @@ int main(int argc, char *argv[])
utilsSleep(1); utilsSleep(1);
while(true) while((applet_status = appletMainLoop()))
{ {
consoleClear(); consoleClear();
@ -971,7 +973,7 @@ int main(int argc, char *argv[])
bool data_update = false; bool data_update = false;
u64 btn_down = 0, btn_held = 0; u64 btn_down = 0, btn_held = 0;
while(true) while((applet_status = appletMainLoop()))
{ {
utilsScanPads(); utilsScanPads();
btn_down = utilsGetButtonsDown(); btn_down = utilsGetButtonsDown();
@ -1015,6 +1017,8 @@ int main(int argc, char *argv[])
} }
} }
if (!applet_status) break;
if (data_update) continue; if (data_update) continue;
if (btn_down & HidNpadButton_A) if (btn_down & HidNpadButton_A)
@ -1173,6 +1177,8 @@ int main(int argc, char *argv[])
if (btn_held & (HidNpadButton_StickLDown | HidNpadButton_StickRDown | HidNpadButton_StickLUp | HidNpadButton_StickRUp)) svcSleepThread(50000000); // 50 ms if (btn_held & (HidNpadButton_StickLDown | HidNpadButton_StickRDown | HidNpadButton_StickLUp | HidNpadButton_StickRUp)) svcSleepThread(50000000); // 50 ms
} }
if (!applet_status) menu = UINT32_MAX;
out2: out2:
if (menu != UINT32_MAX) if (menu != UINT32_MAX)
{ {

View file

@ -1000,6 +1000,8 @@ int main(int argc, char *argv[])
u32 type_idx = 0, type_scroll = 0; u32 type_idx = 0, type_scroll = 0;
u32 list_count = 0, list_idx = 0; u32 list_count = 0, list_idx = 0;
bool applet_status = true;
app_metadata = titleGetApplicationMetadataEntries(false, &app_count); app_metadata = titleGetApplicationMetadataEntries(false, &app_count);
if (!app_metadata || !app_count) if (!app_metadata || !app_count)
{ {
@ -1012,7 +1014,7 @@ int main(int argc, char *argv[])
utilsSleep(1); utilsSleep(1);
while(true) while((applet_status = appletMainLoop()))
{ {
consoleClear(); consoleClear();
@ -1086,7 +1088,7 @@ int main(int argc, char *argv[])
bool gc_update = false; bool gc_update = false;
u64 btn_down = 0, btn_held = 0; u64 btn_down = 0, btn_held = 0;
while(true) while((applet_status = appletMainLoop()))
{ {
utilsScanPads(); utilsScanPads();
btn_down = utilsGetButtonsDown(); btn_down = utilsGetButtonsDown();
@ -1116,6 +1118,8 @@ int main(int argc, char *argv[])
} }
} }
if (!applet_status) break;
if (gc_update) continue; if (gc_update) continue;
if (btn_down & HidNpadButton_A) if (btn_down & HidNpadButton_A)
@ -1246,6 +1250,8 @@ int main(int argc, char *argv[])
if (btn_held & (HidNpadButton_StickLDown | HidNpadButton_StickRDown | HidNpadButton_StickLUp | HidNpadButton_StickRUp)) svcSleepThread(50000000); // 50 ms if (btn_held & (HidNpadButton_StickLDown | HidNpadButton_StickRDown | HidNpadButton_StickLUp | HidNpadButton_StickRUp)) svcSleepThread(50000000); // 50 ms
} }
if (!applet_status) menu = UINT32_MAX;
out2: out2:
consoleRefresh(); consoleRefresh();

View file

@ -268,6 +268,7 @@ u8 get_program_id_offset(TitleInfo *info, u32 program_count)
u8 id_offset = 0; u8 id_offset = 0;
u32 selected_idx = 0, page_size = 30, scroll = 0; u32 selected_idx = 0, page_size = 30, scroll = 0;
char nca_id_str[0x21] = {0}; char nca_id_str[0x21] = {0};
bool applet_status = true;
NcmContentInfo **content_infos = calloc(program_count, sizeof(NcmContentInfo*)); NcmContentInfo **content_infos = calloc(program_count, sizeof(NcmContentInfo*));
if (!content_infos) return 0; if (!content_infos) return 0;
@ -278,7 +279,7 @@ u8 get_program_id_offset(TitleInfo *info, u32 program_count)
content_infos[j++] = &(info->content_infos[i]); content_infos[j++] = &(info->content_infos[i]);
} }
while(true) while((applet_status = appletMainLoop()))
{ {
consoleClear(); consoleClear();
printf("select a program nca to dump the romfs from.\n\n"); printf("select a program nca to dump the romfs from.\n\n");
@ -295,7 +296,7 @@ u8 get_program_id_offset(TitleInfo *info, u32 program_count)
consoleUpdate(NULL); consoleUpdate(NULL);
u64 btn_down = 0, btn_held = 0; u64 btn_down = 0, btn_held = 0;
while(true) while((applet_status = appletMainLoop()))
{ {
utilsScanPads(); utilsScanPads();
btn_down = utilsGetButtonsDown(); btn_down = utilsGetButtonsDown();
@ -303,6 +304,8 @@ u8 get_program_id_offset(TitleInfo *info, u32 program_count)
if (btn_down || btn_held) break; if (btn_down || btn_held) break;
} }
if (!applet_status) break;
if (btn_down & HidNpadButton_A) if (btn_down & HidNpadButton_A)
{ {
id_offset = content_infos[selected_idx]->id_offset; id_offset = content_infos[selected_idx]->id_offset;
@ -351,7 +354,7 @@ u8 get_program_id_offset(TitleInfo *info, u32 program_count)
free(content_infos); free(content_infos);
return id_offset; return (applet_status ? id_offset : (u8)program_count);
} }
int main(int argc, char *argv[]) int main(int argc, char *argv[])
@ -377,7 +380,7 @@ int main(int argc, char *argv[])
TitleUserApplicationData user_app_data = {0}; TitleUserApplicationData user_app_data = {0};
u32 selected_idx = 0, page_size = 30, scroll = 0; u32 selected_idx = 0, page_size = 30, scroll = 0;
bool exit_prompt = true; bool applet_status = true, exit_prompt = true;
u8 *buf = NULL; u8 *buf = NULL;
@ -427,7 +430,7 @@ int main(int argc, char *argv[])
utilsSleep(1); utilsSleep(1);
while(true) while((applet_status = appletMainLoop()))
{ {
consoleClear(); consoleClear();
printf("select a user application to dump its romfs.\nif an update is available, patch romfs data will be dumped instead.\ndata will be saved to \"sdmc:/romfs\".\npress b to exit.\n\n"); printf("select a user application to dump its romfs.\nif an update is available, patch romfs data will be dumped instead.\ndata will be saved to \"sdmc:/romfs\".\npress b to exit.\n\n");
@ -447,7 +450,7 @@ int main(int argc, char *argv[])
bool gc_update = false; bool gc_update = false;
u64 btn_down = 0, btn_held = 0; u64 btn_down = 0, btn_held = 0;
while(true) while((applet_status = appletMainLoop()))
{ {
utilsScanPads(); utilsScanPads();
btn_down = utilsGetButtonsDown(); btn_down = utilsGetButtonsDown();
@ -472,6 +475,8 @@ int main(int argc, char *argv[])
} }
} }
if (!applet_status) break;
if (gc_update) continue; if (gc_update) continue;
if (btn_down & HidNpadButton_A) if (btn_down & HidNpadButton_A)
@ -532,6 +537,12 @@ int main(int argc, char *argv[])
if (btn_held & (HidNpadButton_StickLDown | HidNpadButton_StickRDown | HidNpadButton_StickLUp | HidNpadButton_StickRUp)) svcSleepThread(50000000); // 50 ms if (btn_held & (HidNpadButton_StickLDown | HidNpadButton_StickRDown | HidNpadButton_StickLUp | HidNpadButton_StickRUp)) svcSleepThread(50000000); // 50 ms
} }
if (!applet_status)
{
exit_prompt = false;
goto out2;
}
u32 program_count = titleGetContentCountByType(user_app_data.app_info, NcmContentType_Program); u32 program_count = titleGetContentCountByType(user_app_data.app_info, NcmContentType_Program);
if (!program_count) if (!program_count)
{ {
@ -540,6 +551,11 @@ int main(int argc, char *argv[])
} }
u8 program_id_offset = get_program_id_offset(user_app_data.app_info, program_count); u8 program_id_offset = get_program_id_offset(user_app_data.app_info, program_count);
if (program_id_offset >= program_count)
{
exit_prompt = false;
goto out2;
}
consoleClear(); consoleClear();
consolePrint("selected title:\n%s (%016lX)\n\n", app_metadata[selected_idx]->lang_entry.name, app_metadata[selected_idx]->title_id + program_id_offset); consolePrint("selected title:\n%s (%016lX)\n\n", app_metadata[selected_idx]->lang_entry.name, app_metadata[selected_idx]->title_id + program_id_offset);

View file

@ -279,6 +279,8 @@ int main(int argc, char *argv[])
NcaContext *nca_ctx = NULL; NcaContext *nca_ctx = NULL;
bool applet_status = true;
app_metadata = titleGetApplicationMetadataEntries(true, &app_count); app_metadata = titleGetApplicationMetadataEntries(true, &app_count);
if (!app_metadata || !app_count) if (!app_metadata || !app_count)
{ {
@ -308,7 +310,7 @@ int main(int argc, char *argv[])
utilsSleep(1); utilsSleep(1);
while(true) while((applet_status = appletMainLoop()))
{ {
consoleClear(); consoleClear();
@ -352,13 +354,16 @@ int main(int argc, char *argv[])
consoleUpdate(NULL); consoleUpdate(NULL);
u64 btn_down = 0, btn_held = 0; u64 btn_down = 0, btn_held = 0;
while(!btn_down && !btn_held) while((applet_status = appletMainLoop()))
{ {
utilsScanPads(); utilsScanPads();
btn_down = utilsGetButtonsDown(); btn_down = utilsGetButtonsDown();
btn_held = utilsGetButtonsHeld(); btn_held = utilsGetButtonsHeld();
if (btn_down || btn_held) break;
} }
if (!applet_status) break;
if (btn_down & HidNpadButton_A) if (btn_down & HidNpadButton_A)
{ {
bool error = false; bool error = false;
@ -464,6 +469,8 @@ int main(int argc, char *argv[])
if (btn_held & (HidNpadButton_StickLDown | HidNpadButton_StickRDown | HidNpadButton_StickLUp | HidNpadButton_StickRUp)) svcSleepThread(50000000); // 50 ms if (btn_held & (HidNpadButton_StickLDown | HidNpadButton_StickRDown | HidNpadButton_StickLUp | HidNpadButton_StickRUp)) svcSleepThread(50000000); // 50 ms
} }
if (!applet_status) menu = UINT32_MAX;
out2: out2:
if (menu != UINT32_MAX) if (menu != UINT32_MAX)
{ {

View file

@ -247,6 +247,7 @@ u8 get_program_id_offset(TitleInfo *info, u32 program_count)
u8 id_offset = 0; u8 id_offset = 0;
u32 selected_idx = 0, page_size = 30, scroll = 0; u32 selected_idx = 0, page_size = 30, scroll = 0;
char nca_id_str[0x21] = {0}; char nca_id_str[0x21] = {0};
bool applet_status = true;
NcmContentInfo **content_infos = calloc(program_count, sizeof(NcmContentInfo*)); NcmContentInfo **content_infos = calloc(program_count, sizeof(NcmContentInfo*));
if (!content_infos) return 0; if (!content_infos) return 0;
@ -257,7 +258,7 @@ u8 get_program_id_offset(TitleInfo *info, u32 program_count)
content_infos[j++] = &(info->content_infos[i]); content_infos[j++] = &(info->content_infos[i]);
} }
while(true) while((applet_status = appletMainLoop()))
{ {
consoleClear(); consoleClear();
printf("select a program nca to dump the romfs from.\n\n"); printf("select a program nca to dump the romfs from.\n\n");
@ -274,7 +275,7 @@ u8 get_program_id_offset(TitleInfo *info, u32 program_count)
consoleUpdate(NULL); consoleUpdate(NULL);
u64 btn_down = 0, btn_held = 0; u64 btn_down = 0, btn_held = 0;
while(true) while((applet_status = appletMainLoop()))
{ {
utilsScanPads(); utilsScanPads();
btn_down = utilsGetButtonsDown(); btn_down = utilsGetButtonsDown();
@ -282,6 +283,8 @@ u8 get_program_id_offset(TitleInfo *info, u32 program_count)
if (btn_down || btn_held) break; if (btn_down || btn_held) break;
} }
if (!applet_status) break;
if (btn_down & HidNpadButton_A) if (btn_down & HidNpadButton_A)
{ {
id_offset = content_infos[selected_idx]->id_offset; id_offset = content_infos[selected_idx]->id_offset;
@ -330,7 +333,7 @@ u8 get_program_id_offset(TitleInfo *info, u32 program_count)
free(content_infos); free(content_infos);
return id_offset; return (applet_status ? id_offset : (u8)program_count);
} }
int main(int argc, char *argv[]) int main(int argc, char *argv[])
@ -356,7 +359,7 @@ int main(int argc, char *argv[])
TitleUserApplicationData user_app_data = {0}; TitleUserApplicationData user_app_data = {0};
u32 selected_idx = 0, page_size = 30, scroll = 0; u32 selected_idx = 0, page_size = 30, scroll = 0;
bool exit_prompt = true; bool applet_status = true, exit_prompt = true;
u8 *buf = NULL; u8 *buf = NULL;
@ -406,7 +409,7 @@ int main(int argc, char *argv[])
utilsSleep(1); utilsSleep(1);
while(true) while((applet_status = appletMainLoop()))
{ {
consoleClear(); consoleClear();
printf("select a user application to dump its romfs.\nif an update is available, patch romfs data will be dumped instead.\ndata will be transferred via usb.\npress b to exit.\n\n"); printf("select a user application to dump its romfs.\nif an update is available, patch romfs data will be dumped instead.\ndata will be transferred via usb.\npress b to exit.\n\n");
@ -424,7 +427,7 @@ int main(int argc, char *argv[])
consoleUpdate(NULL); consoleUpdate(NULL);
u64 btn_down = 0, btn_held = 0; u64 btn_down = 0, btn_held = 0;
while(true) while((applet_status = appletMainLoop()))
{ {
utilsScanPads(); utilsScanPads();
btn_down = utilsGetButtonsDown(); btn_down = utilsGetButtonsDown();
@ -447,6 +450,8 @@ int main(int argc, char *argv[])
} }
} }
if (!applet_status) break;
if (btn_down & HidNpadButton_A) if (btn_down & HidNpadButton_A)
{ {
if (!titleGetUserApplicationData(app_metadata[selected_idx]->title_id, &user_app_data) || !user_app_data.app_info) if (!titleGetUserApplicationData(app_metadata[selected_idx]->title_id, &user_app_data) || !user_app_data.app_info)
@ -505,6 +510,12 @@ int main(int argc, char *argv[])
if (btn_held & (HidNpadButton_StickLDown | HidNpadButton_StickRDown | HidNpadButton_StickLUp | HidNpadButton_StickRUp)) svcSleepThread(50000000); // 50 ms if (btn_held & (HidNpadButton_StickLDown | HidNpadButton_StickRDown | HidNpadButton_StickLUp | HidNpadButton_StickRUp)) svcSleepThread(50000000); // 50 ms
} }
if (!applet_status)
{
exit_prompt = false;
goto out2;
}
u32 program_count = titleGetContentCountByType(user_app_data.app_info, NcmContentType_Program); u32 program_count = titleGetContentCountByType(user_app_data.app_info, NcmContentType_Program);
if (!program_count) if (!program_count)
{ {
@ -513,6 +524,11 @@ int main(int argc, char *argv[])
} }
u8 program_id_offset = get_program_id_offset(user_app_data.app_info, program_count); u8 program_id_offset = get_program_id_offset(user_app_data.app_info, program_count);
if (program_id_offset >= program_count)
{
exit_prompt = false;
goto out2;
}
consoleClear(); consoleClear();
consolePrint("selected title:\n%s (%016lX)\n\n", app_metadata[selected_idx]->lang_entry.name, app_metadata[selected_idx]->title_id + program_id_offset); consolePrint("selected title:\n%s (%016lX)\n\n", app_metadata[selected_idx]->lang_entry.name, app_metadata[selected_idx]->title_id + program_id_offset);
@ -565,7 +581,7 @@ int main(int argc, char *argv[])
time_t start = time(NULL); time_t start = time(NULL);
u8 usb_host_speed = UsbHostSpeed_None; u8 usb_host_speed = UsbHostSpeed_None;
while(true) while((applet_status = appletMainLoop()))
{ {
time_t now = time(NULL); time_t now = time(NULL);
if ((now - start) >= 10) break; if ((now - start) >= 10) break;
@ -575,6 +591,12 @@ int main(int argc, char *argv[])
utilsSleep(1); utilsSleep(1);
} }
if (!applet_status)
{
exit_prompt = false;
goto out2;
}
consolePrint("\n"); consolePrint("\n");
if (!usb_host_speed) if (!usb_host_speed)

View file

@ -102,7 +102,7 @@ int main(int argc, char *argv[])
TitleUserApplicationData user_app_data = {0}; TitleUserApplicationData user_app_data = {0};
u32 selected_idx = 0, page_size = 30, scroll = 0; u32 selected_idx = 0, page_size = 30, scroll = 0;
bool exit_prompt = true; bool applet_status = true, exit_prompt = true;
NcaContext *nca_ctx = NULL; NcaContext *nca_ctx = NULL;
Ticket tik = {0}; Ticket tik = {0};
@ -132,7 +132,7 @@ int main(int argc, char *argv[])
utilsSleep(1); utilsSleep(1);
while(true) while((applet_status = appletMainLoop()))
{ {
consoleClear(); consoleClear();
printf("select a user application to generate xmls for.\npress b to exit.\n\n"); printf("select a user application to generate xmls for.\npress b to exit.\n\n");
@ -150,7 +150,7 @@ int main(int argc, char *argv[])
consoleUpdate(NULL); consoleUpdate(NULL);
u64 btn_down = 0, btn_held = 0; u64 btn_down = 0, btn_held = 0;
while(true) while((applet_status = appletMainLoop()))
{ {
utilsScanPads(); utilsScanPads();
btn_down = utilsGetButtonsDown(); btn_down = utilsGetButtonsDown();
@ -173,6 +173,8 @@ int main(int argc, char *argv[])
} }
} }
if (!applet_status) break;
if (btn_down & HidNpadButton_A) if (btn_down & HidNpadButton_A)
{ {
if (!titleGetUserApplicationData(app_metadata[selected_idx]->title_id, &user_app_data) || !user_app_data.app_info) if (!titleGetUserApplicationData(app_metadata[selected_idx]->title_id, &user_app_data) || !user_app_data.app_info)
@ -231,6 +233,12 @@ int main(int argc, char *argv[])
if (btn_held & (HidNpadButton_StickLDown | HidNpadButton_StickRDown | HidNpadButton_StickLUp | HidNpadButton_StickRUp)) svcSleepThread(50000000); // 50 ms if (btn_held & (HidNpadButton_StickLDown | HidNpadButton_StickRDown | HidNpadButton_StickLUp | HidNpadButton_StickRUp)) svcSleepThread(50000000); // 50 ms
} }
if (!applet_status)
{
exit_prompt = false;
goto out2;
}
consoleClear(); consoleClear();
consolePrint("selected title:\n%s (%016lX)\n\n", app_metadata[selected_idx]->lang_entry.name, app_metadata[selected_idx]->title_id); consolePrint("selected title:\n%s (%016lX)\n\n", app_metadata[selected_idx]->lang_entry.name, app_metadata[selected_idx]->title_id);