encoder-emmarine.cpp 681 B

123456789101112131415161718192021222324
  1. #include "encoder-emmarine.h"
  2. #include "protocols/protocol-emmarin.h"
  3. #include <furi.h>
  4. void EncoderEM::init(const uint8_t* data, const uint8_t data_size) {
  5. ProtocolEMMarin em_marin;
  6. em_marin.encode(data, data_size, reinterpret_cast<uint8_t*>(&card_data), sizeof(uint64_t));
  7. card_data_index = 0;
  8. }
  9. // data transmitted as manchester encoding
  10. // 0 - high2low
  11. // 1 - low2high
  12. void EncoderEM::get_next(bool* polarity, uint16_t* period, uint16_t* pulse) {
  13. *period = clocks_per_bit;
  14. *pulse = clocks_per_bit / 2;
  15. *polarity = (card_data >> (63 - card_data_index)) & 1;
  16. card_data_index++;
  17. if(card_data_index >= 64) {
  18. card_data_index = 0;
  19. }
  20. }