RMT transaction on led strip corrupted by WiFi interrupts

Pixellord
Posts: 13
Joined: Wed Feb 15, 2023 8:58 am

RMT transaction on led strip corrupted by WiFi interrupts

Postby Pixellord » Thu Aug 01, 2024 9:56 am

Greetings,

I am working on a project in which I use RMT of ESP32S3 to transmit data on a LED strip and WiFi for LED configuration. I have observed that some of the LEDs will flicker especially when the number of connected sockets changes in WiFi driver. And the LEDs will be much more stable if WiFi is off.

The LED driver I am using is https://components.espressif.com/compon ... /led_strip (version 2.5.3). So far I have done the following changes and the flickering still exists:
1. DMA is enabled on RMT Tx
2. the freeRToS thread that calls the LED driver (led_strip_new_rmt_device) runs in Core 1.
3. WiFi task is pinned to Core 0 in menuconfig. So do the other application threads in freeRToS.
4. the priority of interrupts in RMT TX is set to level 3. Higher than 3 is not possbile.
5. SPI RAM config: allocate memory of WiFi and LWIP in SPIRAM first. [/list]

I don't understand why the RMT transaction is still corrupted by WiFi driver because the tasks and ISR are supposed to run on different cores. Does anybody have any idea? Thanks!

ESP_Sprite
Posts: 9764
Joined: Thu Nov 26, 2015 4:08 am

Re: RMT transaction on led strip corrupted by WiFi interrupts

Postby ESP_Sprite » Fri Aug 02, 2024 2:41 am

Can you post your code?

Pixellord
Posts: 13
Joined: Wed Feb 15, 2023 8:58 am

Re: RMT transaction on led strip corrupted by WiFi interrupts

Postby Pixellord » Fri Aug 02, 2024 7:51 am

Configuration of the LED driver
  1. esp_err_t ledSetup()
  2. {
  3.    
  4.     led_strip_config_t strip_config = {
  5.         .strip_gpio_num = LED_RMT_TX_GPIO,        
  6.         .max_leds = LED_MAX_LENGTH,              
  7.         .led_pixel_format = LED_PIXEL_FORMAT_GRB,
  8.         .led_model = LED_MODEL_WS2812,            
  9.         .flags.invert_out = false,              
  10.     };
  11.  
  12.     led_strip_rmt_config_t rmt_config = {
  13.         .clk_src = RMT_CLK_SRC_DEFAULT,    
  14.         .resolution_hz = 10 * 1000 * 1000, // 10MHz
  15.         .flags.with_dma = true,            
  16.     };
  17.     ESP_RETURN_ON_ERROR(led_strip_new_rmt_device(&strip_config, &rmt_config, &h_led_strip),
  18.                         TAG, "failed to init RMT device");
  19.  
  20.     return ESP_OK;
  21. }

Thread for LED strip
  1. xTaskCreatePinnedToCore(&mode_init, "mode_thread", 8192, NULL, 24, NULL, 1);
Thread for WiFi. I have mdns also running on core 0.
  1. xTaskCreatePinnedToCore(wifi_app_task, "wifi-app", 8192, NULL, 6, NULL, 0);
Attachments
2024-08-02 09_43_33-Window.png
2024-08-02 09_43_33-Window.png (33.41 KiB) Viewed 2401 times
2024-08-02 09_42_17-Window.png
2024-08-02 09_42_17-Window.png (26.84 KiB) Viewed 2401 times

Pixellord
Posts: 13
Joined: Wed Feb 15, 2023 8:58 am

Re: RMT transaction on led strip corrupted by WiFi interrupts

Postby Pixellord » Wed Aug 07, 2024 7:18 am

ESP_Sprite, do you have any idea?

dmitrij999
Posts: 71
Joined: Sat Mar 02, 2019 8:06 pm

Re: RMT transaction on led strip corrupted by WiFi interrupts

Postby dmitrij999 » Wed Aug 07, 2024 8:59 am

Do you need to use multiple RMT channels for different LED strips?
As for me, I worked this around by using SPI

Pixellord
Posts: 13
Joined: Wed Feb 15, 2023 8:58 am

Re: RMT transaction on led strip corrupted by WiFi interrupts

Postby Pixellord » Wed Aug 07, 2024 12:23 pm

Hi dmitrij999, thanks for help. I am only using one RMT channel for one strip.
Workaround with SPI would be my last option if i really could not fix it with RMT.

Bryght-Richard
Posts: 44
Joined: Thu Feb 22, 2024 3:59 pm

Re: RMT transaction on led strip corrupted by WiFi interrupts

Postby Bryght-Richard » Wed Aug 07, 2024 1:35 pm

I saw this once, but it was 2.4GHz radio transmission was sagging power supply slightly, so then RMT bitstream level was not reaching VIH level for LED strip.

ESP_Sprite
Posts: 9764
Joined: Thu Nov 26, 2015 4:08 am

Re: RMT transaction on led strip corrupted by WiFi interrupts

Postby ESP_Sprite » Thu Aug 08, 2024 1:26 am

That could be it, tbh. If you're using DMA, I'm not sure what else could interrupt the data stream.

Pixellord
Posts: 13
Joined: Wed Feb 15, 2023 8:58 am

Re: RMT transaction on led strip corrupted by WiFi interrupts

Postby Pixellord » Thu Aug 08, 2024 7:47 am

Thank you for the help. I think I found the cause of my problem. The DMA buffer size for RMT is by default too small in my case. The data frame has to break into several pieces and then extra delay caused by WiFi is then added in between the fragments. I have increased the mem_block_symbols in led_strip_rmt_config_t and then I don't see any unexpected error on LED strip so far.

Who is online

Users browsing this forum: Bing [Bot] and 108 guests