mirror of
https://github.com/DarkFlippers/unleashed-firmware.git
synced 2025-01-03 18:59:43 +03:00
bit_lib and nfc_util refactor (#3383)
* nfc_util functions for processing bytes moved into bit_lib * bitlib test update * bit_lib moved from lfrfid to standalone lib * Added bit functions for any supported data types * Error fix and api add * Added test for 64 * Added doc * Testcase for 64 rewrited * Realization error fix * API version bump * sync api version, fix after-merge old libs usage * fix build errors * build fix * fbt format Co-authored-by: assasinfil <nfa57643@gmail.com> Co-authored-by: gornekich <n.gorbadey@gmail.com> Co-authored-by: あく <alleteam@gmail.com>
This commit is contained in:
parent
a46038acbf
commit
dd988ba449
@ -1,6 +1,6 @@
|
|||||||
#include <furi.h>
|
#include <furi.h>
|
||||||
#include "../minunit.h"
|
#include "../minunit.h"
|
||||||
#include <lfrfid/tools/bit_lib.h>
|
#include <bit_lib/bit_lib.h>
|
||||||
|
|
||||||
MU_TEST(test_bit_lib_increment_index) {
|
MU_TEST(test_bit_lib_increment_index) {
|
||||||
uint32_t index = 0;
|
uint32_t index = 0;
|
||||||
@ -218,6 +218,178 @@ MU_TEST(test_bit_lib_get_bits_32) {
|
|||||||
mu_assert_int_eq(0b00001001101100011000110001100010, bit_lib_get_bits_32(value, 0, 32));
|
mu_assert_int_eq(0b00001001101100011000110001100010, bit_lib_get_bits_32(value, 0, 32));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
MU_TEST(test_bit_lib_get_bits_64) {
|
||||||
|
uint8_t value[8] = {
|
||||||
|
0b00001001,
|
||||||
|
0b10110001,
|
||||||
|
0b10001100,
|
||||||
|
0b01100010,
|
||||||
|
0b00001001,
|
||||||
|
0b10110001,
|
||||||
|
0b10001100,
|
||||||
|
0b01100010};
|
||||||
|
mu_assert_int_eq(0b0, bit_lib_get_bits_64(value, 0, 1));
|
||||||
|
mu_assert_int_eq(0b00, bit_lib_get_bits_64(value, 0, 2));
|
||||||
|
mu_assert_int_eq(0b000, bit_lib_get_bits_64(value, 0, 3));
|
||||||
|
mu_assert_int_eq(0b0000, bit_lib_get_bits_64(value, 0, 4));
|
||||||
|
mu_assert_int_eq(0b00001, bit_lib_get_bits_64(value, 0, 5));
|
||||||
|
mu_assert_int_eq(0b000010, bit_lib_get_bits_64(value, 0, 6));
|
||||||
|
mu_assert_int_eq(0b0000100, bit_lib_get_bits_64(value, 0, 7));
|
||||||
|
mu_assert_int_eq(0b00001001, bit_lib_get_bits_64(value, 0, 8));
|
||||||
|
mu_assert_int_eq(0b000010011, bit_lib_get_bits_64(value, 0, 9));
|
||||||
|
mu_assert_int_eq(0b0000100110, bit_lib_get_bits_64(value, 0, 10));
|
||||||
|
mu_assert_int_eq(0b00001001101, bit_lib_get_bits_64(value, 0, 11));
|
||||||
|
mu_assert_int_eq(0b000010011011, bit_lib_get_bits_64(value, 0, 12));
|
||||||
|
mu_assert_int_eq(0b0000100110110, bit_lib_get_bits_64(value, 0, 13));
|
||||||
|
mu_assert_int_eq(0b00001001101100, bit_lib_get_bits_64(value, 0, 14));
|
||||||
|
mu_assert_int_eq(0b000010011011000, bit_lib_get_bits_64(value, 0, 15));
|
||||||
|
mu_assert_int_eq(0b0000100110110001, bit_lib_get_bits_64(value, 0, 16));
|
||||||
|
mu_assert_int_eq(0b00001001101100011, bit_lib_get_bits_64(value, 0, 17));
|
||||||
|
mu_assert_int_eq(0b000010011011000110, bit_lib_get_bits_64(value, 0, 18));
|
||||||
|
mu_assert_int_eq(0b0000100110110001100, bit_lib_get_bits_64(value, 0, 19));
|
||||||
|
mu_assert_int_eq(0b00001001101100011000, bit_lib_get_bits_64(value, 0, 20));
|
||||||
|
mu_assert_int_eq(0b000010011011000110001, bit_lib_get_bits_64(value, 0, 21));
|
||||||
|
mu_assert_int_eq(0b0000100110110001100011, bit_lib_get_bits_64(value, 0, 22));
|
||||||
|
mu_assert_int_eq(0b00001001101100011000110, bit_lib_get_bits_64(value, 0, 23));
|
||||||
|
mu_assert_int_eq(0b000010011011000110001100, bit_lib_get_bits_64(value, 0, 24));
|
||||||
|
mu_assert_int_eq(0b0000100110110001100011000, bit_lib_get_bits_64(value, 0, 25));
|
||||||
|
mu_assert_int_eq(0b00001001101100011000110001, bit_lib_get_bits_64(value, 0, 26));
|
||||||
|
mu_assert_int_eq(0b000010011011000110001100011, bit_lib_get_bits_64(value, 0, 27));
|
||||||
|
mu_assert_int_eq(0b0000100110110001100011000110, bit_lib_get_bits_64(value, 0, 28));
|
||||||
|
mu_assert_int_eq(0b00001001101100011000110001100, bit_lib_get_bits_64(value, 0, 29));
|
||||||
|
mu_assert_int_eq(0b000010011011000110001100011000, bit_lib_get_bits_64(value, 0, 30));
|
||||||
|
mu_assert_int_eq(0b0000100110110001100011000110001, bit_lib_get_bits_64(value, 0, 31));
|
||||||
|
mu_assert_int_eq(0b00001001101100011000110001100010, bit_lib_get_bits_64(value, 0, 32));
|
||||||
|
|
||||||
|
uint64_t res = bit_lib_get_bits_64(value, 0, 33);
|
||||||
|
uint64_t expected = 0b000010011011000110001100011000100;
|
||||||
|
mu_assert_mem_eq(&expected, &res, sizeof(expected));
|
||||||
|
|
||||||
|
res = bit_lib_get_bits_64(value, 0, 34);
|
||||||
|
expected = 0b0000100110110001100011000110001000;
|
||||||
|
mu_assert_mem_eq(&expected, &res, sizeof(expected));
|
||||||
|
|
||||||
|
res = bit_lib_get_bits_64(value, 0, 35);
|
||||||
|
expected = 0b00001001101100011000110001100010000;
|
||||||
|
mu_assert_mem_eq(&expected, &res, sizeof(expected));
|
||||||
|
|
||||||
|
res = bit_lib_get_bits_64(value, 0, 36);
|
||||||
|
expected = 0b000010011011000110001100011000100000;
|
||||||
|
mu_assert_mem_eq(&expected, &res, sizeof(expected));
|
||||||
|
|
||||||
|
res = bit_lib_get_bits_64(value, 0, 37);
|
||||||
|
expected = 0b0000100110110001100011000110001000001;
|
||||||
|
mu_assert_mem_eq(&expected, &res, sizeof(expected));
|
||||||
|
|
||||||
|
res = bit_lib_get_bits_64(value, 0, 38);
|
||||||
|
expected = 0b00001001101100011000110001100010000010;
|
||||||
|
mu_assert_mem_eq(&expected, &res, sizeof(expected));
|
||||||
|
|
||||||
|
res = bit_lib_get_bits_64(value, 0, 39);
|
||||||
|
expected = 0b000010011011000110001100011000100000100;
|
||||||
|
mu_assert_mem_eq(&expected, &res, sizeof(expected));
|
||||||
|
|
||||||
|
res = bit_lib_get_bits_64(value, 0, 40);
|
||||||
|
expected = 0b0000100110110001100011000110001000001001;
|
||||||
|
mu_assert_mem_eq(&expected, &res, sizeof(expected));
|
||||||
|
|
||||||
|
res = bit_lib_get_bits_64(value, 0, 41);
|
||||||
|
expected = 0b00001001101100011000110001100010000010011;
|
||||||
|
mu_assert_mem_eq(&expected, &res, sizeof(expected));
|
||||||
|
|
||||||
|
res = bit_lib_get_bits_64(value, 0, 42);
|
||||||
|
expected = 0b000010011011000110001100011000100000100110;
|
||||||
|
mu_assert_mem_eq(&expected, &res, sizeof(expected));
|
||||||
|
|
||||||
|
res = bit_lib_get_bits_64(value, 0, 43);
|
||||||
|
expected = 0b0000100110110001100011000110001000001001101;
|
||||||
|
mu_assert_mem_eq(&expected, &res, sizeof(expected));
|
||||||
|
|
||||||
|
res = bit_lib_get_bits_64(value, 0, 44);
|
||||||
|
expected = 0b00001001101100011000110001100010000010011011;
|
||||||
|
mu_assert_mem_eq(&expected, &res, sizeof(expected));
|
||||||
|
|
||||||
|
res = bit_lib_get_bits_64(value, 0, 45);
|
||||||
|
expected = 0b000010011011000110001100011000100000100110110;
|
||||||
|
mu_assert_mem_eq(&expected, &res, sizeof(expected));
|
||||||
|
|
||||||
|
res = bit_lib_get_bits_64(value, 0, 46);
|
||||||
|
expected = 0b0000100110110001100011000110001000001001101100;
|
||||||
|
mu_assert_mem_eq(&expected, &res, sizeof(expected));
|
||||||
|
|
||||||
|
res = bit_lib_get_bits_64(value, 0, 47);
|
||||||
|
expected = 0b00001001101100011000110001100010000010011011000;
|
||||||
|
mu_assert_mem_eq(&expected, &res, sizeof(expected));
|
||||||
|
|
||||||
|
res = bit_lib_get_bits_64(value, 0, 48);
|
||||||
|
expected = 0b000010011011000110001100011000100000100110110001;
|
||||||
|
mu_assert_mem_eq(&expected, &res, sizeof(expected));
|
||||||
|
|
||||||
|
res = bit_lib_get_bits_64(value, 0, 49);
|
||||||
|
expected = 0b0000100110110001100011000110001000001001101100011;
|
||||||
|
mu_assert_mem_eq(&expected, &res, sizeof(expected));
|
||||||
|
|
||||||
|
res = bit_lib_get_bits_64(value, 0, 50);
|
||||||
|
expected = 0b00001001101100011000110001100010000010011011000110;
|
||||||
|
mu_assert_mem_eq(&expected, &res, sizeof(expected));
|
||||||
|
|
||||||
|
res = bit_lib_get_bits_64(value, 0, 51);
|
||||||
|
expected = 0b000010011011000110001100011000100000100110110001100;
|
||||||
|
mu_assert_mem_eq(&expected, &res, sizeof(expected));
|
||||||
|
|
||||||
|
res = bit_lib_get_bits_64(value, 0, 52);
|
||||||
|
expected = 0b0000100110110001100011000110001000001001101100011000;
|
||||||
|
mu_assert_mem_eq(&expected, &res, sizeof(expected));
|
||||||
|
|
||||||
|
res = bit_lib_get_bits_64(value, 0, 53);
|
||||||
|
expected = 0b00001001101100011000110001100010000010011011000110001;
|
||||||
|
mu_assert_mem_eq(&expected, &res, sizeof(expected));
|
||||||
|
|
||||||
|
res = bit_lib_get_bits_64(value, 0, 54);
|
||||||
|
expected = 0b000010011011000110001100011000100000100110110001100011;
|
||||||
|
mu_assert_mem_eq(&expected, &res, sizeof(expected));
|
||||||
|
|
||||||
|
res = bit_lib_get_bits_64(value, 0, 55);
|
||||||
|
expected = 0b0000100110110001100011000110001000001001101100011000110;
|
||||||
|
mu_assert_mem_eq(&expected, &res, sizeof(expected));
|
||||||
|
|
||||||
|
res = bit_lib_get_bits_64(value, 0, 56);
|
||||||
|
expected = 0b00001001101100011000110001100010000010011011000110001100;
|
||||||
|
mu_assert_mem_eq(&expected, &res, sizeof(expected));
|
||||||
|
|
||||||
|
res = bit_lib_get_bits_64(value, 0, 57);
|
||||||
|
expected = 0b000010011011000110001100011000100000100110110001100011000;
|
||||||
|
mu_assert_mem_eq(&expected, &res, sizeof(expected));
|
||||||
|
|
||||||
|
res = bit_lib_get_bits_64(value, 0, 58);
|
||||||
|
expected = 0b0000100110110001100011000110001000001001101100011000110001;
|
||||||
|
mu_assert_mem_eq(&expected, &res, sizeof(expected));
|
||||||
|
|
||||||
|
res = bit_lib_get_bits_64(value, 0, 59);
|
||||||
|
expected = 0b00001001101100011000110001100010000010011011000110001100011;
|
||||||
|
mu_assert_mem_eq(&expected, &res, sizeof(expected));
|
||||||
|
|
||||||
|
res = bit_lib_get_bits_64(value, 0, 60);
|
||||||
|
expected = 0b000010011011000110001100011000100000100110110001100011000110;
|
||||||
|
mu_assert_mem_eq(&expected, &res, sizeof(expected));
|
||||||
|
|
||||||
|
res = bit_lib_get_bits_64(value, 0, 61);
|
||||||
|
expected = 0b0000100110110001100011000110001000001001101100011000110001100;
|
||||||
|
mu_assert_mem_eq(&expected, &res, sizeof(expected));
|
||||||
|
|
||||||
|
res = bit_lib_get_bits_64(value, 0, 62);
|
||||||
|
expected = 0b00001001101100011000110001100010000010011011000110001100011000;
|
||||||
|
mu_assert_mem_eq(&expected, &res, sizeof(expected));
|
||||||
|
|
||||||
|
res = bit_lib_get_bits_64(value, 0, 63);
|
||||||
|
expected = 0b000010011011000110001100011000100000100110110001100011000110001;
|
||||||
|
mu_assert_mem_eq(&expected, &res, sizeof(expected));
|
||||||
|
|
||||||
|
res = bit_lib_get_bits_64(value, 0, 64);
|
||||||
|
expected = 0b0000100110110001100011000110001000001001101100011000110001100010;
|
||||||
|
mu_assert_mem_eq(&expected, &res, sizeof(expected));
|
||||||
|
}
|
||||||
|
|
||||||
MU_TEST(test_bit_lib_test_parity_u32) {
|
MU_TEST(test_bit_lib_test_parity_u32) {
|
||||||
// test even parity
|
// test even parity
|
||||||
mu_assert_int_eq(bit_lib_test_parity_32(0b00000000, BitLibParityEven), 0);
|
mu_assert_int_eq(bit_lib_test_parity_32(0b00000000, BitLibParityEven), 0);
|
||||||
@ -447,6 +619,95 @@ MU_TEST(test_bit_lib_crc16) {
|
|||||||
mu_assert_int_eq(0x31C3, bit_lib_crc16(data, data_size, 0x1021, 0x0000, false, false, 0x0000));
|
mu_assert_int_eq(0x31C3, bit_lib_crc16(data, data_size, 0x1021, 0x0000, false, false, 0x0000));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
MU_TEST(test_bit_lib_num_to_bytes_be) {
|
||||||
|
uint8_t src[8] = {0x01, 0x23, 0x45, 0x67, 0x89, 0xAB, 0xCD, 0xEF};
|
||||||
|
uint8_t dest[8];
|
||||||
|
|
||||||
|
bit_lib_num_to_bytes_be(0x01, 1, dest);
|
||||||
|
mu_assert_mem_eq(src, dest, sizeof(src[0]));
|
||||||
|
|
||||||
|
bit_lib_num_to_bytes_be(0x0123456789ABCDEF, 4, dest);
|
||||||
|
mu_assert_mem_eq(src + 4, dest, 4 * sizeof(src[0]));
|
||||||
|
|
||||||
|
bit_lib_num_to_bytes_be(0x0123456789ABCDEF, 8, dest);
|
||||||
|
mu_assert_mem_eq(src, dest, 8 * sizeof(src[0]));
|
||||||
|
|
||||||
|
bit_lib_num_to_bytes_be(bit_lib_bytes_to_num_be(src, 8), 8, dest);
|
||||||
|
mu_assert_mem_eq(src, dest, 8 * sizeof(src[0]));
|
||||||
|
}
|
||||||
|
|
||||||
|
MU_TEST(test_bit_lib_num_to_bytes_le) {
|
||||||
|
uint8_t dest[8];
|
||||||
|
|
||||||
|
uint8_t n2b_le_expected_1[] = {0x01};
|
||||||
|
bit_lib_num_to_bytes_le(0x01, 1, dest);
|
||||||
|
mu_assert_mem_eq(n2b_le_expected_1, dest, sizeof(n2b_le_expected_1[0]));
|
||||||
|
|
||||||
|
uint8_t n2b_le_expected_2[] = {0xEF, 0xCD, 0xAB, 0x89};
|
||||||
|
bit_lib_num_to_bytes_le(0x0123456789ABCDEF, 4, dest);
|
||||||
|
mu_assert_mem_eq(n2b_le_expected_2, dest, 4 * sizeof(n2b_le_expected_2[0]));
|
||||||
|
|
||||||
|
uint8_t n2b_le_expected_3[] = {0xEF, 0xCD, 0xAB, 0x89, 0x67, 0x45, 0x23, 0x01};
|
||||||
|
bit_lib_num_to_bytes_le(0x0123456789ABCDEF, 8, dest);
|
||||||
|
mu_assert_mem_eq(n2b_le_expected_3, dest, 8 * sizeof(n2b_le_expected_3[0]));
|
||||||
|
|
||||||
|
bit_lib_num_to_bytes_le(bit_lib_bytes_to_num_le(n2b_le_expected_3, 8), 8, dest);
|
||||||
|
mu_assert_mem_eq(n2b_le_expected_3, dest, 8 * sizeof(n2b_le_expected_3[0]));
|
||||||
|
}
|
||||||
|
|
||||||
|
MU_TEST(test_bit_lib_bytes_to_num_be) {
|
||||||
|
uint8_t src[8] = {0x01, 0x23, 0x45, 0x67, 0x89, 0xAB, 0xCD, 0xEF};
|
||||||
|
uint64_t res;
|
||||||
|
|
||||||
|
res = bit_lib_bytes_to_num_be(src, 1);
|
||||||
|
mu_assert_int_eq(0x01, res);
|
||||||
|
|
||||||
|
res = bit_lib_bytes_to_num_be(src, 4);
|
||||||
|
mu_assert_int_eq(0x01234567, res);
|
||||||
|
|
||||||
|
res = bit_lib_bytes_to_num_be(src, 8);
|
||||||
|
uint64_t expected = 0x0123456789ABCDEF;
|
||||||
|
mu_assert_mem_eq(&expected, &res, sizeof(expected));
|
||||||
|
}
|
||||||
|
|
||||||
|
MU_TEST(test_bit_lib_bytes_to_num_le) {
|
||||||
|
uint8_t src[8] = {0x01, 0x23, 0x45, 0x67, 0x89, 0xAB, 0xCD, 0xEF};
|
||||||
|
uint64_t res;
|
||||||
|
|
||||||
|
res = bit_lib_bytes_to_num_le(src, 1);
|
||||||
|
mu_assert_int_eq(0x01, res);
|
||||||
|
|
||||||
|
res = bit_lib_bytes_to_num_le(src, 4);
|
||||||
|
mu_assert_int_eq(0x67452301, res);
|
||||||
|
|
||||||
|
res = bit_lib_bytes_to_num_le(src, 8);
|
||||||
|
uint64_t expected = 0xEFCDAB8967452301;
|
||||||
|
mu_assert_mem_eq(&expected, &res, sizeof(expected));
|
||||||
|
}
|
||||||
|
|
||||||
|
MU_TEST(test_bit_lib_bytes_to_num_bcd) {
|
||||||
|
uint8_t src[8] = {0x01, 0x23, 0x45, 0x67, 0x89, 0xAB, 0xCD, 0xEF};
|
||||||
|
uint64_t res;
|
||||||
|
bool is_bcd_res;
|
||||||
|
|
||||||
|
res = bit_lib_bytes_to_num_bcd(src, 1, &is_bcd_res);
|
||||||
|
mu_assert_int_eq(01, res);
|
||||||
|
mu_assert_int_eq(true, is_bcd_res);
|
||||||
|
|
||||||
|
res = bit_lib_bytes_to_num_bcd(src, 4, &is_bcd_res);
|
||||||
|
mu_assert_int_eq(1234567, res);
|
||||||
|
mu_assert_int_eq(true, is_bcd_res);
|
||||||
|
|
||||||
|
uint8_t digits[5] = {0x98, 0x76, 0x54, 0x32, 0x10};
|
||||||
|
uint64_t expected = 9876543210;
|
||||||
|
res = bit_lib_bytes_to_num_bcd(digits, 5, &is_bcd_res);
|
||||||
|
mu_assert_mem_eq(&expected, &res, sizeof(expected));
|
||||||
|
mu_assert_int_eq(true, is_bcd_res);
|
||||||
|
|
||||||
|
res = bit_lib_bytes_to_num_bcd(src, 8, &is_bcd_res);
|
||||||
|
mu_assert_int_eq(false, is_bcd_res);
|
||||||
|
}
|
||||||
|
|
||||||
MU_TEST_SUITE(test_bit_lib) {
|
MU_TEST_SUITE(test_bit_lib) {
|
||||||
MU_RUN_TEST(test_bit_lib_increment_index);
|
MU_RUN_TEST(test_bit_lib_increment_index);
|
||||||
MU_RUN_TEST(test_bit_lib_is_set);
|
MU_RUN_TEST(test_bit_lib_is_set);
|
||||||
@ -457,6 +718,7 @@ MU_TEST_SUITE(test_bit_lib) {
|
|||||||
MU_RUN_TEST(test_bit_lib_get_bits);
|
MU_RUN_TEST(test_bit_lib_get_bits);
|
||||||
MU_RUN_TEST(test_bit_lib_get_bits_16);
|
MU_RUN_TEST(test_bit_lib_get_bits_16);
|
||||||
MU_RUN_TEST(test_bit_lib_get_bits_32);
|
MU_RUN_TEST(test_bit_lib_get_bits_32);
|
||||||
|
MU_RUN_TEST(test_bit_lib_get_bits_64);
|
||||||
MU_RUN_TEST(test_bit_lib_test_parity_u32);
|
MU_RUN_TEST(test_bit_lib_test_parity_u32);
|
||||||
MU_RUN_TEST(test_bit_lib_test_parity);
|
MU_RUN_TEST(test_bit_lib_test_parity);
|
||||||
MU_RUN_TEST(test_bit_lib_remove_bit_every_nth);
|
MU_RUN_TEST(test_bit_lib_remove_bit_every_nth);
|
||||||
@ -465,6 +727,11 @@ MU_TEST_SUITE(test_bit_lib) {
|
|||||||
MU_RUN_TEST(test_bit_lib_get_bit_count);
|
MU_RUN_TEST(test_bit_lib_get_bit_count);
|
||||||
MU_RUN_TEST(test_bit_lib_reverse_16_fast);
|
MU_RUN_TEST(test_bit_lib_reverse_16_fast);
|
||||||
MU_RUN_TEST(test_bit_lib_crc16);
|
MU_RUN_TEST(test_bit_lib_crc16);
|
||||||
|
MU_RUN_TEST(test_bit_lib_num_to_bytes_be);
|
||||||
|
MU_RUN_TEST(test_bit_lib_num_to_bytes_le);
|
||||||
|
MU_RUN_TEST(test_bit_lib_bytes_to_num_be);
|
||||||
|
MU_RUN_TEST(test_bit_lib_bytes_to_num_le);
|
||||||
|
MU_RUN_TEST(test_bit_lib_bytes_to_num_bcd);
|
||||||
}
|
}
|
||||||
|
|
||||||
int run_minunit_test_bit_lib() {
|
int run_minunit_test_bit_lib() {
|
@ -2,7 +2,7 @@
|
|||||||
|
|
||||||
#include <m-array.h>
|
#include <m-array.h>
|
||||||
|
|
||||||
#include <nfc/helpers/nfc_util.h>
|
#include <bit_lib/bit_lib.h>
|
||||||
#include <stream/stream.h>
|
#include <stream/stream.h>
|
||||||
#include <stream/buffered_file_stream.h>
|
#include <stream/buffered_file_stream.h>
|
||||||
|
|
||||||
@ -63,9 +63,9 @@ static bool mfkey32_logger_add_nonce_to_existing_params(
|
|||||||
if(params->sector_num != sector_num) continue;
|
if(params->sector_num != sector_num) continue;
|
||||||
if(params->key_type != auth_context->key_type) continue;
|
if(params->key_type != auth_context->key_type) continue;
|
||||||
|
|
||||||
params->nt1 = nfc_util_bytes2num(auth_context->nt.data, sizeof(MfClassicNt));
|
params->nt1 = bit_lib_bytes_to_num_be(auth_context->nt.data, sizeof(MfClassicNt));
|
||||||
params->nr1 = nfc_util_bytes2num(auth_context->nr.data, sizeof(MfClassicNr));
|
params->nr1 = bit_lib_bytes_to_num_be(auth_context->nr.data, sizeof(MfClassicNr));
|
||||||
params->ar1 = nfc_util_bytes2num(auth_context->ar.data, sizeof(MfClassicAr));
|
params->ar1 = bit_lib_bytes_to_num_be(auth_context->ar.data, sizeof(MfClassicAr));
|
||||||
params->is_filled = true;
|
params->is_filled = true;
|
||||||
|
|
||||||
instance->params_collected++;
|
instance->params_collected++;
|
||||||
@ -90,9 +90,9 @@ void mfkey32_logger_add_nonce(Mfkey32Logger* instance, MfClassicAuthContext* aut
|
|||||||
.cuid = instance->cuid,
|
.cuid = instance->cuid,
|
||||||
.sector_num = sector_num,
|
.sector_num = sector_num,
|
||||||
.key_type = auth_context->key_type,
|
.key_type = auth_context->key_type,
|
||||||
.nt0 = nfc_util_bytes2num(auth_context->nt.data, sizeof(MfClassicNt)),
|
.nt0 = bit_lib_bytes_to_num_be(auth_context->nt.data, sizeof(MfClassicNt)),
|
||||||
.nr0 = nfc_util_bytes2num(auth_context->nr.data, sizeof(MfClassicNr)),
|
.nr0 = bit_lib_bytes_to_num_be(auth_context->nr.data, sizeof(MfClassicNr)),
|
||||||
.ar0 = nfc_util_bytes2num(auth_context->ar.data, sizeof(MfClassicAr)),
|
.ar0 = bit_lib_bytes_to_num_be(auth_context->ar.data, sizeof(MfClassicAr)),
|
||||||
};
|
};
|
||||||
Mfkey32LoggerParams_push_back(instance->params_arr, params);
|
Mfkey32LoggerParams_push_back(instance->params_arr, params);
|
||||||
instance->nonces_saves++;
|
instance->nonces_saves++;
|
||||||
|
@ -3,7 +3,7 @@
|
|||||||
#include <flipper_application/flipper_application.h>
|
#include <flipper_application/flipper_application.h>
|
||||||
|
|
||||||
#include <nfc/nfc_device.h>
|
#include <nfc/nfc_device.h>
|
||||||
#include <nfc/helpers/nfc_util.h>
|
#include <bit_lib/bit_lib.h>
|
||||||
#include <nfc/protocols/mf_classic/mf_classic_poller_sync.h>
|
#include <nfc/protocols/mf_classic/mf_classic_poller_sync.h>
|
||||||
|
|
||||||
#define TAG "Aime"
|
#define TAG "Aime"
|
||||||
@ -19,7 +19,7 @@ bool aime_verify(Nfc* nfc) {
|
|||||||
FURI_LOG_D(TAG, "Verifying sector %u", verify_sector);
|
FURI_LOG_D(TAG, "Verifying sector %u", verify_sector);
|
||||||
|
|
||||||
MfClassicKey key = {};
|
MfClassicKey key = {};
|
||||||
nfc_util_num2bytes(aime_key, COUNT_OF(key.data), key.data);
|
bit_lib_num_to_bytes_be(aime_key, COUNT_OF(key.data), key.data);
|
||||||
|
|
||||||
MfClassicAuthContext auth_ctx = {};
|
MfClassicAuthContext auth_ctx = {};
|
||||||
MfClassicError error =
|
MfClassicError error =
|
||||||
@ -53,9 +53,9 @@ static bool aime_read(Nfc* nfc, NfcDevice* device) {
|
|||||||
data->type = type;
|
data->type = type;
|
||||||
MfClassicDeviceKeys keys = {};
|
MfClassicDeviceKeys keys = {};
|
||||||
for(size_t i = 0; i < mf_classic_get_total_sectors_num(data->type); i++) {
|
for(size_t i = 0; i < mf_classic_get_total_sectors_num(data->type); i++) {
|
||||||
nfc_util_num2bytes(aime_key, sizeof(MfClassicKey), keys.key_a[i].data);
|
bit_lib_num_to_bytes_be(aime_key, sizeof(MfClassicKey), keys.key_a[i].data);
|
||||||
FURI_BIT_SET(keys.key_a_mask, i);
|
FURI_BIT_SET(keys.key_a_mask, i);
|
||||||
nfc_util_num2bytes(aime_key, sizeof(MfClassicKey), keys.key_b[i].data);
|
bit_lib_num_to_bytes_be(aime_key, sizeof(MfClassicKey), keys.key_b[i].data);
|
||||||
FURI_BIT_SET(keys.key_b_mask, i);
|
FURI_BIT_SET(keys.key_b_mask, i);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -85,7 +85,7 @@ static bool aime_parse(const NfcDevice* device, FuriString* parsed_data) {
|
|||||||
do {
|
do {
|
||||||
// verify key
|
// verify key
|
||||||
MfClassicSectorTrailer* sec_tr = mf_classic_get_sector_trailer_by_sector(data, 0);
|
MfClassicSectorTrailer* sec_tr = mf_classic_get_sector_trailer_by_sector(data, 0);
|
||||||
uint64_t key = nfc_util_bytes2num(sec_tr->key_a.data, 6);
|
uint64_t key = bit_lib_bytes_to_num_be(sec_tr->key_a.data, 6);
|
||||||
if(key != aime_key) break;
|
if(key != aime_key) break;
|
||||||
|
|
||||||
// Aime Magic is stored at block 1, starts from byte 0, len 4 bytes
|
// Aime Magic is stored at block 1, starts from byte 0, len 4 bytes
|
||||||
|
@ -22,7 +22,7 @@
|
|||||||
|
|
||||||
#include <flipper_application/flipper_application.h>
|
#include <flipper_application/flipper_application.h>
|
||||||
#include <lib/nfc/protocols/mf_desfire/mf_desfire.h>
|
#include <lib/nfc/protocols/mf_desfire/mf_desfire.h>
|
||||||
#include <lib/nfc/helpers/nfc_util.h>
|
#include <bit_lib/bit_lib.h>
|
||||||
#include <applications/services/locale/locale.h>
|
#include <applications/services/locale/locale.h>
|
||||||
#include <furi_hal_rtc.h>
|
#include <furi_hal_rtc.h>
|
||||||
#include <inttypes.h>
|
#include <inttypes.h>
|
||||||
@ -194,12 +194,12 @@ static bool dump_ride_event(const uint8_t* record, FuriString* parsed_data);
|
|||||||
|
|
||||||
// Unmarshal a 32-bit integer, big endian, unsigned
|
// Unmarshal a 32-bit integer, big endian, unsigned
|
||||||
static inline uint32_t get_u32be(const uint8_t* field) {
|
static inline uint32_t get_u32be(const uint8_t* field) {
|
||||||
return nfc_util_bytes2num(field, 4);
|
return bit_lib_bytes_to_num_be(field, 4);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Unmarshal a 16-bit integer, big endian, unsigned
|
// Unmarshal a 16-bit integer, big endian, unsigned
|
||||||
static uint16_t get_u16be(const uint8_t* field) {
|
static uint16_t get_u16be(const uint8_t* field) {
|
||||||
return nfc_util_bytes2num(field, 2);
|
return bit_lib_bytes_to_num_be(field, 2);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Unmarshal a 16-bit integer, big endian, signed, two's-complement
|
// Unmarshal a 16-bit integer, big endian, signed, two's-complement
|
||||||
@ -330,7 +330,7 @@ static bool decode_id_file(const uint8_t* ef8_data, ClipperCardInfo* info) {
|
|||||||
// uk ?8?? Unknown, 8-bit byte
|
// uk ?8?? Unknown, 8-bit byte
|
||||||
// card_id U32BE Card identifier
|
// card_id U32BE Card identifier
|
||||||
//
|
//
|
||||||
info->serial_number = nfc_util_bytes2num(&ef8_data[1], 4);
|
info->serial_number = bit_lib_bytes_to_num_be(&ef8_data[1], 4);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -10,7 +10,7 @@
|
|||||||
#include <flipper_application/flipper_application.h>
|
#include <flipper_application/flipper_application.h>
|
||||||
#include <nfc/protocols/mf_classic/mf_classic.h>
|
#include <nfc/protocols/mf_classic/mf_classic.h>
|
||||||
#include <nfc/protocols/mf_classic/mf_classic_poller_sync.h>
|
#include <nfc/protocols/mf_classic/mf_classic_poller_sync.h>
|
||||||
#include <nfc/helpers/nfc_util.h>
|
#include <bit_lib/bit_lib.h>
|
||||||
|
|
||||||
static bool gallagher_parse(const NfcDevice* device, FuriString* parsed_data) {
|
static bool gallagher_parse(const NfcDevice* device, FuriString* parsed_data) {
|
||||||
furi_assert(device);
|
furi_assert(device);
|
||||||
@ -30,8 +30,9 @@ static bool gallagher_parse(const NfcDevice* device, FuriString* parsed_data) {
|
|||||||
// Test 1: The first 8 bytes and the second 8 bytes should be bitwise inverses.
|
// Test 1: The first 8 bytes and the second 8 bytes should be bitwise inverses.
|
||||||
const uint8_t* credential_block_start_ptr =
|
const uint8_t* credential_block_start_ptr =
|
||||||
&data->block[credential_sector_start_block_number].data[0];
|
&data->block[credential_sector_start_block_number].data[0];
|
||||||
uint64_t cardholder_credential = nfc_util_bytes2num(credential_block_start_ptr, 8);
|
uint64_t cardholder_credential = bit_lib_bytes_to_num_be(credential_block_start_ptr, 8);
|
||||||
uint64_t cardholder_credential_inverse = nfc_util_bytes2num(credential_block_start_ptr + 8, 8);
|
uint64_t cardholder_credential_inverse =
|
||||||
|
bit_lib_bytes_to_num_be(credential_block_start_ptr + 8, 8);
|
||||||
// Due to endianness, this is testing the bytes in the wrong order,
|
// Due to endianness, this is testing the bytes in the wrong order,
|
||||||
// but the result still should be correct.
|
// but the result still should be correct.
|
||||||
if(cardholder_credential != ~cardholder_credential_inverse) {
|
if(cardholder_credential != ~cardholder_credential_inverse) {
|
||||||
|
@ -1,9 +1,8 @@
|
|||||||
#include "nfc_supported_card_plugin.h"
|
#include "nfc_supported_card_plugin.h"
|
||||||
#include <flipper_application/flipper_application.h>
|
#include <flipper_application/flipper_application.h>
|
||||||
#include <nfc/nfc_device.h>
|
#include <nfc/nfc_device.h>
|
||||||
#include <nfc/helpers/nfc_util.h>
|
#include <bit_lib/bit_lib.h>
|
||||||
#include <nfc/protocols/mf_classic/mf_classic_poller_sync.h>
|
#include <nfc/protocols/mf_classic/mf_classic_poller_sync.h>
|
||||||
#include <stdint.h>
|
|
||||||
|
|
||||||
#define TAG "HI!"
|
#define TAG "HI!"
|
||||||
#define KEY_LENGTH 6
|
#define KEY_LENGTH 6
|
||||||
@ -91,7 +90,7 @@ static bool hi_verify_type(Nfc* nfc, MfClassicType type) {
|
|||||||
FURI_LOG_D(TAG, "Verifying sector %lu", cfg.verify_sector);
|
FURI_LOG_D(TAG, "Verifying sector %lu", cfg.verify_sector);
|
||||||
|
|
||||||
MfClassicKey key = {0};
|
MfClassicKey key = {0};
|
||||||
nfc_util_num2bytes(cfg.keys[cfg.verify_sector].b, COUNT_OF(key.data), key.data);
|
bit_lib_num_to_bytes_be(cfg.keys[cfg.verify_sector].b, COUNT_OF(key.data), key.data);
|
||||||
|
|
||||||
MfClassicAuthContext auth_context;
|
MfClassicAuthContext auth_context;
|
||||||
MfClassicError error =
|
MfClassicError error =
|
||||||
@ -139,16 +138,16 @@ static bool hi_read(Nfc* nfc, NfcDevice* device) {
|
|||||||
|
|
||||||
for(size_t i = 0; i < mf_classic_get_total_sectors_num(data->type); i++) {
|
for(size_t i = 0; i < mf_classic_get_total_sectors_num(data->type); i++) {
|
||||||
if(cfg.keys[i].a == 0x000000000000 && cfg.keys[i].b == 0x000000000000) {
|
if(cfg.keys[i].a == 0x000000000000 && cfg.keys[i].b == 0x000000000000) {
|
||||||
cfg.keys[i].a = nfc_util_bytes2num(keyA[i], KEY_LENGTH);
|
cfg.keys[i].a = bit_lib_bytes_to_num_be(keyA[i], KEY_LENGTH);
|
||||||
cfg.keys[i].b = nfc_util_bytes2num(keyB[i], KEY_LENGTH);
|
cfg.keys[i].b = bit_lib_bytes_to_num_be(keyB[i], KEY_LENGTH);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
MfClassicDeviceKeys keys = {};
|
MfClassicDeviceKeys keys = {};
|
||||||
for(size_t i = 0; i < mf_classic_get_total_sectors_num(data->type); i++) {
|
for(size_t i = 0; i < mf_classic_get_total_sectors_num(data->type); i++) {
|
||||||
nfc_util_num2bytes(cfg.keys[i].a, sizeof(MfClassicKey), keys.key_a[i].data);
|
bit_lib_num_to_bytes_be(cfg.keys[i].a, sizeof(MfClassicKey), keys.key_a[i].data);
|
||||||
FURI_BIT_SET(keys.key_a_mask, i);
|
FURI_BIT_SET(keys.key_a_mask, i);
|
||||||
nfc_util_num2bytes(cfg.keys[i].b, sizeof(MfClassicKey), keys.key_b[i].data);
|
bit_lib_num_to_bytes_be(cfg.keys[i].b, sizeof(MfClassicKey), keys.key_b[i].data);
|
||||||
FURI_BIT_SET(keys.key_b_mask, i);
|
FURI_BIT_SET(keys.key_b_mask, i);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -184,7 +183,7 @@ static bool hi_parse(const NfcDevice* device, FuriString* parsed_data) {
|
|||||||
// Verify key
|
// Verify key
|
||||||
MfClassicSectorTrailer* sec_tr =
|
MfClassicSectorTrailer* sec_tr =
|
||||||
mf_classic_get_sector_trailer_by_sector(data, cfg.verify_sector);
|
mf_classic_get_sector_trailer_by_sector(data, cfg.verify_sector);
|
||||||
uint64_t key = nfc_util_bytes2num(sec_tr->key_b.data, 6);
|
uint64_t key = bit_lib_bytes_to_num_be(sec_tr->key_b.data, 6);
|
||||||
if(key != cfg.keys[cfg.verify_sector].b) return false;
|
if(key != cfg.keys[cfg.verify_sector].b) return false;
|
||||||
|
|
||||||
//Get UID
|
//Get UID
|
||||||
|
@ -3,7 +3,7 @@
|
|||||||
#include <flipper_application/flipper_application.h>
|
#include <flipper_application/flipper_application.h>
|
||||||
|
|
||||||
#include <nfc/nfc_device.h>
|
#include <nfc/nfc_device.h>
|
||||||
#include <nfc/helpers/nfc_util.h>
|
#include <bit_lib/bit_lib.h>
|
||||||
#include <nfc/protocols/mf_classic/mf_classic_poller_sync.h>
|
#include <nfc/protocols/mf_classic/mf_classic_poller_sync.h>
|
||||||
|
|
||||||
#define TAG "HID"
|
#define TAG "HID"
|
||||||
@ -19,7 +19,7 @@ bool hid_verify(Nfc* nfc) {
|
|||||||
FURI_LOG_D(TAG, "Verifying sector %u", verify_sector);
|
FURI_LOG_D(TAG, "Verifying sector %u", verify_sector);
|
||||||
|
|
||||||
MfClassicKey key = {};
|
MfClassicKey key = {};
|
||||||
nfc_util_num2bytes(hid_key, COUNT_OF(key.data), key.data);
|
bit_lib_num_to_bytes_be(hid_key, COUNT_OF(key.data), key.data);
|
||||||
|
|
||||||
MfClassicAuthContext auth_ctx = {};
|
MfClassicAuthContext auth_ctx = {};
|
||||||
MfClassicError error =
|
MfClassicError error =
|
||||||
@ -53,9 +53,9 @@ static bool hid_read(Nfc* nfc, NfcDevice* device) {
|
|||||||
data->type = type;
|
data->type = type;
|
||||||
MfClassicDeviceKeys keys = {};
|
MfClassicDeviceKeys keys = {};
|
||||||
for(size_t i = 0; i < mf_classic_get_total_sectors_num(data->type); i++) {
|
for(size_t i = 0; i < mf_classic_get_total_sectors_num(data->type); i++) {
|
||||||
nfc_util_num2bytes(hid_key, sizeof(MfClassicKey), keys.key_a[i].data);
|
bit_lib_num_to_bytes_be(hid_key, sizeof(MfClassicKey), keys.key_a[i].data);
|
||||||
FURI_BIT_SET(keys.key_a_mask, i);
|
FURI_BIT_SET(keys.key_a_mask, i);
|
||||||
nfc_util_num2bytes(hid_key, sizeof(MfClassicKey), keys.key_b[i].data);
|
bit_lib_num_to_bytes_be(hid_key, sizeof(MfClassicKey), keys.key_b[i].data);
|
||||||
FURI_BIT_SET(keys.key_b_mask, i);
|
FURI_BIT_SET(keys.key_b_mask, i);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -111,7 +111,7 @@ static bool hid_parse(const NfcDevice* device, FuriString* parsed_data) {
|
|||||||
const uint8_t verify_sector = 1;
|
const uint8_t verify_sector = 1;
|
||||||
MfClassicSectorTrailer* sec_tr =
|
MfClassicSectorTrailer* sec_tr =
|
||||||
mf_classic_get_sector_trailer_by_sector(data, verify_sector);
|
mf_classic_get_sector_trailer_by_sector(data, verify_sector);
|
||||||
uint64_t key = nfc_util_bytes2num(sec_tr->key_a.data, 6);
|
uint64_t key = bit_lib_bytes_to_num_be(sec_tr->key_a.data, 6);
|
||||||
if(key != hid_key) break;
|
if(key != hid_key) break;
|
||||||
|
|
||||||
// Currently doesn't support bit length > 63
|
// Currently doesn't support bit length > 63
|
||||||
|
@ -1,9 +1,8 @@
|
|||||||
#include "nfc_supported_card_plugin.h"
|
#include "nfc_supported_card_plugin.h"
|
||||||
#include <flipper_application/flipper_application.h>
|
#include <flipper_application/flipper_application.h>
|
||||||
#include <nfc/nfc_device.h>
|
#include <nfc/nfc_device.h>
|
||||||
#include <nfc/helpers/nfc_util.h>
|
#include <bit_lib/bit_lib.h>
|
||||||
#include <nfc/protocols/mf_classic/mf_classic_poller_sync.h>
|
#include <nfc/protocols/mf_classic/mf_classic_poller_sync.h>
|
||||||
#include <stdint.h>
|
|
||||||
|
|
||||||
#define TAG "Microel"
|
#define TAG "Microel"
|
||||||
#define KEY_LENGTH 6
|
#define KEY_LENGTH 6
|
||||||
@ -116,7 +115,8 @@ static bool microel_read(Nfc* nfc, NfcDevice* device) {
|
|||||||
|
|
||||||
// Check key 0a to verify if it is a microel card
|
// Check key 0a to verify if it is a microel card
|
||||||
MfClassicKey key = {0};
|
MfClassicKey key = {0};
|
||||||
nfc_util_num2bytes(nfc_util_bytes2num(keyA, KEY_LENGTH), COUNT_OF(key.data), key.data);
|
bit_lib_num_to_bytes_be(
|
||||||
|
bit_lib_bytes_to_num_be(keyA, KEY_LENGTH), COUNT_OF(key.data), key.data);
|
||||||
const uint8_t block_num = mf_classic_get_first_block_num_of_sector(0); // This is 0
|
const uint8_t block_num = mf_classic_get_first_block_num_of_sector(0); // This is 0
|
||||||
MfClassicAuthContext auth_context;
|
MfClassicAuthContext auth_context;
|
||||||
error =
|
error =
|
||||||
@ -128,17 +128,19 @@ static bool microel_read(Nfc* nfc, NfcDevice* device) {
|
|||||||
// Save keys generated to stucture
|
// Save keys generated to stucture
|
||||||
for(size_t i = 0; i < mf_classic_get_total_sectors_num(data->type); i++) {
|
for(size_t i = 0; i < mf_classic_get_total_sectors_num(data->type); i++) {
|
||||||
if(microel_1k_keys[i].a == 0x000000000000) {
|
if(microel_1k_keys[i].a == 0x000000000000) {
|
||||||
microel_1k_keys[i].a = nfc_util_bytes2num(keyA, KEY_LENGTH);
|
microel_1k_keys[i].a = bit_lib_bytes_to_num_be(keyA, KEY_LENGTH);
|
||||||
}
|
}
|
||||||
if(microel_1k_keys[i].b == 0x000000000000) {
|
if(microel_1k_keys[i].b == 0x000000000000) {
|
||||||
microel_1k_keys[i].b = nfc_util_bytes2num(keyB, KEY_LENGTH);
|
microel_1k_keys[i].b = bit_lib_bytes_to_num_be(keyB, KEY_LENGTH);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
MfClassicDeviceKeys keys = {};
|
MfClassicDeviceKeys keys = {};
|
||||||
for(size_t i = 0; i < mf_classic_get_total_sectors_num(data->type); i++) {
|
for(size_t i = 0; i < mf_classic_get_total_sectors_num(data->type); i++) {
|
||||||
nfc_util_num2bytes(microel_1k_keys[i].a, sizeof(MfClassicKey), keys.key_a[i].data);
|
bit_lib_num_to_bytes_be(
|
||||||
|
microel_1k_keys[i].a, sizeof(MfClassicKey), keys.key_a[i].data);
|
||||||
FURI_BIT_SET(keys.key_a_mask, i);
|
FURI_BIT_SET(keys.key_a_mask, i);
|
||||||
nfc_util_num2bytes(microel_1k_keys[i].b, sizeof(MfClassicKey), keys.key_b[i].data);
|
bit_lib_num_to_bytes_be(
|
||||||
|
microel_1k_keys[i].b, sizeof(MfClassicKey), keys.key_b[i].data);
|
||||||
FURI_BIT_SET(keys.key_b_mask, i);
|
FURI_BIT_SET(keys.key_b_mask, i);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -179,8 +181,8 @@ static bool microel_parse(const NfcDevice* device, FuriString* parsed_data) {
|
|||||||
// Verify key
|
// Verify key
|
||||||
MfClassicSectorTrailer* sec_tr =
|
MfClassicSectorTrailer* sec_tr =
|
||||||
mf_classic_get_sector_trailer_by_sector(data, verify_sector);
|
mf_classic_get_sector_trailer_by_sector(data, verify_sector);
|
||||||
uint64_t key = nfc_util_bytes2num(sec_tr->key_a.data, 6);
|
uint64_t key = bit_lib_bytes_to_num_be(sec_tr->key_a.data, 6);
|
||||||
uint64_t key_for_check_from_array = nfc_util_bytes2num(keyA, KEY_LENGTH);
|
uint64_t key_for_check_from_array = bit_lib_bytes_to_num_be(keyA, KEY_LENGTH);
|
||||||
if(key != key_for_check_from_array) break;
|
if(key != key_for_check_from_array) break;
|
||||||
|
|
||||||
//Get credit in block number 8
|
//Get credit in block number 8
|
||||||
|
@ -1,9 +1,8 @@
|
|||||||
#include "nfc_supported_card_plugin.h"
|
#include "nfc_supported_card_plugin.h"
|
||||||
#include <flipper_application/flipper_application.h>
|
#include <flipper_application/flipper_application.h>
|
||||||
#include <nfc/nfc_device.h>
|
#include <nfc/nfc_device.h>
|
||||||
#include <nfc/helpers/nfc_util.h>
|
#include <bit_lib/bit_lib.h>
|
||||||
#include <nfc/protocols/mf_classic/mf_classic_poller_sync.h>
|
#include <nfc/protocols/mf_classic/mf_classic_poller_sync.h>
|
||||||
#include <stdint.h>
|
|
||||||
|
|
||||||
#define TAG "MiZIP"
|
#define TAG "MiZIP"
|
||||||
#define KEY_LENGTH 6
|
#define KEY_LENGTH 6
|
||||||
@ -102,7 +101,7 @@ static bool mizip_verify_type(Nfc* nfc, MfClassicType type) {
|
|||||||
FURI_LOG_D(TAG, "Verifying sector %lu", cfg.verify_sector);
|
FURI_LOG_D(TAG, "Verifying sector %lu", cfg.verify_sector);
|
||||||
|
|
||||||
MfClassicKey key = {0};
|
MfClassicKey key = {0};
|
||||||
nfc_util_num2bytes(cfg.keys[cfg.verify_sector].b, COUNT_OF(key.data), key.data);
|
bit_lib_num_to_bytes_be(cfg.keys[cfg.verify_sector].b, COUNT_OF(key.data), key.data);
|
||||||
|
|
||||||
MfClassicAuthContext auth_context;
|
MfClassicAuthContext auth_context;
|
||||||
MfClassicError error =
|
MfClassicError error =
|
||||||
@ -152,16 +151,16 @@ static bool mizip_read(Nfc* nfc, NfcDevice* device) {
|
|||||||
|
|
||||||
for(size_t i = 0; i < mf_classic_get_total_sectors_num(data->type); i++) {
|
for(size_t i = 0; i < mf_classic_get_total_sectors_num(data->type); i++) {
|
||||||
if(cfg.keys[i].a == 0x000000000000 && cfg.keys[i].b == 0x000000000000) {
|
if(cfg.keys[i].a == 0x000000000000 && cfg.keys[i].b == 0x000000000000) {
|
||||||
cfg.keys[i].a = nfc_util_bytes2num(keyA[i], KEY_LENGTH);
|
cfg.keys[i].a = bit_lib_bytes_to_num_be(keyA[i], KEY_LENGTH);
|
||||||
cfg.keys[i].b = nfc_util_bytes2num(keyB[i], KEY_LENGTH);
|
cfg.keys[i].b = bit_lib_bytes_to_num_be(keyB[i], KEY_LENGTH);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
MfClassicDeviceKeys keys = {};
|
MfClassicDeviceKeys keys = {};
|
||||||
for(size_t i = 0; i < mf_classic_get_total_sectors_num(data->type); i++) {
|
for(size_t i = 0; i < mf_classic_get_total_sectors_num(data->type); i++) {
|
||||||
nfc_util_num2bytes(cfg.keys[i].a, sizeof(MfClassicKey), keys.key_a[i].data);
|
bit_lib_num_to_bytes_be(cfg.keys[i].a, sizeof(MfClassicKey), keys.key_a[i].data);
|
||||||
FURI_BIT_SET(keys.key_a_mask, i);
|
FURI_BIT_SET(keys.key_a_mask, i);
|
||||||
nfc_util_num2bytes(cfg.keys[i].b, sizeof(MfClassicKey), keys.key_b[i].data);
|
bit_lib_num_to_bytes_be(cfg.keys[i].b, sizeof(MfClassicKey), keys.key_b[i].data);
|
||||||
FURI_BIT_SET(keys.key_b_mask, i);
|
FURI_BIT_SET(keys.key_b_mask, i);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -197,7 +196,7 @@ static bool mizip_parse(const NfcDevice* device, FuriString* parsed_data) {
|
|||||||
// Verify key
|
// Verify key
|
||||||
MfClassicSectorTrailer* sec_tr =
|
MfClassicSectorTrailer* sec_tr =
|
||||||
mf_classic_get_sector_trailer_by_sector(data, cfg.verify_sector);
|
mf_classic_get_sector_trailer_by_sector(data, cfg.verify_sector);
|
||||||
uint64_t key = nfc_util_bytes2num(sec_tr->key_b.data, 6);
|
uint64_t key = bit_lib_bytes_to_num_be(sec_tr->key_b.data, 6);
|
||||||
if(key != cfg.keys[cfg.verify_sector].b) return false;
|
if(key != cfg.keys[cfg.verify_sector].b) return false;
|
||||||
|
|
||||||
//Get UID
|
//Get UID
|
||||||
|
@ -3,7 +3,7 @@
|
|||||||
#include <flipper_application/flipper_application.h>
|
#include <flipper_application/flipper_application.h>
|
||||||
|
|
||||||
#include <nfc/nfc_device.h>
|
#include <nfc/nfc_device.h>
|
||||||
#include <nfc/helpers/nfc_util.h>
|
#include <bit_lib/bit_lib.h>
|
||||||
#include <nfc/protocols/mf_classic/mf_classic_poller_sync.h>
|
#include <nfc/protocols/mf_classic/mf_classic_poller_sync.h>
|
||||||
|
|
||||||
#define TAG "Plantain"
|
#define TAG "Plantain"
|
||||||
@ -87,7 +87,7 @@ static bool plantain_verify_type(Nfc* nfc, MfClassicType type) {
|
|||||||
FURI_LOG_D(TAG, "Verifying sector %lu", cfg.data_sector);
|
FURI_LOG_D(TAG, "Verifying sector %lu", cfg.data_sector);
|
||||||
|
|
||||||
MfClassicKey key = {0};
|
MfClassicKey key = {0};
|
||||||
nfc_util_num2bytes(cfg.keys[cfg.data_sector].a, COUNT_OF(key.data), key.data);
|
bit_lib_num_to_bytes_be(cfg.keys[cfg.data_sector].a, COUNT_OF(key.data), key.data);
|
||||||
|
|
||||||
MfClassicAuthContext auth_context;
|
MfClassicAuthContext auth_context;
|
||||||
MfClassicError error =
|
MfClassicError error =
|
||||||
@ -128,9 +128,9 @@ static bool plantain_read(Nfc* nfc, NfcDevice* device) {
|
|||||||
|
|
||||||
MfClassicDeviceKeys keys = {};
|
MfClassicDeviceKeys keys = {};
|
||||||
for(size_t i = 0; i < mf_classic_get_total_sectors_num(data->type); i++) {
|
for(size_t i = 0; i < mf_classic_get_total_sectors_num(data->type); i++) {
|
||||||
nfc_util_num2bytes(cfg.keys[i].a, sizeof(MfClassicKey), keys.key_a[i].data);
|
bit_lib_num_to_bytes_be(cfg.keys[i].a, sizeof(MfClassicKey), keys.key_a[i].data);
|
||||||
FURI_BIT_SET(keys.key_a_mask, i);
|
FURI_BIT_SET(keys.key_a_mask, i);
|
||||||
nfc_util_num2bytes(cfg.keys[i].b, sizeof(MfClassicKey), keys.key_b[i].data);
|
bit_lib_num_to_bytes_be(cfg.keys[i].b, sizeof(MfClassicKey), keys.key_b[i].data);
|
||||||
FURI_BIT_SET(keys.key_b_mask, i);
|
FURI_BIT_SET(keys.key_b_mask, i);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -166,7 +166,8 @@ static bool plantain_parse(const NfcDevice* device, FuriString* parsed_data) {
|
|||||||
const MfClassicSectorTrailer* sec_tr =
|
const MfClassicSectorTrailer* sec_tr =
|
||||||
mf_classic_get_sector_trailer_by_sector(data, cfg.data_sector);
|
mf_classic_get_sector_trailer_by_sector(data, cfg.data_sector);
|
||||||
|
|
||||||
const uint64_t key = nfc_util_bytes2num(sec_tr->key_a.data, COUNT_OF(sec_tr->key_a.data));
|
const uint64_t key =
|
||||||
|
bit_lib_bytes_to_num_be(sec_tr->key_a.data, COUNT_OF(sec_tr->key_a.data));
|
||||||
if(key != cfg.keys[cfg.data_sector].a) break;
|
if(key != cfg.keys[cfg.data_sector].a) break;
|
||||||
|
|
||||||
// Point to block 0 of sector 4, value 0
|
// Point to block 0 of sector 4, value 0
|
||||||
|
@ -3,7 +3,7 @@
|
|||||||
#include <flipper_application/flipper_application.h>
|
#include <flipper_application/flipper_application.h>
|
||||||
|
|
||||||
#include <nfc/nfc_device.h>
|
#include <nfc/nfc_device.h>
|
||||||
#include <nfc/helpers/nfc_util.h>
|
#include <bit_lib/bit_lib.h>
|
||||||
#include <nfc/protocols/mf_classic/mf_classic_poller_sync.h>
|
#include <nfc/protocols/mf_classic/mf_classic_poller_sync.h>
|
||||||
#include "furi_hal_rtc.h"
|
#include "furi_hal_rtc.h"
|
||||||
|
|
||||||
@ -221,7 +221,7 @@ static bool troika_verify_type(Nfc* nfc, MfClassicType type) {
|
|||||||
FURI_LOG_D(TAG, "Verifying sector %lu", cfg.data_sector);
|
FURI_LOG_D(TAG, "Verifying sector %lu", cfg.data_sector);
|
||||||
|
|
||||||
MfClassicKey key = {0};
|
MfClassicKey key = {0};
|
||||||
nfc_util_num2bytes(cfg.keys[cfg.data_sector].a, COUNT_OF(key.data), key.data);
|
bit_lib_num_to_bytes_be(cfg.keys[cfg.data_sector].a, COUNT_OF(key.data), key.data);
|
||||||
|
|
||||||
MfClassicAuthContext auth_context;
|
MfClassicAuthContext auth_context;
|
||||||
MfClassicError error =
|
MfClassicError error =
|
||||||
@ -264,9 +264,9 @@ static bool troika_read(Nfc* nfc, NfcDevice* device) {
|
|||||||
.key_b_mask = 0,
|
.key_b_mask = 0,
|
||||||
};
|
};
|
||||||
for(size_t i = 0; i < mf_classic_get_total_sectors_num(data->type); i++) {
|
for(size_t i = 0; i < mf_classic_get_total_sectors_num(data->type); i++) {
|
||||||
nfc_util_num2bytes(cfg.keys[i].a, sizeof(MfClassicKey), keys.key_a[i].data);
|
bit_lib_num_to_bytes_be(cfg.keys[i].a, sizeof(MfClassicKey), keys.key_a[i].data);
|
||||||
FURI_BIT_SET(keys.key_a_mask, i);
|
FURI_BIT_SET(keys.key_a_mask, i);
|
||||||
nfc_util_num2bytes(cfg.keys[i].b, sizeof(MfClassicKey), keys.key_b[i].data);
|
bit_lib_num_to_bytes_be(cfg.keys[i].b, sizeof(MfClassicKey), keys.key_b[i].data);
|
||||||
FURI_BIT_SET(keys.key_b_mask, i);
|
FURI_BIT_SET(keys.key_b_mask, i);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -302,7 +302,8 @@ static bool troika_parse(const NfcDevice* device, FuriString* parsed_data) {
|
|||||||
const MfClassicSectorTrailer* sec_tr =
|
const MfClassicSectorTrailer* sec_tr =
|
||||||
mf_classic_get_sector_trailer_by_sector(data, cfg.data_sector);
|
mf_classic_get_sector_trailer_by_sector(data, cfg.data_sector);
|
||||||
|
|
||||||
const uint64_t key = nfc_util_bytes2num(sec_tr->key_a.data, COUNT_OF(sec_tr->key_a.data));
|
const uint64_t key =
|
||||||
|
bit_lib_bytes_to_num_be(sec_tr->key_a.data, COUNT_OF(sec_tr->key_a.data));
|
||||||
if(key != cfg.keys[cfg.data_sector].a) break;
|
if(key != cfg.keys[cfg.data_sector].a) break;
|
||||||
|
|
||||||
// Get the block number of the block that contains the data
|
// Get the block number of the block that contains the data
|
||||||
|
@ -3,7 +3,7 @@
|
|||||||
#include <flipper_application/flipper_application.h>
|
#include <flipper_application/flipper_application.h>
|
||||||
|
|
||||||
#include <nfc/nfc_device.h>
|
#include <nfc/nfc_device.h>
|
||||||
#include <nfc/helpers/nfc_util.h>
|
#include <bit_lib/bit_lib.h>
|
||||||
#include <nfc/protocols/mf_classic/mf_classic_poller_sync.h>
|
#include <nfc/protocols/mf_classic/mf_classic_poller_sync.h>
|
||||||
|
|
||||||
#define TAG "TwoCities"
|
#define TAG "TwoCities"
|
||||||
@ -45,7 +45,7 @@ bool two_cities_verify(Nfc* nfc) {
|
|||||||
FURI_LOG_D(TAG, "Verifying sector %u", verify_sector);
|
FURI_LOG_D(TAG, "Verifying sector %u", verify_sector);
|
||||||
|
|
||||||
MfClassicKey key = {};
|
MfClassicKey key = {};
|
||||||
nfc_util_num2bytes(two_cities_4k_keys[verify_sector].a, COUNT_OF(key.data), key.data);
|
bit_lib_num_to_bytes_be(two_cities_4k_keys[verify_sector].a, COUNT_OF(key.data), key.data);
|
||||||
|
|
||||||
MfClassicAuthContext auth_ctx = {};
|
MfClassicAuthContext auth_ctx = {};
|
||||||
MfClassicError error =
|
MfClassicError error =
|
||||||
@ -78,9 +78,11 @@ static bool two_cities_read(Nfc* nfc, NfcDevice* device) {
|
|||||||
data->type = type;
|
data->type = type;
|
||||||
MfClassicDeviceKeys keys = {};
|
MfClassicDeviceKeys keys = {};
|
||||||
for(size_t i = 0; i < mf_classic_get_total_sectors_num(data->type); i++) {
|
for(size_t i = 0; i < mf_classic_get_total_sectors_num(data->type); i++) {
|
||||||
nfc_util_num2bytes(two_cities_4k_keys[i].a, sizeof(MfClassicKey), keys.key_a[i].data);
|
bit_lib_num_to_bytes_be(
|
||||||
|
two_cities_4k_keys[i].a, sizeof(MfClassicKey), keys.key_a[i].data);
|
||||||
FURI_BIT_SET(keys.key_a_mask, i);
|
FURI_BIT_SET(keys.key_a_mask, i);
|
||||||
nfc_util_num2bytes(two_cities_4k_keys[i].b, sizeof(MfClassicKey), keys.key_b[i].data);
|
bit_lib_num_to_bytes_be(
|
||||||
|
two_cities_4k_keys[i].b, sizeof(MfClassicKey), keys.key_b[i].data);
|
||||||
FURI_BIT_SET(keys.key_b_mask, i);
|
FURI_BIT_SET(keys.key_b_mask, i);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -110,7 +112,7 @@ static bool two_cities_parse(const NfcDevice* device, FuriString* parsed_data) {
|
|||||||
do {
|
do {
|
||||||
// Verify key
|
// Verify key
|
||||||
MfClassicSectorTrailer* sec_tr = mf_classic_get_sector_trailer_by_sector(data, 4);
|
MfClassicSectorTrailer* sec_tr = mf_classic_get_sector_trailer_by_sector(data, 4);
|
||||||
uint64_t key = nfc_util_bytes2num(sec_tr->key_a.data, 6);
|
uint64_t key = bit_lib_bytes_to_num_be(sec_tr->key_a.data, 6);
|
||||||
if(key != two_cities_4k_keys[4].a) return false;
|
if(key != two_cities_4k_keys[4].a) return false;
|
||||||
|
|
||||||
// =====
|
// =====
|
||||||
|
@ -30,7 +30,7 @@
|
|||||||
#include <flipper_application/flipper_application.h>
|
#include <flipper_application/flipper_application.h>
|
||||||
|
|
||||||
#include <nfc/nfc_device.h>
|
#include <nfc/nfc_device.h>
|
||||||
#include <nfc/helpers/nfc_util.h>
|
#include <bit_lib/bit_lib.h>
|
||||||
#include <nfc/protocols/mf_classic/mf_classic_poller_sync.h>
|
#include <nfc/protocols/mf_classic/mf_classic_poller_sync.h>
|
||||||
|
|
||||||
#include <furi_hal_rtc.h>
|
#include <furi_hal_rtc.h>
|
||||||
@ -63,27 +63,27 @@ static bool umarsh_parse(const NfcDevice* device, FuriString* parsed_data) {
|
|||||||
// Validate specific for Umarsh ticket sector header
|
// Validate specific for Umarsh ticket sector header
|
||||||
const uint8_t* block_start_ptr = &data->block[ticket_sector_start_block_number].data[0];
|
const uint8_t* block_start_ptr = &data->block[ticket_sector_start_block_number].data[0];
|
||||||
|
|
||||||
const uint32_t header_part_0 = nfc_util_bytes2num(block_start_ptr, 4);
|
const uint32_t header_part_0 = bit_lib_bytes_to_num_be(block_start_ptr, 4);
|
||||||
const uint32_t header_part_1 = nfc_util_bytes2num(block_start_ptr + 4, 4);
|
const uint32_t header_part_1 = bit_lib_bytes_to_num_be(block_start_ptr + 4, 4);
|
||||||
if((header_part_0 + header_part_1) != 0xFFFFFFFF) break;
|
if((header_part_0 + header_part_1) != 0xFFFFFFFF) break;
|
||||||
|
|
||||||
// Data parsing from block 1
|
// Data parsing from block 1
|
||||||
block_start_ptr = &data->block[ticket_sector_start_block_number + 1].data[0];
|
block_start_ptr = &data->block[ticket_sector_start_block_number + 1].data[0];
|
||||||
const uint16_t expiry_date = nfc_util_bytes2num(block_start_ptr + 1, 2);
|
const uint16_t expiry_date = bit_lib_bytes_to_num_be(block_start_ptr + 1, 2);
|
||||||
const uint8_t region_number = (((block_start_ptr[8] >> 5) & 0x07) << 4) |
|
const uint8_t region_number = (((block_start_ptr[8] >> 5) & 0x07) << 4) |
|
||||||
(block_start_ptr[12] & 0x0F);
|
(block_start_ptr[12] & 0x0F);
|
||||||
const uint8_t refill_counter = nfc_util_bytes2num(block_start_ptr + 7, 1);
|
const uint8_t refill_counter = bit_lib_bytes_to_num_be(block_start_ptr + 7, 1);
|
||||||
const uint32_t card_number = nfc_util_bytes2num(block_start_ptr + 8, 4) & 0x3FFFFFFF;
|
const uint32_t card_number = bit_lib_bytes_to_num_be(block_start_ptr + 8, 4) & 0x3FFFFFFF;
|
||||||
|
|
||||||
if(card_number == 0) break;
|
if(card_number == 0) break;
|
||||||
|
|
||||||
// Data parsing from block 2
|
// Data parsing from block 2
|
||||||
block_start_ptr = &data->block[ticket_sector_start_block_number + 2].data[0];
|
block_start_ptr = &data->block[ticket_sector_start_block_number + 2].data[0];
|
||||||
const uint16_t valid_to = nfc_util_bytes2num(block_start_ptr, 2);
|
const uint16_t valid_to = bit_lib_bytes_to_num_be(block_start_ptr, 2);
|
||||||
const uint32_t terminal_number = nfc_util_bytes2num(block_start_ptr + 3, 3);
|
const uint32_t terminal_number = bit_lib_bytes_to_num_be(block_start_ptr + 3, 3);
|
||||||
const uint16_t last_refill_date = nfc_util_bytes2num(block_start_ptr + 6, 2);
|
const uint16_t last_refill_date = bit_lib_bytes_to_num_be(block_start_ptr + 6, 2);
|
||||||
const uint16_t balance_rub = (nfc_util_bytes2num(block_start_ptr + 8, 2)) & 0x7FFF;
|
const uint16_t balance_rub = (bit_lib_bytes_to_num_be(block_start_ptr + 8, 2)) & 0x7FFF;
|
||||||
const uint8_t balance_kop = nfc_util_bytes2num(block_start_ptr + 10, 1) & 0x7F;
|
const uint8_t balance_kop = bit_lib_bytes_to_num_be(block_start_ptr + 10, 1) & 0x7F;
|
||||||
|
|
||||||
FuriHalRtcDateTime expiry_datetime;
|
FuriHalRtcDateTime expiry_datetime;
|
||||||
bool is_expiry_datetime_valid = parse_datetime(expiry_date, &expiry_datetime);
|
bool is_expiry_datetime_valid = parse_datetime(expiry_date, &expiry_datetime);
|
||||||
|
@ -24,7 +24,7 @@
|
|||||||
#include <flipper_application/flipper_application.h>
|
#include <flipper_application/flipper_application.h>
|
||||||
|
|
||||||
#include <nfc/nfc_device.h>
|
#include <nfc/nfc_device.h>
|
||||||
#include <nfc/helpers/nfc_util.h>
|
#include <bit_lib/bit_lib.h>
|
||||||
#include <nfc/protocols/mf_classic/mf_classic_poller_sync.h>
|
#include <nfc/protocols/mf_classic/mf_classic_poller_sync.h>
|
||||||
|
|
||||||
#define TAG "WashCity"
|
#define TAG "WashCity"
|
||||||
@ -63,7 +63,8 @@ static bool washcity_verify(Nfc* nfc) {
|
|||||||
FURI_LOG_D(TAG, "Verifying sector %u", ticket_sector_number);
|
FURI_LOG_D(TAG, "Verifying sector %u", ticket_sector_number);
|
||||||
|
|
||||||
MfClassicKey key = {0};
|
MfClassicKey key = {0};
|
||||||
nfc_util_num2bytes(washcity_1k_keys[ticket_sector_number].a, COUNT_OF(key.data), key.data);
|
bit_lib_num_to_bytes_be(
|
||||||
|
washcity_1k_keys[ticket_sector_number].a, COUNT_OF(key.data), key.data);
|
||||||
|
|
||||||
MfClassicAuthContext auth_context;
|
MfClassicAuthContext auth_context;
|
||||||
MfClassicError error = mf_classic_poller_sync_auth(
|
MfClassicError error = mf_classic_poller_sync_auth(
|
||||||
@ -101,9 +102,11 @@ static bool washcity_read(Nfc* nfc, NfcDevice* device) {
|
|||||||
.key_b_mask = 0,
|
.key_b_mask = 0,
|
||||||
};
|
};
|
||||||
for(size_t i = 0; i < mf_classic_get_total_sectors_num(data->type); i++) {
|
for(size_t i = 0; i < mf_classic_get_total_sectors_num(data->type); i++) {
|
||||||
nfc_util_num2bytes(washcity_1k_keys[i].a, sizeof(MfClassicKey), keys.key_a[i].data);
|
bit_lib_num_to_bytes_be(
|
||||||
|
washcity_1k_keys[i].a, sizeof(MfClassicKey), keys.key_a[i].data);
|
||||||
FURI_BIT_SET(keys.key_a_mask, i);
|
FURI_BIT_SET(keys.key_a_mask, i);
|
||||||
nfc_util_num2bytes(washcity_1k_keys[i].b, sizeof(MfClassicKey), keys.key_b[i].data);
|
bit_lib_num_to_bytes_be(
|
||||||
|
washcity_1k_keys[i].b, sizeof(MfClassicKey), keys.key_b[i].data);
|
||||||
FURI_BIT_SET(keys.key_b_mask, i);
|
FURI_BIT_SET(keys.key_b_mask, i);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -138,7 +141,8 @@ static bool washcity_parse(const NfcDevice* device, FuriString* parsed_data) {
|
|||||||
const MfClassicSectorTrailer* sec_tr =
|
const MfClassicSectorTrailer* sec_tr =
|
||||||
mf_classic_get_sector_trailer_by_sector(data, ticket_sector_number);
|
mf_classic_get_sector_trailer_by_sector(data, ticket_sector_number);
|
||||||
|
|
||||||
const uint64_t key = nfc_util_bytes2num(sec_tr->key_a.data, COUNT_OF(sec_tr->key_a.data));
|
const uint64_t key =
|
||||||
|
bit_lib_bytes_to_num_be(sec_tr->key_a.data, COUNT_OF(sec_tr->key_a.data));
|
||||||
if(key != washcity_1k_keys[ticket_sector_number].a) break;
|
if(key != washcity_1k_keys[ticket_sector_number].a) break;
|
||||||
|
|
||||||
// Parse data
|
// Parse data
|
||||||
@ -148,7 +152,7 @@ static bool washcity_parse(const NfcDevice* device, FuriString* parsed_data) {
|
|||||||
const uint8_t* block_start_ptr =
|
const uint8_t* block_start_ptr =
|
||||||
&data->block[start_block_num + ticket_block_number].data[0];
|
&data->block[start_block_num + ticket_block_number].data[0];
|
||||||
|
|
||||||
uint32_t balance = nfc_util_bytes2num(block_start_ptr + 2, 2);
|
uint32_t balance = bit_lib_bytes_to_num_be(block_start_ptr + 2, 2);
|
||||||
|
|
||||||
uint32_t balance_eur = balance / 100;
|
uint32_t balance_eur = balance / 100;
|
||||||
uint8_t balance_cents = balance % 100;
|
uint8_t balance_cents = balance % 100;
|
||||||
@ -157,7 +161,7 @@ static bool washcity_parse(const NfcDevice* device, FuriString* parsed_data) {
|
|||||||
const uint8_t* uid = mf_classic_get_uid(data, &uid_len);
|
const uint8_t* uid = mf_classic_get_uid(data, &uid_len);
|
||||||
|
|
||||||
// Card Number is printed in HEX (equal to UID)
|
// Card Number is printed in HEX (equal to UID)
|
||||||
uint64_t card_number = nfc_util_bytes2num(uid, uid_len);
|
uint64_t card_number = bit_lib_bytes_to_num_be(uid, uid_len);
|
||||||
|
|
||||||
furi_string_printf(
|
furi_string_printf(
|
||||||
parsed_data,
|
parsed_data,
|
||||||
|
@ -1,11 +1,12 @@
|
|||||||
#include "../nfc_app_i.h"
|
#include "../nfc_app_i.h"
|
||||||
|
|
||||||
#include <nfc/helpers/nfc_util.h>
|
#include <bit_lib/bit_lib.h>
|
||||||
|
|
||||||
void nfc_scene_slix_key_input_byte_input_callback(void* context) {
|
void nfc_scene_slix_key_input_byte_input_callback(void* context) {
|
||||||
NfcApp* instance = context;
|
NfcApp* instance = context;
|
||||||
|
|
||||||
SlixPassword password = nfc_util_bytes2num(instance->byte_input_store, sizeof(SlixPassword));
|
SlixPassword password =
|
||||||
|
bit_lib_bytes_to_num_be(instance->byte_input_store, sizeof(SlixPassword));
|
||||||
slix_unlock_set_password(instance->slix_unlock, password);
|
slix_unlock_set_password(instance->slix_unlock, password);
|
||||||
view_dispatcher_send_custom_event(instance->view_dispatcher, NfcCustomEventByteInputDone);
|
view_dispatcher_send_custom_event(instance->view_dispatcher, NfcCustomEventByteInputDone);
|
||||||
}
|
}
|
||||||
|
@ -3,6 +3,7 @@
|
|||||||
- `FreeRTOS-Kernel` - FreeRTOS kernel source code
|
- `FreeRTOS-Kernel` - FreeRTOS kernel source code
|
||||||
- `FreeRTOS-glue` - Extra glue to hold together FreeRTOS kernel and flipper firmware
|
- `FreeRTOS-glue` - Extra glue to hold together FreeRTOS kernel and flipper firmware
|
||||||
- `app-scened-template` - C++ app library
|
- `app-scened-template` - C++ app library
|
||||||
|
- `bit_lib` - library for working with bits/bytes directly
|
||||||
- `callback-connector` - Callback connector library
|
- `callback-connector` - Callback connector library
|
||||||
- `cmsis_core` - CMSIS Core package, contain cortex-m core headers
|
- `cmsis_core` - CMSIS Core package, contain cortex-m core headers
|
||||||
- `cxxheaderparser` - C++ headers parser, used by SDK bundler
|
- `cxxheaderparser` - C++ headers parser, used by SDK bundler
|
||||||
|
@ -42,6 +42,7 @@ libs = env.BuildModules(
|
|||||||
"nanopb",
|
"nanopb",
|
||||||
"update_util",
|
"update_util",
|
||||||
"heatshrink",
|
"heatshrink",
|
||||||
|
"bit_lib",
|
||||||
],
|
],
|
||||||
)
|
)
|
||||||
|
|
||||||
|
22
lib/bit_lib/SConscript
Normal file
22
lib/bit_lib/SConscript
Normal file
@ -0,0 +1,22 @@
|
|||||||
|
Import("env")
|
||||||
|
|
||||||
|
env.Append(
|
||||||
|
LINT_SOURCES=[
|
||||||
|
Dir("."),
|
||||||
|
],
|
||||||
|
CPPPATH=[
|
||||||
|
"#/lib/bit_lib",
|
||||||
|
],
|
||||||
|
SDK_HEADERS=[
|
||||||
|
File("bit_lib.h"),
|
||||||
|
],
|
||||||
|
)
|
||||||
|
|
||||||
|
libenv = env.Clone(FW_LIB_NAME="bit_lib")
|
||||||
|
libenv.ApplyLibFlags()
|
||||||
|
|
||||||
|
sources = libenv.GlobRecursive("*.c*")
|
||||||
|
|
||||||
|
lib = libenv.StaticLibrary("${FW_LIB_NAME}", sources)
|
||||||
|
libenv.Install("${LIB_DIST_DIR}", lib)
|
||||||
|
Return("lib")
|
@ -78,6 +78,57 @@ uint32_t bit_lib_get_bits_32(const uint8_t* data, size_t position, uint8_t lengt
|
|||||||
return value;
|
return value;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
uint64_t bit_lib_get_bits_64(const uint8_t* data, size_t position, uint8_t length) {
|
||||||
|
uint64_t value = 0;
|
||||||
|
if(length <= 8) {
|
||||||
|
value = bit_lib_get_bits(data, position, length);
|
||||||
|
} else if(length <= 16) {
|
||||||
|
value = bit_lib_get_bits(data, position, 8) << (length - 8);
|
||||||
|
value |= bit_lib_get_bits(data, position + 8, length - 8);
|
||||||
|
} else if(length <= 24) {
|
||||||
|
value = bit_lib_get_bits(data, position, 8) << (length - 8);
|
||||||
|
value |= bit_lib_get_bits(data, position + 8, 8) << (length - 16);
|
||||||
|
value |= bit_lib_get_bits(data, position + 16, length - 16);
|
||||||
|
} else if(length <= 32) {
|
||||||
|
value = (uint64_t)bit_lib_get_bits(data, position, 8) << (length - 8);
|
||||||
|
value |= (uint64_t)bit_lib_get_bits(data, position + 8, 8) << (length - 16);
|
||||||
|
value |= (uint64_t)bit_lib_get_bits(data, position + 16, 8) << (length - 24);
|
||||||
|
value |= bit_lib_get_bits(data, position + 24, length - 24);
|
||||||
|
} else if(length <= 40) {
|
||||||
|
value = (uint64_t)bit_lib_get_bits(data, position, 8) << (length - 8);
|
||||||
|
value |= (uint64_t)bit_lib_get_bits(data, position + 8, 8) << (length - 16);
|
||||||
|
value |= (uint64_t)bit_lib_get_bits(data, position + 16, 8) << (length - 24);
|
||||||
|
value |= (uint64_t)bit_lib_get_bits(data, position + 24, 8) << (length - 32);
|
||||||
|
value |= bit_lib_get_bits(data, position + 32, length - 32);
|
||||||
|
} else if(length <= 48) {
|
||||||
|
value = (uint64_t)bit_lib_get_bits(data, position, 8) << (length - 8);
|
||||||
|
value |= (uint64_t)bit_lib_get_bits(data, position + 8, 8) << (length - 16);
|
||||||
|
value |= (uint64_t)bit_lib_get_bits(data, position + 16, 8) << (length - 24);
|
||||||
|
value |= (uint64_t)bit_lib_get_bits(data, position + 24, 8) << (length - 32);
|
||||||
|
value |= (uint64_t)bit_lib_get_bits(data, position + 32, 8) << (length - 40);
|
||||||
|
value |= bit_lib_get_bits(data, position + 40, length - 40);
|
||||||
|
} else if(length <= 56) {
|
||||||
|
value = (uint64_t)bit_lib_get_bits(data, position, 8) << (length - 8);
|
||||||
|
value |= (uint64_t)bit_lib_get_bits(data, position + 8, 8) << (length - 16);
|
||||||
|
value |= (uint64_t)bit_lib_get_bits(data, position + 16, 8) << (length - 24);
|
||||||
|
value |= (uint64_t)bit_lib_get_bits(data, position + 24, 8) << (length - 32);
|
||||||
|
value |= (uint64_t)bit_lib_get_bits(data, position + 32, 8) << (length - 40);
|
||||||
|
value |= (uint64_t)bit_lib_get_bits(data, position + 40, 8) << (length - 48);
|
||||||
|
value |= bit_lib_get_bits(data, position + 48, length - 48);
|
||||||
|
} else {
|
||||||
|
value = (uint64_t)bit_lib_get_bits(data, position, 8) << (length - 8);
|
||||||
|
value |= (uint64_t)bit_lib_get_bits(data, position + 8, 8) << (length - 16);
|
||||||
|
value |= (uint64_t)bit_lib_get_bits(data, position + 16, 8) << (length - 24);
|
||||||
|
value |= (uint64_t)bit_lib_get_bits(data, position + 24, 8) << (length - 32);
|
||||||
|
value |= (uint64_t)bit_lib_get_bits(data, position + 32, 8) << (length - 40);
|
||||||
|
value |= (uint64_t)bit_lib_get_bits(data, position + 40, 8) << (length - 48);
|
||||||
|
value |= (uint64_t)bit_lib_get_bits(data, position + 48, 8) << (length - 56);
|
||||||
|
value |= bit_lib_get_bits(data, position + 56, length - 56);
|
||||||
|
}
|
||||||
|
|
||||||
|
return value;
|
||||||
|
}
|
||||||
|
|
||||||
bool bit_lib_test_parity_32(uint32_t bits, BitLibParity parity) {
|
bool bit_lib_test_parity_32(uint32_t bits, BitLibParity parity) {
|
||||||
#if !defined __GNUC__
|
#if !defined __GNUC__
|
||||||
#error Please, implement parity test for non-GCC compilers
|
#error Please, implement parity test for non-GCC compilers
|
||||||
@ -365,3 +416,70 @@ uint16_t bit_lib_crc16(
|
|||||||
|
|
||||||
return crc;
|
return crc;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void bit_lib_num_to_bytes_be(uint64_t src, uint8_t len, uint8_t* dest) {
|
||||||
|
furi_assert(dest);
|
||||||
|
furi_assert(len <= 8);
|
||||||
|
|
||||||
|
while(len--) {
|
||||||
|
dest[len] = (uint8_t)src;
|
||||||
|
src >>= 8;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void bit_lib_num_to_bytes_le(uint64_t src, uint8_t len, uint8_t* dest) {
|
||||||
|
furi_assert(dest);
|
||||||
|
furi_assert(len <= 8);
|
||||||
|
|
||||||
|
for(int i = 0; i < len; i++) {
|
||||||
|
dest[i] = (uint8_t)(src >> (8 * i));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
uint64_t bit_lib_bytes_to_num_be(const uint8_t* src, uint8_t len) {
|
||||||
|
furi_assert(src);
|
||||||
|
furi_assert(len <= 8);
|
||||||
|
|
||||||
|
uint64_t res = 0;
|
||||||
|
while(len--) {
|
||||||
|
res = (res << 8) | (*src);
|
||||||
|
src++;
|
||||||
|
}
|
||||||
|
return res;
|
||||||
|
}
|
||||||
|
|
||||||
|
uint64_t bit_lib_bytes_to_num_le(const uint8_t* src, uint8_t len) {
|
||||||
|
furi_assert(src);
|
||||||
|
furi_assert(len <= 8);
|
||||||
|
|
||||||
|
uint64_t res = 0;
|
||||||
|
uint8_t shift = 0;
|
||||||
|
while(len--) {
|
||||||
|
res |= ((uint64_t)*src) << (8 * shift++);
|
||||||
|
src++;
|
||||||
|
}
|
||||||
|
return res;
|
||||||
|
}
|
||||||
|
|
||||||
|
uint64_t bit_lib_bytes_to_num_bcd(const uint8_t* src, uint8_t len, bool* is_bcd) {
|
||||||
|
furi_assert(src);
|
||||||
|
furi_assert(len <= 9);
|
||||||
|
|
||||||
|
uint64_t res = 0;
|
||||||
|
uint8_t nibble_1, nibble_2;
|
||||||
|
*is_bcd = true;
|
||||||
|
|
||||||
|
for(uint8_t i = 0; i < len; i++) {
|
||||||
|
nibble_1 = src[i] / 16;
|
||||||
|
nibble_2 = src[i] % 16;
|
||||||
|
if((nibble_1 > 9) || (nibble_2 > 9)) *is_bcd = false;
|
||||||
|
|
||||||
|
res *= 10;
|
||||||
|
res += nibble_1;
|
||||||
|
|
||||||
|
res *= 10;
|
||||||
|
res += nibble_2;
|
||||||
|
}
|
||||||
|
|
||||||
|
return res;
|
||||||
|
}
|
@ -90,6 +90,15 @@ uint16_t bit_lib_get_bits_16(const uint8_t* data, size_t position, uint8_t lengt
|
|||||||
*/
|
*/
|
||||||
uint32_t bit_lib_get_bits_32(const uint8_t* data, size_t position, uint8_t length);
|
uint32_t bit_lib_get_bits_32(const uint8_t* data, size_t position, uint8_t length);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Get the bits of a data, as uint64_t.
|
||||||
|
* @param data The data to get the bits from.
|
||||||
|
* @param position The position of the first bit.
|
||||||
|
* @param length The length of the bits.
|
||||||
|
* @return The bits.
|
||||||
|
*/
|
||||||
|
uint64_t bit_lib_get_bits_64(const uint8_t* data, size_t position, uint8_t length);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Test parity of given bits
|
* @brief Test parity of given bits
|
||||||
* @param bits Bits to test parity of
|
* @param bits Bits to test parity of
|
||||||
@ -267,6 +276,54 @@ uint16_t bit_lib_crc16(
|
|||||||
bool ref_out,
|
bool ref_out,
|
||||||
uint16_t xor_out);
|
uint16_t xor_out);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Convert number to bytes in big endian order
|
||||||
|
*
|
||||||
|
* @param src number to convert
|
||||||
|
* @param len max used bytes count
|
||||||
|
* @param dest destination
|
||||||
|
* @return void
|
||||||
|
*/
|
||||||
|
void bit_lib_num_to_bytes_be(uint64_t src, uint8_t len, uint8_t* dest);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Convert number to bytes in little endian order
|
||||||
|
*
|
||||||
|
* @param src number to convert
|
||||||
|
* @param len max used bytes count
|
||||||
|
* @param dest destination
|
||||||
|
* @return void
|
||||||
|
*/
|
||||||
|
void bit_lib_num_to_bytes_le(uint64_t src, uint8_t len, uint8_t* dest);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Convert bytes to number in big endian order
|
||||||
|
*
|
||||||
|
* @param src byte array
|
||||||
|
* @param len max used bytes count
|
||||||
|
* @return uint64_t
|
||||||
|
*/
|
||||||
|
uint64_t bit_lib_bytes_to_num_be(const uint8_t* src, uint8_t len);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Convert bytes to number in little endian order
|
||||||
|
*
|
||||||
|
* @param src byte array
|
||||||
|
* @param len max used bytes count
|
||||||
|
* @return uint64_t
|
||||||
|
*/
|
||||||
|
uint64_t bit_lib_bytes_to_num_le(const uint8_t* src, uint8_t len);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Convert bytes in binary-coded decimal encoding to number
|
||||||
|
*
|
||||||
|
* @param src byte array
|
||||||
|
* @param len max used bytes count
|
||||||
|
* @param is_bcd will be true if all processed bytes is BCD encoded (no A-F nibbles)
|
||||||
|
* @return uint64_t
|
||||||
|
*/
|
||||||
|
uint64_t bit_lib_bytes_to_num_bcd(const uint8_t* src, uint8_t len, bool* is_bcd);
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
@ -12,7 +12,6 @@ env.Append(
|
|||||||
File("lfrfid_raw_worker.h"),
|
File("lfrfid_raw_worker.h"),
|
||||||
File("lfrfid_raw_file.h"),
|
File("lfrfid_raw_file.h"),
|
||||||
File("lfrfid_dict_file.h"),
|
File("lfrfid_dict_file.h"),
|
||||||
File("tools/bit_lib.h"),
|
|
||||||
File("protocols/lfrfid_protocols.h"),
|
File("protocols/lfrfid_protocols.h"),
|
||||||
],
|
],
|
||||||
)
|
)
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
#include "lfrfid_dict_file.h"
|
#include "lfrfid_dict_file.h"
|
||||||
#include <storage/storage.h>
|
#include <storage/storage.h>
|
||||||
#include <flipper_format/flipper_format.h>
|
#include <flipper_format/flipper_format.h>
|
||||||
#include <lfrfid/tools/bit_lib.h>
|
#include <bit_lib/bit_lib.h>
|
||||||
|
|
||||||
#define LFRFID_DICT_FILETYPE "Flipper RFID key"
|
#define LFRFID_DICT_FILETYPE "Flipper RFID key"
|
||||||
|
|
||||||
|
@ -5,7 +5,7 @@
|
|||||||
#include <toolbox/pulse_protocols/pulse_glue.h>
|
#include <toolbox/pulse_protocols/pulse_glue.h>
|
||||||
#include <toolbox/buffer_stream.h>
|
#include <toolbox/buffer_stream.h>
|
||||||
#include "tools/varint_pair.h"
|
#include "tools/varint_pair.h"
|
||||||
#include "tools/bit_lib.h"
|
#include <lib/bit_lib/bit_lib.h>
|
||||||
|
|
||||||
#define TAG "LfRfidWorker"
|
#define TAG "LfRfidWorker"
|
||||||
|
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
#include <toolbox/protocols/protocol.h>
|
#include <toolbox/protocols/protocol.h>
|
||||||
#include <lfrfid/tools/fsk_demod.h>
|
#include <lfrfid/tools/fsk_demod.h>
|
||||||
#include <lfrfid/tools/fsk_osc.h>
|
#include <lfrfid/tools/fsk_osc.h>
|
||||||
#include <lfrfid/tools/bit_lib.h>
|
#include <bit_lib/bit_lib.h>
|
||||||
#include "lfrfid_protocols.h"
|
#include "lfrfid_protocols.h"
|
||||||
|
|
||||||
#define JITTER_TIME (20)
|
#define JITTER_TIME (20)
|
||||||
|
@ -3,7 +3,7 @@
|
|||||||
#include <lfrfid/tools/fsk_demod.h>
|
#include <lfrfid/tools/fsk_demod.h>
|
||||||
#include <lfrfid/tools/fsk_osc.h>
|
#include <lfrfid/tools/fsk_osc.h>
|
||||||
#include "lfrfid_protocols.h"
|
#include "lfrfid_protocols.h"
|
||||||
#include <lfrfid/tools/bit_lib.h>
|
#include <bit_lib/bit_lib.h>
|
||||||
|
|
||||||
#define JITTER_TIME (20)
|
#define JITTER_TIME (20)
|
||||||
#define MIN_TIME (64 - JITTER_TIME)
|
#define MIN_TIME (64 - JITTER_TIME)
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
#include "toolbox/level_duration.h"
|
#include "toolbox/level_duration.h"
|
||||||
#include "protocol_fdx_b.h"
|
#include "protocol_fdx_b.h"
|
||||||
#include <toolbox/manchester_decoder.h>
|
#include <toolbox/manchester_decoder.h>
|
||||||
#include <lfrfid/tools/bit_lib.h>
|
#include <bit_lib/bit_lib.h>
|
||||||
#include "lfrfid_protocols.h"
|
#include "lfrfid_protocols.h"
|
||||||
#include <furi_hal_rtc.h>
|
#include <furi_hal_rtc.h>
|
||||||
|
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
#include <furi.h>
|
#include <furi.h>
|
||||||
#include <toolbox/protocols/protocol.h>
|
#include <toolbox/protocols/protocol.h>
|
||||||
#include <toolbox/manchester_decoder.h>
|
#include <toolbox/manchester_decoder.h>
|
||||||
#include <lfrfid/tools/bit_lib.h>
|
#include <bit_lib/bit_lib.h>
|
||||||
#include "lfrfid_protocols.h"
|
#include "lfrfid_protocols.h"
|
||||||
|
|
||||||
#define GALLAGHER_CLOCK_PER_BIT (32)
|
#define GALLAGHER_CLOCK_PER_BIT (32)
|
||||||
|
@ -3,7 +3,7 @@
|
|||||||
#include <lfrfid/tools/fsk_demod.h>
|
#include <lfrfid/tools/fsk_demod.h>
|
||||||
#include <lfrfid/tools/fsk_osc.h>
|
#include <lfrfid/tools/fsk_osc.h>
|
||||||
#include "lfrfid_protocols.h"
|
#include "lfrfid_protocols.h"
|
||||||
#include <lfrfid/tools/bit_lib.h>
|
#include <bit_lib/bit_lib.h>
|
||||||
|
|
||||||
#define JITTER_TIME (20)
|
#define JITTER_TIME (20)
|
||||||
#define MIN_TIME (64 - JITTER_TIME)
|
#define MIN_TIME (64 - JITTER_TIME)
|
||||||
|
@ -3,7 +3,7 @@
|
|||||||
#include <lfrfid/tools/fsk_demod.h>
|
#include <lfrfid/tools/fsk_demod.h>
|
||||||
#include <lfrfid/tools/fsk_osc.h>
|
#include <lfrfid/tools/fsk_osc.h>
|
||||||
#include "lfrfid_protocols.h"
|
#include "lfrfid_protocols.h"
|
||||||
#include <lfrfid/tools/bit_lib.h>
|
#include <bit_lib/bit_lib.h>
|
||||||
|
|
||||||
#define JITTER_TIME (20)
|
#define JITTER_TIME (20)
|
||||||
#define MIN_TIME (64 - JITTER_TIME)
|
#define MIN_TIME (64 - JITTER_TIME)
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
#include <furi.h>
|
#include <furi.h>
|
||||||
#include <toolbox/protocols/protocol.h>
|
#include <toolbox/protocols/protocol.h>
|
||||||
#include <lfrfid/tools/bit_lib.h>
|
#include <bit_lib/bit_lib.h>
|
||||||
#include "lfrfid_protocols.h"
|
#include "lfrfid_protocols.h"
|
||||||
|
|
||||||
// Example: 4944544B 351FBE4B
|
// Example: 4944544B 351FBE4B
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
#include <furi.h>
|
#include <furi.h>
|
||||||
#include <toolbox/protocols/protocol.h>
|
#include <toolbox/protocols/protocol.h>
|
||||||
#include <lfrfid/tools/bit_lib.h>
|
#include <bit_lib/bit_lib.h>
|
||||||
#include "lfrfid_protocols.h"
|
#include "lfrfid_protocols.h"
|
||||||
|
|
||||||
#define INDALA26_PREAMBLE_BIT_SIZE (33)
|
#define INDALA26_PREAMBLE_BIT_SIZE (33)
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
#include <toolbox/protocols/protocol.h>
|
#include <toolbox/protocols/protocol.h>
|
||||||
#include <lfrfid/tools/fsk_demod.h>
|
#include <lfrfid/tools/fsk_demod.h>
|
||||||
#include <lfrfid/tools/fsk_osc.h>
|
#include <lfrfid/tools/fsk_osc.h>
|
||||||
#include <lfrfid/tools/bit_lib.h>
|
#include <bit_lib/bit_lib.h>
|
||||||
#include "lfrfid_protocols.h"
|
#include "lfrfid_protocols.h"
|
||||||
|
|
||||||
#define JITTER_TIME (20)
|
#define JITTER_TIME (20)
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
#include "toolbox/level_duration.h"
|
#include "toolbox/level_duration.h"
|
||||||
#include "protocol_jablotron.h"
|
#include "protocol_jablotron.h"
|
||||||
#include <toolbox/manchester_decoder.h>
|
#include <toolbox/manchester_decoder.h>
|
||||||
#include <lfrfid/tools/bit_lib.h>
|
#include <bit_lib/bit_lib.h>
|
||||||
#include "lfrfid_protocols.h"
|
#include "lfrfid_protocols.h"
|
||||||
|
|
||||||
#define JABLOTRON_ENCODED_BIT_SIZE (64)
|
#define JABLOTRON_ENCODED_BIT_SIZE (64)
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
#include <furi.h>
|
#include <furi.h>
|
||||||
#include <toolbox/protocols/protocol.h>
|
#include <toolbox/protocols/protocol.h>
|
||||||
#include <lfrfid/tools/bit_lib.h>
|
#include <bit_lib/bit_lib.h>
|
||||||
#include "lfrfid_protocols.h"
|
#include "lfrfid_protocols.h"
|
||||||
|
|
||||||
#define KERI_PREAMBLE_BIT_SIZE (33)
|
#define KERI_PREAMBLE_BIT_SIZE (33)
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
#include <furi.h>
|
#include <furi.h>
|
||||||
#include <toolbox/protocols/protocol.h>
|
#include <toolbox/protocols/protocol.h>
|
||||||
#include <lfrfid/tools/bit_lib.h>
|
#include <bit_lib/bit_lib.h>
|
||||||
#include "lfrfid_protocols.h"
|
#include "lfrfid_protocols.h"
|
||||||
|
|
||||||
#define NEXWATCH_PREAMBLE_BIT_SIZE (8)
|
#define NEXWATCH_PREAMBLE_BIT_SIZE (8)
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
#include <math.h>
|
#include <math.h>
|
||||||
#include <toolbox/protocols/protocol.h>
|
#include <toolbox/protocols/protocol.h>
|
||||||
#include <toolbox/hex.h>
|
#include <toolbox/hex.h>
|
||||||
#include <lfrfid/tools/bit_lib.h>
|
#include <bit_lib/bit_lib.h>
|
||||||
#include "lfrfid_protocols.h"
|
#include "lfrfid_protocols.h"
|
||||||
|
|
||||||
#define PAC_STANLEY_ENCODED_BIT_SIZE (128)
|
#define PAC_STANLEY_ENCODED_BIT_SIZE (128)
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
#include <toolbox/protocols/protocol.h>
|
#include <toolbox/protocols/protocol.h>
|
||||||
#include <lfrfid/tools/fsk_demod.h>
|
#include <lfrfid/tools/fsk_demod.h>
|
||||||
#include <lfrfid/tools/fsk_osc.h>
|
#include <lfrfid/tools/fsk_osc.h>
|
||||||
#include <lfrfid/tools/bit_lib.h>
|
#include <bit_lib/bit_lib.h>
|
||||||
#include "lfrfid_protocols.h"
|
#include "lfrfid_protocols.h"
|
||||||
|
|
||||||
#define JITTER_TIME (20)
|
#define JITTER_TIME (20)
|
||||||
|
@ -3,7 +3,7 @@
|
|||||||
#include <lfrfid/tools/fsk_demod.h>
|
#include <lfrfid/tools/fsk_demod.h>
|
||||||
#include <lfrfid/tools/fsk_osc.h>
|
#include <lfrfid/tools/fsk_osc.h>
|
||||||
#include "lfrfid_protocols.h"
|
#include "lfrfid_protocols.h"
|
||||||
#include <lfrfid/tools/bit_lib.h>
|
#include <bit_lib/bit_lib.h>
|
||||||
|
|
||||||
#define JITTER_TIME (20)
|
#define JITTER_TIME (20)
|
||||||
#define MIN_TIME (64 - JITTER_TIME)
|
#define MIN_TIME (64 - JITTER_TIME)
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
#include <furi.h>
|
#include <furi.h>
|
||||||
#include <toolbox/protocols/protocol.h>
|
#include <toolbox/protocols/protocol.h>
|
||||||
#include <toolbox/manchester_decoder.h>
|
#include <toolbox/manchester_decoder.h>
|
||||||
#include <lfrfid/tools/bit_lib.h>
|
#include <bit_lib/bit_lib.h>
|
||||||
#include "lfrfid_protocols.h"
|
#include "lfrfid_protocols.h"
|
||||||
|
|
||||||
#define VIKING_CLOCK_PER_BIT (32)
|
#define VIKING_CLOCK_PER_BIT (32)
|
||||||
|
@ -13,41 +13,6 @@ static const uint8_t nfc_util_odd_byte_parity[256] = {
|
|||||||
0, 1, 0, 0, 1, 0, 1, 1, 0, 1, 0, 0, 1, 1, 0, 0, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 0, 0, 1,
|
0, 1, 0, 0, 1, 0, 1, 1, 0, 1, 0, 0, 1, 1, 0, 0, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 0, 0, 1,
|
||||||
1, 0, 0, 1, 0, 1, 1, 0, 1, 0, 0, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 0, 0, 1};
|
1, 0, 0, 1, 0, 1, 1, 0, 1, 0, 0, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 0, 0, 1};
|
||||||
|
|
||||||
void nfc_util_num2bytes(uint64_t src, uint8_t len, uint8_t* dest) {
|
|
||||||
furi_assert(dest);
|
|
||||||
furi_assert(len <= 8);
|
|
||||||
|
|
||||||
while(len--) {
|
|
||||||
dest[len] = (uint8_t)src;
|
|
||||||
src >>= 8;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
uint64_t nfc_util_bytes2num(const uint8_t* src, uint8_t len) {
|
|
||||||
furi_assert(src);
|
|
||||||
furi_assert(len <= 8);
|
|
||||||
|
|
||||||
uint64_t res = 0;
|
|
||||||
while(len--) {
|
|
||||||
res = (res << 8) | (*src);
|
|
||||||
src++;
|
|
||||||
}
|
|
||||||
return res;
|
|
||||||
}
|
|
||||||
|
|
||||||
uint64_t nfc_util_bytes2num_little_endian(const uint8_t* src, uint8_t len) {
|
|
||||||
furi_assert(src);
|
|
||||||
furi_assert(len <= 8);
|
|
||||||
|
|
||||||
uint64_t res = 0;
|
|
||||||
uint8_t shift = 0;
|
|
||||||
while(len--) {
|
|
||||||
res |= ((uint64_t)*src) << (8 * shift++);
|
|
||||||
src++;
|
|
||||||
}
|
|
||||||
return res;
|
|
||||||
}
|
|
||||||
|
|
||||||
uint8_t nfc_util_even_parity32(uint32_t data) {
|
uint8_t nfc_util_even_parity32(uint32_t data) {
|
||||||
// data ^= data >> 16;
|
// data ^= data >> 16;
|
||||||
// data ^= data >> 8;
|
// data ^= data >> 8;
|
||||||
|
@ -6,12 +6,6 @@
|
|||||||
extern "C" {
|
extern "C" {
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
void nfc_util_num2bytes(uint64_t src, uint8_t len, uint8_t* dest);
|
|
||||||
|
|
||||||
uint64_t nfc_util_bytes2num(const uint8_t* src, uint8_t len);
|
|
||||||
|
|
||||||
uint64_t nfc_util_bytes2num_little_endian(const uint8_t* src, uint8_t len);
|
|
||||||
|
|
||||||
uint8_t nfc_util_even_parity32(uint32_t data);
|
uint8_t nfc_util_even_parity32(uint32_t data);
|
||||||
|
|
||||||
uint8_t nfc_util_odd_parity8(uint8_t data);
|
uint8_t nfc_util_odd_parity8(uint8_t data);
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
#include "crypto1.h"
|
#include "crypto1.h"
|
||||||
|
|
||||||
#include <lib/nfc/helpers/nfc_util.h>
|
#include <lib/nfc/helpers/nfc_util.h>
|
||||||
|
#include <lib/bit_lib/bit_lib.h>
|
||||||
#include <furi.h>
|
#include <furi.h>
|
||||||
|
|
||||||
// Algorithm from https://github.com/RfidResearchGroup/proxmark3.git
|
// Algorithm from https://github.com/RfidResearchGroup/proxmark3.git
|
||||||
@ -151,7 +152,7 @@ void crypto1_encrypt_reader_nonce(
|
|||||||
furi_assert(out);
|
furi_assert(out);
|
||||||
|
|
||||||
bit_buffer_set_size_bytes(out, 8);
|
bit_buffer_set_size_bytes(out, 8);
|
||||||
uint32_t nt_num = nfc_util_bytes2num(nt, sizeof(uint32_t));
|
uint32_t nt_num = bit_lib_bytes_to_num_be(nt, sizeof(uint32_t));
|
||||||
|
|
||||||
crypto1_init(crypto, key);
|
crypto1_init(crypto, key);
|
||||||
if(is_nested) {
|
if(is_nested) {
|
||||||
|
@ -3,7 +3,7 @@
|
|||||||
#include <furi/furi.h>
|
#include <furi/furi.h>
|
||||||
#include <toolbox/hex.h>
|
#include <toolbox/hex.h>
|
||||||
|
|
||||||
#include <lib/nfc/helpers/nfc_util.h>
|
#include <lib/bit_lib/bit_lib.h>
|
||||||
|
|
||||||
#define MF_CLASSIC_PROTOCOL_NAME "Mifare Classic"
|
#define MF_CLASSIC_PROTOCOL_NAME "Mifare Classic"
|
||||||
|
|
||||||
@ -121,7 +121,8 @@ static void mf_classic_parse_block(FuriString* block_str, MfClassicData* data, u
|
|||||||
// Load Key A
|
// Load Key A
|
||||||
// Key A mask 0b0000000000111111 = 0x003f
|
// Key A mask 0b0000000000111111 = 0x003f
|
||||||
if((block_unknown_bytes_mask & 0x003f) == 0) {
|
if((block_unknown_bytes_mask & 0x003f) == 0) {
|
||||||
uint64_t key = nfc_util_bytes2num(sec_tr_tmp->key_a.data, sizeof(MfClassicKey));
|
uint64_t key =
|
||||||
|
bit_lib_bytes_to_num_be(sec_tr_tmp->key_a.data, sizeof(MfClassicKey));
|
||||||
mf_classic_set_key_found(data, sector_num, MfClassicKeyTypeA, key);
|
mf_classic_set_key_found(data, sector_num, MfClassicKeyTypeA, key);
|
||||||
}
|
}
|
||||||
// Load Access Bits
|
// Load Access Bits
|
||||||
@ -132,7 +133,8 @@ static void mf_classic_parse_block(FuriString* block_str, MfClassicData* data, u
|
|||||||
// Load Key B
|
// Load Key B
|
||||||
// Key B mask 0b1111110000000000 = 0xfc00
|
// Key B mask 0b1111110000000000 = 0xfc00
|
||||||
if((block_unknown_bytes_mask & 0xfc00) == 0) {
|
if((block_unknown_bytes_mask & 0xfc00) == 0) {
|
||||||
uint64_t key = nfc_util_bytes2num(sec_tr_tmp->key_b.data, sizeof(MfClassicKey));
|
uint64_t key =
|
||||||
|
bit_lib_bytes_to_num_be(sec_tr_tmp->key_b.data, sizeof(MfClassicKey));
|
||||||
mf_classic_set_key_found(data, sector_num, MfClassicKeyTypeB, key);
|
mf_classic_set_key_found(data, sector_num, MfClassicKeyTypeB, key);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
@ -493,7 +495,7 @@ void mf_classic_set_key_found(
|
|||||||
uint8_t key_arr[6] = {};
|
uint8_t key_arr[6] = {};
|
||||||
MfClassicSectorTrailer* sec_trailer =
|
MfClassicSectorTrailer* sec_trailer =
|
||||||
mf_classic_get_sector_trailer_by_sector(data, sector_num);
|
mf_classic_get_sector_trailer_by_sector(data, sector_num);
|
||||||
nfc_util_num2bytes(key, 6, key_arr);
|
bit_lib_num_to_bytes_be(key, 6, key_arr);
|
||||||
if(key_type == MfClassicKeyTypeA) {
|
if(key_type == MfClassicKeyTypeA) {
|
||||||
memcpy(sec_trailer->key_a.data, key_arr, sizeof(MfClassicKey));
|
memcpy(sec_trailer->key_a.data, key_arr, sizeof(MfClassicKey));
|
||||||
FURI_BIT_SET(data->key_a_mask, sector_num);
|
FURI_BIT_SET(data->key_a_mask, sector_num);
|
||||||
|
@ -3,7 +3,7 @@
|
|||||||
#include <nfc/protocols/nfc_listener_base.h>
|
#include <nfc/protocols/nfc_listener_base.h>
|
||||||
|
|
||||||
#include <nfc/helpers/iso14443_crc.h>
|
#include <nfc/helpers/iso14443_crc.h>
|
||||||
#include <nfc/helpers/nfc_util.h>
|
#include <bit_lib/bit_lib.h>
|
||||||
|
|
||||||
#include <furi.h>
|
#include <furi.h>
|
||||||
#include <furi_hal_random.h>
|
#include <furi_hal_random.h>
|
||||||
@ -68,14 +68,15 @@ static MfClassicListenerCommand mf_classic_listener_auth_first_part_handler(
|
|||||||
MfClassicSectorTrailer* sec_tr =
|
MfClassicSectorTrailer* sec_tr =
|
||||||
mf_classic_get_sector_trailer_by_sector(instance->data, sector_num);
|
mf_classic_get_sector_trailer_by_sector(instance->data, sector_num);
|
||||||
MfClassicKey* key = (key_type == MfClassicKeyTypeA) ? &sec_tr->key_a : &sec_tr->key_b;
|
MfClassicKey* key = (key_type == MfClassicKeyTypeA) ? &sec_tr->key_a : &sec_tr->key_b;
|
||||||
uint64_t key_num = nfc_util_bytes2num(key->data, sizeof(MfClassicKey));
|
uint64_t key_num = bit_lib_bytes_to_num_be(key->data, sizeof(MfClassicKey));
|
||||||
uint32_t cuid = iso14443_3a_get_cuid(instance->data->iso14443_3a_data);
|
uint32_t cuid = iso14443_3a_get_cuid(instance->data->iso14443_3a_data);
|
||||||
|
|
||||||
instance->auth_context.key_type = key_type;
|
instance->auth_context.key_type = key_type;
|
||||||
instance->auth_context.block_num = block_num;
|
instance->auth_context.block_num = block_num;
|
||||||
|
|
||||||
furi_hal_random_fill_buf(instance->auth_context.nt.data, sizeof(MfClassicNt));
|
furi_hal_random_fill_buf(instance->auth_context.nt.data, sizeof(MfClassicNt));
|
||||||
uint32_t nt_num = nfc_util_bytes2num(instance->auth_context.nt.data, sizeof(MfClassicNt));
|
uint32_t nt_num =
|
||||||
|
bit_lib_bytes_to_num_be(instance->auth_context.nt.data, sizeof(MfClassicNt));
|
||||||
|
|
||||||
crypto1_init(instance->crypto, key_num);
|
crypto1_init(instance->crypto, key_num);
|
||||||
if(instance->comm_state == MfClassicListenerCommStatePlain) {
|
if(instance->comm_state == MfClassicListenerCommStatePlain) {
|
||||||
@ -88,7 +89,7 @@ static MfClassicListenerCommand mf_classic_listener_auth_first_part_handler(
|
|||||||
command = MfClassicListenerCommandProcessed;
|
command = MfClassicListenerCommandProcessed;
|
||||||
} else {
|
} else {
|
||||||
uint8_t key_stream[4] = {};
|
uint8_t key_stream[4] = {};
|
||||||
nfc_util_num2bytes(nt_num ^ cuid, sizeof(uint32_t), key_stream);
|
bit_lib_num_to_bytes_be(nt_num ^ cuid, sizeof(uint32_t), key_stream);
|
||||||
bit_buffer_copy_bytes(
|
bit_buffer_copy_bytes(
|
||||||
instance->tx_plain_buffer, instance->auth_context.nt.data, sizeof(MfClassicNt));
|
instance->tx_plain_buffer, instance->auth_context.nt.data, sizeof(MfClassicNt));
|
||||||
crypto1_encrypt(
|
crypto1_encrypt(
|
||||||
@ -147,11 +148,14 @@ static MfClassicListenerCommand
|
|||||||
instance->callback(instance->generic_event, instance->context);
|
instance->callback(instance->generic_event, instance->context);
|
||||||
}
|
}
|
||||||
|
|
||||||
uint32_t nr_num = nfc_util_bytes2num(instance->auth_context.nr.data, sizeof(MfClassicNr));
|
uint32_t nr_num =
|
||||||
uint32_t ar_num = nfc_util_bytes2num(instance->auth_context.ar.data, sizeof(MfClassicAr));
|
bit_lib_bytes_to_num_be(instance->auth_context.nr.data, sizeof(MfClassicNr));
|
||||||
|
uint32_t ar_num =
|
||||||
|
bit_lib_bytes_to_num_be(instance->auth_context.ar.data, sizeof(MfClassicAr));
|
||||||
|
|
||||||
crypto1_word(instance->crypto, nr_num, 1);
|
crypto1_word(instance->crypto, nr_num, 1);
|
||||||
uint32_t nt_num = nfc_util_bytes2num(instance->auth_context.nt.data, sizeof(MfClassicNt));
|
uint32_t nt_num =
|
||||||
|
bit_lib_bytes_to_num_be(instance->auth_context.nt.data, sizeof(MfClassicNt));
|
||||||
uint32_t secret_poller = ar_num ^ crypto1_word(instance->crypto, 0, 0);
|
uint32_t secret_poller = ar_num ^ crypto1_word(instance->crypto, 0, 0);
|
||||||
if(secret_poller != prng_successor(nt_num, 64)) {
|
if(secret_poller != prng_successor(nt_num, 64)) {
|
||||||
FURI_LOG_T(
|
FURI_LOG_T(
|
||||||
@ -161,7 +165,7 @@ static MfClassicListenerCommand
|
|||||||
}
|
}
|
||||||
|
|
||||||
uint32_t at_num = prng_successor(nt_num, 96);
|
uint32_t at_num = prng_successor(nt_num, 96);
|
||||||
nfc_util_num2bytes(at_num, sizeof(uint32_t), instance->auth_context.at.data);
|
bit_lib_num_to_bytes_be(at_num, sizeof(uint32_t), instance->auth_context.at.data);
|
||||||
bit_buffer_copy_bytes(
|
bit_buffer_copy_bytes(
|
||||||
instance->tx_plain_buffer, instance->auth_context.at.data, sizeof(MfClassicAr));
|
instance->tx_plain_buffer, instance->auth_context.at.data, sizeof(MfClassicAr));
|
||||||
crypto1_encrypt(
|
crypto1_encrypt(
|
||||||
|
@ -73,7 +73,7 @@ static void mf_classic_poller_check_key_b_is_readable(
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
MfClassicSectorTrailer* sec_tr = (MfClassicSectorTrailer*)data;
|
MfClassicSectorTrailer* sec_tr = (MfClassicSectorTrailer*)data;
|
||||||
uint64_t key_b = nfc_util_bytes2num(sec_tr->key_b.data, sizeof(MfClassicKey));
|
uint64_t key_b = bit_lib_bytes_to_num_be(sec_tr->key_b.data, sizeof(MfClassicKey));
|
||||||
uint8_t sector_num = mf_classic_get_sector_by_block(block_num);
|
uint8_t sector_num = mf_classic_get_sector_by_block(block_num);
|
||||||
mf_classic_set_key_found(instance->data, sector_num, MfClassicKeyTypeB, key_b);
|
mf_classic_set_key_found(instance->data, sector_num, MfClassicKeyTypeB, key_b);
|
||||||
} while(false);
|
} while(false);
|
||||||
@ -456,7 +456,7 @@ NfcCommand mf_classic_poller_handler_request_read_sector_blocks(MfClassicPoller*
|
|||||||
MfClassicError error = MfClassicErrorNone;
|
MfClassicError error = MfClassicErrorNone;
|
||||||
|
|
||||||
if(!sec_read_ctx->auth_passed) {
|
if(!sec_read_ctx->auth_passed) {
|
||||||
uint64_t key = nfc_util_bytes2num(sec_read_ctx->key.data, sizeof(MfClassicKey));
|
uint64_t key = bit_lib_bytes_to_num_be(sec_read_ctx->key.data, sizeof(MfClassicKey));
|
||||||
FURI_LOG_D(
|
FURI_LOG_D(
|
||||||
TAG,
|
TAG,
|
||||||
"Auth to block %d with key %c: %06llx",
|
"Auth to block %d with key %c: %06llx",
|
||||||
@ -530,7 +530,8 @@ NfcCommand mf_classic_poller_handler_auth_a(MfClassicPoller* instance) {
|
|||||||
instance->state = MfClassicPollerStateAuthKeyB;
|
instance->state = MfClassicPollerStateAuthKeyB;
|
||||||
} else {
|
} else {
|
||||||
uint8_t block = mf_classic_get_first_block_num_of_sector(dict_attack_ctx->current_sector);
|
uint8_t block = mf_classic_get_first_block_num_of_sector(dict_attack_ctx->current_sector);
|
||||||
uint64_t key = nfc_util_bytes2num(dict_attack_ctx->current_key.data, sizeof(MfClassicKey));
|
uint64_t key =
|
||||||
|
bit_lib_bytes_to_num_be(dict_attack_ctx->current_key.data, sizeof(MfClassicKey));
|
||||||
FURI_LOG_D(TAG, "Auth to block %d with key A: %06llx", block, key);
|
FURI_LOG_D(TAG, "Auth to block %d with key A: %06llx", block, key);
|
||||||
|
|
||||||
MfClassicError error = mf_classic_poller_auth(
|
MfClassicError error = mf_classic_poller_auth(
|
||||||
@ -568,7 +569,8 @@ NfcCommand mf_classic_poller_handler_auth_b(MfClassicPoller* instance) {
|
|||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
uint8_t block = mf_classic_get_first_block_num_of_sector(dict_attack_ctx->current_sector);
|
uint8_t block = mf_classic_get_first_block_num_of_sector(dict_attack_ctx->current_sector);
|
||||||
uint64_t key = nfc_util_bytes2num(dict_attack_ctx->current_key.data, sizeof(MfClassicKey));
|
uint64_t key =
|
||||||
|
bit_lib_bytes_to_num_be(dict_attack_ctx->current_key.data, sizeof(MfClassicKey));
|
||||||
FURI_LOG_D(TAG, "Auth to block %d with key B: %06llx", block, key);
|
FURI_LOG_D(TAG, "Auth to block %d with key B: %06llx", block, key);
|
||||||
|
|
||||||
MfClassicError error = mf_classic_poller_auth(
|
MfClassicError error = mf_classic_poller_auth(
|
||||||
@ -711,7 +713,8 @@ NfcCommand mf_classic_poller_handler_key_reuse_auth_key_a(MfClassicPoller* insta
|
|||||||
} else {
|
} else {
|
||||||
uint8_t block =
|
uint8_t block =
|
||||||
mf_classic_get_first_block_num_of_sector(dict_attack_ctx->reuse_key_sector);
|
mf_classic_get_first_block_num_of_sector(dict_attack_ctx->reuse_key_sector);
|
||||||
uint64_t key = nfc_util_bytes2num(dict_attack_ctx->current_key.data, sizeof(MfClassicKey));
|
uint64_t key =
|
||||||
|
bit_lib_bytes_to_num_be(dict_attack_ctx->current_key.data, sizeof(MfClassicKey));
|
||||||
FURI_LOG_D(TAG, "Key attack auth to block %d with key A: %06llx", block, key);
|
FURI_LOG_D(TAG, "Key attack auth to block %d with key A: %06llx", block, key);
|
||||||
|
|
||||||
MfClassicError error = mf_classic_poller_auth(
|
MfClassicError error = mf_classic_poller_auth(
|
||||||
@ -746,7 +749,8 @@ NfcCommand mf_classic_poller_handler_key_reuse_auth_key_b(MfClassicPoller* insta
|
|||||||
} else {
|
} else {
|
||||||
uint8_t block =
|
uint8_t block =
|
||||||
mf_classic_get_first_block_num_of_sector(dict_attack_ctx->reuse_key_sector);
|
mf_classic_get_first_block_num_of_sector(dict_attack_ctx->reuse_key_sector);
|
||||||
uint64_t key = nfc_util_bytes2num(dict_attack_ctx->current_key.data, sizeof(MfClassicKey));
|
uint64_t key =
|
||||||
|
bit_lib_bytes_to_num_be(dict_attack_ctx->current_key.data, sizeof(MfClassicKey));
|
||||||
FURI_LOG_D(TAG, "Key attack auth to block %d with key B: %06llx", block, key);
|
FURI_LOG_D(TAG, "Key attack auth to block %d with key B: %06llx", block, key);
|
||||||
|
|
||||||
MfClassicError error = mf_classic_poller_auth(
|
MfClassicError error = mf_classic_poller_auth(
|
||||||
|
@ -128,7 +128,7 @@ static MfClassicError mf_classic_poller_auth_common(
|
|||||||
}
|
}
|
||||||
|
|
||||||
uint32_t cuid = iso14443_3a_get_cuid(instance->data->iso14443_3a_data);
|
uint32_t cuid = iso14443_3a_get_cuid(instance->data->iso14443_3a_data);
|
||||||
uint64_t key_num = nfc_util_bytes2num(key->data, sizeof(MfClassicKey));
|
uint64_t key_num = bit_lib_bytes_to_num_be(key->data, sizeof(MfClassicKey));
|
||||||
MfClassicNr nr = {};
|
MfClassicNr nr = {};
|
||||||
furi_hal_random_fill_buf(nr.data, sizeof(MfClassicNr));
|
furi_hal_random_fill_buf(nr.data, sizeof(MfClassicNr));
|
||||||
|
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
|
|
||||||
#include "mf_classic_poller.h"
|
#include "mf_classic_poller.h"
|
||||||
#include <lib/nfc/protocols/iso14443_3a/iso14443_3a_poller_i.h>
|
#include <lib/nfc/protocols/iso14443_3a/iso14443_3a_poller_i.h>
|
||||||
#include <lib/nfc/helpers/nfc_util.h>
|
#include <bit_lib/bit_lib.h>
|
||||||
#include "crypto1.h"
|
#include "crypto1.h"
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
#include "mf_ultralight.h"
|
#include "mf_ultralight.h"
|
||||||
|
|
||||||
#include <nfc/helpers/nfc_util.h>
|
#include <bit_lib/bit_lib.h>
|
||||||
#include <furi.h>
|
#include <furi.h>
|
||||||
|
|
||||||
#define MF_ULTRALIGHT_PROTOCOL_NAME "NTAG/Ultralight"
|
#define MF_ULTRALIGHT_PROTOCOL_NAME "NTAG/Ultralight"
|
||||||
@ -603,10 +603,10 @@ bool mf_ultralight_is_all_data_read(const MfUltralightData* data) {
|
|||||||
} else {
|
} else {
|
||||||
MfUltralightConfigPages* config = NULL;
|
MfUltralightConfigPages* config = NULL;
|
||||||
if(mf_ultralight_get_config_page(data, &config)) {
|
if(mf_ultralight_get_config_page(data, &config)) {
|
||||||
uint32_t pass =
|
uint32_t pass = bit_lib_bytes_to_num_be(
|
||||||
nfc_util_bytes2num(config->password.data, sizeof(MfUltralightAuthPassword));
|
config->password.data, sizeof(MfUltralightAuthPassword));
|
||||||
uint16_t pack =
|
uint16_t pack =
|
||||||
nfc_util_bytes2num(config->pack.data, sizeof(MfUltralightAuthPack));
|
bit_lib_bytes_to_num_be(config->pack.data, sizeof(MfUltralightAuthPack));
|
||||||
all_read = ((pass != 0) || (pack != 0));
|
all_read = ((pass != 0) || (pack != 0));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -417,7 +417,7 @@ static NfcCommand mf_ultralight_poller_handler_auth(MfUltralightPoller* instance
|
|||||||
command = instance->callback(instance->general_event, instance->context);
|
command = instance->callback(instance->general_event, instance->context);
|
||||||
if(!instance->mfu_event.data->auth_context.skip_auth) {
|
if(!instance->mfu_event.data->auth_context.skip_auth) {
|
||||||
instance->auth_context.password = instance->mfu_event.data->auth_context.password;
|
instance->auth_context.password = instance->mfu_event.data->auth_context.password;
|
||||||
uint32_t pass = nfc_util_bytes2num(
|
uint32_t pass = bit_lib_bytes_to_num_be(
|
||||||
instance->auth_context.password.data, sizeof(MfUltralightAuthPassword));
|
instance->auth_context.password.data, sizeof(MfUltralightAuthPassword));
|
||||||
FURI_LOG_D(TAG, "Trying to authenticate with password %08lX", pass);
|
FURI_LOG_D(TAG, "Trying to authenticate with password %08lX", pass);
|
||||||
instance->error = mf_ultralight_poller_auth_pwd(instance, &instance->auth_context);
|
instance->error = mf_ultralight_poller_auth_pwd(instance, &instance->auth_context);
|
||||||
@ -497,14 +497,14 @@ static NfcCommand mf_ultralight_poller_handler_try_default_pass(MfUltralightPoll
|
|||||||
config->pack = instance->auth_context.pack;
|
config->pack = instance->auth_context.pack;
|
||||||
} else if(config->access.authlim == 0) {
|
} else if(config->access.authlim == 0) {
|
||||||
FURI_LOG_D(TAG, "No limits in authentication. Trying default password");
|
FURI_LOG_D(TAG, "No limits in authentication. Trying default password");
|
||||||
nfc_util_num2bytes(
|
bit_lib_num_to_bytes_be(
|
||||||
MF_ULTRALIGHT_DEFAULT_PASSWORD,
|
MF_ULTRALIGHT_DEFAULT_PASSWORD,
|
||||||
sizeof(MfUltralightAuthPassword),
|
sizeof(MfUltralightAuthPassword),
|
||||||
instance->auth_context.password.data);
|
instance->auth_context.password.data);
|
||||||
instance->error = mf_ultralight_poller_auth_pwd(instance, &instance->auth_context);
|
instance->error = mf_ultralight_poller_auth_pwd(instance, &instance->auth_context);
|
||||||
if(instance->error == MfUltralightErrorNone) {
|
if(instance->error == MfUltralightErrorNone) {
|
||||||
FURI_LOG_D(TAG, "Default password detected");
|
FURI_LOG_D(TAG, "Default password detected");
|
||||||
nfc_util_num2bytes(
|
bit_lib_num_to_bytes_be(
|
||||||
MF_ULTRALIGHT_DEFAULT_PASSWORD,
|
MF_ULTRALIGHT_DEFAULT_PASSWORD,
|
||||||
sizeof(MfUltralightAuthPassword),
|
sizeof(MfUltralightAuthPassword),
|
||||||
config->password.data);
|
config->password.data);
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
|
|
||||||
#include "mf_ultralight_poller.h"
|
#include "mf_ultralight_poller.h"
|
||||||
#include <lib/nfc/protocols/iso14443_3a/iso14443_3a_poller_i.h>
|
#include <lib/nfc/protocols/iso14443_3a/iso14443_3a_poller_i.h>
|
||||||
#include <lib/nfc/helpers/nfc_util.h>
|
#include <lib/bit_lib/bit_lib.h>
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
extern "C" {
|
extern "C" {
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
#include "slix_poller_i.h"
|
#include "slix_poller_i.h"
|
||||||
#include <nfc/helpers/nfc_util.h>
|
#include <bit_lib/bit_lib.h>
|
||||||
|
|
||||||
#include <furi.h>
|
#include <furi.h>
|
||||||
|
|
||||||
@ -107,7 +107,7 @@ SlixError
|
|||||||
uint32_t double_rand_num = (rn_h << 24) | (rn_l << 16) | (rn_h << 8) | rn_l;
|
uint32_t double_rand_num = (rn_h << 24) | (rn_l << 16) | (rn_h << 8) | rn_l;
|
||||||
uint32_t xored_password = double_rand_num ^ password;
|
uint32_t xored_password = double_rand_num ^ password;
|
||||||
uint8_t xored_password_arr[4] = {};
|
uint8_t xored_password_arr[4] = {};
|
||||||
nfc_util_num2bytes(xored_password, 4, xored_password_arr);
|
bit_lib_num_to_bytes_be(xored_password, 4, xored_password_arr);
|
||||||
bit_buffer_append_bytes(instance->tx_buffer, xored_password_arr, 4);
|
bit_buffer_append_bytes(instance->tx_buffer, xored_password_arr, 4);
|
||||||
|
|
||||||
SlixError error = SlixErrorNone;
|
SlixError error = SlixErrorNone;
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
entry,status,name,type,params
|
entry,status,name,type,params
|
||||||
Version,+,55.2,,
|
Version,+,56.0,,
|
||||||
Header,+,applications/services/bt/bt_service/bt.h,,
|
Header,+,applications/services/bt/bt_service/bt.h,,
|
||||||
Header,+,applications/services/cli/cli.h,,
|
Header,+,applications/services/cli/cli.h,,
|
||||||
Header,+,applications/services/cli/cli_vcp.h,,
|
Header,+,applications/services/cli/cli_vcp.h,,
|
||||||
@ -37,6 +37,7 @@ Header,+,applications/services/notification/notification_messages.h,,
|
|||||||
Header,+,applications/services/power/power_service/power.h,,
|
Header,+,applications/services/power/power_service/power.h,,
|
||||||
Header,+,applications/services/rpc/rpc_app.h,,
|
Header,+,applications/services/rpc/rpc_app.h,,
|
||||||
Header,+,applications/services/storage/storage.h,,
|
Header,+,applications/services/storage/storage.h,,
|
||||||
|
Header,+,lib/bit_lib/bit_lib.h,,
|
||||||
Header,+,lib/digital_signal/digital_sequence.h,,
|
Header,+,lib/digital_signal/digital_sequence.h,,
|
||||||
Header,+,lib/digital_signal/digital_signal.h,,
|
Header,+,lib/digital_signal/digital_signal.h,,
|
||||||
Header,+,lib/drivers/cc1101_regs.h,,
|
Header,+,lib/drivers/cc1101_regs.h,,
|
||||||
@ -574,6 +575,32 @@ Function,+,bit_buffer_starts_with_byte,_Bool,"const BitBuffer*, uint8_t"
|
|||||||
Function,+,bit_buffer_write_bytes,void,"const BitBuffer*, void*, size_t"
|
Function,+,bit_buffer_write_bytes,void,"const BitBuffer*, void*, size_t"
|
||||||
Function,+,bit_buffer_write_bytes_mid,void,"const BitBuffer*, void*, size_t, size_t"
|
Function,+,bit_buffer_write_bytes_mid,void,"const BitBuffer*, void*, size_t, size_t"
|
||||||
Function,+,bit_buffer_write_bytes_with_parity,void,"const BitBuffer*, void*, size_t, size_t*"
|
Function,+,bit_buffer_write_bytes_with_parity,void,"const BitBuffer*, void*, size_t, size_t*"
|
||||||
|
Function,+,bit_lib_add_parity,size_t,"const uint8_t*, size_t, uint8_t*, size_t, uint8_t, uint8_t, BitLibParity"
|
||||||
|
Function,+,bit_lib_bytes_to_num_bcd,uint64_t,"const uint8_t*, uint8_t, _Bool*"
|
||||||
|
Function,+,bit_lib_bytes_to_num_be,uint64_t,"const uint8_t*, uint8_t"
|
||||||
|
Function,+,bit_lib_bytes_to_num_le,uint64_t,"const uint8_t*, uint8_t"
|
||||||
|
Function,+,bit_lib_copy_bits,void,"uint8_t*, size_t, size_t, const uint8_t*, size_t"
|
||||||
|
Function,+,bit_lib_crc16,uint16_t,"const uint8_t*, size_t, uint16_t, uint16_t, _Bool, _Bool, uint16_t"
|
||||||
|
Function,+,bit_lib_crc8,uint16_t,"const uint8_t*, size_t, uint8_t, uint8_t, _Bool, _Bool, uint8_t"
|
||||||
|
Function,+,bit_lib_get_bit,_Bool,"const uint8_t*, size_t"
|
||||||
|
Function,+,bit_lib_get_bit_count,uint8_t,uint32_t
|
||||||
|
Function,+,bit_lib_get_bits,uint8_t,"const uint8_t*, size_t, uint8_t"
|
||||||
|
Function,+,bit_lib_get_bits_16,uint16_t,"const uint8_t*, size_t, uint8_t"
|
||||||
|
Function,+,bit_lib_get_bits_32,uint32_t,"const uint8_t*, size_t, uint8_t"
|
||||||
|
Function,+,bit_lib_get_bits_64,uint64_t,"const uint8_t*, size_t, uint8_t"
|
||||||
|
Function,+,bit_lib_num_to_bytes_be,void,"uint64_t, uint8_t, uint8_t*"
|
||||||
|
Function,+,bit_lib_num_to_bytes_le,void,"uint64_t, uint8_t, uint8_t*"
|
||||||
|
Function,+,bit_lib_print_bits,void,"const uint8_t*, size_t"
|
||||||
|
Function,+,bit_lib_print_regions,void,"const BitLibRegion*, size_t, const uint8_t*, size_t"
|
||||||
|
Function,+,bit_lib_push_bit,void,"uint8_t*, size_t, _Bool"
|
||||||
|
Function,+,bit_lib_remove_bit_every_nth,size_t,"uint8_t*, size_t, uint8_t, uint8_t"
|
||||||
|
Function,+,bit_lib_reverse_16_fast,uint16_t,uint16_t
|
||||||
|
Function,+,bit_lib_reverse_8_fast,uint8_t,uint8_t
|
||||||
|
Function,+,bit_lib_reverse_bits,void,"uint8_t*, size_t, uint8_t"
|
||||||
|
Function,+,bit_lib_set_bit,void,"uint8_t*, size_t, _Bool"
|
||||||
|
Function,+,bit_lib_set_bits,void,"uint8_t*, size_t, uint8_t, uint8_t"
|
||||||
|
Function,+,bit_lib_test_parity,_Bool,"const uint8_t*, size_t, uint8_t, BitLibParity, uint8_t"
|
||||||
|
Function,+,bit_lib_test_parity_32,_Bool,"uint32_t, BitLibParity"
|
||||||
Function,+,ble_app_get_key_storage_buff,void,"uint8_t**, uint16_t*"
|
Function,+,ble_app_get_key_storage_buff,void,"uint8_t**, uint16_t*"
|
||||||
Function,+,ble_app_init,_Bool,
|
Function,+,ble_app_init,_Bool,
|
||||||
Function,+,ble_app_thread_stop,void,
|
Function,+,ble_app_thread_stop,void,
|
||||||
|
|
@ -36,7 +36,8 @@
|
|||||||
"update_util",
|
"update_util",
|
||||||
"heatshrink",
|
"heatshrink",
|
||||||
"flipperformat",
|
"flipperformat",
|
||||||
"flipper18"
|
"flipper18",
|
||||||
|
"bit_lib"
|
||||||
],
|
],
|
||||||
"excluded_sources": [
|
"excluded_sources": [
|
||||||
"furi_hal_infrared.c",
|
"furi_hal_infrared.c",
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
entry,status,name,type,params
|
entry,status,name,type,params
|
||||||
Version,+,55.2,,
|
Version,+,56.0,,
|
||||||
Header,+,applications/drivers/subghz/cc1101_ext/cc1101_ext_interconnect.h,,
|
Header,+,applications/drivers/subghz/cc1101_ext/cc1101_ext_interconnect.h,,
|
||||||
Header,+,applications/services/bt/bt_service/bt.h,,
|
Header,+,applications/services/bt/bt_service/bt.h,,
|
||||||
Header,+,applications/services/cli/cli.h,,
|
Header,+,applications/services/cli/cli.h,,
|
||||||
@ -38,6 +38,7 @@ Header,+,applications/services/notification/notification_messages.h,,
|
|||||||
Header,+,applications/services/power/power_service/power.h,,
|
Header,+,applications/services/power/power_service/power.h,,
|
||||||
Header,+,applications/services/rpc/rpc_app.h,,
|
Header,+,applications/services/rpc/rpc_app.h,,
|
||||||
Header,+,applications/services/storage/storage.h,,
|
Header,+,applications/services/storage/storage.h,,
|
||||||
|
Header,+,lib/bit_lib/bit_lib.h,,
|
||||||
Header,+,lib/digital_signal/digital_sequence.h,,
|
Header,+,lib/digital_signal/digital_sequence.h,,
|
||||||
Header,+,lib/digital_signal/digital_signal.h,,
|
Header,+,lib/digital_signal/digital_signal.h,,
|
||||||
Header,+,lib/drivers/cc1101_regs.h,,
|
Header,+,lib/drivers/cc1101_regs.h,,
|
||||||
@ -62,7 +63,6 @@ Header,+,lib/lfrfid/lfrfid_raw_file.h,,
|
|||||||
Header,+,lib/lfrfid/lfrfid_raw_worker.h,,
|
Header,+,lib/lfrfid/lfrfid_raw_worker.h,,
|
||||||
Header,+,lib/lfrfid/lfrfid_worker.h,,
|
Header,+,lib/lfrfid/lfrfid_worker.h,,
|
||||||
Header,+,lib/lfrfid/protocols/lfrfid_protocols.h,,
|
Header,+,lib/lfrfid/protocols/lfrfid_protocols.h,,
|
||||||
Header,+,lib/lfrfid/tools/bit_lib.h,,
|
|
||||||
Header,+,lib/libusb_stm32/inc/hid_usage_button.h,,
|
Header,+,lib/libusb_stm32/inc/hid_usage_button.h,,
|
||||||
Header,+,lib/libusb_stm32/inc/hid_usage_consumer.h,,
|
Header,+,lib/libusb_stm32/inc/hid_usage_consumer.h,,
|
||||||
Header,+,lib/libusb_stm32/inc/hid_usage_desktop.h,,
|
Header,+,lib/libusb_stm32/inc/hid_usage_desktop.h,,
|
||||||
@ -644,6 +644,9 @@ Function,+,bit_buffer_write_bytes,void,"const BitBuffer*, void*, size_t"
|
|||||||
Function,+,bit_buffer_write_bytes_mid,void,"const BitBuffer*, void*, size_t, size_t"
|
Function,+,bit_buffer_write_bytes_mid,void,"const BitBuffer*, void*, size_t, size_t"
|
||||||
Function,+,bit_buffer_write_bytes_with_parity,void,"const BitBuffer*, void*, size_t, size_t*"
|
Function,+,bit_buffer_write_bytes_with_parity,void,"const BitBuffer*, void*, size_t, size_t*"
|
||||||
Function,+,bit_lib_add_parity,size_t,"const uint8_t*, size_t, uint8_t*, size_t, uint8_t, uint8_t, BitLibParity"
|
Function,+,bit_lib_add_parity,size_t,"const uint8_t*, size_t, uint8_t*, size_t, uint8_t, uint8_t, BitLibParity"
|
||||||
|
Function,+,bit_lib_bytes_to_num_bcd,uint64_t,"const uint8_t*, uint8_t, _Bool*"
|
||||||
|
Function,+,bit_lib_bytes_to_num_be,uint64_t,"const uint8_t*, uint8_t"
|
||||||
|
Function,+,bit_lib_bytes_to_num_le,uint64_t,"const uint8_t*, uint8_t"
|
||||||
Function,+,bit_lib_copy_bits,void,"uint8_t*, size_t, size_t, const uint8_t*, size_t"
|
Function,+,bit_lib_copy_bits,void,"uint8_t*, size_t, size_t, const uint8_t*, size_t"
|
||||||
Function,+,bit_lib_crc16,uint16_t,"const uint8_t*, size_t, uint16_t, uint16_t, _Bool, _Bool, uint16_t"
|
Function,+,bit_lib_crc16,uint16_t,"const uint8_t*, size_t, uint16_t, uint16_t, _Bool, _Bool, uint16_t"
|
||||||
Function,+,bit_lib_crc8,uint16_t,"const uint8_t*, size_t, uint8_t, uint8_t, _Bool, _Bool, uint8_t"
|
Function,+,bit_lib_crc8,uint16_t,"const uint8_t*, size_t, uint8_t, uint8_t, _Bool, _Bool, uint8_t"
|
||||||
@ -652,6 +655,9 @@ Function,+,bit_lib_get_bit_count,uint8_t,uint32_t
|
|||||||
Function,+,bit_lib_get_bits,uint8_t,"const uint8_t*, size_t, uint8_t"
|
Function,+,bit_lib_get_bits,uint8_t,"const uint8_t*, size_t, uint8_t"
|
||||||
Function,+,bit_lib_get_bits_16,uint16_t,"const uint8_t*, size_t, uint8_t"
|
Function,+,bit_lib_get_bits_16,uint16_t,"const uint8_t*, size_t, uint8_t"
|
||||||
Function,+,bit_lib_get_bits_32,uint32_t,"const uint8_t*, size_t, uint8_t"
|
Function,+,bit_lib_get_bits_32,uint32_t,"const uint8_t*, size_t, uint8_t"
|
||||||
|
Function,+,bit_lib_get_bits_64,uint64_t,"const uint8_t*, size_t, uint8_t"
|
||||||
|
Function,+,bit_lib_num_to_bytes_be,void,"uint64_t, uint8_t, uint8_t*"
|
||||||
|
Function,+,bit_lib_num_to_bytes_le,void,"uint64_t, uint8_t, uint8_t*"
|
||||||
Function,+,bit_lib_print_bits,void,"const uint8_t*, size_t"
|
Function,+,bit_lib_print_bits,void,"const uint8_t*, size_t"
|
||||||
Function,+,bit_lib_print_regions,void,"const BitLibRegion*, size_t, const uint8_t*, size_t"
|
Function,+,bit_lib_print_regions,void,"const BitLibRegion*, size_t, const uint8_t*, size_t"
|
||||||
Function,+,bit_lib_push_bit,void,"uint8_t*, size_t, _Bool"
|
Function,+,bit_lib_push_bit,void,"uint8_t*, size_t, _Bool"
|
||||||
@ -2606,10 +2612,7 @@ Function,+,nfc_set_guard_time_us,void,"Nfc*, uint32_t"
|
|||||||
Function,+,nfc_set_mask_receive_time_fc,void,"Nfc*, uint32_t"
|
Function,+,nfc_set_mask_receive_time_fc,void,"Nfc*, uint32_t"
|
||||||
Function,+,nfc_start,void,"Nfc*, NfcEventCallback, void*"
|
Function,+,nfc_start,void,"Nfc*, NfcEventCallback, void*"
|
||||||
Function,+,nfc_stop,void,Nfc*
|
Function,+,nfc_stop,void,Nfc*
|
||||||
Function,+,nfc_util_bytes2num,uint64_t,"const uint8_t*, uint8_t"
|
|
||||||
Function,+,nfc_util_bytes2num_little_endian,uint64_t,"const uint8_t*, uint8_t"
|
|
||||||
Function,+,nfc_util_even_parity32,uint8_t,uint32_t
|
Function,+,nfc_util_even_parity32,uint8_t,uint32_t
|
||||||
Function,+,nfc_util_num2bytes,void,"uint64_t, uint8_t, uint8_t*"
|
|
||||||
Function,+,nfc_util_odd_parity,void,"const uint8_t*, uint8_t*, uint8_t"
|
Function,+,nfc_util_odd_parity,void,"const uint8_t*, uint8_t*, uint8_t"
|
||||||
Function,+,nfc_util_odd_parity8,uint8_t,uint8_t
|
Function,+,nfc_util_odd_parity8,uint8_t,uint8_t
|
||||||
Function,+,notification_internal_message,void,"NotificationApp*, const NotificationSequence*"
|
Function,+,notification_internal_message,void,"NotificationApp*, const NotificationSequence*"
|
||||||
|
|
@ -48,6 +48,7 @@
|
|||||||
"update_util",
|
"update_util",
|
||||||
"heatshrink",
|
"heatshrink",
|
||||||
"flipperformat",
|
"flipperformat",
|
||||||
"flipper7"
|
"flipper7",
|
||||||
|
"bit_lib"
|
||||||
]
|
]
|
||||||
}
|
}
|
Loading…
Reference in New Issue
Block a user