]> git.zerfleddert.de Git - proxmark3-svn/blame - armsrc/apps.h
ARM code cleanup (lfops)
[proxmark3-svn] / armsrc / apps.h
CommitLineData
6658905f 1//-----------------------------------------------------------------------------\r
2// Definitions internal to the app source.\r
3// Jonathan Westhues, Aug 2005\r
4// Added ISO14443-A support by Gerhard de Koning Gans, April 2008\r
5//-----------------------------------------------------------------------------\r
6\r
7#ifndef __APPS_H\r
8#define __APPS_H\r
9\r
32cfae43 10#include "stdint.h"\r
11#include "stddef.h"\r
12typedef unsigned char byte_t;\r
13\r
9bea179a 14// The large multi-purpose buffer, typically used to hold A/D samples,\r
15// maybe processed in some way.\r
7381e8f2 16DWORD BigBuf[12000];\r
9bea179a 17\r
18/// appmain.h\r
17465c9e 19void ReadMem(int addr);\r
1b2c8936 20void __attribute__((noreturn)) AppMain(void);\r
955fc5e2 21void SamyRun(void);\r
6658905f 22void DbpIntegers(int a, int b, int c);\r
23void DbpString(char *str);\r
6658905f 24void ToSendStuffBit(int b);\r
25void ToSendReset(void);\r
17465c9e 26void ListenReaderField(int limit);\r
27void AcquireRawAdcSamples125k(BOOL at134khz);\r
0d974852 28void DoAcquisition125k(void);\r
6658905f 29extern int ToSendMax;\r
30extern BYTE ToSend[];\r
31extern DWORD BigBuf[];\r
32\r
9bea179a 33/// fpga.h\r
30f2a7d3 34void FpgaSendCommand(WORD cmd, WORD v);\r
6658905f 35void FpgaWriteConfWord(BYTE v);\r
36void FpgaDownloadAndGo(void);\r
ba8a80b3 37void FpgaGatherVersion(char *dst, int len);\r
6658905f 38void FpgaSetupSsc(void);\r
39void SetupSpi(int mode);\r
40void FpgaSetupSscDma(BYTE *buf, int len);\r
6949aca9 41void SetAdcMuxFor(DWORD whichGpio);\r
6658905f 42\r
30f2a7d3 43// Definitions for the FPGA commands.\r
6949aca9 44#define FPGA_CMD_SET_CONFREG (1<<12)\r
45#define FPGA_CMD_SET_DIVISOR (2<<12)\r
6658905f 46// Definitions for the FPGA configuration word.\r
6949aca9 47#define FPGA_MAJOR_MODE_LF_READER (0<<5)\r
17465c9e 48#define FPGA_MAJOR_MODE_LF_SIMULATOR (1<<5)\r
49#define FPGA_MAJOR_MODE_HF_READER_TX (2<<5)\r
6949aca9 50#define FPGA_MAJOR_MODE_HF_READER_RX_XCORR (3<<5)\r
17465c9e 51#define FPGA_MAJOR_MODE_HF_SIMULATOR (4<<5)\r
52#define FPGA_MAJOR_MODE_HF_ISO14443A (5<<5)\r
53#define FPGA_MAJOR_MODE_LF_PASSTHRU (6<<5)\r
6949aca9 54#define FPGA_MAJOR_MODE_OFF (7<<5)\r
6658905f 55// Options for the HF reader, tx to tag\r
17465c9e 56#define FPGA_HF_READER_TX_SHALLOW_MOD (1<<0)\r
6658905f 57// Options for the HF reader, correlating against rx from tag\r
6949aca9 58#define FPGA_HF_READER_RX_XCORR_848_KHZ (1<<0)\r
17465c9e 59#define FPGA_HF_READER_RX_XCORR_SNOOP (1<<1)\r
8d40aba5 60#define FPGA_HF_READER_RX_XCORR_QUARTER_FREQ (1<<2)\r
6658905f 61// Options for the HF simulated tag, how to modulate\r
6949aca9 62#define FPGA_HF_SIMULATOR_NO_MODULATION (0<<0)\r
63#define FPGA_HF_SIMULATOR_MODULATE_BPSK (1<<0)\r
ecf53cb2 64#define FPGA_HF_SIMULATOR_MODULATE_212K (2<<0)\r
6658905f 65// Options for ISO14443A\r
6949aca9 66#define FPGA_HF_ISO14443A_SNIFFER (0<<0)\r
67#define FPGA_HF_ISO14443A_TAGSIM_LISTEN (1<<0)\r
17465c9e 68#define FPGA_HF_ISO14443A_TAGSIM_MOD (2<<0)\r
6949aca9 69#define FPGA_HF_ISO14443A_READER_LISTEN (3<<0)\r
17465c9e 70#define FPGA_HF_ISO14443A_READER_MOD (4<<0)\r
6658905f 71\r
9bea179a 72/// lfops.h\r
73void AcquireRawAdcSamples125k(BOOL at134khz);\r
9bea179a 74void ModThenAcquireRawAdcSamples125k(int delay_off,int period_0,int period_1,BYTE *command);\r
0d974852 75void ReadTItag(void);\r
9bea179a 76void WriteTItag(DWORD idhi, DWORD idlo, WORD crc);\r
77void AcquireTiType(void);\r
78void AcquireRawBitsTI(void);\r
79void SimulateTagLowFrequency(int period, int ledcontrol);\r
80void CmdHIDsimTAG(int hi, int lo, int ledcontrol);\r
81void CmdHIDdemodFSK(int findone, int *high, int *low, int ledcontrol);\r
0fa9ca5b 82void SimulateTagLowFrequencyBidir(int divisor, int max_bitlen);\r
9bea179a 83\r
6658905f 84/// iso14443.h\r
85void SimulateIso14443Tag(void);\r
86void AcquireRawAdcSamplesIso14443(DWORD parameter);\r
17465c9e 87void ReadSRI512Iso14443(DWORD parameter);\r
32cfae43 88void ReadSRIX4KIso14443(DWORD parameter);\r
89void ReadSTMemoryIso14443(DWORD parameter,DWORD dwLast);\r
6658905f 90void SnoopIso14443(void);\r
91\r
92/// iso14443a.h\r
93void SnoopIso14443a(void);\r
94void SimulateIso14443aTag(int tagType, int TagUid); // ## simulate iso14443a tag\r
95void ReaderIso14443a(DWORD parameter);\r
32cfae43 96void ReaderMifare(DWORD parameter);\r
6658905f 97\r
98/// iso15693.h\r
99void AcquireRawAdcSamplesIso15693(void);\r
100void ReaderIso15693(DWORD parameter); // Simulate an ISO15693 reader - greg\r
101void SimTagIso15693(DWORD parameter); // simulate an ISO15693 tag - greg\r
102\r
103/// util.h\r
17465c9e 104#define LED_RED 1\r
105#define LED_ORANGE 2\r
106#define LED_GREEN 4\r
107#define LED_RED2 8\r
108#define BUTTON_HOLD 1\r
109#define BUTTON_NO_CLICK 0\r
110#define BUTTON_SINGLE_CLICK -1\r
111#define BUTTON_DOUBLE_CLICK -2\r
112#define BUTTON_ERROR -99\r
6658905f 113int strlen(char *str);\r
114void *memcpy(void *dest, const void *src, int len);\r
115void *memset(void *dest, int c, int len);\r
116int memcmp(const void *av, const void *bv, int len);\r
ba8a80b3 117char *strncat(char *dest, const char *src, unsigned int n);\r
32cfae43 118void num_to_bytes(uint64_t n, size_t len, byte_t* dest);\r
119uint64_t bytes_to_num(byte_t* src, size_t len);\r
120\r
17465c9e 121void SpinDelay(int ms);\r
955fc5e2 122void SpinDelayUs(int us);\r
17465c9e 123void LED(int led, int ms);\r
124void LEDsoff();\r
125int BUTTON_CLICKED(int ms);\r
126int BUTTON_HELD(int ms);\r
8a6aec16 127void FormatVersionInformation(char *dst, int len, const char *prefix, void *version_information);\r
6658905f 128\r
129#endif\r
Impressum, Datenschutz