Go to file
2016-12-14 13:11:10 +02:00
cores/esp32 allow setting internal pull resistors for any mode and enable them for I2C 2016-12-14 13:11:10 +02:00
doc Update windows.md 2016-12-06 21:26:47 +02:00
libraries Hopefully fix I2C/Wire 2016-12-14 02:41:22 +02:00
package Add "WEMOS LoLin32" boards support. (#35) 2016-11-08 10:54:56 +02:00
tools Add analogRead, touchRead, dacWrite and updated esp-idf 2016-12-08 23:43:41 +02:00
variants Add some missing defines 2016-12-12 02:12:18 +02:00
.gitignore ignore dist folder 2016-10-06 07:09:44 -06:00
boards.txt latest IDF, 240MHz and BLE enabled libs 2016-11-28 01:11:36 +02:00
component.mk Add Kconfig for IDF and option to disable HAL mutexes 2016-11-18 15:07:25 +02:00
Kconfig add "monitor" build target for idf 2016-11-18 17:58:32 +02:00
Makefile.projbuild add "monitor" build target for idf 2016-11-18 17:58:32 +02:00
platform.txt Add analogRead, touchRead, dacWrite and updated esp-idf 2016-12-08 23:43:41 +02:00
programmers.txt initial import 2016-10-06 07:09:44 -06:00
README.md Update README.md 2016-12-13 13:45:58 +02:00

Arduino core for ESP32 WiFi chip

Need help or have a question? Join the chat at https://gitter.im/espressif/arduino-esp32

Development Status

Not everything is working yet, you can not get it through package manager, but you can give it a go and help us find bugs in the things that are implemented :)

The framework can also be downloaded as component in an IDF project and be used like that.

Things that work:

  • pinMode
  • digitalRead/digitalWrite
  • attachInterrupt/detachInterrupt
  • analogRead/touchRead/touchAttachInterrupt
  • ledcWrite/sdWrite/dacWrite
  • Serial (global Serial is attached to pins 1 and 3 by default, there are another 2 serials that you can attach to any pin)
  • SPI (global SPI is attached to VSPI pins by default and HSPI can be attached to any pins)
  • Wire (global Wire is attached to pins 21 and 22 by default and there is another I2C bus that you can attach to any pins)
  • WiFi (about 99% the same as ESP8266)

WiFiClient, WiFiServer and WiFiUdp are not quite ready yet because there are still some small hiccups in LwIP to be overcome. You can try WiFiClient but you need to disconnect the client yourself to be sure that connection is closed.

Using Arduino IDE

###Instructions for Windows

Instructions for Mac

  • Install latest Arduino IDE from arduino.cc

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

    curl -o get-pip.py https://bootstrap.pypa.io/get-pip.py && \
    sudo python get-pip.py && \
    sudo pip install pyserial && \
    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
    
  • Restart Arduino IDE

Instructions for Debian/Ubuntu Linux

  • 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 python get-pip.py && \
    sudo pip install 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

Using PlatformIO

PlatformIO is an open source ecosystem for IoT development with cross platform build system, library manager and full support for Espressif ESP32 development. It works on the popular host OS: Mac OS X, Windows, Linux 32/64, Linux ARM (like Raspberry Pi, BeagleBone, CubieBoard).

Using as ESP-IDF component

  • Download and install esp-idf

  • Create blank idf project (from one of the examples)

  • in the project folder, create a folder called components and clone this repository inside

    mkdir -p components && \
    cd components && \
    git clone https://github.com/espressif/arduino-esp32.git arduino && \
    cd .. && \
    make menuconfig
    
  • make menuconfig has some Arduino options

    • "Autostart Arduino setup and loop on boot"
      • If you enable this options, your main.cpp should be formated like any other sketch

        //file: main.cpp
        #include "Arduino.h"
        
        void setup(){
          Serial.begin(115200);
        }
        
        void loop(){
          Serial.println("loop");
          delay(1000);
        }
        
      • Else you need to implement app_main() and call initArduino(); in it.

        Keep in mind that setup() and loop() will not be called in this case

        //file: main.cpp
        #include "Arduino.h"
        
        extern "C" void app_main()
        {
            initArduino();
            pinMode(4, OUTPUT);
            digitalWrite(4, HIGH);
            //do your own thing
        }
        
    • "Disable mutex locks for HAL"
      • If enabled, there will be no protection on the drivers from concurently accessing them from another thread/interrupt/core
    • "Autoconnect WiFi on boot"
      • If enabled, WiFi will start with the last known configuration
      • Else it will wait for WiFi.begin
  • make flash monitor will build, upload and open serial monitor to your board

ESP32Dev Board PINMAP

Pin Functions