irda_nec.c 1.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546
  1. #include "flipper.h"
  2. #include "irda_nec.h"
  3. #include "irda_protocols.h"
  4. void ir_nec_preambula(void) {
  5. // 9ms carrier + 4.5ms pause
  6. irda_pwm_set(NEC_DUTY_CYCLE, NEC_CARRIER_FREQUENCY);
  7. delay_us(9000);
  8. irda_pwm_stop();
  9. delay_us(4500);
  10. }
  11. void ir_nec_send_bit(bool bit) {
  12. // 0 is 562.5us carrier + 1687.5us pause
  13. // 1 is 562.5us carrier + 562.5us pause
  14. irda_pwm_set(NEC_DUTY_CYCLE, NEC_CARRIER_FREQUENCY);
  15. delay_us(562.5);
  16. irda_pwm_stop();
  17. if(bit) {
  18. delay_us(562.5);
  19. } else {
  20. delay_us(1687.5);
  21. }
  22. }
  23. void ir_nec_send_byte(uint8_t data) {
  24. for(uint8_t i = 0; i < 8; i++) {
  25. ir_nec_send_bit((data & (1 << (i))) != 0);
  26. }
  27. }
  28. void ir_nec_send(uint8_t addr, uint8_t data) {
  29. // nec protocol is:
  30. // preambula + addr + inverse addr + command + inverse command + bit pulse
  31. //
  32. // oddly enough, my analyzer (https://github.com/ukw100/IRMP) displays the reverse command
  33. // and I don’t know if this is my fault or a feature of the analyzer
  34. // TODO: check the dictionary and check with a known remote
  35. uint8_t nec_packet[4] = {addr, ~(uint8_t)addr, ~(uint8_t)data, data};
  36. ir_nec_preambula();
  37. ir_nec_send_byte(nec_packet[0]);
  38. ir_nec_send_byte(nec_packet[1]);
  39. ir_nec_send_byte(nec_packet[2]);
  40. ir_nec_send_byte(nec_packet[3]);
  41. ir_nec_send_bit(1);
  42. }