2011-06-07 20:35:52 +08:00
|
|
|
//-----------------------------------------------------------------------------
|
|
|
|
// Merlok - June 2011
|
|
|
|
// Gerhard de Koning Gans - May 2008
|
|
|
|
// Hagen Fritsch - June 2010
|
|
|
|
//
|
|
|
|
// This code is licensed to you under the terms of the GNU GPL, version 2 or,
|
|
|
|
// at your option, any later version. See the LICENSE.txt file for the text of
|
|
|
|
// the license.
|
|
|
|
//-----------------------------------------------------------------------------
|
|
|
|
// Routines to support ISO 14443 type A.
|
|
|
|
//-----------------------------------------------------------------------------
|
|
|
|
|
2010-07-13 21:39:30 +08:00
|
|
|
#ifndef __ISO14443A_H
|
|
|
|
#define __ISO14443A_H
|
|
|
|
#include "common.h"
|
2012-07-11 23:52:33 +08:00
|
|
|
#include "mifaresniff.h"
|
2010-07-13 21:39:30 +08:00
|
|
|
|
2011-06-16 22:43:49 +08:00
|
|
|
// mifare reader over DMA buffer (SnoopIso14443a())!!!
|
|
|
|
#define MIFARE_BUFF_OFFSET 3560 // \/ \/ \/
|
|
|
|
// card emulator memory
|
|
|
|
#define EML_RESPONSES 4000
|
|
|
|
#define CARD_MEMORY 6000
|
2012-05-30 11:45:55 +08:00
|
|
|
#define CARD_MEMORY_LEN 4096
|
2011-06-16 22:43:49 +08:00
|
|
|
|
2011-05-31 19:31:20 +08:00
|
|
|
typedef struct nestedVector { uint32_t nt, ks1; } nestedVector;
|
|
|
|
|
2012-07-07 00:19:05 +08:00
|
|
|
typedef struct {
|
|
|
|
enum {
|
|
|
|
DEMOD_UNSYNCD,
|
|
|
|
DEMOD_START_OF_COMMUNICATION,
|
|
|
|
DEMOD_MANCHESTER_D,
|
|
|
|
DEMOD_MANCHESTER_E,
|
|
|
|
DEMOD_MANCHESTER_F,
|
|
|
|
DEMOD_ERROR_WAIT
|
|
|
|
} state;
|
|
|
|
int bitCount;
|
|
|
|
int posCount;
|
|
|
|
int syncBit;
|
|
|
|
int parityBits;
|
|
|
|
uint16_t shiftReg;
|
|
|
|
int buffer;
|
|
|
|
int buff;
|
|
|
|
int samples;
|
|
|
|
int len;
|
|
|
|
enum {
|
|
|
|
SUB_NONE,
|
|
|
|
SUB_FIRST_HALF,
|
|
|
|
SUB_SECOND_HALF
|
|
|
|
} sub;
|
|
|
|
uint8_t *output;
|
|
|
|
} tDemod;
|
|
|
|
|
|
|
|
typedef struct {
|
|
|
|
enum {
|
|
|
|
STATE_UNSYNCD,
|
|
|
|
STATE_START_OF_COMMUNICATION,
|
|
|
|
STATE_MILLER_X,
|
|
|
|
STATE_MILLER_Y,
|
|
|
|
STATE_MILLER_Z,
|
|
|
|
STATE_ERROR_WAIT
|
|
|
|
} state;
|
|
|
|
uint16_t shiftReg;
|
|
|
|
int bitCnt;
|
|
|
|
int byteCnt;
|
|
|
|
int byteCntMax;
|
|
|
|
int posCnt;
|
|
|
|
int syncBit;
|
|
|
|
int parityBits;
|
|
|
|
int samples;
|
|
|
|
int highCnt;
|
|
|
|
int bitBuffer;
|
|
|
|
enum {
|
|
|
|
DROP_NONE,
|
|
|
|
DROP_FIRST_HALF,
|
|
|
|
DROP_SECOND_HALF
|
|
|
|
} drop;
|
|
|
|
uint8_t *output;
|
|
|
|
} tUart;
|
|
|
|
|
|
|
|
|
2011-05-26 20:55:15 +08:00
|
|
|
extern byte_t oddparity (const byte_t bt);
|
|
|
|
extern uint32_t GetParity(const uint8_t * pbtCmd, int iLen);
|
2010-07-13 21:39:30 +08:00
|
|
|
extern void AppendCrc14443a(uint8_t* data, int len);
|
2011-05-26 20:55:15 +08:00
|
|
|
|
2010-07-13 21:39:30 +08:00
|
|
|
extern void ReaderTransmitShort(const uint8_t* bt);
|
|
|
|
extern void ReaderTransmit(uint8_t* frame, int len);
|
2011-05-26 20:55:15 +08:00
|
|
|
extern void ReaderTransmitPar(uint8_t* frame, int len, uint32_t par);
|
2010-07-13 21:39:30 +08:00
|
|
|
extern int ReaderReceive(uint8_t* receivedAnswer);
|
2011-05-31 19:31:20 +08:00
|
|
|
extern int ReaderReceivePar(uint8_t* receivedAnswer, uint32_t * parptr);
|
2011-05-26 20:55:15 +08:00
|
|
|
|
2010-07-13 21:39:30 +08:00
|
|
|
extern void iso14443a_setup();
|
2012-08-25 05:00:03 +08:00
|
|
|
extern int iso14_apdu(uint8_t * cmd, size_t cmd_len, void * data);
|
2011-05-26 20:55:15 +08:00
|
|
|
extern int iso14443a_select_card(uint8_t * uid_ptr, iso14a_card_select_t * resp_data, uint32_t * cuid_ptr);
|
2012-12-05 07:39:18 +08:00
|
|
|
extern void iso14a_set_trigger(bool enable);
|
2012-08-25 05:00:03 +08:00
|
|
|
extern void iso14a_set_timeout(uint32_t timeout);
|
2010-07-13 21:39:30 +08:00
|
|
|
|
2012-12-05 07:39:18 +08:00
|
|
|
extern void iso14a_clear_tracelen();
|
|
|
|
extern void iso14a_set_tracing(bool enable);
|
2011-06-18 02:39:54 +08:00
|
|
|
|
2010-07-13 21:39:30 +08:00
|
|
|
#endif /* __ISO14443A_H */
|