-
Notifications
You must be signed in to change notification settings - Fork 75
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
TimeoutError: Timed out waiting for SPI char (Teensy 4.0 + Adafruit AirLift FeatherWing - ESP32 WiFi Co-Processor) #170
Comments
At this point in time I have it running which is great. I changed the baud rate of 8000000 (Which isn't very common, or common at all) to common values such as 115200 or the highest common 921600 and it worked.
I did run into some scanning network problems for CircuitPython 8 alpha for the Teensy4.0 but the 7.3.1 version works great! This is a bit of self closure but Im interested in why the baudrate is set so high? Might just be a teensy thing and it not understand that number means more limitless and needs a defined common rate. Im going to leave this open a tad bit longer to see if I run into any other problems and to see if my question gets answered. |
This the the SPI clock frequency -- it's not a UART baud rate, so it can be much higher. However, it's interesting that reducing the SPI clock rate improved things for you. |
Hi there, I've been having this problem with my Pyportal Titano for the last year. It will crash randomly after making network requests - sometimes on the first try, sometime after many hours of working smoothly. I have the latest Nina 1.7.4 firmware installed, and I've tried 6.x, 7.x and all the newest 8.x CP builds and libraries as well. I have tested three different Titanos, and they all do this, so it doesn't seem to be a problems that's unique to one of them. I'm a novice programmer, so it's not been easy trying to figure out how to fix this, and I'm trying to make gadgets that will work reliably and indefinitely without crashing. Are there any resolution to this problem in the works for future released? AFAICT, it looks like I need to compile my own version of adafruit_esp32spi with a baud rate change to fix this. I would be so happy to have this officially resolved, so that I can distribute my gadgets in a way where future updates won't always require custom hacked libs. |
@HowdyMoto When you say "crash", does that mean: the PyPortal becomes completely unresponsive until reset? the PyPortal gets a hardfault? the PyPortal exits your code with an exception? Depending on which behavior, there are a number of things to try. Under normal circumstances, it should not be necessary to reduce the SPI frequency. Generally, the PyPortal devices and typical libraries are stable under 7.3.3, and even under the 8.0.0-betas. It is expected that networking code will get exceptions, so the https://adafru.it/discord is a great place to go for support questions. |
Thanks for this! When I say "crash", I mean that I get the this error: which halts the program. I tried try/catch blocks, and tried resetting the esp with esp.reset(), followed by re-initializing it and re-conecting to Wifi, but after that error is thrown, it never seem to be able to recover until I reboot the device. My program is based on this: However, as I got frustrated from these crashes, I re-wrote the entire thing just to expose the esp.reset() function, which I seem to recall isn't exposed when you're using the Pyportal libs. Here's my new code. Unfortunately, worldtimeapi.org went down last week. so it won't run anymore - Here's one piece of code that generated this error - when it happens, I try to reset the esp and re-inititialize it, and reconnect to wifi, but it doesn't work (and unfortuantely it won't run at all right now, and I forget what exactly the error is)
|
btw, you can init the esp separately, then pass it in to the PyPortal https://docs.circuitpython.org/projects/pyportal/en/latest/api.html#adafruit_pyportal.PyPortal, then you have access to It is unusual that |
I'm also getting this timeout error with my PyPortal. my_minimqtt is adafruit_minimqtt with modifications (primarily moving SUBACK to _wait_for_msg and adding a code to MMQTTException that can be checked)
I tried adjusting the baudrate as above, but it still ocurred I was able to get around the issue with the following code block in my main loop
the connectNeeded is an indicator to reconnect to wifi & mqtt, etc |
Hi all, here is a solution to this problem. I can confirm that my device now runs forever without crashing with this approach. You can see my approach here on line 93: In short, you'l need to do the following: from adafruit_esp32spi import adafruit_esp32spi
from adafruit_pyportal import PyPortal
...
esp = adafruit_esp32spi.ESP_SPIcontrol(SPI, ESP32_CS, ESP32_READY, ESP32_RESET )
pyportal = PyPortal(esp=esp, external_spi=SPI, debug=PYPORTAL_DEBUG)
# write code like this in a try/except to detect esp problems and simply brute-force reset the esp chip:
while True:
try:
pyportal.get_local_time(secrets["timezone"])
break
except (ValueError, RuntimeError, ConnectionError, OSError) as e:
print("esp has an issue, reset and retry\n", e)
esp.reset()
esp.disconnect()
pyportal.network.connect()
time.sleep(5) Voila! Works perfectly. Good luck, friends! |
@HowdyMoto are you still sure your application runs forever without freezing? Referring to the issue I linked to above, my PyPortal Titano still freezes after doing the same error handling as you do. I even bought a new device in case it was hardware related. The new device ran 1120 iterations reloading API data before freezing, which is way more than my first device. But that might be a coincidence.
Console log between iteration 1120 and 1121:
|
I found that the problem went away completely, but I suppose it's possible that a different version of CircuitPython/different libraries could cause you problems. This is the app I made that seemed to work fine, if you want to try it out: |
Hello i just installed CircuitPython on my Teensy 4.0. Im trying to use a Adafruit AirLift FeatherWing - ESP32 WiFi Co-Processor. Following the guide i installed all the dependencies/ libraries and have the Wifi Co-Processor up to date. Using the ScanNetwork Arduino sketch it runs fine and i can see available networks. As soon as i use CircuitPython i get this error.
I saw a similar problem arise and followed the outlined steps but i still have the problem.
If anyone has any recommendations id much appreciate it.
Best,
W
Example code:
library folder:
The text was updated successfully, but these errors were encountered: