2009-04-09 14:43:20 +08:00
|
|
|
//-----------------------------------------------------------------------------
|
|
|
|
// Definitions internal to the app source.
|
|
|
|
// Jonathan Westhues, Aug 2005
|
|
|
|
// Added ISO14443-A support by Gerhard de Koning Gans, April 2008
|
|
|
|
//-----------------------------------------------------------------------------
|
|
|
|
|
|
|
|
#ifndef __APPS_H
|
|
|
|
#define __APPS_H
|
|
|
|
|
2009-12-30 08:11:50 +08:00
|
|
|
#include "stdint.h"
|
|
|
|
#include "stddef.h"
|
|
|
|
typedef unsigned char byte_t;
|
|
|
|
|
2009-07-25 19:47:43 +08:00
|
|
|
// The large multi-purpose buffer, typically used to hold A/D samples,
|
|
|
|
// maybe processed in some way.
|
2009-08-06 20:53:06 +08:00
|
|
|
DWORD BigBuf[12000];
|
2009-07-25 19:47:43 +08:00
|
|
|
|
|
|
|
/// appmain.h
|
2009-07-19 11:58:02 +08:00
|
|
|
void ReadMem(int addr);
|
2009-09-08 23:40:22 +08:00
|
|
|
void __attribute__((noreturn)) AppMain(void);
|
2009-07-13 12:54:37 +08:00
|
|
|
void SamyRun(void);
|
2009-04-09 14:43:20 +08:00
|
|
|
void DbpIntegers(int a, int b, int c);
|
|
|
|
void DbpString(char *str);
|
|
|
|
void ToSendStuffBit(int b);
|
|
|
|
void ToSendReset(void);
|
2009-07-19 11:58:02 +08:00
|
|
|
void ListenReaderField(int limit);
|
|
|
|
void AcquireRawAdcSamples125k(BOOL at134khz);
|
2009-12-30 10:52:33 +08:00
|
|
|
void DoAcquisition125k(void);
|
2009-04-09 14:43:20 +08:00
|
|
|
extern int ToSendMax;
|
|
|
|
extern BYTE ToSend[];
|
|
|
|
extern DWORD BigBuf[];
|
|
|
|
|
2009-07-25 19:47:43 +08:00
|
|
|
/// fpga.h
|
2009-04-15 16:09:06 +08:00
|
|
|
void FpgaSendCommand(WORD cmd, WORD v);
|
2009-04-09 14:43:20 +08:00
|
|
|
void FpgaWriteConfWord(BYTE v);
|
|
|
|
void FpgaDownloadAndGo(void);
|
2009-08-28 08:37:28 +08:00
|
|
|
void FpgaGatherVersion(char *dst, int len);
|
2009-04-09 14:43:20 +08:00
|
|
|
void FpgaSetupSsc(void);
|
|
|
|
void SetupSpi(int mode);
|
|
|
|
void FpgaSetupSscDma(BYTE *buf, int len);
|
2009-09-29 20:13:41 +08:00
|
|
|
void SetAdcMuxFor(DWORD whichGpio);
|
2009-04-09 14:43:20 +08:00
|
|
|
|
2009-04-15 16:09:06 +08:00
|
|
|
// Definitions for the FPGA commands.
|
2009-09-29 20:13:41 +08:00
|
|
|
#define FPGA_CMD_SET_CONFREG (1<<12)
|
|
|
|
#define FPGA_CMD_SET_DIVISOR (2<<12)
|
2009-04-09 14:43:20 +08:00
|
|
|
// Definitions for the FPGA configuration word.
|
2009-09-29 20:13:41 +08:00
|
|
|
#define FPGA_MAJOR_MODE_LF_READER (0<<5)
|
2009-07-19 11:58:02 +08:00
|
|
|
#define FPGA_MAJOR_MODE_LF_SIMULATOR (1<<5)
|
|
|
|
#define FPGA_MAJOR_MODE_HF_READER_TX (2<<5)
|
2009-09-29 20:13:41 +08:00
|
|
|
#define FPGA_MAJOR_MODE_HF_READER_RX_XCORR (3<<5)
|
2009-07-19 11:58:02 +08:00
|
|
|
#define FPGA_MAJOR_MODE_HF_SIMULATOR (4<<5)
|
|
|
|
#define FPGA_MAJOR_MODE_HF_ISO14443A (5<<5)
|
|
|
|
#define FPGA_MAJOR_MODE_LF_PASSTHRU (6<<5)
|
2009-09-29 20:13:41 +08:00
|
|
|
#define FPGA_MAJOR_MODE_OFF (7<<5)
|
2009-04-09 14:43:20 +08:00
|
|
|
// Options for the HF reader, tx to tag
|
2009-07-19 11:58:02 +08:00
|
|
|
#define FPGA_HF_READER_TX_SHALLOW_MOD (1<<0)
|
2009-04-09 14:43:20 +08:00
|
|
|
// Options for the HF reader, correlating against rx from tag
|
2009-09-29 20:13:41 +08:00
|
|
|
#define FPGA_HF_READER_RX_XCORR_848_KHZ (1<<0)
|
2009-07-19 11:58:02 +08:00
|
|
|
#define FPGA_HF_READER_RX_XCORR_SNOOP (1<<1)
|
2009-12-09 10:31:01 +08:00
|
|
|
#define FPGA_HF_READER_RX_XCORR_QUARTER_FREQ (1<<2)
|
2009-04-09 14:43:20 +08:00
|
|
|
// Options for the HF simulated tag, how to modulate
|
2009-09-29 20:13:41 +08:00
|
|
|
#define FPGA_HF_SIMULATOR_NO_MODULATION (0<<0)
|
|
|
|
#define FPGA_HF_SIMULATOR_MODULATE_BPSK (1<<0)
|
2009-10-12 15:46:03 +08:00
|
|
|
#define FPGA_HF_SIMULATOR_MODULATE_212K (2<<0)
|
2009-04-09 14:43:20 +08:00
|
|
|
// Options for ISO14443A
|
2009-09-29 20:13:41 +08:00
|
|
|
#define FPGA_HF_ISO14443A_SNIFFER (0<<0)
|
|
|
|
#define FPGA_HF_ISO14443A_TAGSIM_LISTEN (1<<0)
|
2009-07-19 11:58:02 +08:00
|
|
|
#define FPGA_HF_ISO14443A_TAGSIM_MOD (2<<0)
|
2009-09-29 20:13:41 +08:00
|
|
|
#define FPGA_HF_ISO14443A_READER_LISTEN (3<<0)
|
2009-07-19 11:58:02 +08:00
|
|
|
#define FPGA_HF_ISO14443A_READER_MOD (4<<0)
|
2009-04-09 14:43:20 +08:00
|
|
|
|
2009-07-25 19:47:43 +08:00
|
|
|
/// lfops.h
|
|
|
|
void AcquireRawAdcSamples125k(BOOL at134khz);
|
|
|
|
void ModThenAcquireRawAdcSamples125k(int delay_off,int period_0,int period_1,BYTE *command);
|
2009-12-30 10:52:33 +08:00
|
|
|
void ReadTItag(void);
|
2009-07-25 19:47:43 +08:00
|
|
|
void WriteTItag(DWORD idhi, DWORD idlo, WORD crc);
|
|
|
|
void AcquireTiType(void);
|
|
|
|
void AcquireRawBitsTI(void);
|
|
|
|
void SimulateTagLowFrequency(int period, int ledcontrol);
|
|
|
|
void CmdHIDsimTAG(int hi, int lo, int ledcontrol);
|
|
|
|
void CmdHIDdemodFSK(int findone, int *high, int *low, int ledcontrol);
|
2009-08-29 05:56:43 +08:00
|
|
|
void SimulateTagLowFrequencyBidir(int divisor, int max_bitlen);
|
2009-07-25 19:47:43 +08:00
|
|
|
|
2009-04-09 14:43:20 +08:00
|
|
|
/// iso14443.h
|
|
|
|
void SimulateIso14443Tag(void);
|
|
|
|
void AcquireRawAdcSamplesIso14443(DWORD parameter);
|
2009-07-19 11:58:02 +08:00
|
|
|
void ReadSRI512Iso14443(DWORD parameter);
|
2009-12-30 08:11:50 +08:00
|
|
|
void ReadSRIX4KIso14443(DWORD parameter);
|
|
|
|
void ReadSTMemoryIso14443(DWORD parameter,DWORD dwLast);
|
2009-04-09 14:43:20 +08:00
|
|
|
void SnoopIso14443(void);
|
|
|
|
|
|
|
|
/// iso14443a.h
|
|
|
|
void SnoopIso14443a(void);
|
|
|
|
void SimulateIso14443aTag(int tagType, int TagUid); // ## simulate iso14443a tag
|
|
|
|
void ReaderIso14443a(DWORD parameter);
|
2009-12-30 08:11:50 +08:00
|
|
|
void ReaderMifare(DWORD parameter);
|
2009-04-09 14:43:20 +08:00
|
|
|
|
|
|
|
/// iso15693.h
|
|
|
|
void AcquireRawAdcSamplesIso15693(void);
|
|
|
|
void ReaderIso15693(DWORD parameter); // Simulate an ISO15693 reader - greg
|
|
|
|
void SimTagIso15693(DWORD parameter); // simulate an ISO15693 tag - greg
|
|
|
|
|
|
|
|
/// util.h
|
2009-07-19 11:58:02 +08:00
|
|
|
#define LED_RED 1
|
|
|
|
#define LED_ORANGE 2
|
|
|
|
#define LED_GREEN 4
|
|
|
|
#define LED_RED2 8
|
|
|
|
#define BUTTON_HOLD 1
|
|
|
|
#define BUTTON_NO_CLICK 0
|
|
|
|
#define BUTTON_SINGLE_CLICK -1
|
|
|
|
#define BUTTON_DOUBLE_CLICK -2
|
|
|
|
#define BUTTON_ERROR -99
|
2009-04-09 14:43:20 +08:00
|
|
|
int strlen(char *str);
|
|
|
|
void *memcpy(void *dest, const void *src, int len);
|
|
|
|
void *memset(void *dest, int c, int len);
|
|
|
|
int memcmp(const void *av, const void *bv, int len);
|
2009-08-28 08:37:28 +08:00
|
|
|
char *strncat(char *dest, const char *src, unsigned int n);
|
2009-12-30 08:11:50 +08:00
|
|
|
void num_to_bytes(uint64_t n, size_t len, byte_t* dest);
|
|
|
|
uint64_t bytes_to_num(byte_t* src, size_t len);
|
|
|
|
|
2009-07-19 11:58:02 +08:00
|
|
|
void SpinDelay(int ms);
|
2009-07-13 12:54:37 +08:00
|
|
|
void SpinDelayUs(int us);
|
2009-07-19 11:58:02 +08:00
|
|
|
void LED(int led, int ms);
|
|
|
|
void LEDsoff();
|
|
|
|
int BUTTON_CLICKED(int ms);
|
|
|
|
int BUTTON_HELD(int ms);
|
2009-08-28 14:40:44 +08:00
|
|
|
void FormatVersionInformation(char *dst, int len, const char *prefix, void *version_information);
|
2009-04-09 14:43:20 +08:00
|
|
|
|
|
|
|
#endif
|