X-Git-Url: https://git.zerfleddert.de/cgi-bin/gitweb.cgi/proxmark3-svn/blobdiff_plain/20f9a2a1d54952ed15066c93490f0e8fb0d43b67..664f658650f466eaae758bf01088bbeaeace422f:/common/iso15693tools.c diff --git a/common/iso15693tools.c b/common/iso15693tools.c index ec9c4a5e..26e636ca 100644 --- a/common/iso15693tools.c +++ b/common/iso15693tools.c @@ -12,6 +12,9 @@ #include //#include "iso15693tools.h" +#define POLY 0x8408 + + // The CRC as described in ISO 15693-Part 3-Annex C // v buffer with data // n length @@ -58,10 +61,36 @@ int sprintf(char *str, const char *format, ...); char* Iso15693sprintUID(char *target,uint8_t *uid) { static char tempbuf[2*8+1]=""; if (target==NULL) target=tempbuf; - sprintf(target,"%02hX%02hX%02hX%02hX%02hX%02hX%02hX%02hX", + sprintf(target,"%02X%02X%02X%02X%02X%02X%02X%02X", uid[7],uid[6],uid[5],uid[4],uid[3],uid[2],uid[1],uid[0]); return target; } +uint16_t iclass_crc16(char *data_p, unsigned short length) +{ + unsigned char i; + unsigned int data; + uint16_t crc = 0xffff; + + if (length == 0) + return (~crc); + + do + { + for (i=0, data=(unsigned int)0xff & *data_p++; + i < 8; + i++, data >>= 1) + { + if ((crc & 0x0001) ^ (data & 0x0001)) + crc = (crc >> 1) ^ POLY; + else crc >>= 1; + } + } while (--length); + crc = ~crc; + data = crc; + crc = (crc << 8) | (data >> 8 & 0xff); + crc = crc ^ 0xBC3; + return (crc); +}