-
-
Notifications
You must be signed in to change notification settings - Fork 3.4k
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
ESP32-C6, -C2, -C5, -H2, -P4 are not supported #3078
Comments
Correct observation. |
Similar for other very brandnew chips: -C2, -C6 , -C61, ESP32-H2, -H4, or ESP32-P4, or -C5. To put it into some context - market availeability of ESP32-C6 was announced just 3 weeks ago on Jan 6, 2023. Knowing espressif, I bet it will take at least 2 years until stable development environments and open source libraries are ready for any "serious use" on -C6. We should put it on the backburner, until stable support is availeable from the core libraries we need, for example: For now, we have enough troubles to make -S3/-S2/-C3 work. So don't expect support for other new models this year. |
Supporting those newer chips requires updating to the esp-idf v5.1. From what I've seen, the migration documentation is pretty good. A potentially valuable bonus is that some of the newer chips, like the S3, now support DMA over the RMT interface. From my experiments, enabling DMA reduces the CPU usage during a transmission to 0.01% compared to about 18% using PIO. I believe this would also reduce the chances of a rogue interrupt causing a glitch proportionally. I'm not sure if this project bumps up into those limits or has a problem with interrupt-caused glitches, but if so, that might be another reason to consider it. |
A project as big as WLED needs manpower to support various chips, not just development environment. |
Sorry, but what you propose is not enough for WLED. We have a long list of dependencies, including (but not limited to) arduino-esp32, and NeoPixelBus. All dependencies (libraries / frameworks that we use with WLED) need to be upgraded to support new chips. For some (like NPB) explicit support must be added by developing new code. it's not just about dropping in a new framework, then be happy. I fully concur with @blazoncek - any real help (personal commitment for coding & testing) would be much appreciated.
Edit: Not sure about quality of the migration document, it is definitely "pretty big" . Espressif announces a huge number of "breaking changes", some important APIs were either deprecated, or already replaced with something completely other. It means a lot of work to go from esp-idf 4.4.x to esp-idf 5.1. |
I'm not a user of WLED but also write LED drivers for ESP32, and I'm not making requests, demands or suggestions that you do anything at all. I was sharing information I'd learned about the new features in ESP-IDFv5 that might be relevant to someone else writing LED driver code on ESP chips, since it offers a significant performance improvement. I was excited by my discovery and thought the people working on this project would be too. Your project is impressive and I hope you find the help you're looking for. |
Thanks for your willingness to share. As such there is (almost) nothing (apart GPIO numbers related stuff) in WLED core code that is chip specific. Libraries as NeoPixelBus or LittleFS and AsyncWebServer are the ones that would need to add support for the above mentioned chips before WLED can support them as well Though some usermods may use particular HW but those are optional and not all support every chip. |
I've been over to the NeoPixelBus repo and looking at Makuna/NeoPixelBus#598 it seems they're already looking into it. |
It's been some time since this issue has been created, have there been any advancements with the libraries and such to make the new chips work? |
Not enough advances, unfortunately - it looks like my old "at least 2 years" estimate was quite accurate.. If NeoPixelBus would be able to utilize the new RMT driver in esp-IDF 5.1.x, we could make an attempt to get WLED running on the -C6. Maybe this will happen during the next year. For other new chips - nothing in sight. |
The new RMT support is in the NeoPixelBus/Core3 branch. Still not configured to use the new boards yet. Still waiting on an updated IDF to fix issues others have seen with it. |
Sorry to be that guy, but is there an rough estimate on how long it will take? I'm looking to invest in to these boards, once support is added. Thanks |
As you are "that guy" you probably guessed the answer 😉 A bit more seriously - there is no schedule for supporting the -C6 in WLED. Personally I have a fork that compiles for -C6, but there is still a looooong way to go. From experience with other "new boards" like the -S3, I would expect that we'll need around two years from "experimental" to "WLED runs stable on this MCU". The same was true for -S3, where we started "experimental support" in mid 2022. Same for possible support of the "C61" and P4". OK P4 might even take longer because there is no support from arduino-esp32 or other libraries yet. So if you're looking at a project or other business case, I'd say don't bet your money on the -C6. If you need ZigBee, you could be faster by taking a ZigBee "daughter board" (e.g. XBee module) and then you'd program a usermod that communicates with the daughter board. |
I'm a bit confused. You write that the esp32-c3 and esp32-s3 boards, the mini ones, are not supported normally yet. But still, do you have some firmware posted, are these boards supported or not? If yes, do they work well? |
C3 and S3 are mostly supported now but still not as stable as classic ESP32 and there may still be undiscovered bugs. Not all variations of C3 and S3 boards are supported by the installer or WLED, you may need to edit code or manually install. |
What would be the best way to help out with -C6 support? I should have a few -C6 boards to try out in a couple of weeks, and should be able to contribute some development effort. |
Nobody said that. MCUs, C3 and S3 (and S2) are well supported in WLED. The issue is development board implementation by different hardware manufacturers. There are variants that will not play well with officially distributed versions of WLED binaries. In such case you'll need to compile (and figure out compilation parameters) yourself. There are also poorly designed boards out there. No software can help with that.
Yes we have. Yes and no. Depends on particular development board. See above.
Depends on what you consider "well". There may be connectivity issues if your WiFi is not perfect, you may see performance lag compared to ESP32, etc. As there are numerous development boards available and not all are made equal we cannot support all of them. Currently working "well" are the following (the ones I tested, @softhack007 and @DedeHai may add theirs):
|
Compile until it works. When compile works, figure out GPIO restrictions, RAM restrictions, library restrictions. |
I can add this to the list
Personally I do not see any benefit in the C6 over C3 for WLED, it just has more GPIOs but so does the S3. |
I'm looking for the smallest board possible to put a levelshifter on and connect it to the strip. My maximum profile width is 3 cm and the depth is 2 cm. Esp32-c3 is ideal - it just fits, all other boards are bigger unfortunately. |
C3 is far from ideal. But it is a good start. Depending on what you need, @srg74 may have LilyGo TTGO T-01 C3 compatible board which is 30x20x17 mm including LilyGo board. |
The smallest one I know about is the waveshare S3 Zero - 1.8cm x 2.5cm. It needs the |
So here ist my list of boards I have.
plus a "nanoESP32-C6" for experimenting with C6 builds. But that's absolutely experimental. Please note that some of the boards need a modified platformio.ini buildenv - usually to adjust for flash size, or add |
@DedeHai @blazoncek I fully agree - running WLED on -C6 is useless at the moment - see below @amcewen @aaalek some facts as to where we are, and what can be expected from -C6
For the curious, this my own experimental branch for -C6: Maybe a usermod for ZigBee would be a game-changer - but this usermod is "yet to be created" by the WLED community. |
Yeah I wanted to try the C6 for ZigBee, but it's looking like I might end up writing a usermod to communicate with a C6 from a supported ESP32 before having a WLED build running on the C6 alone |
@netmindz Actually having a similar idea but instead of writing a usermod I will just remote control WLED by simulating a ESP-NOW remote on my C6. I need the C6 because it has 2 TWAI controllers, that I need for my project. |
Is this particular board currently supported or not? Контроллер WLED ESP32C3 5-24 В, Here on Ali they sell some ready-made boards. Are they bad? |
Please define "supported". I have one on my desk and I can upload WLED 0.15 to it - from the developer environment (VSCode+platformIO). I'm not sure if the web installer has all the necessary files. But you may be lucky. Please remember it is just the ESP32-S3, so you'll need to add level shift and other components for driving your LED strip. This is an open source community project - you can't get a definite guarantee from us. My suggestion would be to order one, and try it out.
I have no idea. It's a C3 so its very minimal, and no audio support. Maybe ask the seller how to upload WLED updates (USB preferred).
|
Do I understand correctly that the main problem is the lack of libraries during the firmware of the board? If the firmware is loaded somehow into the esp32-c3, then most likely it will work fine? |
"Somehow" is by using web installer or PIO upload or manually uploading using esptool. As mentioned several times C3, S2 and S3 are fully supported in firmware. Getting correct binary is somehow tricky for S3. |
@softhack007 thanks for sharing your experiences with -C6 and take on where things are build-wise. I hadn't seen the platformio / espressif politics until now - my other big ESP32 project at the moment is using esp-idf directly (with Arduino as a component). It does seem like -C6 support would only make sense once it's clearer how WLED is going to address things w.r.t. platformio and arduino-esp32 v3.0.x I'll probably go with a -C3 for now then (the Bluetooth 5.3 support on the -C6 was what was tempting me that way, but was always a longer-term thing-to-play-with 😁) As I say, I'm not tracking platformio closely and so might be looking in the wrong place, but it looks like they're still supporting later versions of esp-idf? Would moving to Arduino as a component be a path to migrate to newer versions, and arduino-esp32 v3, while continuing to use platformio? I've got the move from esp-idf v4 and arduino-esp32 v2 to v5.3 and v3 looming on another project, so will have a bit of experience with that move (with arduino as a component) in a month or so. On a personal note it's a shame to see |
The c6 would be very nice for me because of those 2 reasons:
would love to see support, even if its only experimental, for the c6. |
Sorry but -C6 is still 2.4Ghz only. So it would not help in your situation. |
Thanks, i got tricked by this "Wifi6" and did not see the "2.4ghz". Should be -C5 |
Hi all. I am not new to the ESP32 family but relatively new to WLED. I have purchased several commercial controllers from Athom and have been relatively pleased. I have also done two of my one designs. Not using a development board but using the Espressif device on a board of my own design. The first one I did was a simple Christmas tree star. To avoid the issues of device compatability, I used the ESP32-MINI-1-N4. As I have done in the past, I included the UART device (CP2102N) and the same transistor circuitry that Espressif uses to perform the bootloading through the USB COM port. I even put the two EN and BOOT buttons on the board even though they aren't needed to write to the flash memory. (See the attached.) I ended up using esp32tool from the Command line to erase, load the bootloader, and then load WLED. The most recent version of WLED that I was able to load was v0.13.3. Versions v0.14.3 and v0.14.4 loaded but would not come up properly. There were several unhandled exceptions that put the device in to endless reboots. Also, under v0.13.3, the WiFi and LED settings are saved but not the lastest effect and color used. Any thoughts on that? I understand that there are some development boards that are better than others and that can cause issues with WLED even if using an ESP32. I am not sure where my board would fall because I did basically the same thing that Espressif does on their development boards. I very much would like to base all my future designs on the ESP32-C3. Since I am designing the boards, I can put whatever I need to in order to ensure proper performance. The problem is that I haven't been able to find out what exactly that is. What should I put in any new designs with the ESP32-C3 that would keep it compatible with WLED? Thanks very much. |
Regarding ESP32-MINI-1-N. Basically it’s an encased pico-d4. For this variant you have to use different bin file because pinout is slightly different than esp32 based modules. |
srg74, |
THAT'S IT!!! Thanks very much! Why is this not on the official release page? Now I can move forward with my other designs based on this device. |
It is listed in official KB. There’s few most often used repos with ready to use binaries. |
As an update on progress on the RISC-V chipsets, the ESP32-P4 is running the WLED-MM fork very well with Arduino-ESP32 built on IDF v5.3.2 - but it's entirely limited to network pixels at the moment. https://github.com/MoonModules/WLED/tree/P4_experimental There's still a few rough code edges, but I have several of these (still hard to find) boards in use in the wild, including one at a venue where it's driving their Art-Net lighting installation with over 11000 pixels every night with full audio reactive effects - so the build is reliable. Once Makuna has some NeoPixelBus magic done for the P4 it should just snap in and we'll have local LED output as well. @Makuna - I'd be very happy to ship you a few free ESP32-P4 boards to support development, BTW. Just send me your address. ❤️ 18432 pixels in this display pushed from a single ESP32-P4 to Art-Net hardware. 😀 |
@troyhacks |
@Cherish-Gww the -P4 port from @troyhacks is based on my work for the esp32-C6 (see a few posts up). So yes it could be ported to C6, but the result will not make you happy right now. Currently we have no (zero, nada, nothing, nix) usable support for led pins, not for digital leds and not for analog leds, either. That's due to massive API changes in the new framework versions we are forced to use for C6 and P4. So there is still a long way ahead of us. The message is, we're moving. |
Fixed that. I said "semi-professional" once but it actually works on all Art-Net controllers, and it's stupid fast. I was referring to "semi-professional" as more a price point. It'll work on all of them, from using WLED itself as an Art-Net endpoint to middle range $150 Chinese controllers all the way up to "this costs a stupid amount of money because it's meant for stadium shows" controllers. To say the P4 port isn't useful isn't true - it works extremely well with Art-Net, and Art-Net is what you want when you're running huge displays anyway, as you can have essentially unlimited "pins" (outputs) with Art-Net. Parallel outputs, stupid fast, accurately clocked. It costs more money, but using the P4 to drive a few local LEDs is kinda overkill even if it worked. The P4 is for driving a LOT of LEDs... I've pushed over 65,000 LEDs with it via Art-Net from WLED. Nothing on the market does this for $0 software at this rate of speed with full audio reactive effects. It's useful - but more on the "I'm a crazy person" level. 😁 |
What happened?
Unable to flash WLED firmware to ESP32-C6-DevKitC-1 v1.1
To Reproduce Bug
Just try to flash wled firmware to any ESP32-C6 chip
Expected Behavior
I guess we need two versions of firmware
Install Method
Binary from WLED.me
What version of WLED?
WLED_0.14.0-b1
Which microcontroller/board are you seeing the problem on?
Other
Relevant log/trace output
Anything else?
No response
Code of Conduct
The text was updated successfully, but these errors were encountered: