Always pretend cards are not vulnerable

This commit is contained in:
Davide Depau 2023-10-21 00:41:39 +02:00
parent ba072f16f6
commit 5524dd8af4
2 changed files with 15 additions and 14 deletions

View file

@ -96,17 +96,17 @@ int main(int argc, char *const argv[])
uint8_t defaultKeys[][6] = { uint8_t defaultKeys[][6] = {
{0xff, 0xff, 0xff, 0xff, 0xff, 0xff}, // Default key (first key used by program if no user defined key) {0xff, 0xff, 0xff, 0xff, 0xff, 0xff}, // Default key (first key used by program if no user defined key)
{0xa0, 0xa1, 0xa2, 0xa3, 0xa4, 0xa5}, // NFCForum MAD key {0xa0, 0xa1, 0xa2, 0xa3, 0xa4, 0xa5}, // NFCForum MAD key
{0xd3, 0xf7, 0xd3, 0xf7, 0xd3, 0xf7}, // NFCForum content key // {0xd3, 0xf7, 0xd3, 0xf7, 0xd3, 0xf7}, // NFCForum content key
{0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, // Blank key // {0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, // Blank key
{0xb0, 0xb1, 0xb2, 0xb3, 0xb4, 0xb5}, // {0xb0, 0xb1, 0xb2, 0xb3, 0xb4, 0xb5},
{0x4d, 0x3a, 0x99, 0xc3, 0x51, 0xdd}, // {0x4d, 0x3a, 0x99, 0xc3, 0x51, 0xdd},
{0x1a, 0x98, 0x2c, 0x7e, 0x45, 0x9a}, // {0x1a, 0x98, 0x2c, 0x7e, 0x45, 0x9a},
{0xaa, 0xbb, 0xcc, 0xdd, 0xee, 0xff}, // {0xaa, 0xbb, 0xcc, 0xdd, 0xee, 0xff},
{0x71, 0x4c, 0x5c, 0x88, 0x6e, 0x97}, // {0x71, 0x4c, 0x5c, 0x88, 0x6e, 0x97},
{0x58, 0x7e, 0xe5, 0xf9, 0x35, 0x0f}, // {0x58, 0x7e, 0xe5, 0xf9, 0x35, 0x0f},
{0xa0, 0x47, 0x8c, 0xc3, 0x90, 0x91}, // {0xa0, 0x47, 0x8c, 0xc3, 0x90, 0x91},
{0x53, 0x3c, 0xb6, 0xc7, 0x23, 0xf6}, // {0x53, 0x3c, 0xb6, 0xc7, 0x23, 0xf6},
{0x8f, 0xd0, 0xa4, 0xf2, 0x56, 0xe9} // {0x8f, 0xd0, 0xa4, 0xf2, 0x56, 0xe9}
}; };
@ -143,7 +143,8 @@ int main(int argc, char *const argv[])
switch (ch) { switch (ch) {
case 'P': case 'P':
// Number of probes // Number of probes
if (!(probes = atoi(optarg)) || probes < 1) { probes = atoi(optarg);
if (probes < 0) {
ERR("The number of probes must be a positive number"); ERR("The number of probes must be a positive number");
exit(EXIT_FAILURE); exit(EXIT_FAILURE);
} }
@ -1059,7 +1060,7 @@ int mf_enhanced_auth(int e_sector, int a_sector, mftag t, mfreader r, denonce *d
NtLast = bytes_to_num(Rx, 4) ^ crypto1_word(pcs, bytes_to_num(Rx, 4) ^ t.authuid, 1); NtLast = bytes_to_num(Rx, 4) ^ crypto1_word(pcs, bytes_to_num(Rx, 4) ^ t.authuid, 1);
// Make sure the card is using the known PRNG // Make sure the card is using the known PRNG
if (! validate_prng_nonce(NtLast)) { if (true || ! validate_prng_nonce(NtLast)) {
printf("Card is not vulnerable to nested attack\n"); printf("Card is not vulnerable to nested attack\n");
return -99999; return -99999;
} }

View file

@ -30,7 +30,7 @@
#define DEFAULT_DIST_NR 15 #define DEFAULT_DIST_NR 15
// Default number of probes for a key recovery for one sector // Default number of probes for a key recovery for one sector
#define DEFAULT_PROBES_NR 150 #define DEFAULT_PROBES_NR 1
// Number of sets with 32b keys // Number of sets with 32b keys
#define DEFAULT_SETS_NR 5 #define DEFAULT_SETS_NR 5