mirror of
https://github.com/RfidResearchGroup/proxmark3.git
synced 2025-08-21 22:03:42 -07:00
text
This commit is contained in:
parent
49ba544190
commit
8ddf03b302
1 changed files with 28 additions and 34 deletions
|
@ -101,7 +101,7 @@ static bool sendPing(void){
|
||||||
static bool sendTry(uint8_t fmtlen, uint32_t fc, uint32_t cn, uint32_t delay, uint8_t *bits, size_t bs_len, bool verbose){
|
static bool sendTry(uint8_t fmtlen, uint32_t fc, uint32_t cn, uint32_t delay, uint8_t *bits, size_t bs_len, bool verbose){
|
||||||
|
|
||||||
if ( verbose )
|
if ( verbose )
|
||||||
PrintAndLogEx(NORMAL, "Trying FC: %u; CN: %u", fc, cn);
|
PrintAndLogEx(INFO, "Trying FC: %u; CN: %u", fc, cn);
|
||||||
|
|
||||||
if ( !getAWIDBits(fmtlen, fc, cn, bits)) {
|
if ( !getAWIDBits(fmtlen, fc, cn, bits)) {
|
||||||
PrintAndLogEx(WARNING, "Error with tag bitstream generation.");
|
PrintAndLogEx(WARNING, "Error with tag bitstream generation.");
|
||||||
|
@ -171,7 +171,7 @@ int getAWIDBits(uint8_t fmtlen, uint32_t fc, uint32_t cn, uint8_t *bits) {
|
||||||
|
|
||||||
if (bitLen != 88) return 0;
|
if (bitLen != 88) return 0;
|
||||||
|
|
||||||
PrintAndLogEx(NORMAL, "awid raw bits:\n %s \n", sprint_bin(bits, bitLen));
|
PrintAndLogEx(SUCCESS, "awid raw bits:\n %s \n", sprint_bin(bits, bitLen));
|
||||||
|
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
@ -181,27 +181,27 @@ static void verify_values(uint8_t *fmtlen, uint32_t *fc, uint32_t *cn){
|
||||||
case 50:
|
case 50:
|
||||||
if ((*fc & 0xFFFF) != *fc) {
|
if ((*fc & 0xFFFF) != *fc) {
|
||||||
*fc &= 0xFFFF;
|
*fc &= 0xFFFF;
|
||||||
PrintAndLogEx(NORMAL, "Facility-Code Truncated to 16-bits (AWID50): %u", *fc);
|
PrintAndLogEx(INFO, "Facility-Code Truncated to 16-bits (AWID50): %u", *fc);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 37:
|
case 37:
|
||||||
if ((*fc & 0x1FFF) != *fc) {
|
if ((*fc & 0x1FFF) != *fc) {
|
||||||
*fc &= 0x1FFF;
|
*fc &= 0x1FFF;
|
||||||
PrintAndLogEx(NORMAL, "Facility-Code Truncated to 13-bits (AWID37): %u", *fc);
|
PrintAndLogEx(INFO, "Facility-Code Truncated to 13-bits (AWID37): %u", *fc);
|
||||||
}
|
}
|
||||||
if ((*cn & 0x3FFFF) != *cn) {
|
if ((*cn & 0x3FFFF) != *cn) {
|
||||||
*cn &= 0x3FFFF;
|
*cn &= 0x3FFFF;
|
||||||
PrintAndLogEx(NORMAL, "Card Number Truncated to 18-bits (AWID37): %u", *cn);
|
PrintAndLogEx(INFO, "Card Number Truncated to 18-bits (AWID37): %u", *cn);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 34:
|
case 34:
|
||||||
if ((*fc & 0xFF) != *fc) {
|
if ((*fc & 0xFF) != *fc) {
|
||||||
*fc &= 0xFF;
|
*fc &= 0xFF;
|
||||||
PrintAndLogEx(NORMAL, "Facility-Code Truncated to 8-bits (AWID34): %u", *fc);
|
PrintAndLogEx(INFO, "Facility-Code Truncated to 8-bits (AWID34): %u", *fc);
|
||||||
}
|
}
|
||||||
if ((*cn & 0xFFFFFF) != *cn) {
|
if ((*cn & 0xFFFFFF) != *cn) {
|
||||||
*cn &= 0xFFFFFF;
|
*cn &= 0xFFFFFF;
|
||||||
PrintAndLogEx(NORMAL, "Card Number Truncated to 24-bits (AWID34): %u", *cn);
|
PrintAndLogEx(INFO, "Card Number Truncated to 24-bits (AWID34): %u", *cn);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 26:
|
case 26:
|
||||||
|
@ -209,11 +209,11 @@ static void verify_values(uint8_t *fmtlen, uint32_t *fc, uint32_t *cn){
|
||||||
*fmtlen = 26;
|
*fmtlen = 26;
|
||||||
if ((*fc & 0xFF) != *fc) {
|
if ((*fc & 0xFF) != *fc) {
|
||||||
*fc &= 0xFF;
|
*fc &= 0xFF;
|
||||||
PrintAndLogEx(NORMAL, "Facility-Code Truncated to 8-bits (AWID26): %u", *fc);
|
PrintAndLogEx(INFO, "Facility-Code Truncated to 8-bits (AWID26): %u", *fc);
|
||||||
}
|
}
|
||||||
if ((*cn & 0xFFFF) != *cn) {
|
if ((*cn & 0xFFFF) != *cn) {
|
||||||
*cn &= 0xFFFF;
|
*cn &= 0xFFFF;
|
||||||
PrintAndLogEx(NORMAL, "Card Number Truncated to 16-bits (AWID26): %u", *cn);
|
PrintAndLogEx(INFO, "Card Number Truncated to 16-bits (AWID26): %u", *cn);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -323,21 +323,21 @@ int CmdAWIDDemod(const char *Cmd) {
|
||||||
fc = bytebits_to_byte(bits + 9, 8);
|
fc = bytebits_to_byte(bits + 9, 8);
|
||||||
cardnum = bytebits_to_byte(bits + 17, 16);
|
cardnum = bytebits_to_byte(bits + 17, 16);
|
||||||
code1 = bytebits_to_byte(bits + 8,fmtLen);
|
code1 = bytebits_to_byte(bits + 8,fmtLen);
|
||||||
PrintAndLogEx(NORMAL, "AWID Found - BitLength: %d, FC: %d, Card: %u - Wiegand: %x, Raw: %08x%08x%08x", fmtLen, fc, cardnum, code1, rawHi2, rawHi, rawLo);
|
PrintAndLogEx(SUCCESS, "AWID Found - BitLength: %d, FC: %d, Card: %u - Wiegand: %x, Raw: %08x%08x%08x", fmtLen, fc, cardnum, code1, rawHi2, rawHi, rawLo);
|
||||||
break;
|
break;
|
||||||
case 34:
|
case 34:
|
||||||
fc = bytebits_to_byte(bits + 9, 8);
|
fc = bytebits_to_byte(bits + 9, 8);
|
||||||
cardnum = bytebits_to_byte(bits + 17, 24);
|
cardnum = bytebits_to_byte(bits + 17, 24);
|
||||||
code1 = bytebits_to_byte(bits + 8, (fmtLen-32) );
|
code1 = bytebits_to_byte(bits + 8, (fmtLen-32) );
|
||||||
code2 = bytebits_to_byte(bits + 8 + (fmtLen-32), 32);
|
code2 = bytebits_to_byte(bits + 8 + (fmtLen-32), 32);
|
||||||
PrintAndLogEx(NORMAL, "AWID Found - BitLength: %d, FC: %d, Card: %u - Wiegand: %x%08x, Raw: %08x%08x%08x", fmtLen, fc, cardnum, code1, code2, rawHi2, rawHi, rawLo);
|
PrintAndLogEx(SUCCESS, "AWID Found - BitLength: %d, FC: %d, Card: %u - Wiegand: %x%08x, Raw: %08x%08x%08x", fmtLen, fc, cardnum, code1, code2, rawHi2, rawHi, rawLo);
|
||||||
break;
|
break;
|
||||||
case 37:
|
case 37:
|
||||||
fc = bytebits_to_byte(bits + 9, 13);
|
fc = bytebits_to_byte(bits + 9, 13);
|
||||||
cardnum = bytebits_to_byte(bits + 22, 18);
|
cardnum = bytebits_to_byte(bits + 22, 18);
|
||||||
code1 = bytebits_to_byte(bits + 8, (fmtLen-32) );
|
code1 = bytebits_to_byte(bits + 8, (fmtLen-32) );
|
||||||
code2 = bytebits_to_byte(bits + 8 + (fmtLen-32), 32);
|
code2 = bytebits_to_byte(bits + 8 + (fmtLen-32), 32);
|
||||||
PrintAndLogEx(NORMAL, "AWID Found - BitLength: %d, FC: %d, Card: %u - Wiegand: %x%08x, Raw: %08x%08x%08x", fmtLen, fc, cardnum, code1, code2, rawHi2, rawHi, rawLo);
|
PrintAndLogEx(SUCCESS, "AWID Found - BitLength: %d, FC: %d, Card: %u - Wiegand: %x%08x, Raw: %08x%08x%08x", fmtLen, fc, cardnum, code1, code2, rawHi2, rawHi, rawLo);
|
||||||
break;
|
break;
|
||||||
// case 40:
|
// case 40:
|
||||||
// break;
|
// break;
|
||||||
|
@ -346,18 +346,18 @@ int CmdAWIDDemod(const char *Cmd) {
|
||||||
cardnum = bytebits_to_byte(bits + 25, 32);
|
cardnum = bytebits_to_byte(bits + 25, 32);
|
||||||
code1 = bytebits_to_byte(bits + 8, (fmtLen-32) );
|
code1 = bytebits_to_byte(bits + 8, (fmtLen-32) );
|
||||||
code2 = bytebits_to_byte(bits + 8 + (fmtLen-32), 32);
|
code2 = bytebits_to_byte(bits + 8 + (fmtLen-32), 32);
|
||||||
PrintAndLogEx(NORMAL, "AWID Found - BitLength: %d, FC: %d, Card: %u - Wiegand: %x%08x, Raw: %08x%08x%08x", fmtLen, fc, cardnum, code1, code2, rawHi2, rawHi, rawLo);
|
PrintAndLogEx(SUCCESS, "AWID Found - BitLength: %d, FC: %d, Card: %u - Wiegand: %x%08x, Raw: %08x%08x%08x", fmtLen, fc, cardnum, code1, code2, rawHi2, rawHi, rawLo);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
if (fmtLen > 32 ) {
|
if (fmtLen > 32 ) {
|
||||||
cardnum = bytebits_to_byte(bits + 8 + (fmtLen-17), 16);
|
cardnum = bytebits_to_byte(bits + 8 + (fmtLen-17), 16);
|
||||||
code1 = bytebits_to_byte(bits + 8, fmtLen-32);
|
code1 = bytebits_to_byte(bits + 8, fmtLen-32);
|
||||||
code2 = bytebits_to_byte(bits + 8 + (fmtLen-32), 32);
|
code2 = bytebits_to_byte(bits + 8 + (fmtLen-32), 32);
|
||||||
PrintAndLogEx(NORMAL, "AWID Found - BitLength: %d -unknown BitLength- (%u) - Wiegand: %x%08x, Raw: %08x%08x%08x", fmtLen, cardnum, code1, code2, rawHi2, rawHi, rawLo);
|
PrintAndLogEx(SUCCESS, "AWID Found - BitLength: %d -unknown BitLength- (%u) - Wiegand: %x%08x, Raw: %08x%08x%08x", fmtLen, cardnum, code1, code2, rawHi2, rawHi, rawLo);
|
||||||
} else {
|
} else {
|
||||||
cardnum = bytebits_to_byte(bits + 8 + (fmtLen-17), 16);
|
cardnum = bytebits_to_byte(bits + 8 + (fmtLen-17), 16);
|
||||||
code1 = bytebits_to_byte(bits + 8, fmtLen);
|
code1 = bytebits_to_byte(bits + 8, fmtLen);
|
||||||
PrintAndLogEx(NORMAL, "AWID Found - BitLength: %d -unknown BitLength- (%u) - Wiegand: %x, Raw: %08x%08x%08x", fmtLen, cardnum, code1, rawHi2, rawHi, rawLo);
|
PrintAndLogEx(SUCCESS, "AWID Found - BitLength: %d -unknown BitLength- (%u) - Wiegand: %x, Raw: %08x%08x%08x", fmtLen, cardnum, code1, rawHi2, rawHi, rawLo);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -386,8 +386,8 @@ int CmdAWIDSim(const char *Cmd) {
|
||||||
|
|
||||||
verify_values(&fmtlen, &fc, &cn);
|
verify_values(&fmtlen, &fc, &cn);
|
||||||
|
|
||||||
PrintAndLogEx(NORMAL, "Emulating AWID %u -- FC: %u; CN: %u\n", fmtlen, fc, cn);
|
PrintAndLogEx(SUCCESS, "Emulating AWID %u -- FC: %u; CN: %u\n", fmtlen, fc, cn);
|
||||||
PrintAndLogEx(NORMAL, "Press pm3-button to abort simulation or run another command");
|
PrintAndLogEx(SUCCESS, "Press pm3-button to abort simulation or run another command");
|
||||||
|
|
||||||
if (!getAWIDBits(fmtlen, fc, cn, bits)) {
|
if (!getAWIDBits(fmtlen, fc, cn, bits)) {
|
||||||
PrintAndLogEx(WARNING, "Error with tag bitstream generation.");
|
PrintAndLogEx(WARNING, "Error with tag bitstream generation.");
|
||||||
|
@ -417,8 +417,8 @@ int CmdAWIDClone(const char *Cmd) {
|
||||||
uint8_t *bs=bits;
|
uint8_t *bs=bits;
|
||||||
memset(bs,0,sizeof(bits));
|
memset(bs,0,sizeof(bits));
|
||||||
|
|
||||||
char cmdp = param_getchar(Cmd, 0);
|
char cmdp = tolower(param_getchar(Cmd, 0));
|
||||||
if (strlen(Cmd) == 0 || cmdp == 'h' || cmdp == 'H') return usage_lf_awid_clone();
|
if (strlen(Cmd) == 0 || cmdp == 'h') return usage_lf_awid_clone();
|
||||||
|
|
||||||
fmtlen = param_get8(Cmd, 0);
|
fmtlen = param_get8(Cmd, 0);
|
||||||
fc = param_get32ex(Cmd, 1, 0, 10);
|
fc = param_get32ex(Cmd, 1, 0, 10);
|
||||||
|
@ -426,7 +426,7 @@ int CmdAWIDClone(const char *Cmd) {
|
||||||
|
|
||||||
if ( !fc || !cn) return usage_lf_awid_clone();
|
if ( !fc || !cn) return usage_lf_awid_clone();
|
||||||
|
|
||||||
if (param_getchar(Cmd, 3) == 'Q' || param_getchar(Cmd, 3) == 'q')
|
if (tolower(param_getchar(Cmd, 3)) == 'q')
|
||||||
//t5555 (Q5) BITRATE = (RF-2)/2 (iceman)
|
//t5555 (Q5) BITRATE = (RF-2)/2 (iceman)
|
||||||
blocks[0] = T5555_MODULATION_FSK2 | T5555_INVERT_OUTPUT | T5555_SET_BITRATE(50) | 3<<T5555_MAXBLOCK_SHIFT;
|
blocks[0] = T5555_MODULATION_FSK2 | T5555_INVERT_OUTPUT | T5555_SET_BITRATE(50) | 3<<T5555_MAXBLOCK_SHIFT;
|
||||||
|
|
||||||
|
@ -441,7 +441,7 @@ int CmdAWIDClone(const char *Cmd) {
|
||||||
blocks[2] = bytebits_to_byte(bs + 32, 32);
|
blocks[2] = bytebits_to_byte(bs + 32, 32);
|
||||||
blocks[3] = bytebits_to_byte(bs + 64, 32);
|
blocks[3] = bytebits_to_byte(bs + 64, 32);
|
||||||
|
|
||||||
PrintAndLogEx(NORMAL, "Preparing to clone AWID %u to T55x7 with FC: %u, CN: %u", fmtlen, fc, cn);
|
PrintAndLogEx(INFO, "Preparing to clone AWID %u to T55x7 with FC: %u, CN: %u", fmtlen, fc, cn);
|
||||||
print_blocks(blocks, 4);
|
print_blocks(blocks, 4);
|
||||||
|
|
||||||
UsbCommand resp;
|
UsbCommand resp;
|
||||||
|
@ -470,38 +470,32 @@ int CmdAWIDBrute(const char *Cmd) {
|
||||||
memset(bits, 0x00, size);
|
memset(bits, 0x00, size);
|
||||||
uint8_t cmdp = 0;
|
uint8_t cmdp = 0;
|
||||||
|
|
||||||
while(param_getchar(Cmd, cmdp) != 0x00 && !errors) {
|
while (param_getchar(Cmd, cmdp) != 0x00 && !errors) {
|
||||||
switch(param_getchar(Cmd, cmdp)) {
|
switch ( tolower(param_getchar(Cmd, cmdp))) {
|
||||||
case 'h':
|
case 'h':
|
||||||
case 'H':
|
|
||||||
return usage_lf_awid_brute();
|
return usage_lf_awid_brute();
|
||||||
case 'f':
|
case 'f':
|
||||||
case 'F':
|
|
||||||
fc = param_get32ex(Cmd ,cmdp+1, 0, 10);
|
fc = param_get32ex(Cmd ,cmdp+1, 0, 10);
|
||||||
if ( !fc )
|
if ( !fc )
|
||||||
errors = true;
|
errors = true;
|
||||||
cmdp += 2;
|
cmdp += 2;
|
||||||
break;
|
break;
|
||||||
case 'd':
|
case 'd':
|
||||||
case 'D':
|
|
||||||
// delay between attemps, defaults to 1000ms.
|
// delay between attemps, defaults to 1000ms.
|
||||||
delay = param_get32ex(Cmd, cmdp+1, 1000, 10);
|
delay = param_get32ex(Cmd, cmdp+1, 1000, 10);
|
||||||
cmdp += 2;
|
cmdp += 2;
|
||||||
break;
|
break;
|
||||||
case 'c':
|
case 'c':
|
||||||
case 'C':
|
|
||||||
cn = param_get32ex(Cmd, cmdp+1, 0, 10);
|
cn = param_get32ex(Cmd, cmdp+1, 0, 10);
|
||||||
// truncate cardnumber.
|
// truncate cardnumber.
|
||||||
cn &= 0xFFFF;
|
cn &= 0xFFFF;
|
||||||
cmdp += 2;
|
cmdp += 2;
|
||||||
break;
|
break;
|
||||||
case 'a':
|
case 'a':
|
||||||
case 'A':
|
|
||||||
fmtlen = param_get8(Cmd, cmdp+1);
|
fmtlen = param_get8(Cmd, cmdp+1);
|
||||||
cmdp += 2;
|
cmdp += 2;
|
||||||
break;
|
break;
|
||||||
case 'v':
|
case 'v':
|
||||||
case 'V':
|
|
||||||
verbose = true;
|
verbose = true;
|
||||||
cmdp++;
|
cmdp++;
|
||||||
break;
|
break;
|
||||||
|
@ -511,7 +505,7 @@ int CmdAWIDBrute(const char *Cmd) {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if ( fc == 0 )errors = true;
|
if ( fc == 0 ) errors = true;
|
||||||
if ( errors ) return usage_lf_awid_brute();
|
if ( errors ) return usage_lf_awid_brute();
|
||||||
|
|
||||||
// limit fc according to selected format
|
// limit fc according to selected format
|
||||||
|
@ -519,19 +513,19 @@ int CmdAWIDBrute(const char *Cmd) {
|
||||||
case 50:
|
case 50:
|
||||||
if ((fc & 0xFFFF) != fc) {
|
if ((fc & 0xFFFF) != fc) {
|
||||||
fc &= 0xFFFF;
|
fc &= 0xFFFF;
|
||||||
PrintAndLogEx(NORMAL, "Facility-code truncated to 16-bits (AWID50): %u", fc);
|
PrintAndLogEx(INFO, "Facility-code truncated to 16-bits (AWID50): %u", fc);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
if ((fc & 0xFF) != fc) {
|
if ((fc & 0xFF) != fc) {
|
||||||
fc &= 0xFF;
|
fc &= 0xFF;
|
||||||
PrintAndLogEx(NORMAL, "Facility-code truncated to 8-bits (AWID26): %u", fc);
|
PrintAndLogEx(INFO, "Facility-code truncated to 8-bits (AWID26): %u", fc);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
PrintAndLogEx(NORMAL, "Bruteforceing AWID %d Reader", fmtlen);
|
PrintAndLogEx(SUCCESS, "Bruteforceing AWID %d Reader", fmtlen);
|
||||||
PrintAndLogEx(NORMAL, "Press pm3-button to abort simulation or press key");
|
PrintAndLogEx(SUCCESS, "Press pm3-button to abort simulation or press key");
|
||||||
|
|
||||||
uint16_t up = cn;
|
uint16_t up = cn;
|
||||||
uint16_t down = cn;
|
uint16_t down = cn;
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue