Installing

This guide will show how to install the Arduino-ESP32 support.

Before Installing

We recommend you install the support using your favorite IDE, but other options are available depending on your operating system. To install Arduino-ESP32 support, you can use one of the following options.

Installing using Arduino IDE

_images/logo_arduino.png

This is the way to install Arduino-ESP32 directly from the Arduino IDE.

Note

For overview of SoC’s support, take a look on Supported Soc’s table where you can find if the particular chip is under stable or development release.

  • Stable release link:

    https://espressif.github.io/arduino-esp32/package_esp32_index.json
    
  • Development release link:

    https://espressif.github.io/arduino-esp32/package_esp32_dev_index.json
    

Note

Starting with the Arduino IDE version 1.6.4, Arduino allows installation of third-party platform packages using Boards Manager. We have packages available for Windows, macOS, and Linux.

To start the installation process using the Boards Manager, follow these steps:

  • Install the current upstream Arduino IDE at the 1.8 level or later. The current version is at the arduino.cc website.

  • Start Arduino and open the Preferences window.

_images/install_guide_preferences.png
  • Enter one of the release links above into Additional Board Manager URLs field. You can add multiple URLs, separating them with commas.

_images/install_guide_boards_manager_url.png
  • Open Boards Manager from Tools > Board menu and install esp32 platform (and do not forget to select your ESP32 board from Tools > Board menu after installation).

_images/install_guide_boards_manager_esp32.png
  • Restart Arduino IDE.

Windows (manual installation)

Warning

Arduino ESP32 core v2.x.x cannot be used on Windows 8.x x86 (32 bits), Windows 7 or earlier. The Windows 32 bits OS is no longer supported by this toolchain.

The Arduino ESP32 v1.0.6 still works on WIN32. You might want to install python 3.8.x because it is the latest release supported by Windows 7.

Steps to install Arduino ESP32 support on Windows:

Step 1

  1. Download and install the latest Arduino IDE Windows Installer from [arduino.cc](https://www.arduino.cc/en/Main/Software)

  2. Download and install Git from [git-scm.com](https://git-scm.com/download/win)

  3. Start Git GUI and do the following steps:

  • Select Clone Existing Repository

_images/win-gui-1.png
  • Select source and destination
    • Sketchbook Directory: Usually C:/Users/[YOUR_USER_NAME]/Documents/Arduino and is listed underneath the “Sketchbook location” in Arduino preferences.

    • Source Location: https://github.com/espressif/arduino-esp32.git

    • Target Directory: [ARDUINO_SKETCHBOOK_DIR]/hardware/espressif/esp32

    • Click Clone to start cloning the repository

Step 2

_images/win-gui-2.png

Step 3

_images/win-gui-3.png
  • open a Git Bash session pointing to [ARDUINO_SKETCHBOOK_DIR]/hardware/espressif/esp32 and execute `git submodule update --init --recursive`

  • Open [ARDUINO_SKETCHBOOK_DIR]/hardware/espressif/esp32/tools and double-click get.exe

Step 4

_images/win-gui-4.png
  • When `get.exe` finishes, you should see the following files in the directory

Step 5

_images/win-gui-5.png
  1. Plug your ESP32 board and wait for the drivers to install (or install manually any that might be required)

  2. Start Arduino IDE

  3. Select your board in Tools > Board menu

  4. Select the COM port that the board is attached to

  5. Compile and upload (You might need to hold the boot button while uploading)

_images/arduino-ide.png

How to update to the latest code

  1. Start Git GUI and you should see the repository under Open Recent Repository. Click on it!

_images/win-gui-update-1.png
  1. From menu Remote select Fetch from > origin

_images/win-gui-update-2.png
  1. Wait for git to pull any changes and close Git GUI

  2. Open [ARDUINO_SKETCHBOOK_DIR]/hardware/espressif/esp32/tools and double-click get.exe

_images/win-gui-4.png

Linux

_images/logo_linux.png

Debian/Ubuntu

  • Install latest Arduino IDE from arduino.cc.

  • Open Terminal and execute the following command (copy -> paste and hit enter):

sudo usermod -a -G dialout $USER && \
sudo apt-get install git && \
wget https://bootstrap.pypa.io/get-pip.py && \
sudo python3 get-pip.py && \
sudo pip3 install pyserial && \
mkdir -p ~/Arduino/hardware/espressif && \
cd ~/Arduino/hardware/espressif && \
git clone https://github.com/espressif/arduino-esp32.git esp32 && \
cd esp32/tools && \
python3 get.py
  • Restart Arduino IDE.

  • If you have Arduino installed to ~/, modify the installation as follows, beginning at mkdir -p ~/Arduino/hardware:

cd ~/Arduino/hardware
mkdir -p espressif && \
cd espressif && \
git clone https://github.com/espressif/arduino-esp32.git esp32 && \
cd esp32/tools && \
python3 get.py

Fedora

Note

Command $ sudo dnf -y install arduino will most likely install an older release.

  • Open Terminal and execute the following command (copy -> paste and hit enter):

sudo usermod -a -G dialout $USER && \
sudo dnf install git python3-pip python3-pyserial && \
mkdir -p ~/Arduino/hardware/espressif && \
cd ~/Arduino/hardware/espressif && \
git clone https://github.com/espressif/arduino-esp32.git esp32 && \
cd esp32/tools && \
python get.py
  • Restart Arduino IDE.

openSUSE

  • Install the latest Arduino IDE from arduino.cc.

  • Open Terminal and execute the following command (copy -> paste and hit enter):

sudo usermod -a -G dialout $USER && \
if [ `python --version 2>&1 | grep '2.7' | wc -l` = "1" ]; then \
sudo zypper install git python-pip python-pyserial; \
else \
sudo zypper install git python3-pip python3-pyserial; \
fi && \
mkdir -p ~/Arduino/hardware/espressif && \
cd ~/Arduino/hardware/espressif && \
git clone https://github.com/espressif/arduino-esp32.git esp32 && \
cd esp32/tools && \
python get.py
  • Restart Arduino IDE.

macOS

  • Install the latest Arduino IDE from arduino.cc.

  • Open Terminal and execute the following command (copy -> paste and hit enter):

mkdir -p ~/Documents/Arduino/hardware/espressif && \
cd ~/Documents/Arduino/hardware/espressif && \
git clone https://github.com/espressif/arduino-esp32.git esp32 && \
cd esp32/tools && \
python get.py

Where ~/Documents/Arduino represents your sketch book location as per “Arduino” > “Preferences” > “Sketchbook location” (in the IDE once started). Adjust the command above accordingly.

  • If you get the error below, install through the command line dev tools with xcode-select –install and try the command above again:

xcrun: error: invalid active developer path (/Library/Developer/CommandLineTools), missing xcrun at: /Library/Developer/CommandLineTools/usr/bin/xcrun
  • Run the command:

xcode-select --install
  • Try python3 instead of python if you get the error: IOError: [Errno socket error] [SSL: TLSV1_ALERT_PROTOCOL_VERSION] tlsv1 alert protocol version (_ssl.c:590) when running python get.py

  • If you get the following error when running python get.py: urllib.error.URLError: <urlopen error SSL: CERTIFICATE_VERIFY_FAILED, go to Macintosh HD > Applications > Python3.6 folder (or any other python version), and run the following scripts: Install Certificates.command and Update Shell Profile.command

  • Restart Arduino IDE.