encoder_hid_h10301.cpp 1.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546
  1. #include "encoder_hid_h10301.h"
  2. #include "protocols/protocol_hid_h10301.h"
  3. #include <furi.h>
  4. void EncoderHID_H10301::init(const uint8_t* data, const uint8_t data_size) {
  5. ProtocolHID10301 hid;
  6. hid.encode(data, data_size, reinterpret_cast<uint8_t*>(&card_data), sizeof(card_data) * 3);
  7. card_data_index = 0;
  8. }
  9. void EncoderHID_H10301::write_bit(bool bit, uint8_t position) {
  10. write_raw_bit(bit, position + 0);
  11. write_raw_bit(!bit, position + 1);
  12. }
  13. void EncoderHID_H10301::write_raw_bit(bool bit, uint8_t position) {
  14. if(bit) {
  15. card_data[position / 32] |= 1UL << (31 - (position % 32));
  16. } else {
  17. card_data[position / 32] &= ~(1UL << (31 - (position % 32)));
  18. }
  19. }
  20. void EncoderHID_H10301::get_next(bool* polarity, uint16_t* period, uint16_t* pulse) {
  21. uint8_t bit = (card_data[card_data_index / 32] >> (31 - (card_data_index % 32))) & 1;
  22. bool advance = fsk->next(bit, period);
  23. if(advance) {
  24. card_data_index++;
  25. if(card_data_index >= (32 * card_data_max)) {
  26. card_data_index = 0;
  27. }
  28. }
  29. *polarity = true;
  30. *pulse = *period / 2;
  31. }
  32. EncoderHID_H10301::EncoderHID_H10301() {
  33. fsk = new OscFSK(8, 10, 50);
  34. }
  35. EncoderHID_H10301::~EncoderHID_H10301() {
  36. delete fsk;
  37. }