]>
git.zerfleddert.de Git - proxmark3-svn/blob - armsrc/apps.h
1 //-----------------------------------------------------------------------------
2 // Definitions internal to the app source.
3 // Jonathan Westhues, Aug 2005
4 // Added ISO14443-A support by Gerhard de Koning Gans, April 2008
5 //-----------------------------------------------------------------------------
10 // The large multi-purpose buffer, typically used to hold A/D samples,
11 // maybe processed in some way.
15 void ReadMem(int addr
);
18 void DbpIntegers(int a
, int b
, int c
);
19 void DbpString(char *str
);
20 void ToSendStuffBit(int b
);
21 void ToSendReset(void);
22 void ListenReaderField(int limit
);
23 void AcquireRawAdcSamples125k(BOOL at134khz
);
24 void DoAcquisition125k(BOOL at134khz
);
27 extern DWORD BigBuf
[];
30 void FpgaSendCommand(WORD cmd
, WORD v
);
31 void FpgaWriteConfWord(BYTE v
);
32 void FpgaDownloadAndGo(void);
33 void FpgaSetupSsc(void);
34 void SetupSpi(int mode
);
35 void FpgaSetupSscDma(BYTE
*buf
, int len
);
36 void SetAdcMuxFor(int whichGpio
);
38 // Definitions for the FPGA commands.
39 #define FPGA_CMD_SET_CONFREG (1<<12)
40 #define FPGA_CMD_SET_DIVISOR (2<<12)
41 // Definitions for the FPGA configuration word.
42 #define FPGA_MAJOR_MODE_LF_READER (0<<5)
43 #define FPGA_MAJOR_MODE_LF_SIMULATOR (1<<5)
44 #define FPGA_MAJOR_MODE_HF_READER_TX (2<<5)
45 #define FPGA_MAJOR_MODE_HF_READER_RX_XCORR (3<<5)
46 #define FPGA_MAJOR_MODE_HF_SIMULATOR (4<<5)
47 #define FPGA_MAJOR_MODE_HF_ISO14443A (5<<5)
48 #define FPGA_MAJOR_MODE_LF_PASSTHRU (6<<5)
49 #define FPGA_MAJOR_MODE_OFF (7<<5)
50 // Options for the HF reader, tx to tag
51 #define FPGA_HF_READER_TX_SHALLOW_MOD (1<<0)
52 // Options for the HF reader, correlating against rx from tag
53 #define FPGA_HF_READER_RX_XCORR_848_KHZ (1<<0)
54 #define FPGA_HF_READER_RX_XCORR_SNOOP (1<<1)
55 // Options for the HF simulated tag, how to modulate
56 #define FPGA_HF_SIMULATOR_NO_MODULATION (0<<0)
57 #define FPGA_HF_SIMULATOR_MODULATE_BPSK (1<<0)
58 // Options for ISO14443A
59 #define FPGA_HF_ISO14443A_SNIFFER (0<<0)
60 #define FPGA_HF_ISO14443A_TAGSIM_LISTEN (1<<0)
61 #define FPGA_HF_ISO14443A_TAGSIM_MOD (2<<0)
62 #define FPGA_HF_ISO14443A_READER_LISTEN (3<<0)
63 #define FPGA_HF_ISO14443A_READER_MOD (4<<0)
66 void AcquireRawAdcSamples125k(BOOL at134khz
);
67 void DoAcquisition125k(BOOL at134khz
);
68 void ModThenAcquireRawAdcSamples125k(int delay_off
,int period_0
,int period_1
,BYTE
*command
);
70 void WriteTItag(DWORD idhi
, DWORD idlo
, WORD crc
);
71 void AcquireTiType(void);
72 void AcquireRawBitsTI(void);
73 void SimulateTagLowFrequency(int period
, int ledcontrol
);
74 void CmdHIDsimTAG(int hi
, int lo
, int ledcontrol
);
75 void CmdHIDdemodFSK(int findone
, int *high
, int *low
, int ledcontrol
);
78 void SimulateIso14443Tag(void);
79 void AcquireRawAdcSamplesIso14443(DWORD parameter
);
80 void ReadSRI512Iso14443(DWORD parameter
);
81 void SnoopIso14443(void);
84 void SnoopIso14443a(void);
85 void SimulateIso14443aTag(int tagType
, int TagUid
); // ## simulate iso14443a tag
86 void ReaderIso14443a(DWORD parameter
);
89 void AcquireRawAdcSamplesIso15693(void);
90 void ReaderIso15693(DWORD parameter
); // Simulate an ISO15693 reader - greg
91 void SimTagIso15693(DWORD parameter
); // simulate an ISO15693 tag - greg
99 #define BUTTON_NO_CLICK 0
100 #define BUTTON_SINGLE_CLICK -1
101 #define BUTTON_DOUBLE_CLICK -2
102 #define BUTTON_ERROR -99
103 int strlen(char *str
);
104 void *memcpy(void *dest
, const void *src
, int len
);
105 void *memset(void *dest
, int c
, int len
);
106 int memcmp(const void *av
, const void *bv
, int len
);
107 void SpinDelay(int ms
);
108 void SpinDelayUs(int us
);
109 void LED(int led
, int ms
);
111 int BUTTON_CLICKED(int ms
);
112 int BUTTON_HELD(int ms
);