Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

drivers/ws281x: Bit banging STM32 support #20302

Closed
wants to merge 4 commits into from
Closed

drivers/ws281x: Bit banging STM32 support #20302

wants to merge 4 commits into from

Conversation

Lennart-Lutz
Copy link

Contribution description

This pull request adds support for driving ws281x LEDs on STM32 microcontrollers operating at 84, 100, and 180 MHz clock frequencies. That's the case for almost all STM32F4 microcontrollers, except 405/415 and 407/417. The implementation uses the bit banging approach by exploiting NOPs. (Don't be afraid of all the lines I've changed. Most of them are NOPs.)

The following parts of the RIOT are involved:

  • drivers/ws281x
  • drivers/include

You can test my changes with the test application provided in tests/ws281x and using a STM32 board like the "nucleo-f411re" or any other Nucleo with a STM32 that operates at 84, 100, and 180 MHz.

Testing procedure

This implementation was tested with the test application provided in tests/ws281x using a "weact-f401cc", "nucleo-f411re" and "nucleo-f446re" board. Each time I did a visual inspection of the LEDs. In addition to that, I also checked the timings with a "Saleae Logic Analyzer" at 500MS/s. Since every board I mentioned above has a different CPU speed, I confirmed that my implementation works for all mentioned clock frequencies.

= added 4 commits January 26, 2024 18:35
Currently only implemented for 84, 100 and 180 MHz MCUs of the  STM32F4 family. Timings were verfied with a Saleae Logic Analyzer at 500 MS/s.
@Lennart-Lutz Lennart-Lutz requested a review from maribu as a code owner January 26, 2024 18:24
@github-actions github-actions bot added the Area: drivers Area: Device drivers label Jan 26, 2024
@maribu
Copy link
Member

maribu commented Apr 30, 2024

Thanks for you pull request and sorry for the long delay.

This PR has been opened just shortly after #19891 was merged. I think it might be, that you have been unaware of #19891.

For #19891 to work on STM32 MCUs the periph_timer_poll extension is needed. I do believe that this would be the better approach, as this API extension would be useful not only for ws281x bit-banging, but other bit-banging as well.

In addition I have made some unpleasant experiences with counting CPU cycles for timing, as this can vary a lot between different MCUs. E.g. the Cortex M7 has this dual issue feature that may allow the CPU to perform two instructions in a single CPU cycle. However, it is difficult to find out documentation that clearly specifies which instructions get executed simultaneously and which not. Specifically, would to nops qualify for this to be executed in one CPU cycles, or not? Also whether the instruction cache is hot or not has a huge impact. Hence, I believe that using a timer for timing is less fragile.

In conclusion, I would prefer if ws281x bit-banging would be implemented using the timer.

Also note: #20218 would be even another approach that would work for STM32. (Ab)using SPI with DMA for the bit-banging would allow the CPU to either attend other tasks, or to conserve power. That would only work for STM32 MCUs with DMA, though.

@maribu
Copy link
Member

maribu commented May 2, 2024

Would #20646 be a viable alternative for you?

@Lennart-Lutz
Copy link
Author

Hi,

yes at this time i was unaware of #19891 and it seems like the better option.

@maribu
Copy link
Member

maribu commented Aug 7, 2024

Hi,

I haven't looked in my PR for a while. I sadly was unable to reliably control one family of ws281x LEDs with that PR.

It might be a hardware issue with that 5x5 LED matrix I was testing against.

It might be that the alternative I suggested doesn't meet the timing requirements good enough for consistently controlling the ws281x LEDs. Or I just didn't get the implementation right yet. Or I messed up the PCB desing of LED matrix tested against.

I sadly do not have time to dig deeper into it as of now ☹️

@Lennart-Lutz Lennart-Lutz closed this by deleting the head repository Oct 2, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Area: drivers Area: Device drivers
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants