Merge pull request #1517 from colinoflynn/fix_unwrapped_desfireev2

Fix MF-DESFIRE decoding when not using wrapped cmds
This commit is contained in:
Iceman 2021-10-10 18:40:32 +02:00 committed by GitHub
commit d782788e5b
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23

View file

@ -899,13 +899,31 @@ void annotateMfDesfire(char *exp, size_t size, uint8_t *cmd, uint8_t cmdsize) {
snprintf(exp, size, "DELETE FILE"); snprintf(exp, size, "DELETE FILE");
break; break;
case MFDES_AUTHENTICATE: case MFDES_AUTHENTICATE:
snprintf(exp, size, "AUTH NATIVE (keyNo %d)", cmd[pos + 4]); if (cmdsize > 6) {
//Assume wrapped
snprintf(exp, size, "AUTH NATIVE (keyNo %d)", cmd[pos + 4]);
} else {
//Assume unwrapped
snprintf(exp, size, "AUTH NATIVE (keyNo %d)", cmd[pos + 1]);
}
break; // AUTHENTICATE_NATIVE break; // AUTHENTICATE_NATIVE
case MFDES_AUTHENTICATE_ISO: case MFDES_AUTHENTICATE_ISO:
snprintf(exp, size, "AUTH ISO (keyNo %d)", cmd[pos + 4]); if (cmdsize > 6) {
//Assume wrapped
snprintf(exp, size, "AUTH ISO (keyNo %d)", cmd[pos + 4]);
} else {
//Assume unwrapped
snprintf(exp, size, "AUTH ISO (keyNo %d)", cmd[pos + 1]);
}
break; // AUTHENTICATE_STANDARD break; // AUTHENTICATE_STANDARD
case MFDES_AUTHENTICATE_AES: case MFDES_AUTHENTICATE_AES:
snprintf(exp, size, "AUTH AES (keyNo %d)", cmd[pos + 4]); if (cmdsize > 6) {
//Assume wrapped
snprintf(exp, size, "AUTH AES (keyNo %d)", cmd[pos + 4]);
} else {
//Assume unwrapped
snprintf(exp, size, "AUTH AES (keyNo %d)", cmd[pos + 1]);
}
break; break;
case MFDES_AUTHENTICATE_EV2F: case MFDES_AUTHENTICATE_EV2F:
snprintf(exp, size, "AUTH EV2 First"); snprintf(exp, size, "AUTH EV2 First");