-
Notifications
You must be signed in to change notification settings - Fork 218
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
Display tuning for better ESP32 compatibility #88
Comments
@thenicnic Thanks for the suggestion on this. However, I've managed to get this working today, no removal of capacitors (yet, I'll see how it goes) but I was intrigued that you were running this display from 5v. This means both CLK and DIO are at 5v, not compatible with the EP32s 3v3 maximum on any pin. I run mine from the TTGO v1.7.1 on-board 3v3 pin (ironically this is at 3v8 for reasons unknown, I've raised an issue with TTGO) and it's all working fine so far. Any comment on your use of 5v? Are you using level shifters or a simple resistor potential divider? Or just plain 5v? |
I should have mentioned that I used an ESP32 "Dev Board" with a voltage regulator on it. It's capable of handling 5 to 12 V DC (but higher voltages are not so recommended because of the heat). Your 3,8 V board is indeed strange. Did you measure under load? And what's the input voltage? Maybe a not-so-great regulator on this Dev Board. |
@thenicnic Regarding the 3.8v out of my "3.3v" regulator, I checked the schematic against what I have. It is definitely a genuine TTGO T8 but that voltage regulator seems very bad. It's powered from USB 5v (barely, more like 4.8v). Unfortunately it's a 5 pin regulator device and I only have 3 pin devices. I still might be able to replace it. I'm certainly not happy using this particular module in the field. I'm astounding the ESP32 is not releasing the magic smoke as the absolute maximum voltage (stressed) is 3.6v - strange! Thanks for your reply, it's all very interesting what the ESP32 will withstand. |
@RalphBacon Thank you really much for investigating and your good work at finding the cause. You're absolutely right - mine does also communicate with 5 V which is a flaw! |
Oh no my fault! I was using reserved GPIOs on my rebuild. I remapped the LED display to pins 26 and 27 and everything is working fine on 3,3 V! Display is a bit darker but no problems at all although no diode is in the circuit. |
The absolute solution would be to use level shifters on the pins 26 & 27 then you could use 5v on the display and make it nice and bright! In this case I think a simple two-resistor divider (2k2 from the display to each ESP pin, and a 3k3 from each ESP pin to GND would drop 5v to around 3v - I do this, but do check with a multimeter). So, four resistors in total for your project would be sufficient. But I am glad you found the cause of the issue and now have it working. |
Yes lowering the logic level is the optimal solution but since I changed the circuit now to run at 3,3 V I won't rework it again because I'm fine with the brightness. I set it to 15 (0x0F) which is maximum and even with a dark tint foil (for better contrast) I cannot complain. Thank you again! |
Indeed, your photo shows a good brightness from the LED display and the foil certainly increases the contrast nicely. I'm happy you got it all working. |
TLDR - will be fine on a 3v3 MCU like esp32 / 8266 etc. From the datasheet, the IO lines are open collector. Most boards implement a 10k pullups to 5V so if you're using a 3v3 MCU then these will try to pull higher than 3v3. All MCU (not CPU's) silicon have supply rail clamp diodes that clamp inputs to the 3v3 rail. With that clamped to 3v3 the 10k pullup resistors will be seeing 1v7 which means they will limit the diode clamp current to 0.2mA which is well within their capability of a few mA and in fact they have an easier time than the output transistors trying to pull down from 5V. |
Great library, thanks! There's nothing wrong with it on the software side.
If you have problems with your TM1637 display (in my case a 4-digit 7-segment):
Paul_B gave the clever tip to remove the two 100 nF SMD capacitors - this is really neccessary since they should be in pF range and cause trouble than solving problems when they have a much too high capacity on higher clock rates like ESP32's up to 240 MHz. (My exemplaries also had two 200 nF caps - no need to remove these.)
My displays caused WiFi loss occasionally when the displays were powered by the same 5 V voltage source like the ESP, especially at startup/reset. I fixed this by adding a N14007 diode between the voltage source (DC-DC) and the 5 V input of the LED display.
The text was updated successfully, but these errors were encountered: