infrared_encoder_sirc.c 2.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768
  1. #include "infrared_protocol_sirc_i.h"
  2. #include <core/check.h>
  3. void infrared_encoder_sirc_reset(void* encoder_ptr, const InfraredMessage* message) {
  4. furi_assert(encoder_ptr);
  5. furi_assert(message);
  6. InfraredCommonEncoder* encoder = encoder_ptr;
  7. infrared_common_encoder_reset(encoder);
  8. uint32_t* data = (void*)encoder->data;
  9. if(message->protocol == InfraredProtocolSIRC) {
  10. *data = (message->command & 0x7F);
  11. *data |= (message->address & 0x1F) << 7;
  12. encoder->bits_to_encode = 12;
  13. } else if(message->protocol == InfraredProtocolSIRC15) {
  14. *data = (message->command & 0x7F);
  15. *data |= (message->address & 0xFF) << 7;
  16. encoder->bits_to_encode = 15;
  17. } else if(message->protocol == InfraredProtocolSIRC20) {
  18. *data = (message->command & 0x7F);
  19. *data |= (message->address & 0x1FFF) << 7;
  20. encoder->bits_to_encode = 20;
  21. } else {
  22. furi_assert(0);
  23. }
  24. }
  25. InfraredStatus infrared_encoder_sirc_encode_repeat(
  26. InfraredCommonEncoder* encoder,
  27. uint32_t* duration,
  28. bool* level) {
  29. furi_assert(encoder);
  30. furi_assert(encoder->timings_encoded == (1u + 2 + encoder->bits_to_encode * 2 - 1));
  31. furi_assert(encoder->timings_sum < INFRARED_SIRC_REPEAT_PERIOD);
  32. *duration = INFRARED_SIRC_REPEAT_PERIOD - encoder->timings_sum;
  33. *level = false;
  34. encoder->timings_sum = 0;
  35. encoder->timings_encoded = 1;
  36. encoder->bits_encoded = 0;
  37. encoder->state = InfraredCommonEncoderStatePreamble;
  38. return InfraredStatusOk;
  39. }
  40. void* infrared_encoder_sirc_alloc(void) {
  41. return infrared_common_encoder_alloc(&infrared_protocol_sirc);
  42. }
  43. void infrared_encoder_sirc_free(void* encoder_ptr) {
  44. infrared_common_encoder_free(encoder_ptr);
  45. }
  46. InfraredStatus infrared_encoder_sirc_encode(void* encoder_ptr, uint32_t* duration, bool* level) {
  47. InfraredCommonEncoder* encoder = encoder_ptr;
  48. InfraredStatus status = infrared_common_encode(encoder, duration, level);
  49. if((status == InfraredStatusOk) && (encoder->bits_encoded == encoder->bits_to_encode)) {
  50. furi_assert(!*level);
  51. status = InfraredStatusDone;
  52. encoder->state = InfraredCommonEncoderStateEncodeRepeat;
  53. }
  54. return status;
  55. }