//-----------------------------------------------------------------------------\r
\r
#include "mifarecmd.h"\r
-#include "apps.h"\r
-#include "util.h"\r
-#include "crc.h"\r
-#include "protocols.h"\r
-#include "parity.h"\r
\r
//-----------------------------------------------------------------------------\r
// Select, Authenticate, Read a MIFARE tag. \r
}\r
\r
void MifareCIdent(){\r
- \r
+ #define GEN_1A 1\r
+ #define GEN_1B 2\r
+ #define GEN_2 4\r
// variables\r
- bool isOK = true; \r
- uint8_t receivedAnswer[1] = {0x00};\r
- uint8_t receivedAnswerPar[1] = {0x00};\r
-\r
+ uint8_t isGen = 0;\r
+ uint8_t rec[1] = {0x00};\r
+ uint8_t recpar[1] = {0x00};\r
+ \r
+ // Generation 1 test\r
ReaderTransmitBitsPar(wupC1, 7, NULL, NULL);\r
- if(!ReaderReceive(receivedAnswer, receivedAnswerPar) || (receivedAnswer[0] != 0x0a)) {\r
- isOK = false;\r
- }\r
-\r
+ if(!ReaderReceive(rec, recpar) || (rec[0] != 0x0a)) {\r
+ goto TEST2;\r
+ };\r
+ isGen = GEN_1B;\r
+ \r
ReaderTransmit(wupC2, sizeof(wupC2), NULL);\r
- if(!ReaderReceive(receivedAnswer, receivedAnswerPar) || (receivedAnswer[0] != 0x0a)) {\r
- isOK = false;\r
- }\r
+ if(!ReaderReceive(rec, recpar) || (rec[0] != 0x0a)) {\r
+ goto OUT;\r
+ }; \r
+ isGen = GEN_1A;\r
+ goto OUT;\r
+\r
+TEST2:;\r
+/*\r
+ // Generation 2 test\r
+ struct Crypto1State mpcs = {0, 0};\r
+ struct Crypto1State *pcs = &mpcs;\r
\r
+ // halt previous.\r
+ mifare_classic_halt(NULL, 0);\r
+ \r
+ //select\r
+ if (!iso14443a_select_card(NULL, NULL, NULL, true, 0)) {\r
+ goto OUT;\r
+ };\r
+ \r
+ // MIFARE_CLASSIC_WRITEBLOCK 0xA0\r
+ // ACK 0x0a\r
+ uint16_t len = mifare_sendcmd_short(pcs, 1, 0xA0, 0, rec, recpar, NULL);\r
+ if ((len != 1) || (rec[0] != 0x0A)) { \r
+ isGen = GEN_2; \r
+ };\r
+ */\r
+OUT:;\r
// removed the if, since some magic tags misbehavies and send an answer to it.\r
mifare_classic_halt(NULL, 0);\r
- cmd_send(CMD_ACK,isOK,0,0,0,0);\r
+ cmd_send(CMD_ACK,isGen, 0, 0, 0, 0);\r
}\r
\r
void OnSuccessMagic(){\r