ir_transmit.c 1.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061
  1. #include "freertos/FreeRTOS.h"
  2. #include "freertos/task.h"
  3. #include "freertos/queue.h"
  4. #include "esp_log.h"
  5. #include "driver/rmt.h"
  6. #include "toshiba_ir.h"
  7. #include "config.h"
  8. // RMT values
  9. #define RMT_TX_CHANNEL RMT_CHANNEL_0
  10. #define RMT_TX_GPIO GPIO_NUM_26
  11. // channel clock period = 1 uS
  12. #define RMT_CLK_DIV 80
  13. // RAM item that holds the IR protocol
  14. rmt_item32_t toshiba_rmt[1 + 72 + 1];
  15. void initIrTransmit() {
  16. rmt_config_t rmt_tx = RMT_DEFAULT_CONFIG_TX(GPIO_IR_TX_DATA, RMT_TX_CHANNEL);;
  17. rmt_tx.rmt_mode = RMT_MODE_TX;
  18. rmt_tx.channel = RMT_TX_CHANNEL;
  19. rmt_tx.gpio_num = GPIO_IR_TX_DATA;
  20. rmt_tx.mem_block_num = 1;
  21. rmt_tx.clk_div = RMT_CLK_DIV;
  22. rmt_tx.tx_config.loop_en = false;
  23. rmt_tx.tx_config.carrier_duty_percent = 30;
  24. rmt_tx.tx_config.carrier_freq_hz = 38000;
  25. rmt_tx.tx_config.carrier_level = RMT_CARRIER_LEVEL_HIGH;
  26. rmt_tx.tx_config.carrier_en = true;
  27. rmt_tx.tx_config.idle_level = RMT_IDLE_LEVEL_LOW;
  28. rmt_tx.tx_config.idle_output_en = true;
  29. ESP_ERROR_CHECK( rmt_config(&rmt_tx) );
  30. ESP_ERROR_CHECK( rmt_driver_install(rmt_tx.channel, 0, 0) );
  31. // Init the ir data field
  32. toshiba_rmt[0].val = (kToshibaAcHdrMark << 17) | (1 << 16) | (kToshibaAcHdrSpace << 1) | 0; // Header of IR Transmit
  33. toshiba_rmt[73].val = (kToshibaAcBitMark << 17) | (1 << 16) | (kToshibaAcZeroSpace << 1) | 0; // End IR Transmit
  34. for(int i=1;i<72;i++) {
  35. toshiba_rmt[i].val = (kToshibaAcBitMark << 17) | (1 << 16) | (kToshibaAcHdrSpace << 1) | 0; // Header of IR Transmit
  36. }
  37. printf("RMT initialized\n");
  38. }
  39. void sendToshibaIRData() {
  40. ESP_ERROR_CHECK(rmt_write_items(RMT_TX_CHANNEL, toshiba_rmt, sizeof(toshiba_rmt) / sizeof(toshiba_rmt[0]), true));
  41. }