mirror of
https://github.com/DarkMatterCore/nxdumptool.git
synced 2025-01-09 19:17:23 -03:00
gc_dumper: generate text file with dump info.
This commit is contained in:
parent
7bec356181
commit
fea5f8803d
5 changed files with 92 additions and 75 deletions
|
@ -74,6 +74,11 @@ static void consolePrint(const char *text, ...);
|
||||||
|
|
||||||
static u32 menuGetElementCount(const Menu *menu);
|
static u32 menuGetElementCount(const Menu *menu);
|
||||||
|
|
||||||
|
static bool waitForGameCard(void);
|
||||||
|
static void waitForUsb(void);
|
||||||
|
|
||||||
|
static void generateDumpTxt(void);
|
||||||
|
|
||||||
static bool saveGameCardSpecificData(void);
|
static bool saveGameCardSpecificData(void);
|
||||||
static bool saveGameCardCertificate(void);
|
static bool saveGameCardCertificate(void);
|
||||||
static bool saveGameCardInitialData(void);
|
static bool saveGameCardInitialData(void);
|
||||||
|
@ -203,7 +208,7 @@ static Menu g_rootMenu = {
|
||||||
static Mutex g_fileMutex = 0;
|
static Mutex g_fileMutex = 0;
|
||||||
static CondVar g_readCondvar = 0, g_writeCondvar = 0;
|
static CondVar g_readCondvar = 0, g_writeCondvar = 0;
|
||||||
|
|
||||||
static char path[FS_MAX_PATH] = {0};
|
static char path[FS_MAX_PATH] = {0}, txt_info[FS_MAX_PATH] = {0};
|
||||||
|
|
||||||
static void utilsScanPads(void)
|
static void utilsScanPads(void)
|
||||||
{
|
{
|
||||||
|
@ -308,7 +313,23 @@ int main(int argc, char *argv[])
|
||||||
} else
|
} else
|
||||||
if (selected_element->task_func)
|
if (selected_element->task_func)
|
||||||
{
|
{
|
||||||
|
/* Wait for gamecard. */
|
||||||
|
if (!waitForGameCard()) continue;
|
||||||
|
|
||||||
|
/* Wait for USB session. */
|
||||||
|
if (g_useUsbHost) waitForUsb();
|
||||||
|
|
||||||
|
/* Generate dump text. */
|
||||||
|
generateDumpTxt();
|
||||||
|
|
||||||
|
/* Run task. */
|
||||||
|
utilsSetLongRunningProcessState(true);
|
||||||
selected_element->task_func();
|
selected_element->task_func();
|
||||||
|
utilsSetLongRunningProcessState(false);
|
||||||
|
|
||||||
|
/* Display prompt. */
|
||||||
|
consolePrint("press any button to continue");
|
||||||
|
utilsWaitForButtonPress(0);
|
||||||
}
|
}
|
||||||
} else
|
} else
|
||||||
if ((btn_down & HidNpadButton_Down) || (btn_held & (HidNpadButton_StickLDown | HidNpadButton_StickRDown)))
|
if ((btn_down & HidNpadButton_Down) || (btn_held & (HidNpadButton_StickLDown | HidNpadButton_StickRDown)))
|
||||||
|
@ -443,9 +464,35 @@ static void waitForUsb(void)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void generateDumpTxt(void)
|
||||||
|
{
|
||||||
|
*txt_info = '\0';
|
||||||
|
|
||||||
|
struct tm ts = {0};
|
||||||
|
struct timespec now = {0};
|
||||||
|
|
||||||
|
/* Get current time with nanosecond precision. */
|
||||||
|
clock_gettime(CLOCK_REALTIME, &now);
|
||||||
|
|
||||||
|
/* Get UTC time. */
|
||||||
|
gmtime_r(&(now.tv_sec), &ts);
|
||||||
|
ts.tm_year += 1900;
|
||||||
|
ts.tm_mon++;
|
||||||
|
|
||||||
|
/* Generate dump text. */
|
||||||
|
snprintf(txt_info, MAX_ELEMENTS(txt_info), "dump info:\r\n" \
|
||||||
|
"tool: nxdumptool\r\n" \
|
||||||
|
"version: " APP_VERSION "\r\n" \
|
||||||
|
"branch: " GIT_BRANCH "\r\n" \
|
||||||
|
"commit: " GIT_COMMIT "\r\n" \
|
||||||
|
"build date: " __DATE__ " - " __TIME__ "\r\n" \
|
||||||
|
"dump date: %d-%02d-%02d %02d:%02d:%02d.%03lu UTC+0\r\n",
|
||||||
|
ts.tm_year, ts.tm_mon, ts.tm_mday, ts.tm_hour, ts.tm_min, ts.tm_sec, now.tv_nsec);
|
||||||
|
}
|
||||||
|
|
||||||
static bool saveFileData(const char *path, void *data, size_t data_size)
|
static bool saveFileData(const char *path, void *data, size_t data_size)
|
||||||
{
|
{
|
||||||
if (!path || !strlen(path) || !data || !data_size)
|
if (!path || !*path || !data || !data_size)
|
||||||
{
|
{
|
||||||
consolePrint("invalid parameters to save file data!\n");
|
consolePrint("invalid parameters to save file data!\n");
|
||||||
return false;
|
return false;
|
||||||
|
@ -485,6 +532,16 @@ static bool saveFileData(const char *path, void *data, size_t data_size)
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static bool saveDumpTxt(void)
|
||||||
|
{
|
||||||
|
if (!*path || !*txt_info) return true;
|
||||||
|
|
||||||
|
path[strlen(path) - 3] = '\0';
|
||||||
|
strcat(path, "txt");
|
||||||
|
|
||||||
|
return saveFileData(path, txt_info, strlen(txt_info));
|
||||||
|
}
|
||||||
|
|
||||||
static bool dumpGameCardSecurityInformation(GameCardSecurityInformation *out)
|
static bool dumpGameCardSecurityInformation(GameCardSecurityInformation *out)
|
||||||
{
|
{
|
||||||
if (!out)
|
if (!out)
|
||||||
|
@ -505,11 +562,6 @@ static bool dumpGameCardSecurityInformation(GameCardSecurityInformation *out)
|
||||||
|
|
||||||
static bool saveGameCardSpecificData(void)
|
static bool saveGameCardSpecificData(void)
|
||||||
{
|
{
|
||||||
if (!waitForGameCard()) return false;
|
|
||||||
if (g_useUsbHost) waitForUsb();
|
|
||||||
|
|
||||||
utilsSetLongRunningProcessState(true);
|
|
||||||
|
|
||||||
GameCardSecurityInformation gc_security_information = {0};
|
GameCardSecurityInformation gc_security_information = {0};
|
||||||
bool success = false;
|
bool success = false;
|
||||||
u32 crc = 0;
|
u32 crc = 0;
|
||||||
|
@ -525,24 +577,16 @@ static bool saveGameCardSpecificData(void)
|
||||||
printf("successfully saved specific data as \"%s\"\n", path);
|
printf("successfully saved specific data as \"%s\"\n", path);
|
||||||
success = true;
|
success = true;
|
||||||
|
|
||||||
|
saveDumpTxt();
|
||||||
|
|
||||||
end:
|
end:
|
||||||
if (filename) free(filename);
|
if (filename) free(filename);
|
||||||
|
|
||||||
utilsSetLongRunningProcessState(false);
|
|
||||||
|
|
||||||
consolePrint("press any button to continue");
|
|
||||||
utilsWaitForButtonPress(0);
|
|
||||||
|
|
||||||
return success;
|
return success;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool saveGameCardCertificate(void)
|
static bool saveGameCardCertificate(void)
|
||||||
{
|
{
|
||||||
if (!waitForGameCard()) return false;
|
|
||||||
if (g_useUsbHost) waitForUsb();
|
|
||||||
|
|
||||||
utilsSetLongRunningProcessState(true);
|
|
||||||
|
|
||||||
FsGameCardCertificate gc_cert = {0};
|
FsGameCardCertificate gc_cert = {0};
|
||||||
bool success = false;
|
bool success = false;
|
||||||
u32 crc = 0;
|
u32 crc = 0;
|
||||||
|
@ -564,24 +608,16 @@ static bool saveGameCardCertificate(void)
|
||||||
printf("successfully saved certificate as \"%s\"\n", path);
|
printf("successfully saved certificate as \"%s\"\n", path);
|
||||||
success = true;
|
success = true;
|
||||||
|
|
||||||
|
saveDumpTxt();
|
||||||
|
|
||||||
end:
|
end:
|
||||||
if (filename) free(filename);
|
if (filename) free(filename);
|
||||||
|
|
||||||
utilsSetLongRunningProcessState(false);
|
|
||||||
|
|
||||||
consolePrint("press any button to continue");
|
|
||||||
utilsWaitForButtonPress(0);
|
|
||||||
|
|
||||||
return success;
|
return success;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool saveGameCardInitialData(void)
|
static bool saveGameCardInitialData(void)
|
||||||
{
|
{
|
||||||
if (!waitForGameCard()) return false;
|
|
||||||
if (g_useUsbHost) waitForUsb();
|
|
||||||
|
|
||||||
utilsSetLongRunningProcessState(true);
|
|
||||||
|
|
||||||
GameCardSecurityInformation gc_security_information = {0};
|
GameCardSecurityInformation gc_security_information = {0};
|
||||||
bool success = false;
|
bool success = false;
|
||||||
u32 crc = 0;
|
u32 crc = 0;
|
||||||
|
@ -597,24 +633,16 @@ static bool saveGameCardInitialData(void)
|
||||||
printf("successfully saved initial data as \"%s\"\n", path);
|
printf("successfully saved initial data as \"%s\"\n", path);
|
||||||
success = true;
|
success = true;
|
||||||
|
|
||||||
|
saveDumpTxt();
|
||||||
|
|
||||||
end:
|
end:
|
||||||
if (filename) free(filename);
|
if (filename) free(filename);
|
||||||
|
|
||||||
utilsSetLongRunningProcessState(false);
|
|
||||||
|
|
||||||
consolePrint("press any button to continue");
|
|
||||||
utilsWaitForButtonPress(0);
|
|
||||||
|
|
||||||
return success;
|
return success;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool saveGameCardIdSet(void)
|
static bool saveGameCardIdSet(void)
|
||||||
{
|
{
|
||||||
if (!waitForGameCard()) return false;
|
|
||||||
if (g_useUsbHost) waitForUsb();
|
|
||||||
|
|
||||||
utilsSetLongRunningProcessState(true);
|
|
||||||
|
|
||||||
FsGameCardIdSet id_set = {0};
|
FsGameCardIdSet id_set = {0};
|
||||||
bool success = false;
|
bool success = false;
|
||||||
u32 crc = 0;
|
u32 crc = 0;
|
||||||
|
@ -630,24 +658,16 @@ static bool saveGameCardIdSet(void)
|
||||||
printf("successfully saved gamecard id set as \"%s\"\n", path);
|
printf("successfully saved gamecard id set as \"%s\"\n", path);
|
||||||
success = true;
|
success = true;
|
||||||
|
|
||||||
|
saveDumpTxt();
|
||||||
|
|
||||||
end:
|
end:
|
||||||
if (filename) free(filename);
|
if (filename) free(filename);
|
||||||
|
|
||||||
utilsSetLongRunningProcessState(false);
|
|
||||||
|
|
||||||
consolePrint("press any button to continue");
|
|
||||||
utilsWaitForButtonPress(0);
|
|
||||||
|
|
||||||
return success;
|
return success;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool saveGameCardImage(void)
|
static bool saveGameCardImage(void)
|
||||||
{
|
{
|
||||||
if (!waitForGameCard()) return false;
|
|
||||||
if (g_useUsbHost) waitForUsb();
|
|
||||||
|
|
||||||
utilsSetLongRunningProcessState(true);
|
|
||||||
|
|
||||||
u64 gc_size = 0;
|
u64 gc_size = 0;
|
||||||
|
|
||||||
ThreadSharedData shared_data = {0};
|
ThreadSharedData shared_data = {0};
|
||||||
|
@ -725,8 +745,10 @@ static bool saveGameCardImage(void)
|
||||||
{
|
{
|
||||||
if (shared_data.read_error || shared_data.write_error) break;
|
if (shared_data.read_error || shared_data.write_error) break;
|
||||||
|
|
||||||
|
struct tm ts = {0};
|
||||||
time_t now = time(NULL);
|
time_t now = time(NULL);
|
||||||
struct tm *ts = localtime(&now);
|
localtime_r(&now, &ts);
|
||||||
|
|
||||||
size_t size = shared_data.data_written;
|
size_t size = shared_data.data_written;
|
||||||
|
|
||||||
utilsScanPads();
|
utilsScanPads();
|
||||||
|
@ -752,11 +774,11 @@ static bool saveGameCardImage(void)
|
||||||
|
|
||||||
btn_cancel_prev_state = btn_cancel_cur_state;
|
btn_cancel_prev_state = btn_cancel_cur_state;
|
||||||
|
|
||||||
if (prev_time == ts->tm_sec || prev_size == size) continue;
|
if (prev_time == ts.tm_sec || prev_size == size) continue;
|
||||||
|
|
||||||
percent = (u8)((size * 100) / shared_data.total_size);
|
percent = (u8)((size * 100) / shared_data.total_size);
|
||||||
|
|
||||||
prev_time = ts->tm_sec;
|
prev_time = ts.tm_sec;
|
||||||
prev_size = size;
|
prev_size = size;
|
||||||
|
|
||||||
printf("%lu / %lu (%u%%) | Time elapsed: %lu\n", size, shared_data.total_size, percent, (now - start));
|
printf("%lu / %lu (%u%%) | Time elapsed: %lu\n", size, shared_data.total_size, percent, (now - start));
|
||||||
|
@ -788,6 +810,8 @@ static bool saveGameCardImage(void)
|
||||||
|
|
||||||
if (g_calcCrc) printf("xci crc: %08X\n", shared_data.xci_crc);
|
if (g_calcCrc) printf("xci crc: %08X\n", shared_data.xci_crc);
|
||||||
|
|
||||||
|
saveDumpTxt();
|
||||||
|
|
||||||
end:
|
end:
|
||||||
if (shared_data.fp)
|
if (shared_data.fp)
|
||||||
{
|
{
|
||||||
|
@ -801,21 +825,11 @@ end:
|
||||||
|
|
||||||
if (filename) free(filename);
|
if (filename) free(filename);
|
||||||
|
|
||||||
utilsSetLongRunningProcessState(false);
|
|
||||||
|
|
||||||
consolePrint("press any button to continue");
|
|
||||||
utilsWaitForButtonPress(0);
|
|
||||||
|
|
||||||
return success;
|
return success;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool saveConsoleLafwBlob(void)
|
static bool saveConsoleLafwBlob(void)
|
||||||
{
|
{
|
||||||
if (!waitForGameCard()) return false;
|
|
||||||
if (g_useUsbHost) waitForUsb();
|
|
||||||
|
|
||||||
utilsSetLongRunningProcessState(true);
|
|
||||||
|
|
||||||
u64 lafw_version = 0;
|
u64 lafw_version = 0;
|
||||||
LotusAsicFirmwareBlob lafw_blob = {0};
|
LotusAsicFirmwareBlob lafw_blob = {0};
|
||||||
bool success = false;
|
bool success = false;
|
||||||
|
@ -843,12 +857,9 @@ static bool saveConsoleLafwBlob(void)
|
||||||
printf("successfully saved lafw blob as \"%s\"\n", path);
|
printf("successfully saved lafw blob as \"%s\"\n", path);
|
||||||
success = true;
|
success = true;
|
||||||
|
|
||||||
|
saveDumpTxt();
|
||||||
|
|
||||||
end:
|
end:
|
||||||
utilsSetLongRunningProcessState(false);
|
|
||||||
|
|
||||||
consolePrint("press any button to continue");
|
|
||||||
utilsWaitForButtonPress(0);
|
|
||||||
|
|
||||||
return success;
|
return success;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -912,8 +912,10 @@ static void nspDump(TitleInfo *title_info)
|
||||||
{
|
{
|
||||||
if (shared_data.error) break;
|
if (shared_data.error) break;
|
||||||
|
|
||||||
|
struct tm ts = {0};
|
||||||
time_t now = time(NULL);
|
time_t now = time(NULL);
|
||||||
struct tm *ts = localtime(&now);
|
localtime_r(&now, &ts);
|
||||||
|
|
||||||
size_t size = shared_data.data_written;
|
size_t size = shared_data.data_written;
|
||||||
|
|
||||||
utilsScanPads();
|
utilsScanPads();
|
||||||
|
@ -937,11 +939,11 @@ static void nspDump(TitleInfo *title_info)
|
||||||
|
|
||||||
btn_cancel_prev_state = btn_cancel_cur_state;
|
btn_cancel_prev_state = btn_cancel_cur_state;
|
||||||
|
|
||||||
if (prev_time == ts->tm_sec || prev_size == size) continue;
|
if (prev_time == ts.tm_sec || prev_size == size) continue;
|
||||||
|
|
||||||
percent = (u8)((size * 100) / shared_data.total_size);
|
percent = (u8)((size * 100) / shared_data.total_size);
|
||||||
|
|
||||||
prev_time = ts->tm_sec;
|
prev_time = ts.tm_sec;
|
||||||
prev_size = size;
|
prev_size = size;
|
||||||
|
|
||||||
consolePrint("%lu / %lu (%u%%) | Time elapsed: %lu\n", size, shared_data.total_size, percent, (now - start));
|
consolePrint("%lu / %lu (%u%%) | Time elapsed: %lu\n", size, shared_data.total_size, percent, (now - start));
|
||||||
|
|
|
@ -609,8 +609,10 @@ int main(int argc, char *argv[])
|
||||||
{
|
{
|
||||||
if (shared_data.read_error || shared_data.write_error) break;
|
if (shared_data.read_error || shared_data.write_error) break;
|
||||||
|
|
||||||
|
struct tm ts = {0};
|
||||||
time_t now = time(NULL);
|
time_t now = time(NULL);
|
||||||
struct tm *ts = localtime(&now);
|
localtime_r(&now, &ts);
|
||||||
|
|
||||||
size_t size = shared_data.data_written;
|
size_t size = shared_data.data_written;
|
||||||
|
|
||||||
utilsScanPads();
|
utilsScanPads();
|
||||||
|
@ -636,11 +638,11 @@ int main(int argc, char *argv[])
|
||||||
|
|
||||||
btn_cancel_prev_state = btn_cancel_cur_state;
|
btn_cancel_prev_state = btn_cancel_cur_state;
|
||||||
|
|
||||||
if (prev_time == ts->tm_sec || prev_size == size) continue;
|
if (prev_time == ts.tm_sec || prev_size == size) continue;
|
||||||
|
|
||||||
percent = (u8)((size * 100) / shared_data.total_size);
|
percent = (u8)((size * 100) / shared_data.total_size);
|
||||||
|
|
||||||
prev_time = ts->tm_sec;
|
prev_time = ts.tm_sec;
|
||||||
prev_size = size;
|
prev_size = size;
|
||||||
|
|
||||||
printf("%lu / %lu (%u%%) | Time elapsed: %lu\n", size, shared_data.total_size, percent, (now - start));
|
printf("%lu / %lu (%u%%) | Time elapsed: %lu\n", size, shared_data.total_size, percent, (now - start));
|
||||||
|
|
|
@ -604,8 +604,10 @@ int main(int argc, char *argv[])
|
||||||
{
|
{
|
||||||
if (shared_data.read_error || shared_data.write_error) break;
|
if (shared_data.read_error || shared_data.write_error) break;
|
||||||
|
|
||||||
|
struct tm ts = {0};
|
||||||
time_t now = time(NULL);
|
time_t now = time(NULL);
|
||||||
struct tm *ts = localtime(&now);
|
localtime_r(&now, &ts);
|
||||||
|
|
||||||
size_t size = shared_data.data_written;
|
size_t size = shared_data.data_written;
|
||||||
|
|
||||||
utilsScanPads();
|
utilsScanPads();
|
||||||
|
@ -631,11 +633,11 @@ int main(int argc, char *argv[])
|
||||||
|
|
||||||
btn_cancel_prev_state = btn_cancel_cur_state;
|
btn_cancel_prev_state = btn_cancel_cur_state;
|
||||||
|
|
||||||
if (prev_time == ts->tm_sec || prev_size == size) continue;
|
if (prev_time == ts.tm_sec || prev_size == size) continue;
|
||||||
|
|
||||||
percent = (u8)((size * 100) / shared_data.total_size);
|
percent = (u8)((size * 100) / shared_data.total_size);
|
||||||
|
|
||||||
prev_time = ts->tm_sec;
|
prev_time = ts.tm_sec;
|
||||||
prev_size = size;
|
prev_size = size;
|
||||||
|
|
||||||
printf("%lu / %lu (%u%%) | Time elapsed: %lu\n", size, shared_data.total_size, percent, (now - start));
|
printf("%lu / %lu (%u%%) | Time elapsed: %lu\n", size, shared_data.total_size, percent, (now - start));
|
||||||
|
|
|
@ -1,2 +1,2 @@
|
||||||
-r requirements.txt
|
-r requirements.txt
|
||||||
comtypes==1.1.9
|
comtypes>=1.1.11
|
||||||
|
|
Loading…
Reference in a new issue