]> git.zerfleddert.de Git - proxmark3-svn/blame_incremental - client/mifarehost.h
Adding support for standard USB Smartcard Readers (#769)
[proxmark3-svn] / client / mifarehost.h
... / ...
CommitLineData
1// Merlok, 2011, 2017\r
2// people from mifare@nethemba.com, 2010\r
3//\r
4// This code is licensed to you under the terms of the GNU GPL, version 2 or,\r
5// at your option, any later version. See the LICENSE.txt file for the text of\r
6// the license.\r
7//-----------------------------------------------------------------------------\r
8// High frequency ISO14443A commands\r
9//-----------------------------------------------------------------------------\r
10\r
11#ifndef MIFAREHOST_H\r
12#define MIFAREHOST_H\r
13\r
14#include <stdint.h>\r
15#include <stdbool.h>\r
16#include "crapto1/crapto1.h"\r
17#include "util.h"\r
18\r
19// defaults\r
20// timeout in units. (ms * 106)/10 or us*0.0106\r
21// 5 == 500us\r
22#define MF_CHKKEYS_DEFTIMEOUT 5\r
23\r
24// mfCSetBlock work flags\r
25#define CSETBLOCK_UID 0x01\r
26#define CSETBLOCK_WUPC 0x02\r
27#define CSETBLOCK_HALT 0x04\r
28#define CSETBLOCK_INIT_FIELD 0x08\r
29#define CSETBLOCK_RESET_FIELD 0x10\r
30#define CSETBLOCK_SINGLE_OPER 0x1F\r
31#define CSETBLOCK_MAGIC_1B 0x40\r
32\r
33typedef struct {\r
34 uint64_t Key[2];\r
35 int foundKey[2];\r
36} sector_t;\r
37\r
38extern char logHexFileName[FILE_PATH_SIZE];\r
39\r
40extern int mfDarkside(uint64_t *key);\r
41extern int mfnested(uint8_t blockNo, uint8_t keyType, uint8_t *key, uint8_t trgBlockNo, uint8_t trgKeyType, uint8_t *ResultKeys, bool calibrate);\r
42extern int mfCheckKeys (uint8_t blockNo, uint8_t keyType, bool clear_trace, uint8_t keycnt, uint8_t *keyBlock, uint64_t *key);\r
43extern int mfCheckKeysSec(uint8_t sectorCnt, uint8_t keyType, uint8_t timeout14a, bool clear_trace, uint8_t keycnt, uint8_t * keyBlock, sector_t * e_sector);\r
44\r
45extern int mfEmlGetMem(uint8_t *data, int blockNum, int blocksCount);\r
46extern int mfEmlSetMem(uint8_t *data, int blockNum, int blocksCount);\r
47\r
48extern int mfCWipe(uint32_t numSectors, bool gen1b, bool wantWipe, bool wantFill);\r
49extern int mfCSetUID(uint8_t *uid, uint8_t *atqa, uint8_t *sak, uint8_t *oldUID);\r
50extern int mfCSetBlock(uint8_t blockNo, uint8_t *data, uint8_t *uid, bool wantWipe, uint8_t params);\r
51extern int mfCGetBlock(uint8_t blockNo, uint8_t *data, uint8_t params);\r
52\r
53extern int mfTraceInit(uint8_t *tuid, uint8_t *atqa, uint8_t sak, bool wantSaveToEmlFile);\r
54extern int mfTraceDecode(uint8_t *data_src, int len, uint8_t parity, bool wantSaveToEmlFile);\r
55\r
56extern int isTraceCardEmpty(void);\r
57extern int isBlockEmpty(int blockN);\r
58extern int isBlockTrailer(int blockN);\r
59extern int loadTraceCard(uint8_t *tuid);\r
60extern int saveTraceCard(void);\r
61extern int tryDecryptWord(uint32_t nt, uint32_t ar_enc, uint32_t at_enc, uint8_t *data, int len);\r
62\r
63extern int mfCIdentify();\r
64extern int DetectClassicPrng(void);\r
65extern bool validate_prng_nonce(uint32_t nonce);\r
66extern void mf_crypto1_decrypt(struct Crypto1State *pcs, uint8_t *data, int len, bool isEncrypted);\r
67\r
68#endif\r
Impressum, Datenschutz