mirror of
https://github.com/RfidResearchGroup/proxmark3.git
synced 2025-08-21 13:53:55 -07:00
receive_ng in common/
This commit is contained in:
parent
4e31c6110b
commit
cb411ffab4
4 changed files with 59 additions and 74 deletions
|
@ -1563,90 +1563,23 @@ void __attribute__((noreturn)) AppMain(void) {
|
||||||
usb_disable();
|
usb_disable();
|
||||||
usb_enable();
|
usb_enable();
|
||||||
|
|
||||||
UsbCommandNG rx;
|
|
||||||
UsbCommandNGRaw rx_raw;
|
|
||||||
|
|
||||||
for (;;) {
|
for (;;) {
|
||||||
WDT_HIT();
|
WDT_HIT();
|
||||||
|
|
||||||
// Check if there is a usb packet available
|
// Check if there is a usb packet available
|
||||||
if (usb_poll_validate_length()) {
|
if (usb_poll_validate_length()) {
|
||||||
bool error = false;
|
UsbCommandNG rx;
|
||||||
size_t bytes = usb_read_ng((uint8_t *)&rx_raw.pre, sizeof(UsbCommandNGPreamble));
|
if (receive_ng(&rx) == 0) {
|
||||||
if (bytes == sizeof(UsbCommandNGPreamble)) {
|
|
||||||
rx.magic = rx_raw.pre.magic;
|
|
||||||
rx.length = rx_raw.pre.length;
|
|
||||||
rx.cmd = rx_raw.pre.cmd;
|
|
||||||
if (rx.magic == USB_COMMANDNG_PREAMBLE_MAGIC) { // New style NG command
|
|
||||||
if (rx.length > USB_CMD_DATA_SIZE) {
|
|
||||||
Dbprintf("Packet frame with incompatible length: 0x%04x", rx.length);
|
|
||||||
error = true;
|
|
||||||
}
|
|
||||||
if (!error) { // Get the core and variable length payload
|
|
||||||
bytes = usb_read_ng(((uint8_t *)&rx_raw.data), rx.length);
|
|
||||||
if (bytes != rx.length) {
|
|
||||||
Dbprintf("Packet frame error variable part too short? %d/%d", bytes, rx.length);
|
|
||||||
error = true;
|
|
||||||
} else {
|
|
||||||
memcpy(&rx.data, &rx_raw.data, rx.length);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (!error) { // Get the postamble
|
|
||||||
bytes = usb_read_ng(((uint8_t *)&rx_raw.foopost), sizeof(UsbCommandNGPostamble));
|
|
||||||
if (bytes != sizeof(UsbCommandNGPostamble)) {
|
|
||||||
Dbprintf("Packet frame error fetching postamble");
|
|
||||||
error = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (!error) { // Check CRC
|
|
||||||
rx.crc = rx_raw.foopost.crc;
|
|
||||||
uint8_t first, second;
|
|
||||||
compute_crc(CRC_14443_A, (uint8_t *)&rx_raw, sizeof(UsbCommandNGPreamble) + rx.length, &first, &second);
|
|
||||||
if ((first << 8) + second != rx.crc) {
|
|
||||||
Dbprintf("Packet frame CRC error %02X%02X <> %04X", first, second, rx.crc);
|
|
||||||
error = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (!error) {
|
|
||||||
#ifdef WITH_FPC_HOST
|
|
||||||
reply_via_fpc = false;
|
|
||||||
#endif
|
|
||||||
rx.ng = true;
|
|
||||||
UsbPacketReceived(&rx);
|
UsbPacketReceived(&rx);
|
||||||
}
|
|
||||||
} else { // Old style command
|
|
||||||
UsbCommandOLD rx_old;
|
|
||||||
memcpy(&rx_old, &rx_raw.pre, sizeof(UsbCommandNGPreamble));
|
|
||||||
bytes = usb_read_ng(((uint8_t *)&rx_old) + sizeof(UsbCommandNGPreamble), sizeof(UsbCommandOLD) - sizeof(UsbCommandNGPreamble));
|
|
||||||
if (bytes != sizeof(UsbCommandOLD) - sizeof(UsbCommandNGPreamble)) {
|
|
||||||
Dbprintf("Packet frame error var part too short? %d/%d", bytes, sizeof(UsbCommandOLD) - sizeof(UsbCommandNGPreamble));
|
|
||||||
error = true;
|
|
||||||
}
|
|
||||||
if (!error) {
|
|
||||||
#ifdef WITH_FPC_HOST
|
|
||||||
reply_via_fpc = false;
|
|
||||||
#endif
|
|
||||||
rx.ng = false;
|
|
||||||
rx.magic = 0;
|
|
||||||
rx.crc = 0;
|
|
||||||
rx.cmd = rx_old.cmd;
|
|
||||||
rx.oldarg[0] = rx_old.arg[0];
|
|
||||||
rx.oldarg[1] = rx_old.arg[1];
|
|
||||||
rx.oldarg[2] = rx_old.arg[2];
|
|
||||||
rx.length = USB_CMD_DATA_SIZE;
|
|
||||||
memcpy(&rx.data, &rx_old.d, rx.length);
|
|
||||||
UsbPacketReceived(&rx);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
} else {
|
} else {
|
||||||
Dbprintf("Packet frame preamble too short: %d/%d", bytes, sizeof(UsbCommandNGPreamble));
|
Dbprintf("Error in frame reception");
|
||||||
error = true;
|
|
||||||
}
|
|
||||||
// TODO DOEGOX if error, shall we resync ?
|
// TODO DOEGOX if error, shall we resync ?
|
||||||
}
|
}
|
||||||
|
}
|
||||||
#ifdef WITH_FPC_HOST
|
#ifdef WITH_FPC_HOST
|
||||||
// Check if there is a FPC packet available
|
// Check if there is a FPC packet available
|
||||||
// TODO DOEGOX NG packets support here too
|
// TODO DOEGOX NG packets support here too
|
||||||
|
UsbCommandNG rx;
|
||||||
if (usart_readbuffer((uint8_t *)&rx)) {
|
if (usart_readbuffer((uint8_t *)&rx)) {
|
||||||
reply_via_fpc = true;
|
reply_via_fpc = true;
|
||||||
rx.ng = false;
|
rx.ng = false;
|
||||||
|
|
|
@ -222,7 +222,6 @@ void iClass_Clone(uint8_t startblock, uint8_t endblock, uint8_t *data);
|
||||||
void iClass_ReadCheck(uint8_t blockno, uint8_t keytype);
|
void iClass_ReadCheck(uint8_t blockno, uint8_t keytype);
|
||||||
|
|
||||||
// cmd.h
|
// cmd.h
|
||||||
uint8_t cmd_receive(UsbCommandOLD *cmd);
|
|
||||||
uint8_t cmd_send(uint64_t cmd, uint64_t arg0, uint64_t arg1, uint64_t arg2, void *data, size_t len);
|
uint8_t cmd_send(uint64_t cmd, uint64_t arg0, uint64_t arg1, uint64_t arg2, void *data, size_t len);
|
||||||
|
|
||||||
// util.h
|
// util.h
|
||||||
|
|
52
common/cmd.c
52
common/cmd.c
|
@ -127,3 +127,55 @@ uint8_t reply_ng(uint16_t cmd, int16_t status, uint8_t *data, size_t len) {
|
||||||
|
|
||||||
return sendlen;
|
return sendlen;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int16_t receive_ng(UsbCommandNG *rx) {
|
||||||
|
UsbCommandNGRaw rx_raw;
|
||||||
|
size_t bytes = usb_read_ng((uint8_t *)&rx_raw.pre, sizeof(UsbCommandNGPreamble));
|
||||||
|
if (bytes != sizeof(UsbCommandNGPreamble))
|
||||||
|
return PM3_EIO;
|
||||||
|
rx->magic = rx_raw.pre.magic;
|
||||||
|
rx->length = rx_raw.pre.length;
|
||||||
|
rx->cmd = rx_raw.pre.cmd;
|
||||||
|
if (rx->magic == USB_COMMANDNG_PREAMBLE_MAGIC) { // New style NG command
|
||||||
|
if (rx->length > USB_CMD_DATA_SIZE)
|
||||||
|
return PM3_EOVFLOW;
|
||||||
|
// Get the core and variable length payload
|
||||||
|
bytes = usb_read_ng((uint8_t *)&rx_raw.data, rx->length);
|
||||||
|
if (bytes != rx->length)
|
||||||
|
return PM3_EIO;
|
||||||
|
memcpy(rx->data.asBytes, rx_raw.data, rx->length);
|
||||||
|
// Get the postamble
|
||||||
|
bytes = usb_read_ng((uint8_t *)&rx_raw.foopost, sizeof(UsbCommandNGPostamble));
|
||||||
|
if (bytes != sizeof(UsbCommandNGPostamble))
|
||||||
|
return PM3_EIO;
|
||||||
|
// Check CRC
|
||||||
|
rx->crc = rx_raw.foopost.crc;
|
||||||
|
uint8_t first, second;
|
||||||
|
compute_crc(CRC_14443_A, (uint8_t *)&rx_raw, sizeof(UsbCommandNGPreamble) + rx->length, &first, &second);
|
||||||
|
if ((first << 8) + second != rx->crc)
|
||||||
|
return PM3_EIO;
|
||||||
|
#ifdef WITH_FPC_HOST
|
||||||
|
reply_via_fpc = false;
|
||||||
|
#endif
|
||||||
|
rx->ng = true;
|
||||||
|
} else { // Old style command
|
||||||
|
UsbCommandOLD rx_old;
|
||||||
|
memcpy(&rx_old, &rx_raw.pre, sizeof(UsbCommandNGPreamble));
|
||||||
|
bytes = usb_read_ng(((uint8_t *)&rx_old) + sizeof(UsbCommandNGPreamble), sizeof(UsbCommandOLD) - sizeof(UsbCommandNGPreamble));
|
||||||
|
if (bytes != sizeof(UsbCommandOLD) - sizeof(UsbCommandNGPreamble))
|
||||||
|
return PM3_EIO;
|
||||||
|
#ifdef WITH_FPC_HOST
|
||||||
|
reply_via_fpc = false;
|
||||||
|
#endif
|
||||||
|
rx->ng = false;
|
||||||
|
rx->magic = 0;
|
||||||
|
rx->crc = 0;
|
||||||
|
rx->cmd = rx_old.cmd;
|
||||||
|
rx->oldarg[0] = rx_old.arg[0];
|
||||||
|
rx->oldarg[1] = rx_old.arg[1];
|
||||||
|
rx->oldarg[2] = rx_old.arg[2];
|
||||||
|
rx->length = USB_CMD_DATA_SIZE;
|
||||||
|
memcpy(&rx->data, &rx_old.d.asBytes, rx->length);
|
||||||
|
}
|
||||||
|
return PM3_SUCCESS;
|
||||||
|
}
|
||||||
|
|
|
@ -41,6 +41,7 @@
|
||||||
|
|
||||||
uint8_t cmd_send(uint64_t cmd, uint64_t arg0, uint64_t arg1, uint64_t arg2, void *data, size_t len);
|
uint8_t cmd_send(uint64_t cmd, uint64_t arg0, uint64_t arg1, uint64_t arg2, void *data, size_t len);
|
||||||
uint8_t reply_ng(uint16_t cmd, int16_t status, uint8_t *data, size_t len);
|
uint8_t reply_ng(uint16_t cmd, int16_t status, uint8_t *data, size_t len);
|
||||||
|
int16_t receive_ng(UsbCommandNG *rx);
|
||||||
|
|
||||||
#endif // _PROXMARK_CMD_H_
|
#endif // _PROXMARK_CMD_H_
|
||||||
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue