Skip to content
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

Can not auto reset on my board #25

Open
chenjr15 opened this issue Dec 25, 2021 · 24 comments
Open

Can not auto reset on my board #25

chenjr15 opened this issue Dec 25, 2021 · 24 comments

Comments

@chenjr15
Copy link

chenjr15 commented Dec 25, 2021

The screen cant reset after I flash the code. After I double the delay of reset pin it can auto reset now.

	if ( GPIO_RESET >= 0 ) {
		//gpio_pad_select_gpio( GPIO_RESET );
		gpio_reset_pin( GPIO_RESET );
		gpio_set_direction( GPIO_RESET, GPIO_MODE_OUTPUT );
		gpio_set_level( GPIO_RESET, 1 );
		delayMS(50);
		gpio_set_level( GPIO_RESET, 0 );
		// change from 50
		delayMS(100);
		gpio_set_level( GPIO_RESET, 1 );
		delayMS(50);
	}
@chenjr15 chenjr15 changed the title Can not auto reset on 没有 Can not auto reset on my board Dec 25, 2021
@nopnop2002
Copy link
Owner

The reset timing may be different for each TFT.

@nopnop2002
Copy link
Owner

I think there is an electrical problem around reset circuit in the breakout without the CS pin.
Perhaps the reset circuit requires a lot of current.
I inserted a 100 ohm resistor between Vcc and RESET.

TroubleShooting

@DaveDavenport
Copy link

I find the 100 ohm pull up weird.. Its an active low signal and if I measure the level when not asserted it is 3.3V.
On the esp8266 the display works (without external components, with the adafruit library) and in general esp8266 (from what I found) can sink/source less current then the esp32. I wonder if it is more a timing issue.

Secondly, with the 100 Ohm pull up the esp32 needs to sink at least 33mA to pull the signal low (active low to reset), this feels high. The documentation (but it is not very clear) states a max of 28mA.

If I find time I will hook up a scope and see if I can spot a difference so we know for sure.

@DaveDavenport
Copy link

The moment I add some debug code to delayMS my display works, if I remove it, it fails.. this suggest a timing issue (is compiler optimizing stuff away?)

@DaveDavenport
Copy link

This made it work for me (tm), might be a double thing?

diff --git a/main/st7789.c b/main/st7789.c
index 5bde9bc..da8b62e 100644
--- a/main/st7789.c
+++ b/main/st7789.c
@@ -63,11 +63,11 @@ void spi_master_init(TFT_t * dev, int16_t GPIO_MOSI, int16_t GPIO_SCLK, int16_t
                gpio_reset_pin( GPIO_RESET );
                gpio_set_direction( GPIO_RESET, GPIO_MODE_OUTPUT );
                gpio_set_level( GPIO_RESET, 1 );
-               delayMS(50);
+               delayMS(100);
                gpio_set_level( GPIO_RESET, 0 );
-               delayMS(50);
+               delayMS(200);
                gpio_set_level( GPIO_RESET, 1 );
-               delayMS(50);
+               delayMS(300);
        }

        ESP_LOGI(TAG, "GPIO_BL=%d",GPIO_BL);
@@ -98,7 +98,7 @@ void spi_master_init(TFT_t * dev, int16_t GPIO_MOSI, int16_t GPIO_SCLK, int16_t
        memset(&devcfg, 0, sizeof(devcfg));
        devcfg.clock_speed_hz = SPI_Frequency;
        devcfg.queue_size = 7;
-       devcfg.mode = 2;
+       devcfg.mode = 3;
        devcfg.flags = SPI_DEVICE_NO_DUMMY;

        if ( GPIO_CS >= 0 ) {
@@ -199,11 +199,13 @@ bool spi_master_write_colors(TFT_t * dev, uint16_t * colors, uint16_t size)
        return spi_master_write_byte( dev->_SPIHandle, Byte, size*2);
 }

change spi mode to 3 (hint I found somewhere else) and add a bit more delay.

@nopnop2002
Copy link
Owner

I tried your code, But don’t work for me.

After adding the circuit below, it works fine.

ESP32 3V3  -------------------------------+
                                          |
                                          | Emitter
                                         /
                                        /
ESP32 RES  ------------R(2.2K)---------|    S8080
                                Base    \
                                         \
                                          | Collector
                                          |
ST7789 RST -------------------------------+
                                          |
                                          |
                                          |
                                          |
ESP32 GND  ------------R(220)-------------+

@DaveDavenport
Copy link

DaveDavenport commented Nov 3, 2022

So you are inverting the reset signal? did not expect that as solution.
(if V(E-B) is above threshold it conducts, so if res is pulled low, ST7780 RST goes high)

@nopnop2002
Copy link
Owner

nopnop2002 commented Nov 3, 2022

you are inverting the reset signal?

No.

There was a typo for S8050 instead of S8080

The two circuits below are very similar.
In both cases, when the ESP32 RES goes HIGH, the ST7789's RST goes HIGH.
The current flowing through the RST of the ST7789 is different.
The upper circuit carries more current.

ESP32 3V3  -------------------------------+
                                          |
                                          | Emitter
                                         /
                                        /
ESP32 RES  ------------R(2.2K)---------|    S8050
                                Base    \
                                         \
                                          | Collector
                                          |
ST7789 RST -------------------------------+
                                          |
                                          |
                                          |
                                          |
ESP32 GND  ------------R(220)-------------+




ESP32 RES  -------------------------------+
                                          |
ST7789 RST -------------------------------+

@DaveDavenport
Copy link

hmm I assume C/E is swapped, so you are pulling the rst to ~(3.3V-0.7V ) . It is still odd behavior, I will scope it when I have time.

For me the SPI mode 3 (same as was used in the adafruit demo on the esp8266) and slightly longer reset (again picked values from working esp8266 example) works reliable so far. I've done 40 resets and around 15 power cycles and it came back fine every time.

@nopnop2002
Copy link
Owner

For me, SPI mode 3 and mode 2 both work fine.

@DaveDavenport
Copy link

I'm going to get some more modules (slighlty different form factor) soon, I will report back how they work.

@nopnop2002
Copy link
Owner

nopnop2002 commented Nov 3, 2022

If you have a scope, I want you to observe the current through RES and the voltage on RES.

@DaveDavenport
Copy link

image
That signal looks fine. the esp32c3 has no problems asserting that.

@nopnop2002
Copy link
Owner

nopnop2002 commented Nov 3, 2022

Do you know the current value?

I think that the current value has an effect.

@DaveDavenport
Copy link

DaveDavenport commented Nov 3, 2022

Given the above trace, I see no reason to measure current. It clearly is not an issue.

(also your above schematic with the 220 ohm resistor to ground shows the current it takes is most likely < 10mA. )

Did a quick measurement, at high, the current going is 0.1mA, less for pulling to ground. so this is clearly a high-z input.

@nopnop2002
Copy link
Owner

nopnop2002 commented Nov 4, 2022

The schematic was wrong.
Sorry for the confusion.

Circuit A works on ESP32.
Circuit B don't works on ESP32.
Circuit B works on ESP32-S2/ESP32-C3.

circuit A
ESP32 3V3  -------------------------------+
                                          |
                                          | Collector
                                         /
                                        /
ESP32 RES  ------------R(2.2K)---------|    SS8050
                                Base    \
                                         \
                                          | Emitter
                                          |
ST7789 RST -------------------------------+
                                          |
                                          |
                                          |
                                          |
ESP32 GND  ------------R(220)-------------+
circuit B
ESP32 RES  -------------------------------+
                                          |
ST7789 RST -------------------------------+

@DaveDavenport
Copy link

Ill retry it with an esp32. Was using an esp32c3 now.

@sl45sms
Copy link

sl45sms commented Nov 16, 2023

Try to use SPI mode 3 for modules with CS grounded. Not any external circuit required.

@DaveDavenport
Copy link

Try to use SPI mode 3 for modules with CS grounded. Not any external circuit required.

yes, see my reply above. SPI mode 3 works perfectly reliable. I have ~400 devices now running with the right mode without any issues or any extra reset circuitry.

@nopnop2002
Copy link
Owner

I'll test it on the weekend.

@nopnop2002
Copy link
Owner

nopnop2002 commented Nov 16, 2023

Changed SPI mode from 2 to 3.
Test results are good.
No pull-up resistor is required on the reset pin.

Thank you. @DaveDavenport @sl45sms

@DaveDavenport
Copy link

related #38

@nopnop2002
Copy link
Owner

@DaveDavenport

Thank you.

@DaveDavenport
Copy link

Thanks again for your library.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

4 participants