====== ESP AT Networking ======
{{:en:iot-open:czapka_b.png?50| General audience classification icon }}{{:en:iot-open:czapka_e.png?50| General audience classification icon }}\\
ESP8266 SoC can work as the WiFi communication module for other microcontrollers. To use the ESP8266 chip as a modem (figure {{ref>esp_at}}), the module must be flashed with the appropriate AT-command firmware. Espressif and other developers prepared the ready-to-use firmware with the AT-command interpreter. This firmware can be downloaded from the web and flashed into ESP8266 memory with a flash tool.
AT commands were developed to control telephony modems. They are often used to control modules connected via a serial port, including GPS receivers, GSM/LTE modems, network modules, and others.
====Preparing an ESP8266 chip with AT commands firmware====
== Downloading Software==
* Download the latest ESP Flash Download Tool (v3.9.5 at the time of writing) from ((https://www.espressif.com/en/support/download/other-tools)).
Other flashing tools like NodeMcu Flasher ((https://github.com/nodemcu/nodemcu-flasher)) exist. While using a single binary file, other flashing tools can be used like esp8266 flasher ((https://github.com/binaryupdates/esp01-firmware)), Tasmotizer ((https://github.com/tasmota/tasmotizer)) or others.
* Download the latest AT release from ((https://bbs.espressif.com/viewforum.php?f=46))
The newest version of Espressif firmware is not compatible with ESP8266 SoCs. In the case of using ESP8266-based boards, download older AiThinker firmware available on GitHub ((http://www.electrodragon.com/w/ESP8266_AT-Command_firmware)).
The firmware can come in different versions. It can be a set of binary files that must be uploaded to specific memory addresses or as a combined single binary file. Note that a single file is prepared for a particular flash memory size.
==Flashing Procedure with single binary file==
* Detect ESP8266 module parameters. Start the ESP Flash Download Tool ("ESPFlashDownloadTool_v3.9.5"), set the COM port corresponding to your programmer, and then click the START button to detect the board's specs. After detection, one should see something like this (figure {{ref>AT_flash}}):
* Gather information. Make a note of the flash memory size. In this example, we have a 32 Mbit flash.
* Load the correct size of the combined AT binary firmware file (".bin") and set the offset as 0×0; one should see something like the view present in figure {{ref>AT_load}}.
* Click the START button and wait until the flashing process ends.
==Flashing Procedure with a set of separate files==
To flash the firmware from a set of files or to restore the original firmware:
* Detect ESP8266 module parameters. Start the ESP Flash Download Tool ("ESPFlashDownloadTool_v3.9.5"), set the COM port corresponding to your programmer, and then click the START button to detect the board's specs. After detection, you should see something like the view present in figure {{ref>AT_flash1}}.
* From the downloaded AT firmware folder, open the "readme.txt" file containing the information for flashing the firmware. Inside the file, there should be a "BOOT MODE" section as follows:
# BOOT MODE
## download
### Flash size 8Mbit: 512KB+512KB
boot_v1.2+.bin 0x00000
user1.1024.new.2.bin 0x01000
esp_init_data_default.bin 0xfc000 (optional)
blank.bin 0x7e000 & 0xfe000
### Flash size 16Mbit: 512KB+512KB
boot_v1.5.bin 0x00000
user1.1024.new.2.bin 0x01000
esp_init_data_default.bin 0x1fc000 (optional)
blank.bin 0x7e000 & 0x1fe000
### Flash size 16Mbit-C1: 1024KB+1024KB
boot_v1.2+.bin 0x00000
user1.2048.new.5.bin 0x01000
esp_init_data_default.bin 0x1fc000 (optional)
blank.bin 0xfe000 & 0x1fe000
### Flash size 32Mbit: 512KB+512KB
boot_v1.2+.bin 0x00000
user1.1024.new.2.bin 0x01000
esp_init_data_default.bin 0x3fc000 (optional)
blank.bin 0x7e000 & 0x3fe000
### Flash size 32Mbit-C1: 1024KB+1024KB
boot_v1.2+.bin 0x00000
user1.2048.new.5.bin 0x01000
esp_init_data_default.bin 0x3fc000 (optional)
blank.bin 0xfe000 & 0x3fe000
* Indicate -- correct for your ESP8266 flash size -- firmware files & addresses. The firmware is broken down into several files. They must be provided to the ESP Flash Download Tool and the corresponding addresses in the readme.txt file above. For our ESP8266 example, it should look like in figure {{ref>AT_reflash}}.
* Click the START button and wait until the flashing process ends.
==== Basic ESP8266 Networking ====
After uploading AT firmware and connecting the module to the PC, an ESP8266 can be used as a modem with simple AT commands.
It is possible to connect ESP8266 to a PC with a TTL-Serial-to-USB adapter. Connection to any microcontroller with a serial interface does not need an adapter. The default baud rate settings are 115200,N,8,1. To check if the module works properly, a simple "AT" command can be used:
AT
If the response is "OK", the ESP8266 module is ready to use and accept other commands. For example, to figure out exactly what firmware version is installed, the following command can be used:
AT+GMR The AT command interpreter requires full "Enter" code. Both "CR" and "LF" characters must be sent. Some popular terminal programs like Putty do not send both characters. Be sure that the serial terminal software sends "CRLF" at the end of the line.
As a WiFi device, ESP8266 can connect to the network in such modes:
* mode 1 - client mode - the ESP8266 connecting to an existing wireless network,
* mode 2 - access point mode (AP) - other wireless network devices can be connected to the ESP8266,
* mode 3 - dual mode (router) - the ESP8266 is an access point and connects simultaneously to an existing wireless network.
*
By default, the ESP8266's stock firmware is set to AP mode. To confirm that, send the following command:
AT+CWMODE?
The response should look like ''+CWMODE:2'', where 2 corresponds to AP mode. To switch ESP8266 to client device mode, the following command can be used:
AT+CWMODE=1
To scan the airwaves for all WiFi access points in range, the following command can be used:
AT+CWLAP
Then, the ESP8266 will return a list of all the access points in range. In each line will be an item consisting of the security level of the access point, the network name, the signal strength, the MAC address, and the wireless channel used. Possible security levels of the access point <0-4> mean:
* 0 - open,
* 1 - WEP,
* 2 - WPA_PSK,
* 3 - WPA2_PSK,
* 4 - WPA_WPA2_PSK.
The following command establishes the connection to the available access point with proper ''ssid_name'' and ''password'':
AT+CWJAP=,
If everything is OK, the ESP8266 will answer:
WIFI CONNECTED
WIFI GOT IP
OK
ESP8266 is connected to the chosen AP and obtained a proper IP address. The following command checks what is the assigned IP address:
AT+CIFSR
To set up ESP8266 to behave both as a WiFi client and a WiFi Access point, the mode should be set to 3:
AT+CWMODE=3