-
-
Notifications
You must be signed in to change notification settings - Fork 19.3k
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
[FR] Marlin 2.0 ESP32 support for alternative WiFi lib like ESP3D #14390
Comments
outstanding work |
I have been using @luc-github fork which allows use of ESP3D. I must say it sets the stage for using the ESP32 to its full capabilities by providing a functional webUI. Without something like the ESP3D webUI, the ESP32 ends up just being yet another 32-bit microcontroller with less pins; its WiFi capability is not being fully exploited. With ESP3D webUI, the printer can be controlled using a web browser on a smart phone. Files can be sent to it via my PC (where I run my slicing software), then printed using any web browser either on my phone or PC. I have a webcam near my printer too, and the webUI also allows you to put the IP address of the webcam. This allows me to actually see the printer printing too. I really hope those working on the ESP32 HAL, and Marlin code in general, can see how we can integrate this feature in the main Marlin repo. |
@felixstormI link and continue discussion started here because it better not to poluate other topic ^_^
this one is easy and not actully related to ESP3D so it should not be an issue
Well that one is not small as web servers API are totally different as well as constraints in code, the handlers are differents as well as type, I do a support such thing in ESP3D 2.0 and 3.0 and this complexify code, that is why I suggested to separate code because bring everything to HAL will make things different, also there are others web servers available that could be used like use the httpd one used for ESP32 Cam. and to again clarify the webUI is not part of that code - we are talking about web url and handler, as well as functions that are handled in code like DHT notification, email/push notifications, telnet, and any other network features. I am open to any implementation - but merging ESP3D webserver code may bring lot mess (if it is even merged after work is done make both webserver to be defined at compilation level) |
@luc-github about WiFi, OTA etc. - I do not think it's necessary to support both WiFi implementations. The current one IMHO is very, very basic (AFAIR it will even prevent Marlin from booting if it cannot connect), so IMHO enhancements would be very welcome here anyway. I would again suggest a separate PR that can take mode, SSID and password from defines in And about the web server implementation: I agree it makes stuff a bit more complicated, but probably not as much as it seems. The current code is enclosed in Again - this is only my humble personal opinion, but if I am not mistaken @simon-jouet, @grownseed and @Idorobots expressed very similar opinions here. |
@felixstorm sorry I may not have same reading as you about the thread,
About maintaining Async and Sync together, yes I know the impact of maintaining such situation this is why I stop to do it in new version of ESP3D. :) Your suggestion to have both web servers solutions (which cover most of the network code actually) in HAL, it will add more code to maintain in Marlin repo not related to Marlin itself, more issues to monitor, more PR to review, etc ... and again for something not really related to Marlin but WiFi or even soon ethernet. Anyway, let's say it is Ok to handle such new code, (I am not talking about replacement like EEPROM support but Async / Sync servers) what the benefit to make both solutions to coexists in Marlin? Current one with webserver with serial like output monitoring and fixed wifi, and the features present in my fork (https://github.com/luc-github/Marlin/issues/10). Again to clarify, my proposal is not only for ESP3D code but any wifi solution, like WiFiManager or any other libs handling wifi features. and any new board with also wifi feature but different API than ESP32 But I would prefer to get an official direction/ decision instead of trying one small PR first Also to be honest this ESP3D porting to Marlin is not my main project, I did it as I promised to @simon-jouet when we discussed at the begining and maintained per request for @vivian-ng, But will be more than happy to invest time, do MR/PR, etc, if needed, but only if direction is defined. I think it make sense to have a plan first instead of blind coding, and do not waste time of Marlin Developers reviewing/rejecting MR/PR ^_^ |
I wonder if the Marlin team and the active contributors to the ESP32 HAL can provide some direction on the way ahead for @luc-github so that he can move ahead.
Hopefully, after getting all your inputs, @luc-github will have enough direction to know how best to merge his work with the main Marlin repo. |
Slow reply time, i've been very busy and little time I had went into the new board. Regarding Async/Sync for the webserver code, if the plan is to bring @luc-github code then I don't think there is much point keeping the current async code. It will just add maintenance over time and if nobody uses it then there isn't much point. The current code already needs maintenance because it doesn't fully work, so not much enabling/disabling broken code as an option. The current OTA code is working fine, so not sure there is much benefits changing that? Bringing the features of ESP3D into Marlin would be very good the web interface it provides is clearly much much more advanced than the current code. If it can be cleanly added to the current code it would clearly be a great addition. |
I was facing an issue with the ESP32 rebooting each time an endstop was triggered during homing on a coreXY setup. It was narrowed down to an issue with the Since most of those contributing to the ESP32 HAL like @simon-jouet have already given their inputs, maybe @thinkyhead can provide a bit of clarity on how to proceed with this issue? |
@vivian-ng IMHO you should probably just file a regular PR replacing the multiplication by 0.5f with a division by 2. In case of any objections you could still change the PR to only divide by 2 if you're compiling for an ESP32 and leave the old code for the other architectures. |
Hi, now that 2.0.0 is officially released, is it time to revisit this issue and see how we can merge back the changes by @luc-github for the ESP32 controller into the main repo? |
@luc-github I think we have the "official" view on this from @thinkyhead.
Maybe you can just submit your fork as a new branch through a pull request? |
@vivian-ng @thinkyhead the question is not about knowing github (I think I know) neither how to do PR (I think I know too) - but about Marlin guidelines development to know if it is better to have entry points to integrate external lib when there is already light code for same function in Marlin or to replace existing code by new one. This answer on facebook is weird (at best), and should happen here IMHO, but if it the rule, sorry I missed it. I would suggest to update http://marlinfw.org/docs/development/contributing.html to mention questions about Marlin development rules ( if any could be ask ?), should be done on facebook and not on github ^_^ If this answer is for question I have submitted above (in github), I will do PR without asking any question, because it seems not appropriate, again sorry for doing that with this topic. |
@luc-github My reading of reply from @thinkyhead on FB is that, as long as the guidelines given in the Marlin docs about contributing are followed, people should feel free to submit their PRs. Because that is what open source development is about, everyone can contribute to make things better. Once the PR has been submitted, the main developers can review the code and work to get it in (or reject it), and if necessary, update the documentation about external libs. I mean, the extensible UI is an example of such an evolution. So maybe just create the branch and send in the PR, and everyone can then follow up on the discussion through the PR to see how best to integrate the changes looking at the code. |
Well I am not mind reader sorry, so my reading of the situation is different - may be wrong, may be not 😸. |
Good work, @luc-github, and an exemplary PR. It looks straightforward and I don't anticipate any issues, but now that it's merged I'm sure we'll find out! |
This issue has been automatically locked since there has not been any recent activity after it was closed. Please open a new issue for related bugs. |
Hello,
I have ported ESP3D https://github.com/luc-github/ESP3D and the corresponding WebUI https://github.com/luc-github/ESP3D-WEBUI for Marlin ESP32 here : https://github.com/luc-github/Marlin/tree/bugfix-2.0.x
The behavior is same as the one I did for WiFi backpack and Azteeg WiFi : https://youtu.be/br7BryjWPJU?t=223, it allows SD upload, Printer control, Marlin configuration, and much more ^_^
I do not think making a PR make sense as there is already a basic WiFi support already merged (#11209).
Instead I would like to propose a PR that give entry points in ESP32 HAL for an alternative external library like
#define USE_EXTERNAL_WIFI_HANDLE
inConfiguration_adv.h
so by default if this define is not enabled the existing WiFi handler is used.The PR would also add entry point in GCODE as I use M585/586/587/588/589 to configure wifi and settings. So need to be able to add extra GCODE commands.
If these entries points would exist, this would easily simplify the code for any new Handler without touching the Marlin code.
It would allow also to update external lib without affecting Marlin code and not maintain a fork for Marlin with ESP3D of course.
Additionnaly this would avoid any wifi issue related to external lib to be handled on Marlin github and so not bring extra work on Marlin.
Before starting moving Marlin for ESP3D as library I would like to know if such PR would be accepted. I would be happy to do it of course.
Please let me know.
thank you
The text was updated successfully, but these errors were encountered: