mirror of
https://github.com/Atmosphere-NX/Atmosphere
synced 2025-01-24 07:56:15 +00:00
creport: Further Skeleton Report saving.
This commit is contained in:
parent
92bc396972
commit
b8e0c2855f
4 changed files with 68 additions and 2 deletions
|
@ -19,7 +19,8 @@
|
||||||
"erpt:c": false,
|
"erpt:c": false,
|
||||||
"fatal:u": false,
|
"fatal:u": false,
|
||||||
"fsp-srv": false,
|
"fsp-srv": false,
|
||||||
"ns:dev": false
|
"ns:dev": false,
|
||||||
|
"time:s": true,
|
||||||
},
|
},
|
||||||
"kernel_capabilities": {
|
"kernel_capabilities": {
|
||||||
"kernel_flags": {
|
"kernel_flags": {
|
||||||
|
|
|
@ -1,9 +1,46 @@
|
||||||
|
#include <cstdio>
|
||||||
|
#include <sys/stat.h>
|
||||||
|
#include <sys/types.h>
|
||||||
#include <switch.h>
|
#include <switch.h>
|
||||||
|
|
||||||
#include "creport_crash_report.hpp"
|
#include "creport_crash_report.hpp"
|
||||||
#include "creport_debug_types.hpp"
|
#include "creport_debug_types.hpp"
|
||||||
|
|
||||||
|
void CrashReport::EnsureReportDirectories() {
|
||||||
|
char path[FS_MAX_PATH];
|
||||||
|
strcpy(path, "sdmc:/atmosphere");
|
||||||
|
mkdir(path, S_IRWXU);
|
||||||
|
strcat(path, "/crash reports");
|
||||||
|
mkdir(path, S_IRWXU);
|
||||||
|
strcat(path, "/dumps");
|
||||||
|
mkdir(path, S_IRWXU);
|
||||||
|
}
|
||||||
|
|
||||||
void CrashReport::SaveReport() {
|
void CrashReport::SaveReport() {
|
||||||
/* TODO: Save the report to the SD card. */
|
/* TODO: Save the report to the SD card. */
|
||||||
|
char report_path[FS_MAX_PATH];
|
||||||
|
|
||||||
|
/* Ensure path exists. */
|
||||||
|
EnsureReportDirectories();
|
||||||
|
|
||||||
|
/* Get a timestamp. */
|
||||||
|
u64 timestamp;
|
||||||
|
if (!GetCurrentTime(×tamp)) {
|
||||||
|
timestamp = svcGetSystemTick();
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Open report file. */
|
||||||
|
snprintf(report_path, sizeof(report_path) - 1, "sdmc:/atmosphere/crash reports/%016lx_%016lx.log", timestamp, process_info.title_id),
|
||||||
|
FILE *f_report = fopen(report_path, "w");
|
||||||
|
if (f_report == NULL) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
fprintf(f_report, "Atmosphere Crash Report:\n");
|
||||||
|
|
||||||
|
/* TODO: Actually report about the crash. */
|
||||||
|
|
||||||
|
fclose(f_report);
|
||||||
}
|
}
|
||||||
|
|
||||||
void CrashReport::BuildReport(u64 pid, bool has_extra_info) {
|
void CrashReport::BuildReport(u64 pid, bool has_extra_info) {
|
||||||
|
@ -176,3 +213,26 @@ bool CrashReport::IsAddressReadable(u64 address, u64 size, MemoryInfo *o_mi) {
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool GetCurrentTime(u64 *out) {
|
||||||
|
*out = 0;
|
||||||
|
|
||||||
|
/* Verify that pcv isn't dead. */
|
||||||
|
{
|
||||||
|
Handle dummy;
|
||||||
|
if (R_SUCCEEDED(smRegisterService(&dummy, "time:s", false, 0x20))) {
|
||||||
|
svcCloseHandle(dummy);
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Try to get the current time. */
|
||||||
|
bool success = false;
|
||||||
|
if (R_SUCCEEDED(timeInitialize())) {
|
||||||
|
if (R_SUCCEEDED(timeGetCurrentTime(TimeType_LocalSystemClock, out))) {
|
||||||
|
success = true;
|
||||||
|
}
|
||||||
|
timeExit();
|
||||||
|
}
|
||||||
|
return success;
|
||||||
|
}
|
||||||
|
|
|
@ -90,4 +90,7 @@ class CrashReport {
|
||||||
void ProcessDyingMessage();
|
void ProcessDyingMessage();
|
||||||
void HandleAttachProcess(DebugEventInfo &d);
|
void HandleAttachProcess(DebugEventInfo &d);
|
||||||
void HandleException(DebugEventInfo &d);
|
void HandleException(DebugEventInfo &d);
|
||||||
|
|
||||||
|
void EnsureReportDirectories();
|
||||||
|
bool GetCurrentTime(u64 *out);
|
||||||
};
|
};
|
|
@ -95,6 +95,8 @@ int main(int argc, char **argv) {
|
||||||
/* Try to debug the crashed process. */
|
/* Try to debug the crashed process. */
|
||||||
g_Creport.BuildReport(crashed_pid, argv[1][0] == '1');
|
g_Creport.BuildReport(crashed_pid, argv[1][0] == '1');
|
||||||
if (g_Creport.WasSuccessful()) {
|
if (g_Creport.WasSuccessful()) {
|
||||||
|
g_Creport.SaveReport();
|
||||||
|
|
||||||
if (R_SUCCEEDED(nsdevInitialize())) {
|
if (R_SUCCEEDED(nsdevInitialize())) {
|
||||||
nsdevTerminateProcess(crashed_pid);
|
nsdevTerminateProcess(crashed_pid);
|
||||||
nsdevExit();
|
nsdevExit();
|
||||||
|
|
Loading…
Reference in a new issue