mirror of
https://github.com/Proxmark/proxmark3.git
synced 2025-07-12 16:22:59 -07:00
Merge branch 'master' of github.com:merlokk/proxmark3 into 14a_rework3
This commit is contained in:
commit
bed3e4c20d
4 changed files with 97 additions and 9 deletions
|
@ -1698,6 +1698,13 @@ int iso14443a_select_card(byte_t *uid_ptr, iso14a_card_select_t *p_hi14a_card, u
|
||||||
int cascade_level = 0;
|
int cascade_level = 0;
|
||||||
int len;
|
int len;
|
||||||
|
|
||||||
|
// init card struct
|
||||||
|
if(p_hi14a_card) {
|
||||||
|
p_hi14a_card->uidlen = 0;
|
||||||
|
memset(p_hi14a_card->uid, 0, 10);
|
||||||
|
p_hi14a_card->ats_len = 0;
|
||||||
|
}
|
||||||
|
|
||||||
// Broadcast for a card, WUPA (0x52) will force response from all cards in the field
|
// Broadcast for a card, WUPA (0x52) will force response from all cards in the field
|
||||||
ReaderTransmitBitsPar(wupa, 7, NULL, NULL);
|
ReaderTransmitBitsPar(wupa, 7, NULL, NULL);
|
||||||
|
|
||||||
|
@ -1706,8 +1713,6 @@ int iso14443a_select_card(byte_t *uid_ptr, iso14a_card_select_t *p_hi14a_card, u
|
||||||
|
|
||||||
if(p_hi14a_card) {
|
if(p_hi14a_card) {
|
||||||
memcpy(p_hi14a_card->atqa, resp, 2);
|
memcpy(p_hi14a_card->atqa, resp, 2);
|
||||||
p_hi14a_card->uidlen = 0;
|
|
||||||
memset(p_hi14a_card->uid,0,10);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (anticollision) {
|
if (anticollision) {
|
||||||
|
@ -1813,7 +1818,6 @@ int iso14443a_select_card(byte_t *uid_ptr, iso14a_card_select_t *p_hi14a_card, u
|
||||||
|
|
||||||
if(p_hi14a_card) {
|
if(p_hi14a_card) {
|
||||||
p_hi14a_card->sak = sak;
|
p_hi14a_card->sak = sak;
|
||||||
p_hi14a_card->ats_len = 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// non iso14443a compliant tag
|
// non iso14443a compliant tag
|
||||||
|
@ -1909,7 +1913,7 @@ void ReaderIso14443a(UsbCommand *c)
|
||||||
size_t lenbits = c->arg[1] >> 16;
|
size_t lenbits = c->arg[1] >> 16;
|
||||||
uint32_t timeout = c->arg[2];
|
uint32_t timeout = c->arg[2];
|
||||||
uint32_t arg0 = 0;
|
uint32_t arg0 = 0;
|
||||||
byte_t buf[USB_CMD_DATA_SIZE];
|
byte_t buf[USB_CMD_DATA_SIZE] = {0};
|
||||||
uint8_t par[MAX_PARITY_SIZE];
|
uint8_t par[MAX_PARITY_SIZE];
|
||||||
bool cantSELECT = false;
|
bool cantSELECT = false;
|
||||||
|
|
||||||
|
|
|
@ -663,7 +663,7 @@ int CmdHFList(const char *Cmd)
|
||||||
int CmdHFSearch(const char *Cmd){
|
int CmdHFSearch(const char *Cmd){
|
||||||
int ans = 0;
|
int ans = 0;
|
||||||
PrintAndLog("");
|
PrintAndLog("");
|
||||||
ans = CmdHF14AReader("s");
|
ans = CmdHF14AInfo("s");
|
||||||
if (ans > 0) {
|
if (ans > 0) {
|
||||||
PrintAndLog("\nValid ISO14443A Tag Found - Quiting Search\n");
|
PrintAndLog("\nValid ISO14443A Tag Found - Quiting Search\n");
|
||||||
return ans;
|
return ans;
|
||||||
|
|
|
@ -109,7 +109,80 @@ int CmdHF14AList(const char *Cmd)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
int CmdHF14AReader(const char *Cmd)
|
int CmdHF14AReader(const char *Cmd) {
|
||||||
|
uint32_t cm = ISO14A_CONNECT;
|
||||||
|
bool disconnectAfter = false;
|
||||||
|
|
||||||
|
int cmdp = 0;
|
||||||
|
while(param_getchar(Cmd, cmdp) != 0x00) {
|
||||||
|
switch(param_getchar(Cmd, cmdp)) {
|
||||||
|
case 'h':
|
||||||
|
case 'H':
|
||||||
|
PrintAndLog("Usage: hf 14a reader [d] [3]");
|
||||||
|
PrintAndLog(" d drop the signal field after command executed");
|
||||||
|
PrintAndLog(" x just drop the signal field");
|
||||||
|
PrintAndLog(" 3 ISO14443-3 select only (skip RATS)");
|
||||||
|
return 0;
|
||||||
|
case '3':
|
||||||
|
cm |= ISO14A_NO_RATS;
|
||||||
|
break;
|
||||||
|
case 'd':
|
||||||
|
case 'D':
|
||||||
|
disconnectAfter = true;
|
||||||
|
break;
|
||||||
|
case 'x':
|
||||||
|
case 'X':
|
||||||
|
disconnectAfter = true;
|
||||||
|
cm = cm - ISO14A_CONNECT;
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
PrintAndLog("Unknown command.");
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
cmdp++;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!disconnectAfter)
|
||||||
|
cm |= ISO14A_NO_DISCONNECT;
|
||||||
|
|
||||||
|
UsbCommand c = {CMD_READER_ISO_14443a, {cm, 0, 0}};
|
||||||
|
SendCommand(&c);
|
||||||
|
|
||||||
|
if (ISO14A_CONNECT & cm) {
|
||||||
|
UsbCommand resp;
|
||||||
|
WaitForResponse(CMD_ACK,&resp);
|
||||||
|
|
||||||
|
iso14a_card_select_t card;
|
||||||
|
memcpy(&card, (iso14a_card_select_t *)resp.d.asBytes, sizeof(iso14a_card_select_t));
|
||||||
|
|
||||||
|
uint64_t select_status = resp.arg[0]; // 0: couldn't read, 1: OK, with ATS, 2: OK, no ATS, 3: proprietary Anticollision
|
||||||
|
|
||||||
|
if(select_status == 0) {
|
||||||
|
PrintAndLog("iso14443a card select failed");
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
if(select_status == 3) {
|
||||||
|
PrintAndLog("Card doesn't support standard iso14443-3 anticollision");
|
||||||
|
PrintAndLog("ATQA : %02x %02x", card.atqa[1], card.atqa[0]);
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
PrintAndLog(" UID : %s", sprint_hex(card.uid, card.uidlen));
|
||||||
|
PrintAndLog("ATQA : %02x %02x", card.atqa[1], card.atqa[0]);
|
||||||
|
PrintAndLog(" SAK : %02x [%d]", card.sak, resp.arg[0]);
|
||||||
|
if(card.ats_len >= 3) { // a valid ATS consists of at least the length byte (TL) and 2 CRC bytes
|
||||||
|
PrintAndLog(" ATS : %s", sprint_hex(card.ats, card.ats_len));
|
||||||
|
}
|
||||||
|
PrintAndLog("Card is selected. You can now start sending commands");
|
||||||
|
} else {
|
||||||
|
PrintAndLog("Field dropped.");
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
int CmdHF14AInfo(const char *Cmd)
|
||||||
{
|
{
|
||||||
UsbCommand c = {CMD_READER_ISO_14443a, {ISO14A_CONNECT | ISO14A_NO_DISCONNECT, 0, 0}};
|
UsbCommand c = {CMD_READER_ISO_14443a, {ISO14A_CONNECT | ISO14A_NO_DISCONNECT, 0, 0}};
|
||||||
SendCommand(&c);
|
SendCommand(&c);
|
||||||
|
@ -872,8 +945,17 @@ static int waitCmd(uint8_t iSelect) {
|
||||||
|
|
||||||
if (WaitForResponseTimeout(CMD_ACK,&resp,1500)) {
|
if (WaitForResponseTimeout(CMD_ACK,&resp,1500)) {
|
||||||
recv = resp.d.asBytes;
|
recv = resp.d.asBytes;
|
||||||
uint8_t iLen = iSelect ? resp.arg[1] : resp.arg[0];
|
uint8_t iLen = resp.arg[0];
|
||||||
PrintAndLog("received %i octets", iLen);
|
if (iSelect){
|
||||||
|
iLen = resp.arg[1];
|
||||||
|
if (iLen){
|
||||||
|
PrintAndLog("Card selected. UID[%i]:", iLen);
|
||||||
|
} else {
|
||||||
|
PrintAndLog("Can't select card.");
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
PrintAndLog("received %i bytes:", iLen);
|
||||||
|
}
|
||||||
if(!iLen)
|
if(!iLen)
|
||||||
return 1;
|
return 1;
|
||||||
hexout = (char *)malloc(iLen * 3 + 1);
|
hexout = (char *)malloc(iLen * 3 + 1);
|
||||||
|
@ -898,7 +980,8 @@ static command_t CommandTable[] =
|
||||||
{
|
{
|
||||||
{"help", CmdHelp, 1, "This help"},
|
{"help", CmdHelp, 1, "This help"},
|
||||||
{"list", CmdHF14AList, 0, "[Deprecated] List ISO 14443a history"},
|
{"list", CmdHF14AList, 0, "[Deprecated] List ISO 14443a history"},
|
||||||
{"reader", CmdHF14AReader, 0, "Act like an ISO14443 Type A reader"},
|
{"reader", CmdHF14AReader, 0, "Start acting like an ISO14443 Type A reader"},
|
||||||
|
{"info", CmdHF14AInfo, 0, "Reads card and shows information about it"},
|
||||||
{"cuids", CmdHF14ACUIDs, 0, "<n> Collect n>0 ISO14443 Type A UIDs in one go"},
|
{"cuids", CmdHF14ACUIDs, 0, "<n> Collect n>0 ISO14443 Type A UIDs in one go"},
|
||||||
{"sim", CmdHF14ASim, 0, "<UID> -- Simulate ISO 14443a tag"},
|
{"sim", CmdHF14ASim, 0, "<UID> -- Simulate ISO 14443a tag"},
|
||||||
{"snoop", CmdHF14ASnoop, 0, "Eavesdrop ISO 14443 Type A"},
|
{"snoop", CmdHF14ASnoop, 0, "Eavesdrop ISO 14443 Type A"},
|
||||||
|
|
|
@ -43,6 +43,7 @@ int CmdHF14A(const char *Cmd);
|
||||||
int CmdHF14AList(const char *Cmd);
|
int CmdHF14AList(const char *Cmd);
|
||||||
int CmdHF14AMifare(const char *Cmd);
|
int CmdHF14AMifare(const char *Cmd);
|
||||||
int CmdHF14AReader(const char *Cmd);
|
int CmdHF14AReader(const char *Cmd);
|
||||||
|
extern int CmdHF14AInfo(const char *Cmd);
|
||||||
int CmdHF14ASim(const char *Cmd);
|
int CmdHF14ASim(const char *Cmd);
|
||||||
int CmdHF14ASnoop(const char *Cmd);
|
int CmdHF14ASnoop(const char *Cmd);
|
||||||
char* getTagInfo(uint8_t uid);
|
char* getTagInfo(uint8_t uid);
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue