proxmark3/client/src/mifare/desfirecore.h

93 lines
3.1 KiB
C
Raw Normal View History

2021-07-02 00:53:57 +08:00
//-----------------------------------------------------------------------------
// Copyright (C) 2010 Romain Tartiere.
// Copyright (C) 2014 Iceman
// Copyright (C) 2021 Merlok
//
// This code is licensed to you under the terms of the GNU GPL, version 2 or,
// at your option, any later version. See the LICENSE.txt file for the text of
// the license.
//-----------------------------------------------------------------------------
// High frequency Desfire core functions
//-----------------------------------------------------------------------------
#ifndef __DESFIRECORE_H
#define __DESFIRECORE_H
#include "common.h"
#include "mifare/desfire_crypto.h"
#include "mifare/mifare4.h"
#define DESF_MAX_KEY_LEN 24
#define DESFIRE_GET_ISO_STATUS(x) ( ((uint16_t)(0x91<<8)) + (uint16_t)x )
2021-07-03 05:08:45 +08:00
typedef enum DESFIRE_CRYPTOALGO DesfireCryptoAlgorythm;
2021-07-02 00:53:57 +08:00
typedef enum {
DACNone,
DACd40,
DACEV1,
DACEV2
} DesfireAuthChannel;
typedef enum {
DCCNative,
DCCNativeISO,
DCCISO
} DesfireCommandChannel;
typedef enum {
DCMNone,
DCMPlain,
DCMMACed,
DCMEncrypted
} DesfireCommunicationMode;
typedef struct DesfireContextS {
uint8_t keyNum;
2021-07-02 22:37:15 +08:00
enum DESFIRE_CRYPTOALGO keyType; // des/2tdea/3tdea/aes
2021-07-02 00:53:57 +08:00
uint8_t key[DESF_MAX_KEY_LEN];
// KDF finction
2021-07-02 22:37:15 +08:00
uint8_t kdfAlgo;
uint8_t kdfInputLen;
uint8_t kdfInput[31];
2021-07-02 00:53:57 +08:00
DesfireAuthChannel authChannel; // none/d40/ev1/ev2
DesfireCommandChannel cmdChannel; // native/nativeiso/iso
DesfireCommunicationMode commMode; // plain/mac/enc
uint8_t sessionKeyMAC[DESF_MAX_KEY_LEN];
uint8_t sessionKeyEnc[DESF_MAX_KEY_LEN]; // look at mifare4.h - mf4Session_t
uint8_t lastIV[DESF_MAX_KEY_LEN];
//mf4Session_t AESSession;
uint16_t cntrTx; // for AES
uint16_t cntrRx; // for AES
uint8_t TI[4]; // for AES
} DesfireContext;
void DesfireClearContext(DesfireContext *ctx);
2021-07-02 22:37:15 +08:00
void DesfireClearSession(DesfireContext *ctx);
2021-07-02 00:53:57 +08:00
void DesfireSetKey(DesfireContext *ctx, uint8_t keyNum, enum DESFIRE_CRYPTOALGO keyType, uint8_t *key);
2021-07-02 22:37:15 +08:00
void DesfireSetCommandChannel(DesfireContext *ctx, DesfireCommandChannel cmdChannel);
2021-07-02 00:53:57 +08:00
const char *DesfireGetErrorString(int res, uint16_t *sw);
2021-07-02 23:06:13 +08:00
uint32_t DesfireAIDByteToUint(uint8_t *data);
void DesfireAIDUintToByte(uint32_t aid, uint8_t *data);
2021-07-02 01:32:04 +08:00
int DesfireExchange(DesfireContext *ctx, uint8_t cmd, uint8_t *data, size_t datalen, uint8_t *respcode, uint8_t *resp, size_t *resplen);
2021-07-03 18:11:17 +08:00
int DesfireExchangeEx(bool activate_field, DesfireContext *ctx, uint8_t cmd, uint8_t *data, size_t datalen, uint8_t *respcode, uint8_t *resp, size_t *resplen, bool enable_chaining, size_t splitbysize);
2021-07-02 00:53:57 +08:00
2021-07-02 22:37:15 +08:00
int DesfireSelectAID(DesfireContext *ctx, uint8_t *aid1, uint8_t *aid2);
int DesfireSelectAIDHex(DesfireContext *ctx, uint32_t aid1, bool select_two, uint32_t aid2);
2021-07-02 23:06:13 +08:00
2021-07-02 22:37:15 +08:00
int DesfireAuthenticate(DesfireContext *dctx, DesfireAuthChannel authChannel);
bool DesfireIsAuthenticated(DesfireContext *dctx);
2021-07-02 23:06:13 +08:00
int DesfireGetAIDList(DesfireContext *dctx, uint8_t *resp, size_t *resplen);
int DesfireGetDFList(DesfireContext *dctx, uint8_t *resp, size_t *resplen);
2021-07-02 00:53:57 +08:00
#endif // __DESFIRECORE_H