Esp8266 ошибка загрузки

Пытаюсь прошить Wemod D1 mini.
В приложении «GyverMatrixOS_v1.15» нажимаю на кнопку «Загрузка» ( Прошивку уже настроил ) и выдаёт ошибку

Arduino: 1.8.10 (Windows 7), Плата:»LOLIN(WEMOS) D1 mini Pro, 80 MHz, Flash, Legacy (new can return nullptr), All SSL ciphers (most compatible), 16MB (FS:14MB OTA:~1019KB), v2 Lower Memory, Disabled, None, Only Sketch, 921600″

In file included from D:\Documents\Desktop\GyverMatrixWiFi-master\firmware\GyverMatrixOS_v1.15\GyverMatrixOS_v1.15.ino:132:0:

D:\Documents\Arduino\libraries\FastLED/FastLED.h:14:21: note: #pragma message: FastLED version 3.003.002

# pragma message «FastLED version 3.003.002»

^

In file included from D:\Documents\Arduino\libraries\FastLED/FastLED.h:65:0,

from D:\Documents\Desktop\GyverMatrixWiFi-master\firmware\GyverMatrixOS_v1.15\GyverMatrixOS_v1.15.ino:132:

D:\Documents\Arduino\libraries\FastLED/fastspi.h:130:23: note: #pragma message: No hardware SPI pins defined. All SPI access will default to bitbanged output

# pragma message «No hardware SPI pins defined. All SPI access will default to bitbanged output»

^

Executable segment sizes:

IROM : 311104 — code in flash (default or ICACHE_FLASH_ATTR)

IRAM : 27564 / 32768 — code in IRAM (ICACHE_RAM_ATTR, ISRs…)

DATA : 1416 ) — initialized variables (global, static) in RAM/HEAP

RODATA : 2056 ) / 81920 — constants (global, static) in RAM/HEAP

BSS : 31176 ) — zeroed variables (global, static) in RAM/HEAP

Скетч использует 342140 байт (35%) памяти устройства. Всего доступно 958448 байт.
Глобальные переменные используют 34648 байт (42%) динамической памяти, оставляя 47272 байт для локальных переменных. Максимум: 81920 байт.
esptool.py v2.8
Serial port COM3
Traceback (most recent call last):
File «C:\Users\����\AppData\Local\Arduino15\packages\esp8266\hardware\esp8266\2.6.3/tools/upload.py», line 65, in <module>
esptool.main(cmdline)
File «C:/Users/����/AppData/Local/Arduino15/packages/esp8266/hardware/esp8266/2.6.3/tools/esptool\esptool.py», line 2889, in main
esp = chip_class(each_port, initial_baud, args.trace)
File «C:/Users/����/AppData/Local/Arduino15/packages/esp8266/hardware/esp8266/2.6.3/tools/esptool\esptool.py», line 237, in __init__
self._port = serial.serial_for_url(port)
File «C:/Users/����/AppData/Local/Arduino15/packages/esp8266/hardware/esp8266/2.6.3/tools/pyserial\serial\__init__.py», line 88, in serial_for_url
instance.open()
File «C:/Users/����/AppData/Local/Arduino15/packages/esp8266/hardware/esp8266/2.6.3/tools/pyserial\serial\serialwin32.py», line 62, in open
raise SerialException(«could not open port {!r}: {!r}».format(self.portstr, ctypes.WinError()))
serial.serialutil.SerialException: could not open port ‘COM3’: FileNotFoundError(2, ‘�� ������� ����� ��������� ����.’, None, 2)
serial.serialutil.SerialException: could not open port ‘COM3’: FileNotFoundError(2, ‘�� ������� ����� ��������� ����.’, None, 2)

Этот отчёт будет иметь больше информации с
включенной опцией Файл -> Настройки ->
«Показать подробный вывод во время компиляции»

Что делать? Помогите пожалуйста.

У ESP8266 есть несколько общих проблем, особенно при попытке записать новую прошивку или загрузке скриптов.

Вот подборка наиболее распространенных проблем с ESP8266 и способы для их исправления.

Устранение неполадок ESP8266 — NodeMCU Flasher

Где скачать флешер NodeMCU?

Перейдите в репозиторий GitHub флешера NodeMCU и загрузите флешер для вашей версии Windows, нажав кнопку «Raw»:

  • NodeMCU прошивальщик Windows 64 бит
  • NodeMCU прошивальщик Windows 32 бит

Какие настройки следует использовать с флешером NodeMCU?

Флешер NodeMCU уже поставляется с правильными настройками по умолчанию.

Настройки по умолчанию:

image_1.png

После нажатия кнопки «Flash» ничего не происходит, прошивальщик NodeMCU не запускает процесс перепрошивки

Если вы нажали кнопку «Flash» и ничего не происходит … Это может быть одно из двух:

  •  ESP не находится в режиме прошивки (перепроверьте, подключен ли GPIO 0 к GND при включении питания)
  •  программатор FTDI не может подать достаточный ток на ESP

image_2.png

Проблема 1 — Как заставить ESP перейти в режим прошивки:

  1. Закройте окно флешера NodeMCU
  2. Отключите питание от вашего ESP8266
  3. Подключите ESP следующим образом (дважды проверьте, что GPIO 0 подключен к GND)
  4. Подайте питание на ESP8266 и откройте флешер NodeMCU Нажмите кнопку «Flash»

Если он все еще сообщает «Ожидание MAC», попробуйте следующее:

  1. Подключите провод от вашего reset ESP8266 к GND
  2. Отсоедините этот провод от GND и присоединитесь к VCC

Повторите шаги  несколько раз, пока ESP не перезагрузится, и, скорее всего, флешер NodeMCU сможет обнаружить ESP и начать процесс перепрошивки.

Проблема 2. Если FTDI не может обеспечить достаточный ток, возможно, придется купить новый программатор FTDI или подключить ESP8266 к внешнему источнику питания.

Флешер NodeMCU зависает или останавливается на определенном проценте

image_3.png

  1. Отключите питание от ESP + FTDI: Закройте окно флешера NodeMCU
  2. Подключите ESP + FTDI к компьютеру снова
  3. Откройте флешер NodeMCU и попробуйте скорость передачи 19200 бод

Если этот процесс завершится неудачно, повторите ту же процедуру для следующих скоростей передачи (38400, 57600, 74880 и 115200).

Ппо крайней мере 5 человек столкнулись с той же проблемой, и этот способ решил ее. 

Как должен выглядеть NodeMCU после успешной прошивки?

У него должна быть зеленая стрелка внизу слева.

image_4.png

Разблокировка программатора FTDI на ПК с Windows

Если у вас новый программатор FTDI то сначала необходимо установить драйверы FTDI в Windows, посетите официальный веб-сайт для получения официальных драйверов: http://www.ftdichip.com/Drivers/VCP.htm.

В качестве альтернативы можете связаться с продавцом, который продал программатор FTDI.

Если возникли проблемы с установкой драйверов FTDI в Windows 7/8 / 8.1 / 10, вполне вероятно, что FTDI заблокирован.

Устранение неполадок ESP8266 — ESPlorer IDE

ESPlorer IDE Ошибка: разрешен только один tcp сервер

Это означает, что вы пытались загрузить несколько скриптов, и в ESP все еще выполняется старый скрипт с веб-сервером. Чтобы это исправить, нужно выполнить эти команды, чтобы удалить все файлы и перезапустить ESP:

  1. file.format()
  2. node.restart ()

Загрузите скрипт снова и назовите его «init.lua», и ошибка исчезнет.

ESPlorer IDE Ошибка: не удается автоматически определить прошивку

а также

ESPlorer IDE Ошибка: Ожидание ответа от ESP — истекло время ожидания. Команда прервана. Ожидание ответа от ESP — истекло время ожидания. Команда отменена.

image_5.png

Это означает что ESP, все еще находится в режиме прошивки. Как перевести ESP в режим пользователя:

  1. Закройте соединение ESPlorer IDE
  2. Отключите питание от ESP8266
  3. Подключите GPIO 0 к VCC
  4. Подайте питание на ESP8266 и восстановите соединение с ESPlorer IDE

Если он по-прежнему сообщает «не могу автоматически определить прошивку», попробуйте следующее:

  1. Подключите провод от вашего reset к GND
  2. Отключите этот провод от GND и присоедините к VCC

Код исчезает при перезапуске ESP8266

Если после загрузки скрипта в ESP ничего не происходит. Это означает, что ESP не смог найти скрипт или возникла проблема с памятью.

Возможные причины:

  1. Вы не сохранили свой скрипт под названием «init.lua». Повторная загрузка того же скрипта, но с именем «init.lua» должна решить проблему
  2. Это может быть проблема с памятью. Перепрошивка ESP с помощью прошивальщика NodeMCU обычно решает эту проблему.

Поиск IP-адреса ESP8266

Прежде чем начать, убедитесь, что вы проверили эти два пункта:

  1. Убедитесь, что скрипт, загруженный в ESP, имеет правильные сетевые учетные данные
  2. Убедитесь, что ESP находится рядом с маршрутизатором

Как найти IP-адрес:

1. Отправка команды с помощью ESPlorer IDE. Отправьте команду «print (wifi.sta.getip ())» в IDE ESPlorer, и она должна вывести IP-адрес

image_6.png

Решение 2. Установите программное обеспечение IP-сканера

image_7.png

Устранение неполадок ESP8266 — Arduino IDE

 Не получается загрузить скрипт на ESP8266 через Arduino IDE

Как перевести ESP в режим загрузки при использовании IDE Arduino:

  1. Отключите питание от ESP8266
  2. Проверьте, что GPIO 0 подключен к GND
  3. Подайте питание на ESP8266 и откройте Arduino IDE
  4. Нажмите кнопку «Загрузить»

Добавить комментарий

  1. Столкнулся со странной проблемой: попытался добавить esp через менеджер, он выдает ошибку загрузки архива с гита. Странность в том, что архив на месте и спокойно качается. На зарубежных форумах нашел несколько решений: проверить прокси, положить архив в папку ручками, переустановить другую версию IDE. Как можно догадаться, ничего из этого не помогло. сообщение об ошибке:

    Возникла ошибка при загрузке https://github.com/esp8266/Arduino/releases/download/2.4.1/esp8266-2.4.1.zip
    java.lang.RuntimeException: java.lang.Exception: Возникла ошибка при загрузке https://github.com/esp8266/Arduino/releases/download/2.4.1/esp8266-2.4.1.zip
        at cc.arduino.contributions.packages.ui.ContributionManagerUI.lambda$onInstallPressed$1(ContributionManagerUI.java:176)
        at java.lang.Thread.run(Thread.java:748)
    Caused by: java.lang.Exception: Возникла ошибка при загрузке https://github.com/esp8266/Arduino/releases/download/2.4.1/esp8266-2.4.1.zip
        at cc.arduino.contributions.DownloadableContributionsDownloader.download(DownloadableContributionsDownloader.java:131)
        at cc.arduino.contributions.DownloadableContributionsDownloader.download(DownloadableContributionsDownloader.java:69)
        at cc.arduino.contributions.packages.ContributionInstaller.install(ContributionInstaller.java:102)
        at cc.arduino.contributions.packages.ui.ContributionManagerUI.lambda$onInstallPressed$1(ContributionManagerUI.java:173)
        … 1 more
    Caused by: javax.net.ssl.SSLHandshakeException: sun.security.validator.ValidatorException: PKIX path building failed: sun.security.provider.certpath.SunCertPathBuilderException: unable to find valid certification path to requested target
        at sun.security.ssl.Alerts.getSSLException(Alerts.java:192)
        at sun.security.ssl.SSLSocketImpl.fatal(SSLSocketImpl.java:1959)
        at sun.security.ssl.Handshaker.fatalSE(Handshaker.java:302)
        at sun.security.ssl.Handshaker.fatalSE(Handshaker.java:296)
        at sun.security.ssl.ClientHandshaker.serverCertificate(ClientHandshaker.java:1514)
        at sun.security.ssl.ClientHandshaker.processMessage(ClientHandshaker.java:216)
        at sun.security.ssl.Handshaker.processLoop(Handshaker.java:1026)
        at sun.security.ssl.Handshaker.process_record(Handshaker.java:961)
        at sun.security.ssl.SSLSocketImpl.readRecord(SSLSocketImpl.java:1072)
        at sun.security.ssl.SSLSocketImpl.performInitialHandshake(SSLSocketImpl.java:1385)
        at sun.security.ssl.SSLSocketImpl.startHandshake(SSLSocketImpl.java:1413)
        at sun.security.ssl.SSLSocketImpl.startHandshake(SSLSocketImpl.java:1397)
        at sun.net.www.protocol.https.HttpsClient.afterConnect(HttpsClient.java:559)
        at sun.net.www.protocol.https.AbstractDelegateHttpsURLConnection.connect(AbstractDelegateHttpsURLConnection.java:185)
        at sun.net.www.protocol.https.HttpsURLConnectionImpl.connect(HttpsURLConnectionImpl.java:153)
        at cc.arduino.utils.network.FileDownloader.downloadFile(FileDownloader.java:170)
        at cc.arduino.utils.network.FileDownloader.download(FileDownloader.java:128)
        at cc.arduino.contributions.DownloadableContributionsDownloader.download(DownloadableContributionsDownloader.java:129)
        … 4 more
    Caused by: sun.security.validator.ValidatorException: PKIX path building failed: sun.security.provider.certpath.SunCertPathBuilderException: unable to find valid certification path to requested target
        at sun.security.validator.PKIXValidator.doBuild(PKIXValidator.java:397)
        at sun.security.validator.PKIXValidator.engineValidate(PKIXValidator.java:302)
        at sun.security.validator.Validator.validate(Validator.java:260)
        at sun.security.ssl.X509TrustManagerImpl.validate(X509TrustManagerImpl.java:324)
        at sun.security.ssl.X509TrustManagerImpl.checkTrusted(X509TrustManagerImpl.java:229)
        at sun.security.ssl.X509TrustManagerImpl.checkServerTrusted(X509TrustManagerImpl.java:124)
        at sun.security.ssl.ClientHandshaker.serverCertificate(ClientHandshaker.java:1496)
        … 17 more
    Caused by: sun.security.provider.certpath.SunCertPathBuilderException: unable to find valid certification path to requested target
        at sun.security.provider.certpath.SunCertPathBuilder.build(SunCertPathBuilder.java:141)
        at sun.security.provider.certpath.SunCertPathBuilder.engineBuild(SunCertPathBuilder.java:126)
        at java.security.cert.CertPathBuilder.build(CertPathBuilder.java:280)
        at sun.security.validator.PKIXValidator.doBuild(PKIXValidator.java:392)
        … 23 more
     
  2. Что я пробовал:
    положить архив в каталог вручную, переустановить ide, использовать ссылки на другие версии, добавить ссылку в hosts, включить vpn, устанавливать python скриптом.

    Что заметил:
    Другие платы ставятся нормально; при отключении инета ошибка не меняется; на маке данная ссылка работает

  3. Версия и разрядность ОС, версия Arduino IDE? Интернет не через мобильного оператора? У меня МТС возвращает битый файл по адресу http://arduino.esp8266.com/stable/package_esp8266com_index.json, поэтому в менеждере плат использую ссылку https://github.com/esp8266/Arduino/releases/download/2.4.1/package_esp8266com_index.json.

  4. Инет МГТС оптика, win 10 система х64. Ссылку эту пробовал, перестает видеть даже json. ИДЕ пробовал 1.6.5, 1.8.1, 1.8.5

  5. Руками помещали файлы в %LocalAppData%\Arduino15\staging\packages?

  6. Да, писал выше. Ноль реакции

  7. Хотя вру, я вроде сувал в папку /roaming!!!/arduino15/… Сейчас перепроверю

  8. ПРОДВИЖЕНИЕ!!!! теперь не может загрузить другой файл, «mkspiffs-0.2.0-no_magic_length-windows.zip») Буду класть их в папку по очереди…

  9. Нужны
    win32-xtensa-lx106-elf-gb404fb9-2.tar.gz
    mkspiffs-0.2.0-no_magic_length-windows.zip
    esptool-0.4.13-win32.zip
    esp8266-2.4.1.zip
    их из json можно с путями надергать.

  10. Установилось! Спасибо огромное, бился весь день. Почему IDE потеряла гитхаб — отдельный вопрос. Мало ли, что ркн с маленькими и мягкими начудили

  11. Тоже столкнулся с такой проблемой. Оказалось, что некоторых сертификатов ssl нет в jre, которая идёт с Arduino ide. Не знаю почему так, на одном компе всё нормально скачалось, а на другом ошибку выдаёт как в топике. В общем, недостающий сертификат нужно установить, тогда всё заработает.

    1. Заходим сюда: https://github.com/esp8266/Arduino/releases/

    2. В браузере, где зелёный замочек возле адресной строки нажимаем на него, далее в зависимости от браузера находим что-то вроде посмотреть сертификат, а затем экспортировать. В фаерфоксе: клик на замочек, стрелочка, подробнее, посмотреть сертификат, подробности, экспортировать. В итоге имеем файл сертификата на жёстком диске.

    3. Запускаем командную строку (cmd) от имени администратора.

    4. Переходим в папку с установленной jre, которая используется ArduinoIDE:

    cd “c:\Program Files (x86)\Arduino\java\bin\”

    5. Выполняем следующую команду: keytool -import -alias github -keystore ..\lib\security\cacerts -file c:\githubcom.crt

    Где вместо c:\githubcom.crt путь к сохранённому сертификату.

    6. Спросит пароль. Нужно будет ввести «changeit» (без кавычек). Пароль отображаться не будет, внимательно.

    7. Потом спросит «Trust this certificate? [no]». Нужно ввести «yes» (без кавычек).

    В итоге должно быть сообщение: «Certificate was added to keystore».

    Ну вот и всё, можно пробовать добавлять плату ESP.


    ИгорьК и ZAZ-965 нравится это.

  12. Ребят, помогите с аналогичной проблемой для ESP32
    прописываю путь https://dl.espressif.com/dl/package_esp32_index.json ,но при заходе в менеджер плат

    Возникла ошибка при загрузке https://downloads.arduino.cc/packages/package_index.json
    java.lang.RuntimeException: java.lang.Exception: Возникла ошибка при загрузке https://downloads.arduino.cc/packages/package_index.json
        at cc.arduino.contributions.packages.ui.ContributionManagerUI.lambda$onUpdatePressed$1(ContributionManagerUI.java:150)
        at java.lang.Thread.run(Thread.java:748)
    Caused by: java.lang.Exception: Возникла ошибка при загрузке https://downloads.arduino.cc/packages/package_index.json
        at cc.arduino.contributions.DownloadableContributionsDownloader.download(DownloadableContributionsDownloader.java:139)
        at cc.arduino.contributions.packages.ContributionInstaller.download(ContributionInstaller.java:333)
        at cc.arduino.contributions.packages.ContributionInstaller.downloadIndexAndSignature(ContributionInstaller.java:307)
        at cc.arduino.contributions.packages.ContributionInstaller.updateIndex(ContributionInstaller.java:285)
        at cc.arduino.contributions.packages.ui.ContributionManagerUI.lambda$onUpdatePressed$1(ContributionManagerUI.java:146)
        … 1 more
    Caused by: java.nio.file.FileSystemException: C:\Users\79062\AppData\Local\Arduino15\package_index.json.tmp: Процесс не может получить доступ к файлу, так как этот файл занят другим процессом.

        at sun.nio.fs.WindowsException.translateToIOException(WindowsException.java:86)
        at sun.nio.fs.WindowsException.rethrowAsIOException(WindowsException.java:97)
        at sun.nio.fs.WindowsException.rethrowAsIOException(WindowsException.java:102)
        at sun.nio.fs.WindowsFileSystemProvider.implDelete(WindowsFileSystemProvider.java:269)
        at sun.nio.fs.AbstractFileSystemProvider.delete(AbstractFileSystemProvider.java:103)
        at java.nio.file.Files.delete(Files.java:1126)
        at cc.arduino.utils.network.FileDownloader.downloadFile(FileDownloader.java:156)
        at cc.arduino.utils.network.FileDownloader.download(FileDownloader.java:132)
        at cc.arduino.contributions.DownloadableContributionsDownloader.download(DownloadableContributionsDownloader.java:137)
        … 5 more

    причем не пойму почему пишет » Возникла ошибка при загрузке https://downloads.arduino.cc/packages/package_index.json» хотя я другой путь ведь прописал, в файле «preferences» прописан путь, как поменяный в Arduino. Сертификат, как писал Themen установился без проблем. Что я не так делаю? вручную платы ставить не умею =(

Проверка/Оформление/Редактирование: Мякишев Е.А.

При попытке загрузить ESP8266 получаю ошибку «espcomm_sync failed». Как решить эту проблему?[1]

Это сообщение информирует о проблеме с загрузкой прошивки на ESP8266 через последовательное соединение. Причина может варьироваться в зависимости от типа модуля, от параметров, выбранных при загрузке, от того, используете ли вы отдельный USB-Serial конвертер, и т.д. То есть одного простого ответа на то, что является основной причиной проблемы, нет. Чтобы найти ее, придется выполнить диагностику.

Примечание: Если вы новичок в теме ESP8266 и хотели бы избежать потенциальных проблем с загрузкой прошивки, купите модуль ESP8266 со встроенным конвертером USB-Serial. Это существенно сократит количество факторов (в частности, уменьшит возню с настройками), из-за которых вы можете случайно помешать процессу загрузки.

На картинке ниже показаны платы со встроенным конвертером USB-Serial. Их использование, повторюсь, значительно упростит разработку ваших первых проектов на ESP8266.

Если вы используете «голый» (стандартный) модуль ESP8266 (например, ESP-01 или ESP-12), самостоятельно подключенный к отдельному USB-Serial конвертеру, обязательно проделайте следующее:

  1. Обеспечьте модуль достаточным питанием
  2. Подключите контакты GPIO0, GPIO15 и CH_PD при помощи подтягивающих/стягивающих резисторов
  3. Переведите модуль в режим загрузчика

Более подробно читайте в разделе «Стандартные модули ESP8266» статьи «Платы для аддона ESP8266 для IDE Arduino». На картинке ниже показаны платы без встроенного конвертера USB-Serial:

Платы ESP8266 без встроенного конвертера USB-Serial

Предварительные проверки

Чтобы исправить ошибку «espcomm_sync failed», пройдите шаг за шагом инструкцию ниже. Это список решений, ранжированных от самого простого до самого сложного.

1. Прочтите сообщение, показанное в отладочном окне IDE Arduino. Во многих случаях оно предоставляет точную информацию о том, где именно возникла проблема.

Ошибка «Failed to open COM3»

К примеру, сообщение на картинке выше, говорит, что IDE Arduino не может открыть последовательный порт COM3. Следовательно, нужно проверить, выбран ли в IDE Arduino порт, к которому подключен ваш модуль.

Выбор последовательного порта

2. Если модуль подключен к последовательному порту, но не отвечает как модуль ESP8266, сообщение в отладочном окне будет слегка другим (см. ниже). Если к вашему ПК подключены другие модули, проверьте, что загрузили код на ESP8266, а не на, к примеру, Arduino UNO.

Ошибка «espcomm_sync failed»

3. Чтобы ваш ПК мог общаться с ESP8266, выберите в IDE Arduino правильный модуль ESP8266. Если выбрать неправильный модуль, загрузка прошивки может завершиться неудачей.

Выбор платы

Выбрать правильную плату нужно для того, чтобы IDE Arduino мог применить правильный «метод сброса» при переключении платы в режим загрузчика. Разные платы используют разные методы сброса. У некоторых плат нет аппаратных компонентов, чтобы выполнить сброс через IDE Arduino. В таком случае плату нужно перевести в режим загрузчика вручную.

4. Кроме того, загрузка прошивки может не удаться из-за слишком высокой скорости передачи данных. Если у вас длинный или некачественный USB-кабель, попробуйте снизить скорость загрузки в меню «Upload Speed».

Выбор скорости для передачи данных через последовательное соединение

Дополнительные проверки

1. Если проблема не исчезла, проверьте, точно ли модуль вошел в режим загрузчика. Для этого нужно подключить к ESP8266 добавочный конвертер USB-Serial, а затем посмотреть на показываемые сообщения.

Итак, для начала подключите контакты RX и GND конвертера к контактам TX и GND на ESP8266, как показано ниже:

Подключение добавочного USB-Serial конвертера

Затем откройте терминал на скорости 74880 бод и посмотрите, какие сообщения присылает ESP8266 при сбросе, выполняемом для загрузки прошивки. Правильное сообщение должно выглядеть примерно так:

ets Jan  8 2013,rst cause:2, boot mode:(1,7)

Если у вас появилось такое же сообщение, но с другими значениями, то расшифровать его можно при помощи таблицы из этой статьи (см. третью таблицу в разделе «Сообщения о режимах запуска и причине сброса/перезагрузки»). Ключевая информация содержится в первой цифре, находящейся в скобочках рядом с надписью «boot mode», как показано на картинке ниже:

Расшифровка сообщения о режиме запуска

К примеру, сообщение «boot mode (3, 3)» информирует, что контакты GPIO2 и GPIO0 выставлены на HIGH, а GPIO15 – на LOW. Это настройка для нормальной работы модуля (т.е. выполнения программы, записанной на flash-память), но не для режима загрузчика (т.е. программирования flash-памяти).

Примечание: Если выполнить этот шаг неправильно, вы не сможете загрузить прошивку на модуль через последовательный порт.

2. Вы убедились, что модуль находится в режиме загрузчика, но загрузить прошивку по-прежнему не удается. Если вы используете внешний конвертер USB-Serial, проверьте, правильно ли он работает, закольцевав выход на вход. Этой очень простая проверка. Просто подключите друг к другу контакты RX и TX на конвертере как показано на картинке ниже. Затем откройте монитор порта и впишите там несколько символов. Если все в порядке, то все написанные вами символы должны сразу же появится в мониторе порта. Чтобы выполнить такую проверку на модуле со встроенным USB-Serial конвертером, может понадобиться разрушить некоторые дорожки на печатной плате. Я бы сделал это лишь в полном отчаянии. Лучше попробуйте способы, описываемые еще ниже.

3. Еще один способ – это просмотр более детальных отладочных сообщений. Кликните в IDE Arduino на Файл > Настройки (File > Preferences) и поставьте галочку рядом с пунктом «Показать подробный вывод: Загрузка» («Show verbose output during: upload»). Чтобы загрузка прошивки была успешной, эти логи должны выглядеть примерно так:

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

Логов может быть больше, и это зависит от количества попыток подключения, выполненных «esptool». Проанализируйте эти логи на предмет аномалий в настройках, выбранных в IDE Arduino – вроде другого последовательного порта, метода сброса, скорости передачи данных и т.д. Исправьте найденные ошибки.

Методы сброса

Если вы дошли досюда, а ошибка «espcomm_sync failed» никуда не делась, значит, пришло время расчехлить пушки покрупнее.

Чтобы понять, что происходит, подключите к контактам GPIO0, RST и RXD на ESP8266 осциллограф или логический анализатор. Затем сравните свои измерения с формой сигнала на графиках ниже. В них задокументированы два стандартных метода сброса ESP8266 для загрузки кода, которые можно выбрать в IDE Arduino – «ck» и «nodemcu».

Ck

На картинке ниже изображена цепь, специально подготовленная для определения формы сигнала при использовании метода «ck». Он проще сброса методом «nodemcu» и поэтому часто используется для подключения стандартных модулей ESP к макетной плате. Сверьте это подключение со своим.

Простая цепь для проверки метода «ck»

Графики ниже показывают сигналы напряжения на контактах GPIO0 и RST при загрузке прошивки.

Первый график показывает форму сигнала в начале загрузки кода.

Метод сброса «ck», начало загрузки кода

Второй график показывает полную загрузку скетча «Blink.io» на скорости 921600 бод. Это довольно высокая скорость, поэтому на загрузку уходит всего 8 секунд.

Метод сброса «ck», загрузка скетча «Blink.io»

Когда у «esptool» не получается выполнить загрузку, он инициализирует сброс. Подобная ситуация показана, к примеру, на графике ниже.

Метод сброса «ck», конец загрузки

Каждая новая попытка отображается в логах загрузки:

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

Цепь, показанная выше, имеет одно важное ограничение при работе с IDE Arduino. После открытия монитора порта ( Ctrl + ⇧ Shift + M ) линии RTS и DTR переключаются в состояние LOW. Поскольку линия RTS подключена к входной линии REST на ESP8266, то ESP8266 просто зависнет в состоянии сброса и запустить его будет нельзя. Следовательно, после загрузки прошивки вам нужно отключить обе линии или воспользоваться другой консолью (не монитором порта IDE Arduino), которая не переключает RTS и DTR в состояние LOW. В противном случае модуль зависнет в ожидании переключения REST в состояние HIGH и в мониторе порта ничего показывать не будет.

Что касается другой консоли, можно воспользоваться монитором порта IDE Arduino для ESP8266, разработанной пользователем mytrain и обсуждаемой в отчете 1360.

Если предпочитаете программы, то для Windows я бы порекомендовал бесплатную и удобную Termite.

Nodemcu

Метод сброса «nodemcu» получил название от платы NodeMCU, где он был реализован в самый первый раз. Этот метод позволяет обойти ограничения с управлением линиями RTS и DTR, о которых говорилось в главе о методе «ck».

Ниже показана простая цепь для измерения формы сигнала при помощи метода «nodemcu»:

Простая цепь для проверки метода «nodemcu»

Первый график показывает напряжение на контактах GPIO0 и RST в начале загрузки прошивки:

Метод сброса: «nodemcu», начало загрузки

Обратите внимание, что последовательность сигналов длится в 10 раз короче, чем при использовании метода «ck» – примерно 25 мс против 250 мс.

Второй график показывает загрузку скетча «Blink.ino» на скорости 921600 бод. Не считая разницы в длине последовательности сигналов, он выглядит как аналогичный график для метода «ck».

Метод сброса: «nodemcu», загрузка полностью

Третий график тоже демонстрирует загрузку скетча «Blink.ino» на скорости 921600 бод, но с двумя попытками сброса.

Метод сброса: «nodemcu», с двумя новыми попытками сброса

Если вам интересно, как реализуется этот метод сброса, обратите внимание на схемы ниже. Он не притягивает линии RTS и DTR к «земле», когда вы открываете в IDE Arduino монитор порта.

Реализация сброса методом «nodemcu»

Такая цепь состоит из двух транзисторов и резисторов, расположенных на плате NodeMCU. Слева изображены полная схема и таблица истинности – она показывает, как сигналы RTS и DTR на последовательном порту преобразуются в контакты RST и GPIO0 на ESP8266. Более подробно смотрите в репозитории NodeMCU на GitHub.

Эм… похоже, я застрял

Надеемся, советы выше помогли вам справиться с ошибкой «espcomm_sync failed», а загрузка прошивки на ESP8266 стала быстрой и беспроблемной.

Если опять нет, пробегитесь по вопросам ниже (они представляют короткую версию того, о чем писалось в главах выше):

Предварительные проверки

  • Подключен ли ваш модуль к последовательному порту? Видит ли его IDE Arduino?
  • Отвечает ли подключенный девайс на IDE Arduino? Какое именно сообщение появляется в отладочном окне?
  • Правильный ли модуль ESP8266 выбран в меню «Плата»? Что именно у вас выбрано?
  • Пробовали ли вы снизить скорость загрузки? Какую скорость вы уже попробовали?

Дополнительные проверки

  • Какое сообщение присылает ESP8266 на скорости 74880 бод, когда вы входите в режим загрузчика?
  • Проверяли ли вы конвертер USB-Serial, зациклив его? Каков был результат?
  • Соответствует ли информация, показанная в логах, настройкам IDE Arduino? Если да, что в них?

Метод сброса

  • Какой метод сброса вы используете?
  • Какая у вас схема подключения? Она соответствует той, что показана в FAQ?
  • Какую форму имеет сигнал во время сброса? Она соответствует форме сигнала в FAQ?
  • Какую форму имеет сигнал при полной загрузке скетча? Она соответствует форме сигнала в FAQ?

ПО

  • Вы используете стабильную версию аддона ESP8266 для IDE Arduino? Что это за версия?
  • Как называется и какая версия у ваших IDE и ОС?

Если застопорились на каком-то шаге, опишите его как можно подробней и обратитесь за помощью на форум сообщества ESP8266.

Итого

С таким разнообразием модулей и плат на базе ESP8266, а также возможных методов сброса, решение проблем с загрузкой может потребовать очень много проб и попыток.
Если вы новичок, лучше использовать платы со встроенными USB-Serial конвертером и цепью для питания. Осторожно проверяйте сообщения в отладочном окне, а затем действуйте согласно этим сообщениям. Выберите правильный тип модуля в IDE Arduino и правильно настройте скорость загрузки прошивки. Проверьте, действительно ли плата переключена в режим загрузчика. Проверьте работоспособность USB-Serial конвертера, зациклив его. Проанализируйте детальные логи на предмет несоответствий с настройками IDE Arduino.

Проверьте схему подключения и форму сигнала на соответствие используемому методу сброса.

Если застряли, спросите совета у сообщества, предоставив данные обо всех выполненных вами шагах.

Тестовая площадка, которой я пользовался для проверки метода «ck»

На картинке выше показана тестовая площадка для метода «ck».

Во время подготовки этой статьи не пострадало ни одного ESP8266.

См.также

Внешние ссылки

  1. arduino-esp8266.readthedocs.io — I am getting “espcomm_sync failed” error when trying to upload my ESP. How to resolve this issue?

Error downloading http://arduino.esp8266.com/stable/package_esp8266com_index.json

(Last Updated On: February 12, 2020)

In this ESP8266 Troubleshooting article, we shall discuss “How to Fix – Error downloading http://arduino.esp8266.com/stable/package_esp8266com_index.json

Whenever you are trying to install ESP8266 Add-on in ArduinoIDE you may encounter an error called “Error downloading http://arduino.esp8266.com/stable/package_esp8266com_index.json”

This is happening because http://arduino.esp8266.com server is down, I think you have already tried using either link which is shown below. But the error remains the same.

Stable & Staging URLs:

http://arduino.esp8266.com/stable/package_esp8266com_index.json


http://arduino.esp8266.com/staging/package_esp8266com_index.json

So what you have to do is replace the link in Additional Manager URLs with this. Most probably your issue will be resolved.

In your Arduino IDE, go to FilePreferences

https://github.com/esp8266/Arduino/releases/download/2.3.0/package_esp8266com_index.json

arduinoide-preferences-page

Still, you are getting “Error downloading http://arduino.esp8266.com/stable/package_esp8266com_index.json”, Check your Network settings. Make sure that you have configured the network settings. If your computer connected to a mobile phone hotspot or WiFi router without proxy you can check for either No Proxy or Auto-detect proxy settings. Similarly, if you are using an internet connection with a proxy check for Manual Proxy Configuration and provide the proxy details.  Most of the universities and offices will use proxy servers, so you have to provide proxy details here. Then, tap on the “OK” button. In my case I am using my mobile phone internet, so configured with Auto-detect proxy settings.

arduinoide-network-settings

Yeah, I know your Network Settings are also fine, but still the Error “Error downloading http://arduino.esp8266.com/stable/package_esp8266com_index.json” was not solved. Follow this procedure.

Go to the following directory in your PC “C:\Users\Administrator\AppData\Local” You will find a folder called “Arduino15” delete this folder.

Restart your Arduino IDE (Close all Arduino Tabs and reopen it), In your Arduino IDE, go to FilePreferences, Add the following link in the Additional Boards Manager URLs.

https://github.com/esp8266/Arduino/releases/download/2.3.0/package_esp8266com_index.json

arduinoide-file -preferences

arduinoide-preferences-page

Open the Boards Manager. Go to Tools > Board > Boards Manager…

Arduinoide-boardmanagers

Search for ESP32/ESP8266, you will get it.

esp32-espre

You May Be Interested in the following:

  1. Installing ESP32 Add-on in ArduinoIDE in 1 minute
  2. Installing ESP8266 Add-in in Arduino IDE in 1 Minute

Понравилась статья? Поделить с друзьями:
  • Esp8266 выдает ошибку
  • Esp ошибка сузуки сх4
  • Esp ошибка фольксваген кадди
  • Esp ошибка фольксваген джетта
  • Esp ошибка рено флюенс