chg: 'trace load' - use fileutils

This commit is contained in:
iceman1001 2020-06-03 12:29:52 +02:00
parent 4683f84991
commit 843ab094bb

View file

@ -427,48 +427,23 @@ static int SanityOfflineCheck( bool useTraceBuffer ){
static int CmdTraceLoad(const char *Cmd) { static int CmdTraceLoad(const char *Cmd) {
FILE *f = NULL;
char filename[FILE_PATH_SIZE]; char filename[FILE_PATH_SIZE];
char cmdp = tolower(param_getchar(Cmd, 0)); char cmdp = tolower(param_getchar(Cmd, 0));
if (strlen(Cmd) < 1 || cmdp == 'h') return usage_trace_load(); if (strlen(Cmd) < 1 || cmdp == 'h') return usage_trace_load();
param_getstr(Cmd, 0, filename, sizeof(filename)); param_getstr(Cmd, 0, filename, sizeof(filename));
if ((f = fopen(filename, "rb")) == NULL) {
PrintAndLogEx(FAILED, "Could not open file " _YELLOW_("%s"), filename);
return PM3_EIO;
}
// get filesize in order to malloc memory
fseek(f, 0, SEEK_END);
long fsize = ftell(f);
fseek(f, 0, SEEK_SET);
if (fsize < 0) {
PrintAndLogEx(FAILED, "error, when getting filesize");
fclose(f);
return PM3_EIO;
}
if (fsize < 4) {
PrintAndLogEx(FAILED, "error, file is too small");
fclose(f);
return PM3_ESOFT;
}
if (g_trace) if (g_trace)
free(g_trace); free(g_trace);
g_traceLen = 0; size_t len = 0;
g_trace = calloc(fsize, sizeof(uint8_t)); if (loadFile_safe(filename, ".trace", (void**)&g_trace, &len) != PM3_SUCCESS) {
if (g_trace == NULL) { PrintAndLogEx(FAILED, "Could not open file " _YELLOW_("%s"), filename);
PrintAndLogEx(FAILED, "Cannot allocate memory for trace"); return PM3_EIO;
fclose(f);
return PM3_EMALLOC;
} }
size_t bytes_read = fread(g_trace, 1, fsize, f); g_traceLen = (long)len;
g_traceLen = bytes_read;
fclose(f);
PrintAndLogEx(SUCCESS, "Recorded Activity (TraceLen = " _YELLOW_("%lu") " bytes) loaded from " _YELLOW_("%s"), g_traceLen, filename); PrintAndLogEx(SUCCESS, "Recorded Activity (TraceLen = " _YELLOW_("%lu") " bytes) loaded from " _YELLOW_("%s"), g_traceLen, filename);
return PM3_SUCCESS; return PM3_SUCCESS;
} }