2022-01-05 16:10:18 +00:00
|
|
|
#include "encoder_hid_h10301.h"
|
|
|
|
#include "protocols/protocol_hid_h10301.h"
|
2021-05-04 13:21:16 +00:00
|
|
|
#include <furi.h>
|
|
|
|
|
2021-05-06 08:45:52 +00:00
|
|
|
void EncoderHID_H10301::init(const uint8_t* data, const uint8_t data_size) {
|
2021-05-18 08:37:47 +00:00
|
|
|
ProtocolHID10301 hid;
|
|
|
|
hid.encode(data, data_size, reinterpret_cast<uint8_t*>(&card_data), sizeof(card_data) * 3);
|
2021-05-05 07:50:19 +00:00
|
|
|
|
2021-05-04 13:21:16 +00:00
|
|
|
card_data_index = 0;
|
2021-05-05 07:50:19 +00:00
|
|
|
}
|
|
|
|
|
2021-05-06 08:45:52 +00:00
|
|
|
void EncoderHID_H10301::write_bit(bool bit, uint8_t position) {
|
2021-05-05 07:50:19 +00:00
|
|
|
write_raw_bit(bit, position + 0);
|
|
|
|
write_raw_bit(!bit, position + 1);
|
|
|
|
}
|
|
|
|
|
2021-05-06 08:45:52 +00:00
|
|
|
void EncoderHID_H10301::write_raw_bit(bool bit, uint8_t position) {
|
2021-05-05 07:50:19 +00:00
|
|
|
if(bit) {
|
|
|
|
card_data[position / 32] |= 1UL << (31 - (position % 32));
|
|
|
|
} else {
|
|
|
|
card_data[position / 32] &= ~(1UL << (31 - (position % 32)));
|
|
|
|
}
|
2021-05-04 13:21:16 +00:00
|
|
|
}
|
|
|
|
|
2021-05-06 08:45:52 +00:00
|
|
|
void EncoderHID_H10301::get_next(bool* polarity, uint16_t* period, uint16_t* pulse) {
|
2021-07-30 11:12:36 +00:00
|
|
|
uint8_t bit = (card_data[card_data_index / 32] >> (31 - (card_data_index % 32))) & 1;
|
2021-05-05 07:50:19 +00:00
|
|
|
|
2021-07-30 11:12:36 +00:00
|
|
|
bool advance = fsk->next(bit, period);
|
|
|
|
if(advance) {
|
|
|
|
card_data_index++;
|
|
|
|
if(card_data_index >= (32 * card_data_max)) {
|
|
|
|
card_data_index = 0;
|
2021-05-05 07:50:19 +00:00
|
|
|
}
|
|
|
|
}
|
2021-07-30 11:12:36 +00:00
|
|
|
|
|
|
|
*polarity = true;
|
|
|
|
*pulse = *period / 2;
|
|
|
|
}
|
|
|
|
|
|
|
|
EncoderHID_H10301::EncoderHID_H10301() {
|
|
|
|
fsk = new OscFSK(8, 10, 50);
|
|
|
|
}
|
|
|
|
|
|
|
|
EncoderHID_H10301::~EncoderHID_H10301() {
|
|
|
|
delete fsk;
|
2021-05-04 13:21:16 +00:00
|
|
|
}
|