2020-01-17 22:02:21 +08:00
|
|
|
//-----------------------------------------------------------------------------
|
2022-01-06 18:24:04 +08:00
|
|
|
// Borrowed initially from https://github.com/factoritbv/hitag2hell
|
|
|
|
// and https://github.com/AdamLaurie/RFIDler/blob/master/firmware/Pic32/RFIDler.X/src/hitag2crack.c
|
2022-01-06 09:19:46 +08:00
|
|
|
// Copyright (C) Kevin Sheldrake <kev@headhacking.com>, Aug 2018
|
|
|
|
// Copyright (C) Proxmark3 contributors. See AUTHORS.md for details.
|
2020-01-17 22:02:21 +08:00
|
|
|
//
|
2022-01-06 09:19:46 +08:00
|
|
|
// 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.
|
2020-01-17 22:02:21 +08:00
|
|
|
//-----------------------------------------------------------------------------
|
|
|
|
// Definitions hitag2 attack functions
|
|
|
|
//-----------------------------------------------------------------------------
|
|
|
|
|
|
|
|
bool hitag2_crack(uint8_t *response, uint8_t *nrarhex);
|
|
|
|
bool hitag2crack_find_valid_e_cmd(uint8_t e_cmd[], uint8_t nrar[]);
|
|
|
|
bool hitag2crack_find_e_page0_cmd(uint8_t keybits[], uint8_t e_firstcmd[], uint8_t nrar[], uint8_t uid[]);
|
|
|
|
bool hitag2crack_test_e_p0cmd(uint8_t *keybits, uint8_t *nrar, uint8_t *e_cmd, uint8_t *uid, uint8_t *e_uid);
|
2022-01-06 22:22:36 +08:00
|
|
|
void hitag2crack_xor(uint8_t *target, const uint8_t *source, const uint8_t *pad, unsigned int len);
|
2020-01-17 22:02:21 +08:00
|
|
|
bool hitag2crack_read_page(uint8_t *responsestr, uint8_t pagenum, uint8_t *nrar, uint8_t *keybits);
|
|
|
|
bool hitag2crack_send_e_cmd(uint8_t *responsestr, uint8_t *nrar, uint8_t *cmd, int len);
|
|
|
|
bool hitag2crack_tx_rx(uint8_t *responsestr, uint8_t *msg, int len, int state, bool reset);
|
|
|
|
|
|
|
|
bool hitag2crack_rng_init(uint8_t *response, uint8_t *input);
|
|
|
|
bool hitag2crack_decrypt_hex(uint8_t *response, uint8_t *hex);
|
2020-03-13 20:52:23 +08:00
|
|
|
bool hitag2crack_decrypt_bin(uint8_t *response, uint8_t *e_binstr);
|
2020-01-17 22:02:21 +08:00
|
|
|
bool hitag2crack_encrypt_hex(uint8_t *response, uint8_t *hex);
|
2020-03-13 20:52:23 +08:00
|
|
|
bool hitag2crack_encrypt_bin(uint8_t *response, uint8_t *e_binstr);
|
2020-01-17 22:02:21 +08:00
|
|
|
|
|
|
|
bool hitag2_keystream(uint8_t *response, uint8_t *nrarhex);
|
|
|
|
bool hitag2crack_send_auth(uint8_t *nrar);
|
|
|
|
bool hitag2crack_consume_keystream(uint8_t *keybits, int kslen, int *ksoffset, uint8_t *nrar);
|
|
|
|
bool hitag2crack_extend_keystream(uint8_t *keybits, int *kslen, int ksoffset, uint8_t *nrar, uint8_t *uid);
|
|
|
|
|
|
|
|
bool hitag2_reader(uint8_t *response, uint8_t *key, bool interactive);
|