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

M
Me No Dev 已提交
3
## 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 已提交
4

5
- [Development Status](#development-status)
M
Me No Dev 已提交
6 7 8 9 10 11
- [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)
12 13 14 15 16
  + [Using PlatformIO](#using-platformio)
  + [Using as ESP-IDF component](#using-as-esp-idf-component)
- [ESP32Dev Board PINMAP](#esp32dev-board-pinmap)  

## Development Status
M
Me No Dev 已提交
17 18
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 已提交
19
- 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 已提交
20
- 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 已提交
21

M
Me No Dev 已提交
22 23 24
## Installation Instructions

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

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

M
Me No Dev 已提交
28
#### Instructions for Mac
M
Me No Dev 已提交
29 30 31 32 33 34 35 36 37 38 39 40
- 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 已提交
41
#### Instructions for Debian/Ubuntu Linux
M
Me No Dev 已提交
42 43 44 45 46 47 48 49 50 51 52 53 54
- 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 已提交
55

M
Me No Dev 已提交
56 57 58 59 60
#### Decoding exceptions

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

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

[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)

M
Me No Dev 已提交
74
### Using as ESP-IDF component
M
Me No Dev 已提交
75 76 77
- 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 已提交
78

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

M
Me No Dev 已提交
90 91 92
          ```arduino
          //file: main.cpp
          #include "Arduino.h"
M
Murat Ambarkutuk 已提交
93

M
Me No Dev 已提交
94 95 96
          void setup(){
            Serial.begin(115200);
          }
M
Murat Ambarkutuk 已提交
97

M
Me No Dev 已提交
98 99 100 101 102
          void loop(){
            Serial.println("loop");
            delay(1000);
          }
          ```
103
          
M
Me No Dev 已提交
104
        - Else you need to implement ```app_main()``` and call ```initArduino();``` in it.
M
Murat Ambarkutuk 已提交
105

106 107
          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 已提交
108

M
Me No Dev 已提交
109 110 111
          ```arduino
          //file: main.cpp
          #include "Arduino.h"
M
Murat Ambarkutuk 已提交
112

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

128 129
## ESP32Dev Board PINMAP

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