The ESP32-C3 Super Mini is a widely available and very cheap (€1.50 at AliExpress) microcontroller board that is easy to use, has good support in many platforms, and provides ten freely usable GPIOs.
- Compact: extremely small board (22.5x18mm)
- Easy To Use: works out of the box with many environments like platform.io or ESPHome. There are no issues with entering firmware upload mode, and no fiddling with pressing buttons to select the right mode
- Ultra Low Power: comes with low power consumption and ultra low power modes and supports Bluetooth BLE, making it ideal for battery-operated devices
- Shields: battery shields are available that add battery charging and portable power supply to the C3 Super Mini
- Cheap: available for under €1.50 per piece
The board has a USB-C connector and ten freely usable GPIOs. Four GPIOs can also be used as analog input:
A programmable blue LED is connected to GPIO 8 (inverted: low active), and a red power LED is on when the board is connected to 5V (using its internal voltage regulator), else off (to conserve energy).
Limitations are:
- Performance: while its performance is more than sufficient for most DIY projects and much better than i.e. ESP8266, it uses a single core microcontroller at 160MHz clock speed. The classic ESP32s in comparison is a dual-core microcontroller running at 240MHz. If your project involves computing-intense tasks or needs to respond in real-time to more than one task, you may want to use a different microcontroller.
- GPIOs: due to its small form factor, the ESP32-C3 Super Mini only exposes 10 out of the available 22 GPIOs.
Performance
Key in your decision should be your performance requirements. Here is a comparison to give a good sense how the C3 compares:
Microcontroller | Performance | SRAM | PSRAM |
---|---|---|---|
ESP32-C3 | 16ß0-200MIPS | 400KB | n/a |
ESP8266 | 80MIPS | 160KB + 64KB Instruction RAM + 96KB Data RAM | n/a |
ESP32S | 600MIPS | 520KB | optional, up to 4MB |
GPIO
The ESP32-C3 has 22 GPIOs of which the C3 Super Mini exposes 13 due to its compact size. Of these 13 GPIO, 10 are freely usable whereas the remaining 3 GPIOs are strapping pins and cannot be used during the boot procedure.
Pin | Description | Remark |
---|---|---|
5V | External or USB power | passes the internal voltage regulator |
G | GND | |
3.3 | 3.3V directly (3.0-3.6V) | bypasses the voltage regulator. Does not turn on the red power LED. When supplying more than 3.3V at this pin, you may destroy the microcontroller. When supplying 5V, this is the 3.3V outputted by the voltage regulator |
0-10 | GPIO0 - GPIO10 | 2 and 9 are strapping pins that are reserved during boot. 8 controls the blue LED on the board (inverted) |
20-21 | GPIO20-GPIO21 |
All GPIOs are multifunctional and can be configured for various purposes, such as digital I/O, ADC (Analog-to-Digital Converter), UART, SPI, I2C, PWM, and more.
Ten Freely Usable GPIOs
These 10 GPIO can be freely used:
Pin | Remark |
---|---|
0 | can be used for analog input (ADC1) |
2 | can be used for analog input (ADC1) |
3 | can be used for analog input (ADC1) |
4 | can be used for analog input (ADC1) |
5 | can be used for analog input (ADC1) |
6 | |
7 | |
10 | |
20 | |
21 |
Additional Three GPIOs
If you require more GPIOs, then these three GPIOs can be used with certain restrictions:
Pin | Remark | Default |
---|---|---|
8 | connected to blue LED (low turns LED on). Also used as strapping pin for ROM message printing but using this GPIO during boot does not interfere with the boot process in general | floating |
2 | strapping pin, do not use during boot (selects boot mode) | floating |
9 | strapping pin, do not use during boot (boot button) | pulled up |
JTAG is available on GPIO4-GPIO7.
Interfaces
Interface | Pins | Remarks |
---|---|---|
ADC1 | GPIO0-GPIO4 | Analog input, 12bit, 0-3.3V (supply voltage) are transformed to 0-4096 digitally |
ADC2 | GPIO5 | cannot be used when WiFi is enabled |
I2C | any | recommended to use external pull-ups |
SPI | any | |
LED PWM | any | 6 channels |
UART | *any * |
Boot Modes
The strapping pins control the boot behavior during the boot process:
Mode | GPIO2 | GPIO8 | GPIO9 |
---|---|---|---|
SPI Boot (normal) | high | any | high |
UART/JTAG (firmware upload) | high | high | high |
Board Schematics
Programmable LED
The board has a blue LED connected to GPIO8. This LED is inverted: low turns the LED on, and high turns it off.
Programming
The ESP32-C3 Super Mini is widely adopted and simple to use.
platformio
In platformio, use the board ESP32-C3-DevKitM-1
.
[env:esp32-c3-devkitm-1]
platform = espressif32
board = esp32-c3-devkitm-1
Other IDs may work equally well:
[env:lolin_c3_mini]
platform = espressif32
board = seeed_xiao_esp32c3
ESPHome
In ESPHome configurations, use the board id esp32-c3-devkitm-1
:
esp32:
board: esp32-c3-devkitm-1
You can adjust and override specs if needed:
esphome:
name: c3-supermini-test
friendly_name: C3 SuperMini Test
platformio_options:
board_build.f_flash: 40000000L
board_build.flash_mode: dio
board_build.flash_size: 4MB
esp32:
board: esp32-c3-devkitm-1
variant: esp32c3
framework:
type: arduino
light:
- platform: status_led
name: "Status LED"
id: esp_status_led
icon: "mdi:alarm-light"
pin:
number: GPIO8
inverted: true
restore_mode: ALWAYS_OFF
Comments
Please do leave comments below. I am using utteran.ce, an open-source and ad-free light-weight commenting system.
Here is how your comments are stored
Whenever you leave a comment, a new github issue is created on your behalf.
-
All comments become trackable issues in the Github Issues section, and I (and you) can follow up on them.
-
There is no third-party provider, no disrupting ads, and everything remains transparent inside github.
Github Users Yes, Spammers No
To keep spammers out and comments attributable, all you do is log in using your (free) github account and grant utteranc.es the permission to submit issues on your behalf.
If you don’t have a github account yet, go get yourself one - it’s free and simple.
If for any reason you do not feel comfortable with letting the commenting system submit issues for you, then visit Github Issues directly, i.e. by clicking the red button Submit Issue at the bottom of each page, and submit your issue manually. You control everything.
Discussions
For chit-chat and quick questions, feel free to visit and participate in Discussions. They work much like classic forums or bulletin boards. Just keep in mind: your valued input isn’t equally well trackable there.
(content created Aug 28, 2024)