]> git.zerfleddert.de Git - proxmark3-svn/commitdiff
ADD: first try to implement crc-16 for Legic Advant *not working yet* Can't verify it.
authoriceman1001 <iceman@iuse.se>
Tue, 16 Feb 2016 09:44:12 +0000 (10:44 +0100)
committericeman1001 <iceman@iuse.se>
Tue, 16 Feb 2016 09:44:12 +0000 (10:44 +0100)
common/crc16.c
common/crc16.h

index c90eeb558b22cbb5fb6addf37ea90ac0886f145a..9d3f68c9fe9990645d7f188d3f6566964308c33e 100644 (file)
@@ -9,6 +9,7 @@
 #include "crc16.h"
 #define CRC16_POLY_CCITT 0x1021
 #define CRC16_POLY 0x8408
+#define CRC16_POLY_LEGIC 0xB400
 
 unsigned short update_crc16( unsigned short crc, unsigned char c )
 {
@@ -48,6 +49,13 @@ uint16_t crc16_ccitt(uint8_t const *message, int length) {
 uint16_t crc16_ccitt_kermit(uint8_t const *message, int length) {
     return bit_reverse_uint16(crc16(message, length, 0x0000, CRC16_POLY_CCITT));
 }
+
+//ICEMAN: not working yet,
+// This CRC-16 is used in Legic Advant systems. 
+uint16_t crc16_legic(uint8_t const *message, int length, uint16_t inital) {
+       return crc16(message, length, inital, CRC16_POLY_LEGIC);
+}
+
 uint16_t bit_reverse_uint16 (uint16_t value) {
        const uint16_t mask0 = 0x5555;
        const uint16_t mask1 = 0x3333;
index 8eb4befbcf1d7566cf0d7f8f73c370f29080e0ba..d53c7766eb33a2d88435ba5f54393500d6c8c769 100644 (file)
@@ -13,5 +13,6 @@ unsigned short update_crc16(unsigned short crc, unsigned char c);
 uint16_t crc16(uint8_t const *message, int length, uint16_t remainder, uint16_t polynomial);
 uint16_t crc16_ccitt(uint8_t const *message, int length);
 uint16_t crc16_ccitt_kermit(uint8_t const *message, int length);
+uint16_t crc16_legic(uint8_t const *message, int length, uint16_t inital);
 uint16_t bit_reverse_uint16 (uint16_t value);
 #endif
Impressum, Datenschutz