This Blog lists some key insights I gained on Arduino, ESP32-S3 (Lilygo), RP2040 and Raspberry Pi

ESP32-S3 WiFi connection stability / October 2023

I noticed that the ESP32S3 sometimes looses WiFi connectivity, which is not reflected in WiFi.status(). My workaround is to check every 15 seconds, whether I can make a connection to port 80 of the gateway, and when not successful reset WiFi:
[ .. Code snippet .. ] //check TCP connectivity -- Here, this piece of code is executed once per second if (seconds%15==0){ //every 15 seconds check ('seconds' is part of my clock) WiFiClient client2; //make a new client (executed every 15 seconds) IPAddress myGW=WiFi.gatewayIP(); //create ip address of the gateway if (client2.connect(myGW, 80)) { //make a connection to the gateway, typically the router, which has http management (port 80) GWgood++; //increment my good test counter } else { GWbad++; /increment the bad test counter WiFi.reconnect(); //force a reconnect } client2.stop(); // no longer needed, close the client } After testing for a few days, this has proven to work reliably. I did not observe a change in WiFi.status(), nor did setting core debug level to verbose show any useful information in the Serial Console.

I suspect the above is a bug of some sorts, that a few people ran into. My above workaround does not take much resource in terms of code, memory or CPU time.

ESP32-S3 by Lilygo Battery Power / August 2023

The Lilygo ESP32-S3 T-Display is a great part, but documentation is hard to find. It took me a while to figure out the following:

If only Battery powered, the ESP32-S3 actually is powered and runs. However, unless the user (I use the Arduino IDE) sets GPIO 15 HIGH, the LCD is not powered, neither the green LED nor the R-divider network that let's you check the voltage on GPIO 4. If you reset the module, only using battery power, the LCD controller has no power and is not initialized, hence it will not display anything when you later connect USB power. In summary:

The PWR_EN (GPIO 15) pin controls: -The green LED -The LCD power -the input to the Resistor divider network that lets you analogRead() a corresponding power supply value Moreover, supplying USB power is having the same effect as setting PWR_EN HIGH.

What is confusing: when USB power is supplied the BAT_ADC net (to GPIO 4) acually measures the USB supply and not the BATtery voltage. I think turning off the R-divider input on battery power makes no sense, perhaps it will be corrected in a future version (ref: Schematics 3/13/2023).

The part has an integrated 3V3 voltage regulator for the ESP32, and a LiPo charge chip to charge a LiPo when connected to USB power. That chip gets really hot.

I think the user sketch has to check whether the lower battery voltage has been reached, and then put GPIO 15 low, and put the ESP32 in deep sleep. If your user sketch does not do this, you run the risk of killing the LiPo battery (due to undervoltage).

RPi-4 USB3 power supply problems / February 2022

I have not found much about this issue on the Internet.
The problem is that when connecting a USB3 - SATA adapter with an SSD drive to RPi-4 to get good rootfs performance, not enough power is supplied to the USB port and the drive goes erratic and the OS crashes. I tried various USB3 SATA adapters and various OSs (I prefer Fedora). After many months of elapsed time, I figured out that the FET powerswitch on the RPi4 that enables power on USB (I do not understand why it is designed this way) is too weak. The remedy is simple: I solder a wire directly from the 5V pad at the USB power connector to the USB connector pin that supplies the 5V to USB. The system now runs stably for months! I have not noticed negative side effects. Comments: please email me at ronald (dot) gadget (at) gmail.com

Arduino & Feather RP2040 + Earle Philhower: HowTo and Learnings / 22 Dec 2021

I spent two weeks learning how to get [Arduino & Feather RP2040 & Earle Philhower's core] working, migrating my sketch from a nano Every... In the process, I declared the hardware as 'bad' and almost gave up on this part at least 3 times. However, the hw is great - it is a matter of understanding how the part behaves, partially correct documentation and being among the first ones to use this. I tried using the VSCode IDE, but gave up as PlatformIO does not yet officially support Philhowers board package (mid december 2021).

Notes: I wanted to buy the Raspberry Pico, but shipping costs were 3 times the part costs (don't know what they were smoking). So I ordered the adafruit part thru digikey with reasonable shipping costs. The Arduino RP2040 connect has wifi+bt that I dont need and want to pay for. And too high shipping costs. Philhower docu: Installing the Earle Philhower core | Program RP2040 in Arduino | Adafruit Learning System

RPi4 + Argon One case + Hyperpixel 4 display: fan control not working / January 2022

The Pimironi Hyperpixel display uses all GPIO pins on the header. Obviously, the Argon One also uses some pins, which yields a conflict. This results in the FAN control not working (based on temperature). The main issue is the i2c pins, which the display does not configure as i2c. I found this out by going thru the dmesg output right after boot, where a message informs about this conflict. Of course, you have to actively go an look for this. The good news is that the Hyperpixel display provides.... an i2c connector! Thus I solved the problem by cutting the circuit board i2 traces to the Argon One chip that controls the fan speed, on the Argon One circuit board that connects the RPI4 GPIO connector to the Argon One GPIO connector. The last step is to adapt the python script that is run as a service to use the new i2c interface (thru this error message I discovered how to fix the issue). The system now works as desired!

Data Motion Architecture & Consulting GmbH - Ronald's pagecounter 2459 page visits since 6 March 2022