mirror of
https://github.com/RfidResearchGroup/proxmark3.git
synced 2025-01-08 11:59:50 -08:00
191 lines
5.2 KiB
C
191 lines
5.2 KiB
C
//-----------------------------------------------------------------------------
|
|
// Copyright (C) Proxmark3 contributors. See AUTHORS.md for details.
|
|
//
|
|
// This program is free software: you can redistribute it and/or modify
|
|
// it under the terms of the GNU General Public License as published by
|
|
// the Free Software Foundation, either version 3 of the License, or
|
|
// (at your option) any later version.
|
|
//
|
|
// This program is distributed in the hope that it will be useful,
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
// GNU General Public License for more details.
|
|
//
|
|
// See LICENSE.txt for the text of the license.
|
|
//-----------------------------------------------------------------------------
|
|
// MIFARE type prototyping
|
|
//-----------------------------------------------------------------------------
|
|
|
|
#ifndef _MIFARE_H_
|
|
#define _MIFARE_H_
|
|
|
|
#include "common.h"
|
|
|
|
// These are also used to construct AUTH commands (60+x)
|
|
#define MF_KEY_A 0
|
|
#define MF_KEY_B 1
|
|
#define MF_KEY_BD 4
|
|
|
|
#define MF_MAD1_SECTOR 0x00
|
|
#define MF_MAD2_SECTOR 0x10
|
|
|
|
//-----------------------------------------------------------------------------
|
|
// Common types, used by client and ARM
|
|
//-----------------------------------------------------------------------------
|
|
// New Ultralight/NTAG dump file format
|
|
// Length must be aligned to 4 bytes (UL/NTAG page)
|
|
#define MFU_DUMP_PREFIX_LENGTH 56
|
|
|
|
typedef struct {
|
|
uint8_t version[8];
|
|
uint8_t tbo[2];
|
|
uint8_t tbo1[1];
|
|
uint8_t pages; // max page number in dump
|
|
uint8_t signature[32];
|
|
uint8_t counter_tearing[3][4]; // 3 bytes counter, 1 byte tearing flag
|
|
uint8_t data[1024];
|
|
} PACKED mfu_dump_t;
|
|
|
|
//-----------------------------------------------------------------------------
|
|
// ISO 14443A
|
|
//-----------------------------------------------------------------------------
|
|
typedef struct {
|
|
uint8_t uid[10];
|
|
uint8_t uidlen;
|
|
uint8_t atqa[2];
|
|
uint8_t sak;
|
|
uint8_t ats_len;
|
|
uint8_t ats[256];
|
|
} PACKED iso14a_card_select_t;
|
|
|
|
typedef struct {
|
|
uint8_t uid[10];
|
|
uint8_t uidlen;
|
|
uint8_t atqa[2];
|
|
uint8_t sak;
|
|
uint8_t ats_len;
|
|
uint8_t ats[256];
|
|
uint8_t signature[32];
|
|
} PACKED iso14a_card_select_ev1_t;
|
|
|
|
typedef struct {
|
|
iso14a_card_select_t card_info;
|
|
uint16_t dumplen;
|
|
uint8_t *dump;
|
|
} iso14a_mf_extdump_t;
|
|
|
|
typedef struct {
|
|
union {
|
|
iso14a_card_select_t mfc;
|
|
iso14a_card_select_ev1_t ev1;
|
|
} card;
|
|
uint16_t dumplen;
|
|
uint8_t *dump;
|
|
} iso14a_mf_dump_ev1_t;
|
|
|
|
typedef struct {
|
|
uint8_t nt[17][2][4];
|
|
uint8_t nt_enc[17][2][4];
|
|
uint8_t par_err[17][2];
|
|
uint8_t blocks[64][16]; // [MIFARE_1K_MAXSECTOR * 4][MFBLOCK_SIZE]
|
|
} iso14a_fm11rf08s_nonces_with_data_t;
|
|
|
|
typedef enum ISO14A_COMMAND {
|
|
ISO14A_CONNECT = (1 << 0),
|
|
ISO14A_NO_DISCONNECT = (1 << 1),
|
|
ISO14A_APDU = (1 << 2),
|
|
ISO14A_RAW = (1 << 3),
|
|
ISO14A_REQUEST_TRIGGER = (1 << 4),
|
|
ISO14A_APPEND_CRC = (1 << 5),
|
|
ISO14A_SET_TIMEOUT = (1 << 6),
|
|
ISO14A_NO_SELECT = (1 << 7),
|
|
ISO14A_TOPAZMODE = (1 << 8),
|
|
ISO14A_NO_RATS = (1 << 9),
|
|
ISO14A_SEND_CHAINING = (1 << 10),
|
|
ISO14A_USE_ECP = (1 << 11),
|
|
ISO14A_USE_MAGSAFE = (1 << 12),
|
|
ISO14A_USE_CUSTOM_POLLING = (1 << 13),
|
|
ISO14A_CRYPTO1MODE = (1 << 14)
|
|
} iso14a_command_t;
|
|
|
|
// Defines a frame that will be used in a polling sequence
|
|
// ECP Frames are up to (7 + 16) bytes long, 24 bytes should cover future and other cases
|
|
typedef struct {
|
|
uint8_t frame[24];
|
|
uint8_t frame_length;
|
|
uint8_t last_byte_bits;
|
|
uint16_t extra_delay;
|
|
} PACKED iso14a_polling_frame_t;
|
|
|
|
// Defines polling sequence configuration
|
|
// 6 would be enough for 4 magsafe, 1 wupa, 1 ecp,
|
|
typedef struct {
|
|
iso14a_polling_frame_t frames[6];
|
|
uint8_t frame_count;
|
|
uint16_t extra_timeout;
|
|
} PACKED iso14a_polling_parameters_t;
|
|
|
|
typedef struct {
|
|
uint8_t *response;
|
|
uint8_t *modulation;
|
|
uint16_t response_n;
|
|
uint16_t modulation_n;
|
|
uint32_t ProxToAirDuration;
|
|
uint8_t par; // enough for precalculated parity of 8 Byte responses
|
|
} PACKED tag_response_info_t;
|
|
|
|
// DESFIRE_RAW flag enums
|
|
typedef enum DESFIRE_COMMAND {
|
|
NONE = 0x00,
|
|
INIT = 0x01,
|
|
DISCONNECT = 0x02,
|
|
CLEARTRACE = 0x04,
|
|
BAR = 0x10,
|
|
} desfire_command_t;
|
|
|
|
typedef enum {
|
|
MFDES_AUTH_DES = 1,
|
|
MFDES_AUTH_ISO = 2,
|
|
MFDES_AUTH_AES = 3,
|
|
MFDES_AUTH_PICC = 4
|
|
} mifare_des_authmode_t;
|
|
|
|
typedef enum {
|
|
MFDES_ALGO_DES = 1,
|
|
MFDES_ALGO_3DES = 2,
|
|
MFDES_ALGO_3K3DES = 3,
|
|
MFDES_ALGO_AES = 4
|
|
} mifare_des_authalgo_t;
|
|
|
|
typedef enum {
|
|
MFDES_KDF_ALGO_NONE = 0,
|
|
MFDES_KDF_ALGO_AN10922 = 1,
|
|
MFDES_KDF_ALGO_GALLAGHER = 2,
|
|
} mifare_des_kdf_algo_t;
|
|
|
|
//-----------------------------------------------------------------------------
|
|
// "hf 14a sim -x", "hf mf sim -x" attacks
|
|
//-----------------------------------------------------------------------------
|
|
typedef enum {
|
|
EMPTY,
|
|
FIRST,
|
|
SECOND,
|
|
NESTED
|
|
} nonce_state;
|
|
|
|
typedef struct {
|
|
uint32_t cuid;
|
|
uint32_t nonce;
|
|
uint32_t ar;
|
|
uint32_t nr;
|
|
uint32_t at;
|
|
uint32_t nonce2;
|
|
uint32_t ar2;
|
|
uint32_t nr2;
|
|
uint8_t sector;
|
|
uint8_t keytype;
|
|
uint8_t state;
|
|
} PACKED nonces_t;
|
|
|
|
#endif // _MIFARE_H_
|