mirror of
https://github.com/RfidResearchGroup/proxmark3.git
synced 2025-01-10 10:11:58 +08:00
chg: 'trace load' - use fileutils
This commit is contained in:
parent
4683f84991
commit
843ab094bb
1 changed files with 7 additions and 32 deletions
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue