mirror of
https://github.com/esp8266/Arduino.git
synced 2025-10-24 07:13:45 +03:00
395 lines
18 KiB
ReStructuredText
395 lines
18 KiB
ReStructuredText
:orphan:
|
|
|
|
I am getting "espcomm\_sync failed" error when trying to upload my ESP. How to resolve this issue?
|
|
--------------------------------------------------------------------------------------------------
|
|
|
|
- `Introduction <#Introduction>`__
|
|
- `Initial Checks <#initial-checks>`__
|
|
- `Advanced Checks <#advanced-checks>`__
|
|
- `Reset Methods <#reset-methods>`__
|
|
- `Ck <#ck>`__
|
|
- `Nodemcu <#nodemcu>`__
|
|
- `I'm Stuck <#im-stuck>`__
|
|
- `Conclusion <#conclusion>`__
|
|
|
|
Introduction
|
|
~~~~~~~~~~~~
|
|
|
|
This message indicates issue with uploading ESP module over a serial
|
|
connection. There are couple of possible causes, that depend on the type
|
|
of module, if you use separate USB to serial converter, what parameters
|
|
are selected for upload, etc. As result there is no single answer on the
|
|
root cause. To find it out you may need to complete couple of
|
|
troubleshooting steps.
|
|
|
|
Note: If you are just starting with ESP, to reduce potential issues
|
|
with uploading, select ESP board with integrated USB to serial
|
|
converter. This will considerably reduce number of user depended
|
|
factors or configuration settings that influence upload process.
|
|
|
|
Example boards with USB to serial converter build in, that will make
|
|
your initial project development easier, are shown below.
|
|
|
|
.. figure:: pictures/a01-example-boards-with-usb.png
|
|
:alt: Example boards with integrated USB to serial converter
|
|
|
|
Example boards with integrated USB to serial converter
|
|
|
|
If you are using a Generic ESP8266 module, separate USB to serial
|
|
converter and connect them by yourself, please make sure you have the
|
|
following three things right: 1. Module is provided with enough power,
|
|
2. GPIO0, GPIO15 and CH\_PD are connected using pull up / pull down
|
|
resistors, 3. Module is put into boot loader mode.
|
|
|
|
For specific details please refer to section on `Generic ESP8266
|
|
modules <../boards.rst#generic-esp8266-modules>`__. Example modules
|
|
without USB to serial converter on board are shown below.
|
|
|
|
.. figure:: pictures/a01-example-boards-without-usb.png
|
|
:alt: Example ESP8266 modules without USB to serial converter
|
|
|
|
Example ESP8266 modules without USB to serial converter
|
|
|
|
Initial Checks
|
|
~~~~~~~~~~~~~~
|
|
|
|
In order to troubleshoot "espcomm\_sync failed" error, please proceed
|
|
step by step through the checklist below. This list is organized
|
|
starting with most common and simple to more complex issues.
|
|
|
|
1. Start with reading exact message displayed in debug window of Arduino
|
|
IDE. In many cases it provides direct information where the issue is.
|
|
|
|
.. figure:: pictures/a01-espcomm_open-failed.png
|
|
:alt: "espcomm\_open failed" error
|
|
|
|
"espcomm\_open failed" error
|
|
|
|
For instance message above suggests that Arduino IDE is unable to open a
|
|
serial port COM3. Check if you have selected port where your module is
|
|
connected to.
|
|
|
|
.. figure:: pictures/a01-serial-port-selection.png
|
|
:alt: Serial port selection
|
|
|
|
Serial port selection
|
|
|
|
2. If a module is connected to the serial port but not responding as a
|
|
valid ESP8266 device, the message will read slightly different (see
|
|
below). If you have other modules connected to your PC, make sure
|
|
that you are uploading code to ESP8266 and not to e.g. Arduino UNO.
|
|
|
|
.. figure:: pictures/a01-espcomm_sync-failed.png
|
|
:alt: Serial port selection
|
|
|
|
Serial port selection
|
|
|
|
3. To have your PC talking to ESP, select exact ESP type in upload menu.
|
|
If selection is incorrect then the upload may fail.
|
|
|
|
.. figure:: pictures/a01-board-selection.png
|
|
:alt: Board selection
|
|
|
|
Board selection
|
|
|
|
Basing on selected board type, Arduino IDE will apply specific "reset
|
|
method" to enter the board into boot loading mode. Reset methods are
|
|
board specific. Some boards do not have the h/w in place to support
|
|
reset by Arduino IDE. If this is the case, you need to enter such board
|
|
into boot loading mode manually.
|
|
|
|
4. Upload may be also failing due to too high speed. If you have long or
|
|
poor quality USB cable, try reducing selection under *Upload Speed*.
|
|
|
|
.. figure:: pictures/a01-serial-speed-selection.png
|
|
:alt: Serial speed selection
|
|
|
|
Serial speed selection
|
|
|
|
Advanced Checks
|
|
~~~~~~~~~~~~~~~
|
|
|
|
1. If you are still facing issues, test if module is indeed entering the
|
|
boot loading mode. You can do it by connecting secondary USB to
|
|
serial converter and checking the message displayed. Attach RX and
|
|
GND pins of converter to TX and GND pin of ESP as shown on example
|
|
below (`get fzz
|
|
source <pictures/a01-secondary-serial-hookup.fzz>`__).
|
|
|
|
.. figure:: pictures/a01-secondary-serial-hookup.png
|
|
:alt: Secondary USB to serial converter hookup
|
|
|
|
Secondary USB to serial converter hookup
|
|
|
|
Then open a terminal at 74880 baud, and look what message is reported
|
|
when ESP is being reset for programming. Correct message looks as
|
|
follows:
|
|
|
|
``ets Jan 8 2013,rst cause:2, boot mode:(1,7)``
|
|
|
|
If you see similar message but different values then decode them using
|
|
`Boot Messages and Modes <../boards.rst#boot-messages-and-modes>`__. The
|
|
key information is contained in first digit / three right-most bits of
|
|
the boot mode message as shown below.
|
|
|
|
.. figure:: pictures/a01-boot-mode-decoding.png
|
|
:alt: Decoding of boot mode
|
|
|
|
Decoding of boot mode
|
|
|
|
For instance message ``boot mode (3,3)`` indicates that pins GPIO2 and
|
|
GPIO0 are set HIGH and GPIO15 is set LOW. This is configuration for
|
|
`normal
|
|
operation <../boards.rst#minimal-hardware-setup-for-running-only>`__ of
|
|
module (to execute application from flash), not for `boot
|
|
loading <../boards.rst#minimal-hardware-setup-for-bootloading-only>`__
|
|
(flash programming).
|
|
|
|
Note: Without having this step right you will not be able to upload
|
|
your module over a serial port.
|
|
|
|
2. You have confirmed that module is in boot loading mode but upload
|
|
still fails. If you are using external USB to serial converter, then
|
|
check if it operates correctly by looping it back. This is quite
|
|
simple check. Just connect TX and RX of your converter together like
|
|
on picture below. Then open Serial Monitor and type some characters.
|
|
If everything is fine, then you should see what you type immediately
|
|
printed back on the monitor. For an ESP with USB to serial converter
|
|
on board, this check may involve breaking some PCB traces. I would
|
|
not do it unless being desperate. Instead try steps below.
|
|
|
|
.. figure:: pictures/a01-usb-to-serial-loop-back.png
|
|
:alt: USB to serial converter loop back
|
|
|
|
USB to serial converter loop back
|
|
|
|
3. Next step to try, if not done already, is checking detailed debug
|
|
messages. Go to *File > Preferences*, enable *Show verbose output
|
|
during: upload* and try uploading again. For successful upload this
|
|
log should look similar to example shown below:
|
|
|
|
``C:\Users\Krzysztof\AppData\Local\Arduino15\packages\esp8266\tools\esptool\0.4.8/esptool.exe -vv -cd ck -cb 115200 -cp COM3 -ca 0x00000 -cf C:\Users\KRZYSZ~1\AppData\Local\Temp\build7e44b372385012e74d64fb272d24b802.tmp/Blink.ino.bin esptool v0.4.8 - (c) 2014 Ch. Klippel <ck@atelier-klippel.de> setting board to ck setting baudrate from 115200 to 115200 setting port from COM1 to COM3 setting address from 0x00000000 to 0x00000000 espcomm_upload_file espcomm_upload_mem setting serial port timeouts to 1000 ms opening bootloader resetting board trying to connect flush start setting serial port timeouts to 1 ms setting serial port timeouts to 1000 ms flush complete espcomm_send_command: sending command header espcomm_send_command: sending command payload read 0, requested 1 trying to connect flush start setting serial port timeouts to 1 ms setting serial port timeouts to 1000 ms flush complete espcomm_send_command: sending command header espcomm_send_command: sending command payload espcomm_send_command: receiving 2 bytes of data espcomm_send_command: receiving 2 bytes of data espcomm_send_command: receiving 2 bytes of data espcomm_send_command: receiving 2 bytes of data espcomm_send_command: receiving 2 bytes of data espcomm_send_command: receiving 2 bytes of data espcomm_send_command: receiving 2 bytes of data espcomm_send_command: receiving 2 bytes of data Uploading 226368 bytes from to flash at 0x00000000 erasing flash size: 037440 address: 000000 first_sector_index: 0 total_sector_count: 56 head_sector_count: 16 adjusted_sector_count: 40 erase_size: 028000 espcomm_send_command: sending command header espcomm_send_command: sending command payload setting serial port timeouts to 15000 ms setting serial port timeouts to 1000 ms espcomm_send_command: receiving 2 bytes of data writing flash .............................................................................................................................................................................................................................. starting app without reboot espcomm_send_command: sending command header espcomm_send_command: sending command payload espcomm_send_command: receiving 2 bytes of data closing bootloader flush start setting serial port timeouts to 1 ms setting serial port timeouts to 1000 ms flush complete``
|
|
|
|
Upload log may be longer depending on number of connection attempts made
|
|
by esptool. Analyze it for any anomalies to configuration you have
|
|
selected in Arduino IDE, like different serial port, reset method, baud
|
|
rate, etc. Resolve all noted differences.
|
|
|
|
Reset Methods
|
|
~~~~~~~~~~~~~
|
|
|
|
If you got to this point and still see ``espcomm_sync failed``, then now
|
|
you need to bring in the heavy guns.
|
|
|
|
Connect scope or logic analyzer to GPIO0, RST and RXD pins of the ESP to
|
|
check what's happening.
|
|
|
|
Then compare your measurements with wave-forms collected for circuits
|
|
below. They document two standard methods of resetting ESP8266 for
|
|
upload, that you can select in Arduino IDE - `ck <#ck>`__ and
|
|
`nodemcu <#nodemcu>`__.
|
|
|
|
Ck
|
|
^^
|
|
|
|
Circuit below has been prepared to collect wave-forms for ck reset
|
|
method (`get fzz source <pictures/a01-circuit-ck-reset.fzz>`__). It is
|
|
simpler than for `nodemcu <#nodemcu>`__ reset and therefore often used
|
|
to wire up generic ESP modules on a breadboard. Check it against your
|
|
wiring when comparing your measurements against wave-forms below.
|
|
|
|
.. figure:: pictures/a01-circuit-ck-reset.png
|
|
:alt: Sample circuit to check ck method
|
|
|
|
Sample circuit to check ck method
|
|
|
|
The following wave-forms below show voltage signals on GPIO0 and RST
|
|
pins of the ESP board when uploading the firmware.
|
|
|
|
Close up of ck reset method signal sequence at the beginning of upload
|
|
is shown below.
|
|
|
|
.. figure:: pictures/a01-reset-ck-closeup.png
|
|
:alt: Reset Method: ck, close up at the beginning of upload
|
|
|
|
Reset Method: ck, close up at the beginning of upload
|
|
|
|
Next picture shows complete upload of
|
|
`Blink.ino <https://github.com/esp8266/Arduino/blob/master/libraries/esp8266/examples/Blink/Blink.ino>`__
|
|
example at 921600 baud. This is quite high speed, so the upload takes
|
|
only about 8s.
|
|
|
|
.. figure:: pictures/a01-reset-ck-complete.png
|
|
:alt: Reset Method: ck, complete upload
|
|
|
|
Reset Method: ck, complete upload
|
|
|
|
Please note that when esptool is not able to initialize upload at the
|
|
first time, then it retries reset procedure. Case of one such retry is
|
|
shown on wave-form below.
|
|
|
|
.. figure:: pictures/a01-reset-ck-complete-1-retry.png
|
|
:alt: Reset Method: ck, complete upload
|
|
|
|
Reset Method: ck, complete upload
|
|
|
|
Each retry is reported in upload log as follows:
|
|
|
|
::
|
|
|
|
resetting board
|
|
trying to connect
|
|
flush start
|
|
setting serial port timeouts to 1 ms
|
|
setting serial port timeouts to 1000 ms
|
|
flush complete
|
|
espcomm_send_command: sending command header
|
|
espcomm_send_command: sending command payload
|
|
read 0, requested 1
|
|
|
|
Presented circuit has one important limitation when it comes to work
|
|
with Arduino IDE. After opening Serial Monitor (Ctrl-Shift-M), both RTS
|
|
and DTR lines are permanently pulled down. As RTS line is connected to
|
|
REST input of ESP, the module is hold in reset state / not able to run.
|
|
Therefore after uploading module, you need to disconnect both lines or
|
|
use different serial terminal program that is not pulling down RTS and
|
|
DTR lines. Otherwise the module will get stuck waiting for releasing the
|
|
REST signal and you will see nothing on the Serial Monitor.
|
|
|
|
As for different serial terminal program you can check Arduino IDE
|
|
add-on `Serial Monitor for
|
|
ESP8266 <(https://github.com/esp8266/Arduino/issues/1360)>`__ developed
|
|
by user [@mytrain](https://github.com/mytrain) and discussed in
|
|
`#1360 <https://github.com/esp8266/Arduino/issues/1360>`__.
|
|
|
|
If you prefer external terminal program, then for Windows users we can
|
|
recommend free and handy
|
|
`Termite <http://www.compuphase.com/software_termite.htm>`__.
|
|
|
|
Nodemcu
|
|
^^^^^^^
|
|
|
|
Nodemcu reset method is named after
|
|
`NodeMCU <https://github.com/nodemcu/nodemcu-devkit>`__ board where it
|
|
has been introduced for the first time. It overcomes limitations with
|
|
handling of RTS and DTR lines discussed for `ck <#ck>`__ reset method
|
|
above.
|
|
|
|
Sample circuit to measure wave-form is shown below (`get fzz
|
|
source <pictures/a01-circuit-nodemcu-reset.fzz>`__).
|
|
|
|
.. figure:: pictures/a01-circuit-nodemcu-reset.png
|
|
:alt: Sample circuit to check nodemcu reset method
|
|
|
|
Sample circuit to check nodemcu reset method
|
|
|
|
Close up of voltage signals on GPIO0 and RST pins at the beginning of
|
|
firmware upload is shown below.
|
|
|
|
.. figure:: pictures/a01-reset-nodemcu-closeup.png
|
|
:alt: Reset Method: nodemcu, close up at the beginning of upload
|
|
|
|
Reset Method: nodemcu, close up at the beginning of upload
|
|
|
|
Please note that the reset sequence is about 10x shorter comparing to
|
|
`ck <@ck>`__ reset (about 25ms vs. 250ms).
|
|
|
|
Next picture covers complete upload of
|
|
`Blink.ino <https://github.com/esp8266/Arduino/blob/master/libraries/esp8266/examples/Blink/Blink.ino>`__
|
|
example at 921600 baud. Except for difference of the reset signal
|
|
sequence, the complete upload looks similar to that of `ck <@ck>`__.
|
|
|
|
.. figure:: pictures/a01-reset-nodemcu-complete.png
|
|
:alt: Reset Method: nodemcu, complete upload
|
|
|
|
Reset Method: nodemcu, complete upload
|
|
|
|
A sample wave-form below shows another upload of
|
|
`Blink.ino <https://github.com/esp8266/Arduino/blob/master/libraries/esp8266/examples/Blink/Blink.ino>`__
|
|
example at 921600 baud, but with two reset retries.
|
|
|
|
.. figure:: pictures/a01-reset-nodemcu-complete-2-retries.png
|
|
:alt: Reset Method: nodemcu, reset retries
|
|
|
|
Reset Method: nodemcu, reset retries
|
|
|
|
If you are interested how noodemcu reset method is implemented, then
|
|
check circuit below. As indicated it does not pull to ground RTS and DTR
|
|
lines once you open Serial Monitor in Arduino IDE.
|
|
|
|
.. figure:: pictures/a01-nodemcu-reset-implementation.png
|
|
:alt: Implementation of noodemcu reset
|
|
|
|
Implementation of noodemcu reset
|
|
|
|
It consists of two transistors and resistors that you can locate on
|
|
NodeMCU board on right. On left you can see complete circuit and the
|
|
truth table how RTS and DTR signals of the serial interface are
|
|
translated to RST and GPIO0 on the ESP. For more details please refer to
|
|
`nodemcu <https://github.com/nodemcu/nodemcu-devkit>`__ repository on
|
|
GitHub.
|
|
|
|
I'm Stuck
|
|
~~~~~~~~~
|
|
|
|
Hopefully at this point you were able to resolve ``espcomm_sync failed``
|
|
issue and now enjoy quick and reliable uploads of your ESP modules.
|
|
|
|
If this is still not the case, then review once more all discussed steps
|
|
in the checklist below.
|
|
|
|
**Initial Checks** \* [ ] Is your module connected to serial port and
|
|
visible in IDE? \* [ ] Is connected device responding to IDE? What is
|
|
exact message in debug window? \* [ ] Have you selected correct ESP
|
|
module type in *Board* menu? What is the selection? \* [ ] Have you
|
|
tried to reduce upload speed? What speeds have you tried?
|
|
|
|
**Advanced Checks** \* [ ] What message is reported by ESP at 74880 baud
|
|
when entering boot loading mode? \* [ ] Have you checked your USB to
|
|
serial converter by looping it back? What is the result? \* [ ] Is your
|
|
detailed upload log consistent with settings in IDE? What is the log?
|
|
|
|
**Reset Method** \* [ ] What reset method do you use? \* [ ] What is
|
|
your connection diagram? Does it match diagram in this FAQ? \* [ ] What
|
|
is your wave-form of board reset? Does it match wave-form in this FAQ?
|
|
\* [ ] What is your wave-form of complete upload? Does it match
|
|
wave-form in this FAQ?
|
|
|
|
**Software** \* [ ] Do you use the latest stable version of `esp8266 /
|
|
Arduino <https://github.com/esp8266/Arduino>`__? What is it? \* [ ] What
|
|
is the name and version of your IDE and O/S?
|
|
|
|
If you are stuck at certain step, then post this list on `ESP8266
|
|
Community Forum <http://www.esp8266.com/>`__ asking for support.
|
|
|
|
Conclusion
|
|
~~~~~~~~~~
|
|
|
|
With variety of available ESP8266 modules and boards, as well as
|
|
possible connection methods, troubleshooting of upload issues may take
|
|
several steps.
|
|
|
|
If you are a beginner, then use boards with integrated power supply and
|
|
USB to serial converter. Check carefully message in debug window and act
|
|
accordingly. Select your exact module type in IDE and try to adjust
|
|
upload speed. Check if board is indeed entering boot loading mode. Check
|
|
operation of your USB to serial converter with loop back. Analyze
|
|
detailed upload log for inconsistencies with IDE settings.
|
|
|
|
Verify your connection diagram and wave-form for consistency with
|
|
selected reset method.
|
|
|
|
If you get stuck, then ask `community <http://www.esp8266.com/>`__ for
|
|
support providing summary of all completed checks.
|
|
|
|
.. figure:: pictures/a01-test-stand.jpg
|
|
:alt: Test stand used during checking of ck reset method
|
|
|
|
Test stand used during checking of ck reset method
|
|
|
|
Test stand used for checking of ck reset method is shown above.
|
|
|
|
No any ESP module has been harmed during preparation of this FAQ item.
|
|
|
|
`FAQ list :back: <readme.rst>`__
|