fix nfc MFC dump file loading

This commit is contained in:
iceman1001 2023-11-01 23:39:42 +01:00
parent e94be650aa
commit b17f5ef45c

View file

@ -1030,6 +1030,7 @@ int loadFileNFC_safe(const char *preferredName, void *data, size_t maxdatalen, s
udata_t udata = (udata_t)data; udata_t udata = (udata_t)data;
int n = 0; int n = 0;
uint32_t counter = 0;
while (!feof(f)) { while (!feof(f)) {
@ -1052,14 +1053,14 @@ int loadFileNFC_safe(const char *preferredName, void *data, size_t maxdatalen, s
if (str_startswith(line, "uid:")) { if (str_startswith(line, "uid:")) {
if (ft == NFC_DF_MFC) { if (ft == NFC_DF_MFC) {
param_gethex_to_eol(line + 4, 0, udata.mfc->card_info.uid, sizeof(udata.mfc->card_info.uid), &n); // param_gethex_to_eol(line + 4, 0, udata.mfc->card_info.uid, sizeof(udata.mfc->card_info.uid), &n);
} }
continue; continue;
} }
if (str_startswith(line, "atqa:")) { if (str_startswith(line, "atqa:")) {
if (ft == NFC_DF_MFC) { if (ft == NFC_DF_MFC) {
param_gethex_to_eol(line + 5, 0, udata.mfc->card_info.atqa, sizeof(udata.mfc->card_info.atqa), &n); // param_gethex_to_eol(line + 5, 0, udata.mfc->card_info.atqa, sizeof(udata.mfc->card_info.atqa), &n);
} }
continue; continue;
} }
@ -1068,7 +1069,7 @@ int loadFileNFC_safe(const char *preferredName, void *data, size_t maxdatalen, s
if (ft == NFC_DF_MFC) { if (ft == NFC_DF_MFC) {
int sak = 0; int sak = 0;
sscanf(line, "sak: %d", &sak); sscanf(line, "sak: %d", &sak);
udata.mfc->card_info.sak = sak & 0xFF; // udata.mfc->card_info.sak = sak & 0xFF;
} }
continue; continue;
} }
@ -1166,8 +1167,14 @@ int loadFileNFC_safe(const char *preferredName, void *data, size_t maxdatalen, s
int pageno = 0; int pageno = 0;
sscanf(line, "page %d:", &pageno); sscanf(line, "page %d:", &pageno);
if (strcmp(line, "??") == 0) {
PrintAndLogEx(INFO, "Missing data detected in page %i, skipping...", pageno);
continue;
}
char *p = line; char *p = line;
while (*p++ != ':') {}; while (*p++ != ':') {};
p++;
if (ft == NFC_DF_MFU) { if (ft == NFC_DF_MFU) {
param_gethex_to_eol(p, 0, udata.mfu->data + (pageno * MFU_BLOCK_SIZE), MFU_BLOCK_SIZE, &n); param_gethex_to_eol(p, 0, udata.mfu->data + (pageno * MFU_BLOCK_SIZE), MFU_BLOCK_SIZE, &n);
@ -1181,19 +1188,28 @@ int loadFileNFC_safe(const char *preferredName, void *data, size_t maxdatalen, s
int blockno = 0; int blockno = 0;
sscanf(line, "block %d:", &blockno); sscanf(line, "block %d:", &blockno);
if (strcmp(line, "??") == 0) {
PrintAndLogEx(INFO, "Missing data detected in block %i, skipping...", blockno);
continue;
}
char *p = line; char *p = line;
while (*p++ != ':') {}; while (*p++ != ':') {};
p++;
if (ft == NFC_DF_MFC) { if (ft == NFC_DF_MFC) {
param_gethex_to_eol(p, 0, udata.mfc->dump + (blockno * MFBLOCK_SIZE), MFBLOCK_SIZE, &n); uint8_t block[MFBLOCK_SIZE] = {0};
udata.mfc->dumplen += MFBLOCK_SIZE; param_gethex_to_eol(p, 0, block, MFBLOCK_SIZE, &n);
memcpy(&udata.bytes[(blockno * MFBLOCK_SIZE)], block, MFBLOCK_SIZE);
} }
counter += MFBLOCK_SIZE;
continue; continue;
} }
} }
// add header length // add header length
if (ft == NFC_DF_MFC) { if (ft == NFC_DF_MFC) {
*datalen = counter;
} else if (ft == NFC_DF_MFU) { } else if (ft == NFC_DF_MFU) {
*datalen += MFU_DUMP_PREFIX_LENGTH; *datalen += MFU_DUMP_PREFIX_LENGTH;
} }
@ -2725,7 +2741,11 @@ int pm3_load_dump(const char *fn, void **pdump, size_t *dumplen, size_t maxdumpl
nfc_df_e foo = detect_nfc_dump_format(fn, true); nfc_df_e foo = detect_nfc_dump_format(fn, true);
if (foo == NFC_DF_MFC || foo == NFC_DF_MFU) { if (foo == NFC_DF_MFC || foo == NFC_DF_MFU) {
*pdump = calloc(maxdumplen, sizeof(uint8_t)); if (foo == NFC_DF_MFC) {
*pdump = calloc(maxdumplen, sizeof(uint8_t));
} else {
*pdump = calloc(maxdumplen, sizeof(uint8_t));
}
if (*pdump == NULL) { if (*pdump == NULL) {
PrintAndLogEx(WARNING, "Fail, cannot allocate memory"); PrintAndLogEx(WARNING, "Fail, cannot allocate memory");
return PM3_EMALLOC; return PM3_EMALLOC;