ESP 8266
Úvodní stránka › Fórum › Hardware › Arduino › ESP 8266
Označeno štítky: esp problém nefunguje
- Toto téma obsahuje celkem 36 odpovědí. Do diskuze (7 diskutujících) se naposledy zapojil uživatel technik91 a poslední změna proběhla před 7 roky a 12 měsíci.
-
AutorPříspěvky
-
2.11.2015 v 16:12 #5030terjeÚčastník
Zdravím, máte někdo zkušenost s modulem ESP8266-01? Když chci nahrát program, vždycky se objeví hláška espcomm_open failed.V IDE 1.6.5 vše nastaveno správně. Na AT příkazy v seriove konzoli přitom odpovídá.
10.11.2015 v 1:10 #5095tauntÚčastníkDobrý den,
já mám tyto moduly tři a ani jeden korektně nejde. Všechny tři se chovají stejně. Na wifi se na něj připojím jako na AP. Bohužel přes terminál ve win7(Termite) se při zapojení ohlásí asi správně(podle několika různých návodů na Netu), potom ale stále jen „echuje“ moje AT příkazy. Na žádný z nich nereaguje správně.
Pokud máte někdo více zkušeností s tímto modulem, prosím o radu. Vygooglil jsem již mnoho návodů, ale žádný zatím nepomohl. Asi dělám nějakou chybu, kterou přehlížím, bohužel ji nemohu najít. Zapojení, zdá se, je správné, včetně převodu úrovně 5 na 3 V.
Díky.10.11.2015 v 16:07 #5100terjeÚčastníkJaký tam máš FW.
10.11.2015 v 22:13 #5102AlešÚčastníkMám těch modulů několik, ale všechny používám buď jako client, nebo samostatně s nodemcu firmware. Nemám s nima žádný problém. Při zvolení správného firmware fungují tak, jak mají. Jediný problém je s napájením. V klidu mají odběr cca 20-40mA, při vysílání až 170mA. Arduino UNO nebo MEGA to jakž takž snese. Je dobré zapojit paralelně k napájení ESP kondenzátor 470uF/6,3V. Pro připojení k Nano je třeba použít obvod 1117-3.3 a kondenzátor. Při použití samostatně a napájení z baterií nebo zdroje s vyšším napětím použít spínaný zdroj (LM2596)
Prvnímu dotazu nerozumím. Nejde nahrát program do Arduina?
Druhý dotaz je celkem jasný, je tam nějaký „jiný“ FW. Stáhněte si Br@y terminál, nastavte CR+LF a používejte ten. Pro začátek použijte fw: v0.9.5.2 AT Firmware.bin. Flasher pro nahrání použijte tento: esp8266_flasher.exe Sice na konci flashování ohlásí chybu, ale tu můžete ignorovat. Firmware je nahraný v pořádku. Je nejjednodušší.
Kdyžtak napište, co máte konkrétně za problémy. Zkusím poradit.Třeba tady je Arduino Uno s pár čidlama, LCD5110 a přenáší se to pomocí ESP8266 na ThingSpeak 🙂
11.11.2015 v 18:23 #5113terjeÚčastníkK prvnímu dotazu
Chci napr.nahrát přes převodník usb/uart do esp8266-01 program pro blikání diody na GPI00. Spustím IDE/příklady/esp8266/blink a skončí to hláškou z prvního postu.FW mi jde normálně flešovat. Modul mi přes wifi komunikuje(skenování sítě atd.)Používám Esplorer na AT příkazy.
Nebo jsem nějak mimo?11.11.2015 v 21:04 #5114tauntÚčastníkTak já jsem asi úplně mimo.
Ať použiju jakýkoli terminál, chová se to stejně. Jeden kus se většinou přihlásí na rychlosti 9600 a má fw 0.9.2.4. Dva další se většinou nepřihlásí korektně – jedou asi na 115200, někdy přitom pošlou jen několik zmatených znaků a pokud se jim povede něco smysluplnějsího, tak se jen dozvím že blabla thinker a failed místo ready. Ani nevypíšou fw. Jen jednou se jednomu z nich podařilo vypsat několik (docela dost) řádků, které dávali trochu smyslu, ale stejně skončil failed. Pokud se některému podaří přihlásit, tak potom vůbec nereaguje na AT, na všechny vrací přesné echo.
Přitom všechny tři jedou na wifi, vysílají SSID a chovají se jako AP bez hesla.
Při pokusu o flash všechny tři píšou : conecting… Failed to conect.
Používám Převodník UART TTL – PL2303HX s třívoltovou logikou.
Dnes už na to po několika hodinách pokusů z vysoka ….
Uvidíme o víkendu, zkusím poslední možnost – vyměnit ten převodník. Sám na sebe ale jede bez problémů na všech rychlostech a terminálech.
Už jsem prošel spoustu webů, dozvěděl se několik způsobů zapojení a flashování, ale nic z toho nepomohlo.12.11.2015 v 10:52 #5116AlešÚčastníkK prvnímu dotazu
Aha, tak už jsem to pochopil. Vy se tam to blikání snažíte nahrát pomocí Arduinovského IDE. Pravděpodobně se vám do něj podařilo doinstaloavt ESP8266 rozšíření, když vidíte mezi podporovanýma deskama „Genuino ESP8266“. To ale bohužel nestačí. Ještě tam musíte doinstalovat programátor. Mezi programátorama, tam kde máte teď nastavený „AVRISP mkII“ musíte vidět ještě „esptool“. Pokud ho tam nevidíte, a nemůžete ho zvolit, tak program do ESP8266 nedostanete. Postup s obrázkama je vidět dobře ZDE Já jsem se to snažil nainstalovat do IDE také. Strávil jsem nad tím několik hodin, zkoušel jsem několik verzí IDE, a nerozchodil jsem to. Kdyby se vám to povedlo, tak napište, jak jste to dokázal 🙂
Takže použijte program LuaLoader, a nahrajte tam blikání z TOHOTO ODKAZU Mohlo by to tam jít nahrát i programem Esplorer, ale ten je nějaký divný, jednou funguje, dvakrát ne. Takže raději používám LuaLoader.
Napsal jsem o ESP8266 pár návodů na moje stránky http://xanadu.khnet.info/esp8266.php Je to spíš upozornění na problémy, než návod jak to udělat. Těch je na internetu spousta.12.11.2015 v 11:13 #5117AlešÚčastníkKe druhému dotazu
Pravděpodobně je v nich nějaký „divný“ firmware. Mě když tuto moduly přijdou, tak je ani nezkouším, a rovnou do nich nahraju firmware, který mám vyzkoušený. Převodník máte správný, používám ten samý.
Nejdřív si stáhněte z mých stránek http://xanadu.khnet.info/esp8266.php správný firmware. Nevím, k čemu to máte připojené, ale pokud používáte Arduino MEGA 2560, které má druhý sériový port, a může komunikovat na 115200Bd, tak použijte fw. 0.9.2.2, pokud potřebujete rychlost 9600Bd, tak fw 0.9.5.2. To, co je na mých stránkách je všechno odzkoušené a funkční.
Vyzkoušejte ten BR@Y terminál. Problém může být i v tom.
Napište, jak to dopadlo 🙂12.11.2015 v 13:26 #5120jankopÚčastníkS ESP8266 mám zkušeností dost. S hardwarem problémy nemám, horší to někdy bývá s vývojovým prostředím. Před pár dny jsem s překvapením zjistil, že mimo Lua a další systémy, včetně embeded Espruino, existuje také embeded Arduino. Protože Espruino je ještě v plenkách a ne moc stabilní, tak jsem zkusil embeded Arduino. Je třeba použít IDE 1.6.5. a dohrát k němu board ESP8266. V životě jsem Arduino neviděl, ale počátky jsem zvládl celkem bez problémů. Nahrál jsem nějaký demoserver a on perfektně funguje, stejně jako BLINK s LED.
K vlastnímu modulu. Zásada číslo jedna – kvalitní napájecí zdroj. Web se hemží návody, jak napájet modul z převodníku USB/Serial, ale to je fatální chyba a jeden z častých problémů.
Druhou věcí je nezbytnost ošetřit důležité vstupy. V případě ESP8266-01 musí být GPIO0, GPIO2, CH_PD, RST připojeny na Vcc, nejlépe přes rezistory cca 10k. V případě některých vyšších řad modulů je třeba ještě zapojit GPIO15 přes rezistor na GND. Velice častou chybou bývá také skutečnost, že uživatel zapojí modul přes převodník, správně překříží Tx/Rx, ale zapomene propojit zem převodníku se zemí modulu. Nepodceňujte tyto triviální chyby, jsou velmi časté a chování zařízení je nevyzpytatelné. Nemám zkušenosti s Arduino IDE a proto mě nenapadlo instalovat nějaký programátor. Prostě jsem uvedl ESP8266 do programovacího módu přes sériovou linku a program jsem přes IDE uploadoval. Sériový bootloader pro ESP8266-01 vyvolám tak, že provedu RESET a v okamžiku resetu musí být GPI02 = HIGH a GPIO0=LOW. Pak již stačí přes Arduino IDE nahrát program do modulu.
Na GITHUB je tento mnou vyzkoušený postup instalace IDE pro ESP8266 embeded Arduino. Nic víc není myslím třeba. Když jsem to zvládl já, tak to musí zvládnout každej.Install Arduino 1.6.5 from the Arduino website.
Start Arduino and open Preferences window.
Enter http://arduino.esp8266.com/stable/package_esp8266com_index.json into Additional Board Manager URLs field. You can add multiple URLs, separating them with commas.
Open Boards Manager from Tools > Board menu and install esp8266 platform (and don’t forget to select your ESP8266 board from Tools > Board menu after installation).A teď mám dotaz já. Demo server se zkompiloval a nahrál do ESP8266 a moc pěkně fungoval, tak dobře, že jsem byl překvapen. Proti ekvivalentnímu serveru v Lua je mnohem stabilnější s rychlejší reakcí. Jen vypisovaná potřeba paměti byla značná, ale předpokládám, že hlavní podíl mají knihovny. Ovšem zaujala mě možnost exportovat program z IDE v binární podobě. To považuji za potřebné rozšíření. Ale IDE píše, že tato funkce není pro ESP8266 podporována. Všiml jsem si, že IDE si ukládá do TEMP soubor něco.cpp.bin, tak jsem si myslel, že to je požadovaný binární soubor. Když jsem ho ovšem zkusil flashovacím programem nahrát do modulu, tak program nefungoval. Víte o tom něco prosím?
12.11.2015 v 14:58 #5122AlešÚčastníkKdyž tedy nainstaluju to .json rozšíření do IDE 1.6.5, tak jak potom nahraju program do ESP8266? Když mi tam chybí programátor esptool?
12.11.2015 v 15:20 #5123jankopÚčastníkProveď reset modulu s GPIO připojeným na GND. Pak z IDE normálně nahraj program.
12.11.2015 v 16:27 #5124AlešÚčastníkNojo. Ono to fakt funguje 🙂 Já jsem si myslel, že se to musí programovat přes esptool. Každopádně k tvému dotazu. Mám IDE verzi 1.6.6, a tam normálně export do binárky jde. Dík 🙂
12.11.2015 v 17:15 #5126jankopÚčastníkNo já věřím, že export BIN v 1.6.6. funguje. Ale já mluvím o verzi 1.6.5. ve spojení s modulem ESP8266.
12.11.2015 v 17:49 #5128tauntÚčastníkTak problém z velké části vyřešen. Gigabyte deska nestíhá napájet více USB portů, než asi dva flash disky. Flash firmvare po odpojení všech ostatních kabelů proběhl OK. Běžné AT příkazy, při kterých modul nenutím jít na wifi projdou v pořádku. Jakmile si sáhne na vysílač, tak se terminál kousne a USB porty přestanou komunikovat. Takže jdu řešit PC a neskutěčně nekvalitní nepájivé zkušební pole, které má takové přechodové odpory, že mu třívoltová logika dělá docela problémy.
To Aleš: dík za odkaz na Vaše stránky, dobrá inspirace.12.11.2015 v 19:10 #5130AlešÚčastníkTak si nainstaluj verzi 1.6.6. V čem je problém?
12.11.2015 v 19:13 #5131AlešÚčastníkNepájivé pole používám jenom v krajní nouzi. To raději sletuju několik drátů do Y 🙂 Ale možná by stačilo přidat k napájení ESP8266 nějaký velký kondenzátor. Na vykrytí špiček při vysílání. Jenom na vyzkoušení.
12.11.2015 v 19:18 #5132jankopÚčastníkMimochodem Aleši, na svém webu píšeš, že modul ESP826-01 má 1MB FLASH. Není to pravda, ten běžný, který máš na fotce má pouze 512KB. Jako novinka se teď presentuje provedení ESP8266-01E s 1MB, ale ten vypadá jinak.
12.11.2015 v 19:19 #5133jankopÚčastníkVerze 1.6.6. podle mě nefunguje s ESP8266. Alespoň můj první pokus neprošel.
12.11.2015 v 19:35 #5134AlešÚčastníkMáš pravdu, má jenom 512KB.
Teď si tady s tím znovu hraju, a 1.6.6 opravdu s ESP8266 funguje. Zrovna mi běží demo HelloServer.12.11.2015 v 19:37 #5135jankopÚčastníkZrovna verzi 1.6.6. instaluji, asi máš pravdu, při svém prvním pokusu jsem možná udělal nějakou chybu.
Ale narazil jsem na problém v tom, že nedovedu nastavit piny pro I2C. Potřeboval bych připojit čidla, ale nedokážu definovat SCL a SDA.12.11.2015 v 21:25 #5146jankopÚčastníkTož závěr mého experimentu zní:“Pokud se nechcete dostat s ESP8266/Arduino do problémů, tak zůstaňte u Arduino IDE 1.6.5. Verze 1.6.6. správně se stávajícím doplňkem pro ESP8266 nepracuje!“
12.11.2015 v 22:03 #5150jankopÚčastníkNo tak se zdá, že ten export bináru půjde také. Sice to píše, že funkce není podporována, ale druhým dechem to napíše, kam to BIN uložilo. A podařilo se mi praktickým programem ESP8266Flasher.exe binár nahrát do modulu a spustit.
14.11.2015 v 20:26 #5156AlešÚčastníkCo znamená, že s 1.6.6 nepracuje správně? Já jsem teda verzi 1.6.5 nezkoušel, ale s 1.6.6 nemám problémy. Normálně dám export binaru, a ono mi ho to vyexportuje. Do ESp jsem ho nahrávat nezkoušel. Nic o tom, že není podporována to nepíše. Zkus z //USER/… smazat adresář arduino15, a nainstalovat podporu ESP znovu.
14.11.2015 v 21:24 #5157jankopÚčastníkKdyž chci přeložit, co mi předtím šlo, tak to holt nejde.
Varování: platform.txt z jádra 'ESP8266 Modules' obsahuje zastaralé recipe.ar.pattern="{compiler.path}{compiler.ar.cmd}" {compiler.ar.flags} {compiler.ar.extra_flags} "{build.path}/{archive_file}" "{object_file}", automaticky skonvertované do recipe.ar.pattern="{compiler.path}{compiler.ar.cmd}" {compiler.ar.flags} {compiler.ar.extra_flags} "{archive_file_path}" "{object_file}". Zvažte upgrade tohoto jádra. WARNING: Category '' in library EEPROM is not valid. Setting to 'Uncategorized' WARNING: Category '' in library ESP8266httpUpdate is not valid. Setting to 'Uncategorized' WARNING: Category '' in library Hash is not valid. Setting to 'Uncategorized' WARNING: Category '' in library SPI is not valid. Setting to 'Uncategorized' WARNING: Category '' in library Ticker is not valid. Setting to 'Uncategorized' WARNING: Category '' in library Wire is not valid. Setting to 'Uncategorized' C:\Users\Pavel\AppData\Local\Arduino15\packages\esp8266\hardware\esp8266\1.6.5-947-g39819f0\libraries\ESP8266WebServer\examples\AdvancedWebServer\AdvancedWebServer.ino: In function 'void setup()': AdvancedWebServer:117: error: 'drawGraph' was not declared in this scope server.on ( "/test.svg", drawGraph ); ^ exit status 1 'drawGraph' was not declared in this scope Nalezena neplatná knihovna v C:\Users\Pavel\AppData\Local\Arduino15\packages\esp8266\hardware\esp8266\1.6.5-947-g39819f0\libraries\esp8266: C:\Users\Pavel\AppData\Local\Arduino15\packages\esp8266\hardware\esp8266\1.6.5-947-g39819f0\libraries\esp8266 Nalezena neplatná knihovna v C:\Users\Pavel\AppData\Local\Arduino15\packages\esp8266\hardware\esp8266\1.6.5-947-g39819f0\libraries\esp8266: C:\Users\Pavel\AppData\Local\Arduino15\packages\esp8266\hardware\esp8266\1.6.5-947-g39819f0\libraries\esp8266
16.11.2015 v 20:16 #5180AlešÚčastníkAha. Tak to asi bude nějaký problém nové verze.
Mě zase se..u ty Warningy. Proč musím pokaždé vědět, že je některá knihovna „špatná“. Nemůžu přijít na to, jak to vypnout, a ty knihovny vymazat nechci, protože je používám, a fungujou. Jenom IDE se nějak nelíbí.19.11.2015 v 17:50 #5246Zbyšek VodaÚčastníkTyto problémy se vyskytují snad jen ve verzi 1.6.6. Verze 1.6.5 jede OK.
20.11.2015 v 11:21 #5265AlešÚčastníkJá jsem verzi 1.6.6 nainstaloval jenom proto, abych vyzkoušel kreslení grafů, které tato nová verze obsahuje. Ale už mě to štve natolik, že jsem se vrátil k verzi 1.6.5, a na grafy používám dál Processing.
23.2.2016 v 16:10 #6134terjeÚčastníkZdravím chlapi, mám prosbu. Zprovoznil jsem ESP8266 s jedním čidlem(ds18b20) na thingspeak. Potřeboval bych k tomu modulu připojit více čidel(např.4).V HW se celkem vyznám, ale SW mi dělá potíže. Dík za radu.
Tady je kód:/*
* This sketch sends data via HTTP GET requests to data.sparkfun.com service.
*
* You need to get streamId and privateKey at data.sparkfun.com and paste them
* below. Or just customize this script to talk to other HTTP servers.
*
*/#include <ESP8266WiFi.h>
#include <OneWire.h>
#include <DallasTemperature.h>
#include <stdlib_noniso.h>#define ONE_WIRE_BUS 2 // DS18B20 pin
OneWire oneWire(ONE_WIRE_BUS);
DallasTemperature DS18B20(&oneWire);const char* ssid = „terje“;
const char* password = „xxxxx“;const char* host = „api.thingspeak.com“;
const char* APIkey = „xxxxxxxxxxxx“;float oldTemp;
void setup() {
Serial.begin(115200);
delay(10);// We start by connecting to a WiFi network
Serial.println();
Serial.println();
Serial.print(„Connecting to „);
Serial.println(ssid);WiFi.begin(ssid, password);
while (WiFi.status() != WL_CONNECTED) {
delay(500);
Serial.print(„.“);
}Serial.println(„“);
Serial.println(„WiFi connected“);
Serial.println(„IP address: „);
Serial.println(WiFi.localIP());
}void loop() {
delay(30000);float temp;
DS18B20.requestTemperatures();
temp = DS18B20.getTempCByIndex(0);
Serial.print(„Temperature: „);
Serial.println(temp);char charVal[12];
dtostrf(temp, 8, 2, charVal);
Serial.print(„connecting to „);
Serial.println(host);// Use WiFiClient class to create TCP connections
WiFiClient client;
const int httpPort = 80;
if (!client.connect(host, httpPort)) {
Serial.println(„connection failed“);
return;
}// We now create a URI for the request
String url = „/update?key=“;
url += APIkey;
url += „&field1=“;
url += charVal;//String(temp);Serial.print(„Requesting URL: „);
Serial.println(url);// This will send the request to the server
client.print(String(„GET „) + url + “ HTTP/1.1\r\n“ +
„Host: “ + host + „\r\n“ +
„Connection: close\r\n\r\n“);
delay(10);// Read all the lines of the reply from server and print them to Serial
while (client.available()) {
String line = client.readStringUntil(‚\r‘);
Serial.print(line);
}Serial.println();
Serial.println(„closing connection“);
}23.2.2016 v 16:19 #6135terjeÚčastníkJo, ty čidla by byly na jedné sběrnici.
23.2.2016 v 16:41 #6136AlešÚčastníkTakhle:
temp0 = DS18B20.getTempCByIndex(0); // první čidlo
temp1 = DS18B20.getTempCByIndex(1); // druhé čidlo, atd..char buf[24];
String strTemp0 = dtostrf(temp0, 6, 2, buf);
String strTemp1 = dtostrf(temp1, 6, 2, buf);
….Odeslání:
url += „&field1=“;
url += strTemp0; //String(temp0);
url += „&field2=“;
url += strTemp1; //String(temp1);
….. -
AutorPříspěvky
- Pro reakci na toto téma se musíte přihlásit.