-
Notifications
You must be signed in to change notification settings - Fork 1.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
Sometimes fails with compression allowed. #577
Comments
Hi @mike-s123. Thank you for reporting this. Could you please try to increase the timeout here by increasing 2? It would be interesting to know approximately at what value would start to work for you (if it would at all). Thank you! |
@dobairoland Changing the multiplier to 3 resulted a successful upload without disabling compression.
|
Thank you @mike-s123 for the feedback. We will submit a fix. |
@mike-s123 |
@dobairoland I did some more testing. When I tested earlier, with the multiplier at 3, it worked twice in a row (would fail 100% before). But doing some more uploads I would still get occasional timeout errors (1/4 of the time?). Measuring how long the upload paused - it was usually about 17 seconds, but sometimes over 21. (I added a print to see that esptool.py was setting the timeout to 21 seconds.) So I did some more testing. changing it to 3.5 (timeout 24), I got a failure before I got to 10 tries. I upped the multiplier to 4 (timeout 28). Uploads were successful 25/25. I just happened to find an image which caused these delays which triggered the timeout error. I have no way of knowing if it is the worst case (probably not). It may make sense to change the multiplier to 5. I don't see any disadvantage except taking longer to recognize a legitimate failure, which should be rare. Results:
|
Hi @mike-s123. I really appreciate the time you've taken to run those tests. I'm now testing the following formula to compute the delay:
This should give longer timeout in your case than:
|
@dobairoland On my test file, that results in a timeout of 40, more than the 35 a multiplier of 5 provides. It's good for me, I'll defer to your knowledge of what it's fundamentally based on. Thanks. |
I have this same issue using esptool 3.0 on an 1MB SPI flash "ESP-01" esp8266 module at 115200Bd. The image is an empty 64kB SPIFFS, so highly compressible. When I run esptool.py without --no-compress, it transfers the image almost instantly, then waits a few seconds and prints the timeout error message. When ran with --no-compress, it shows the progress indicator for ~10s, then waits a second or two and exists with "Leaving...". |
Is your feature request related to a problem? Please describe.
esptool.py can fail when uploading some images if compression is allowed: A fatal error occurred: Timed out waiting for packet header
Describe the solution you'd like
Using --no-compress resolves the issue, but a configurable timeout period may solve the issue without the impact on upload time that --no-compress causes.
Additional context
Steps used in troubleshooting here.
The text was updated successfully, but these errors were encountered: