//-----------------------------------------------------------------------------\r
// code for work with mifare cards.\r
//-----------------------------------------------------------------------------\r
+#ifndef __MIFAREUTIL_H\r
+#define __MIFAREUTIL_H\r
\r
#define CRYPT_NONE 0\r
#define CRYPT_ALL 1\r
#define AUTH_FIRST 0\r
#define AUTH_NESTED 2\r
\r
+// debug\r
+// 0 - no debug messages 1 - error messages 2 - all messages 4 - extended debug mode\r
+#define MF_DBG_NONE 0\r
+#define MF_DBG_ERROR 1\r
+#define MF_DBG_ALL 2\r
+#define MF_DBG_EXTENDED 4\r
+\r
+extern int MF_DBGLEVEL;\r
+\r
+//mifare nested\r
+#define MEM_CHUNK 10000\r
+#define TRY_KEYS 50\r
+#define NS_TOLERANCE 10 // [distance avg-value, distance avg+value]\r
+#define NS_RETRIES_GETNONCE 15\r
+#define NES_MAX_INFO 5\r
+\r
+//mifare emulate states\r
+#define MFEMUL_NOFIELD 0\r
+#define MFEMUL_IDLE 1\r
+#define MFEMUL_SELECT1 2\r
+#define MFEMUL_SELECT2 3\r
+#define MFEMUL_AUTH1 4\r
+#define MFEMUL_AUTH2 5\r
+#define MFEMUL_HALTED 6\r
+\r
+//functions\r
uint8_t* mifare_get_bigbufptr(void);\r
int mifare_sendcmd_short(struct Crypto1State *pcs, uint8_t crypted, uint8_t cmd, uint8_t data, uint8_t* answer);\r
int mifare_sendcmd_shortex(struct Crypto1State *pcs, uint8_t crypted, uint8_t cmd, uint8_t data, uint8_t* answer, uint32_t * parptr);\r
int mifare_classic_writeblock(struct Crypto1State *pcs, uint32_t uid, uint8_t blockNo, uint8_t *blockData);\r
int mifare_classic_halt(struct Crypto1State *pcs, uint32_t uid); \r
\r
+#endif
\ No newline at end of file