]>
git.zerfleddert.de Git - proxmark3-svn/blob - client/cmdhflist.h
1 //-----------------------------------------------------------------------------
2 // Copyright (C) Merlok - 2017
4 // This code is licensed to you under the terms of the GNU GPL, version 2 or,
5 // at your option, any later version. See the LICENSE.txt file for the text of
7 //-----------------------------------------------------------------------------
8 // Command: hf mf list. It shows data from arm buffer.
9 //-----------------------------------------------------------------------------
19 uint32_t nt
; // tag challenge
20 uint32_t nt_enc
; // encrypted tag challenge
21 uint8_t nt_enc_par
; // encrypted tag challenge parity
22 uint32_t nr_enc
; // encrypted reader challenge
23 uint32_t ar_enc
; // encrypted reader response
24 uint8_t ar_enc_par
; // encrypted reader response parity
25 uint32_t at_enc
; // encrypted tag response
26 uint8_t at_enc_par
; // encrypted tag response parity
27 bool first_auth
; // is first authentication
28 uint32_t ks2
; // ar ^ ar_enc
29 uint32_t ks3
; // at ^ at_enc
31 extern void ClearAuthData();
33 extern uint8_t iso14443A_CRC_check(bool isResponse
, uint8_t* data
, uint8_t len
);
34 extern uint8_t mifare_CRC_check(bool isResponse
, uint8_t* data
, uint8_t len
);
35 extern void annotateIclass(char *exp
, size_t size
, uint8_t* cmd
, uint8_t cmdsize
);
36 extern void annotateIso15693(char *exp
, size_t size
, uint8_t* cmd
, uint8_t cmdsize
);
37 extern void annotateTopaz(char *exp
, size_t size
, uint8_t* cmd
, uint8_t cmdsize
);
38 extern void annotateIso14443b(char *exp
, size_t size
, uint8_t* cmd
, uint8_t cmdsize
);
39 extern void annotateIso14443a(char *exp
, size_t size
, uint8_t* cmd
, uint8_t cmdsize
);
40 extern void annotateMifare(char *exp
, size_t size
, uint8_t* cmd
, uint8_t cmdsize
, uint8_t* parity
, uint8_t paritysize
, bool isResponse
);
41 extern bool DecodeMifareData(uint8_t *cmd
, uint8_t cmdsize
, uint8_t *parity
, bool isResponse
, uint8_t *mfData
, size_t *mfDataLen
);
42 extern bool NTParityChk(TAuthData
*ad
, uint32_t ntx
);
43 extern bool NestedCheckKey(uint64_t key
, TAuthData
*ad
, uint8_t *cmd
, uint8_t cmdsize
, uint8_t *parity
);
44 extern bool CheckCrypto1Parity(uint8_t *cmd_enc
, uint8_t cmdsize
, uint8_t *cmd
, uint8_t *parity_enc
);
45 extern uint64_t GetCrypto1ProbableKey(TAuthData
*ad
);