| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162 |
- #include "encoder-hid-h10301.h"
- #include "protocols/protocol-hid-h10301.h"
- #include <furi.h>
- void EncoderHID_H10301::init(const uint8_t* data, const uint8_t data_size) {
- ProtocolHID10301 hid;
- hid.encode(data, data_size, reinterpret_cast<uint8_t*>(&card_data), sizeof(card_data) * 3);
- card_data_index = 0;
- bit_index = 0;
- }
- void EncoderHID_H10301::write_bit(bool bit, uint8_t position) {
- write_raw_bit(bit, position + 0);
- write_raw_bit(!bit, position + 1);
- }
- void EncoderHID_H10301::write_raw_bit(bool bit, uint8_t position) {
- if(bit) {
- card_data[position / 32] |= 1UL << (31 - (position % 32));
- } else {
- card_data[position / 32] &= ~(1UL << (31 - (position % 32)));
- }
- }
- void EncoderHID_H10301::get_next(bool* polarity, uint16_t* period, uint16_t* pulse) {
- // hid 0 is 6 cycles by 8 clocks
- const uint8_t hid_0_period = 8;
- const uint8_t hid_0_count = 6;
- // hid 1 is 5 cycles by 10 clocks
- const uint8_t hid_1_period = 10;
- const uint8_t hid_1_count = 5;
- bool bit = (card_data[card_data_index / 32] >> (31 - (card_data_index % 32))) & 1;
- *polarity = true;
- if(bit) {
- *period = hid_1_period;
- *pulse = hid_1_period / 2;
- bit_index++;
- if(bit_index >= hid_1_count) {
- bit_index = 0;
- card_data_index++;
- if(card_data_index >= (32 * card_data_max)) {
- card_data_index = 0;
- }
- }
- } else {
- *period = hid_0_period;
- *pulse = hid_0_period / 2;
- bit_index++;
- if(bit_index >= hid_0_count) {
- bit_index = 0;
- card_data_index++;
- if(card_data_index >= (32 * card_data_max)) {
- card_data_index = 0;
- }
- }
- }
- }
|