README.md 5.8 KB
Newer Older
1
# Arduino core for ESP32 WiFi chip
M
Me No Dev 已提交
2

M
Me No Dev 已提交
3 4
[![Build Status](https://travis-ci.org/espressif/arduino-esp32.svg?branch=master)](https://travis-ci.org/espressif/arduino-esp32)

M
Me No Dev 已提交
5
## Need help or have a question? Join the chat at [![https://gitter.im/espressif/arduino-esp32](https://badges.gitter.im/espressif/arduino-esp32.svg)](https://gitter.im/espressif/arduino-esp32?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge&utm_content=badge)
T
The Gitter Badger 已提交
6

7
- [Development Status](#development-status)
M
Me No Dev 已提交
8 9 10 11 12 13
- [Installation Instructions](#installation-instructions):
  + [Using Arduino IDE](#using-through-arduino-ide)
    + [Windows](https://github.com/espressif/arduino-esp32/blob/master/doc/windows.md)
    + [Mac OS](#instructions-for-mac)
    + [Debian/Ubuntu](#instructions-for-debianubuntu-linux)
    + [Decoding Exceptions](#decoding-exceptions)
14 15
  + [Using PlatformIO](#using-platformio)
  + [Using as ESP-IDF component](#using-as-esp-idf-component)
16
- [ESP32Dev Board PINMAP](#esp32dev-board-pinmap)
17 18

## Development Status
M
Me No Dev 已提交
19 20
Most of the framework is implemented. Most noticable is the missing analogWrite. While analogWrite is on it's way, there are a few other options that you can use:
- 16 channels [LEDC](https://github.com/espressif/arduino-esp32/blob/master/cores/esp32/esp32-hal-ledc.h) which is PWM
M
me-no-dev 已提交
21
- 8 channels [SigmaDelta](https://github.com/espressif/arduino-esp32/blob/master/cores/esp32/esp32-hal-sigmadelta.h) which uses SigmaDelta modulation
M
Me No Dev 已提交
22
- 2 channels [DAC](https://github.com/espressif/arduino-esp32/blob/master/cores/esp32/esp32-hal-dac.h) which gives real analog output
M
Me No Dev 已提交
23

M
Me No Dev 已提交
24 25 26
## Installation Instructions

### Using through Arduino IDE
M
Me No Dev 已提交
27

28
###[Instructions for Windows](doc/windows.md)
M
Me No Dev 已提交
29

M
Me No Dev 已提交
30
#### Instructions for Mac
M
Me No Dev 已提交
31 32 33 34 35 36 37 38 39 40 41 42
- Install latest Arduino IDE from [arduino.cc](https://www.arduino.cc/en/Main/Software)
- Open Terminal and execute the following command (copy->paste and hit enter):

  ```bash
  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

M
Me No Dev 已提交
43
#### Instructions for Debian/Ubuntu Linux
M
Me No Dev 已提交
44 45 46 47 48 49 50 51 52 53 54 55 56
- Install latest Arduino IDE from [arduino.cc](https://www.arduino.cc/en/Main/Software)
- Open Terminal and execute the following command (copy->paste and hit enter):

  ```bash
  sudo usermod -a -G dialout $USER && \
  sudo apt-get install git && \
  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
M
Me No Dev 已提交
57

M
Me No Dev 已提交
58 59 60 61 62
#### Decoding exceptions

You can use [EspExceptionDecoder](https://github.com/me-no-dev/EspExceptionDecoder) to get meaningful call trace.

### Using PlatformIO
63 64 65 66 67 68 69 70 71 72 73 74

[PlatformIO](http://platformio.org) 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).

- [What is PlatformIO?](http://docs.platformio.org/page/what-is-platformio.html)
- [PlatformIO IDE](http://platformio.org/platformio-ide)
- Quick Start with [PlatformIO IDE](http://docs.platformio.org/page/ide/atom.html#quick-start) or [PlatformIO Core](http://docs.platformio.org/page/core.html)
- [Integration with Cloud and Standalone IDEs](http://docs.platformio.org/page/ide.html) -
  Cloud9, Codeanywehre, Eclipse Che (Codenvy), Atom, CLion, Eclipse, Emacs, NetBeans, Qt Creator, Sublime Text, VIM and Visual Studio
- [Project Examples](https://github.com/platformio/platform-espressif32/tree/develop/examples)
75
- [Using "Stage" (Git) version of Arduino Core](http://docs.platformio.org/page/platforms/espressif32.html#using-arduino-framework-with-staging-version)
76

M
Me No Dev 已提交
77
### Using as ESP-IDF component
M
Me No Dev 已提交
78 79 80
- Download and install [esp-idf](https://github.com/espressif/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
M
Murat Ambarkutuk 已提交
81

M
Me No Dev 已提交
82 83 84 85
    ```bash
    mkdir -p components && \
    cd components && \
    git clone https://github.com/espressif/arduino-esp32.git arduino && \
M
Murat Ambarkutuk 已提交
86
    cd .. && \
M
Me No Dev 已提交
87 88 89 90 91
    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
M
Murat Ambarkutuk 已提交
92

M
Me No Dev 已提交
93 94 95
          ```arduino
          //file: main.cpp
          #include "Arduino.h"
M
Murat Ambarkutuk 已提交
96

M
Me No Dev 已提交
97 98 99
          void setup(){
            Serial.begin(115200);
          }
M
Murat Ambarkutuk 已提交
100

M
Me No Dev 已提交
101 102 103 104 105
          void loop(){
            Serial.println("loop");
            delay(1000);
          }
          ```
106

M
Me No Dev 已提交
107
        - Else you need to implement ```app_main()``` and call ```initArduino();``` in it.
M
Murat Ambarkutuk 已提交
108

109 110
          Keep in mind that setup() and loop() will not be called in this case.
          If you plan to base your code on examples provided in [esp-idf](https://github.com/espressif/esp-idf/tree/master/examples), please make sure move the app_main() function in main.cpp from the files in the example.
M
Murat Ambarkutuk 已提交
111

M
Me No Dev 已提交
112 113 114
          ```arduino
          //file: main.cpp
          #include "Arduino.h"
M
Murat Ambarkutuk 已提交
115

M
Me No Dev 已提交
116 117 118
          extern "C" void app_main()
          {
              initArduino();
M
Murat Ambarkutuk 已提交
119
              pinMode(4, OUTPUT);
M
Me No Dev 已提交
120 121 122 123 124 125 126 127 128 129 130
              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

131 132
## ESP32Dev Board PINMAP

M
Me No Dev 已提交
133
![Pin Functions](doc/esp32_pinmap.png)