openpcd/openpicc/application/iso14443_layer3a.h

43 lines
1.7 KiB
C

#ifndef ISO14443_LAYER3A_H_
#define ISO14443_LAYER3A_H_
extern void iso14443_layer3a_state_machine (void *pvParameters);
enum ISO14443_STATES {
STARTING_UP, /* Hardware has not been initialized, initialize hardware, go to power-off */
POWERED_OFF, /* Card not in field, wait for PLL lock */
IDLE, /* Card in field and powered, wait for REQA or WUPA */
READY, /* Perform anticollision, wait for select */
ACTIVE, /* Selected */
HALT, /* Card halted and powered, wait for WUPA */
READY_STAR, /* Perform anticollision, wait for select */
ACTIVE_STAR, /* Selected */
ERROR, /* Some unrecoverable error has occured */
};
#include "iso14443.h"
extern const u_int8_t ISO14443A_SHORT_FRAME_REQA[ISO14443A_SHORT_FRAME_COMPARE_LENGTH];
extern const u_int8_t ISO14443A_SHORT_FRAME_WUPA[ISO14443A_SHORT_FRAME_COMPARE_LENGTH];
/******************** TX ************************************/
/* Magic delay, don't know where it comes from */
//#define MAGIC_OFFSET -32
#define MAGIC_OFFSET -10
/* Delay from modulation till detection in SSC_DATA */
#define DETECTION_DELAY 11
/* See fdt_timinig.dia for these values */
#define MAX_TF_FIQ_ENTRY_DELAY 16
#define MAX_TF_FIQ_OVERHEAD 75 /* guesstimate */
extern volatile int fdt_offset;
/* standard derived magic values */
#define ISO14443A_FDT_SLOTLEN 128
#define ISO14443A_FDT_OFFSET_1 84
#define ISO14443A_FDT_OFFSET_0 20
#define ISO14443A_FDT_SHORT_1 (ISO14443A_FDT_SLOTLEN*9 + ISO14443A_FDT_OFFSET_1 +fdt_offset +MAGIC_OFFSET -DETECTION_DELAY)
#define ISO14443A_FDT_SHORT_0 (ISO14443A_FDT_SLOTLEN*9 + ISO14443A_FDT_OFFSET_0 +fdt_offset +MAGIC_OFFSET -DETECTION_DELAY)
extern const iso14443_frame ATQA_FRAME;
#endif /*ISO14443_LAYER3A_H_*/