infrared_encoder_samsung.c 2.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071
  1. #include <core/check.h>
  2. #include "common/infrared_common_i.h"
  3. #include <stdint.h>
  4. #include "../infrared_i.h"
  5. #include "infrared_protocol_defs_i.h"
  6. #include <furi.h>
  7. static const uint32_t repeat_timings[] = {
  8. INFRARED_SAMSUNG_REPEAT_PAUSE2,
  9. INFRARED_SAMSUNG_REPEAT_MARK,
  10. INFRARED_SAMSUNG_REPEAT_SPACE,
  11. INFRARED_SAMSUNG_BIT1_MARK,
  12. INFRARED_SAMSUNG_BIT1_SPACE,
  13. INFRARED_SAMSUNG_BIT1_MARK,
  14. };
  15. void infrared_encoder_samsung32_reset(void* encoder_ptr, const InfraredMessage* message) {
  16. furi_assert(encoder_ptr);
  17. InfraredCommonEncoder* encoder = encoder_ptr;
  18. infrared_common_encoder_reset(encoder);
  19. uint8_t address = message->address;
  20. uint8_t command = message->command;
  21. uint8_t command_inverse = ~command;
  22. uint32_t* data = (void*)encoder->data;
  23. *data |= address;
  24. *data |= address << 8;
  25. *data |= command << 16;
  26. *data |= command_inverse << 24;
  27. encoder->bits_to_encode = encoder->protocol->databit_len[0];
  28. }
  29. InfraredStatus infrared_encoder_samsung32_encode_repeat(
  30. InfraredCommonEncoder* encoder,
  31. uint32_t* duration,
  32. bool* level) {
  33. furi_assert(encoder);
  34. /* space + 2 timings preambule + payload + stop bit */
  35. uint32_t timings_encoded_up_to_repeat = 1 + 2 + encoder->bits_encoded * 2 + 1;
  36. uint32_t repeat_cnt = encoder->timings_encoded - timings_encoded_up_to_repeat;
  37. furi_assert(encoder->timings_encoded >= timings_encoded_up_to_repeat);
  38. if(repeat_cnt > 0)
  39. *duration = repeat_timings[repeat_cnt % COUNT_OF(repeat_timings)];
  40. else
  41. *duration = INFRARED_SAMSUNG_REPEAT_PAUSE1;
  42. *level = repeat_cnt % 2;
  43. ++encoder->timings_encoded;
  44. bool done = (!((repeat_cnt + 1) % COUNT_OF(repeat_timings)));
  45. return done ? InfraredStatusDone : InfraredStatusOk;
  46. }
  47. void* infrared_encoder_samsung32_alloc(void) {
  48. return infrared_common_encoder_alloc(&protocol_samsung32);
  49. }
  50. void infrared_encoder_samsung32_free(void* encoder_ptr) {
  51. infrared_common_encoder_free(encoder_ptr);
  52. }
  53. InfraredStatus
  54. infrared_encoder_samsung32_encode(void* encoder_ptr, uint32_t* duration, bool* level) {
  55. return infrared_common_encode(encoder_ptr, duration, level);
  56. }