2020-04-08 14:45:35 +02:00
|
|
|
|
README for the Espressif ESP32 Core board (V2)
|
2016-10-14 19:01:28 +02:00
|
|
|
|
==============================================
|
2016-10-14 00:29:54 +02:00
|
|
|
|
|
2020-04-08 14:45:35 +02:00
|
|
|
|
The ESP32 is a dual-core system from Espressif with two Harvard
|
2016-10-14 00:29:54 +02:00
|
|
|
|
architecture Xtensa LX6 CPUs. All embedded memory, external memory and
|
|
|
|
|
peripherals are located on the data bus and/or the instruction bus of
|
|
|
|
|
these CPUs. With some minor exceptions, the address mapping of two CPUs
|
|
|
|
|
is symmetric, meaning they use the same addresses to access the same
|
|
|
|
|
memory. Multiple peripherals in the system can access embedded memory via
|
|
|
|
|
DMA.
|
|
|
|
|
|
|
|
|
|
The two CPUs are named "PRO_CPU" and "APP_CPU" (for "protocol" and
|
|
|
|
|
"application"), however for most purposes the two CPUs are
|
|
|
|
|
interchangeable.
|
|
|
|
|
|
2016-10-15 22:57:06 +02:00
|
|
|
|
Contents
|
|
|
|
|
========
|
|
|
|
|
|
|
|
|
|
o ESP32 Features
|
|
|
|
|
o ESP32 Toolchain
|
2016-11-12 22:10:23 +01:00
|
|
|
|
o Memory Map
|
2016-10-15 22:57:06 +02:00
|
|
|
|
o Serial Console
|
|
|
|
|
o Buttons and LEDs
|
2020-08-06 19:50:44 +02:00
|
|
|
|
o Ethernet
|
2020-11-05 13:35:51 +01:00
|
|
|
|
o 64-bit Timers
|
2020-11-28 05:03:51 +01:00
|
|
|
|
o Watchdog Timers
|
2016-10-31 15:29:28 +01:00
|
|
|
|
o SMP
|
2016-11-15 00:51:50 +01:00
|
|
|
|
o OpenOCD for the ESP32
|
|
|
|
|
o Executing and Debugging from FLASH and IRAM
|
2016-10-15 22:57:06 +02:00
|
|
|
|
o Configurations
|
2016-11-01 22:12:30 +01:00
|
|
|
|
o Things to Do
|
2016-10-15 22:57:06 +02:00
|
|
|
|
|
|
|
|
|
STATUS
|
|
|
|
|
======
|
|
|
|
|
|
2020-11-05 13:35:51 +01:00
|
|
|
|
Currently we have support to UART, SPI, I2C, Ethernet, Timers,
|
|
|
|
|
Watchdog Timers, etc.
|
2018-08-19 23:38:06 +02:00
|
|
|
|
|
2020-08-20 19:04:18 +02:00
|
|
|
|
Espressif is working to include support to WiFi and Bluetooth, but
|
|
|
|
|
it will depends on their external libraries to get it up and running.
|
2019-03-04 19:55:23 +01:00
|
|
|
|
|
2016-10-14 19:01:28 +02:00
|
|
|
|
ESP32 Features
|
|
|
|
|
==============
|
2016-10-14 00:29:54 +02:00
|
|
|
|
|
|
|
|
|
* Address Space
|
|
|
|
|
- Symmetric address mapping
|
|
|
|
|
- 4 GB (32-bit) address space for both data bus and instruction bus
|
|
|
|
|
- 1296 KB embedded memory address space
|
|
|
|
|
- 19704 KB external memory address space
|
|
|
|
|
- 512 KB peripheral address space
|
|
|
|
|
- Some embedded and external memory regions can be accessed by either
|
|
|
|
|
data bus or instruction bus
|
|
|
|
|
- 328 KB DMA address space
|
|
|
|
|
* Embedded Memory
|
|
|
|
|
- 448 KB Internal ROM
|
|
|
|
|
- 520 KB Internal SRAM
|
|
|
|
|
- 8 KB RTC FAST Memory
|
|
|
|
|
- 8 KB RTC SLOW Memory
|
|
|
|
|
* External Memory
|
|
|
|
|
Off-chip SPI memory can be mapped into the available address space as
|
|
|
|
|
external memory. Parts of the embedded memory can be used as transparent
|
|
|
|
|
cache for this external memory.
|
|
|
|
|
- Supports up to 16 MB off-Chip SPI Flash.
|
|
|
|
|
- Supports up to 8 MB off-Chip SPI SRAM.
|
|
|
|
|
* Peripherals
|
|
|
|
|
- 41 peripherals
|
|
|
|
|
* DMA
|
|
|
|
|
- 13 modules are capable of DMA operation
|
|
|
|
|
|
|
|
|
|
ESP32 Toolchain
|
|
|
|
|
===============
|
|
|
|
|
|
2016-10-14 19:01:28 +02:00
|
|
|
|
You must use the custom Xtensa toolchain in order to build the ESP32 Core
|
|
|
|
|
BSP. The steps to build toolchain with crosstool-NG on Linux are as
|
|
|
|
|
follows:
|
2016-10-14 00:29:54 +02:00
|
|
|
|
|
2019-12-10 20:44:28 +01:00
|
|
|
|
git clone https://github.com/espressif/crosstool-NG.git
|
2016-10-14 00:29:54 +02:00
|
|
|
|
cd crosstool-NG
|
2019-12-10 20:44:28 +01:00
|
|
|
|
git checkout esp-2019r2
|
|
|
|
|
git submodule update --init
|
|
|
|
|
|
|
|
|
|
./bootstrap && ./configure --enable-local && make
|
|
|
|
|
|
2016-10-14 00:29:54 +02:00
|
|
|
|
./ct-ng xtensa-esp32-elf
|
|
|
|
|
./ct-ng build
|
2019-12-10 20:44:28 +01:00
|
|
|
|
|
2016-10-14 00:29:54 +02:00
|
|
|
|
chmod -R u+w builds/xtensa-esp32-elf
|
|
|
|
|
|
2019-12-10 20:44:28 +01:00
|
|
|
|
export PATH="crosstool-NG/builds/xtensa-esp32-elf/bin:$PATH"
|
2016-10-14 00:29:54 +02:00
|
|
|
|
|
2019-12-10 20:44:28 +01:00
|
|
|
|
These steps are given in setup guide in ESP-IDF repository:
|
|
|
|
|
https://docs.espressif.com/projects/esp-idf/en/latest/get-started/linux-setup-scratch.html
|
2016-10-15 22:57:06 +02:00
|
|
|
|
|
2016-11-12 22:10:23 +01:00
|
|
|
|
Memory Map
|
|
|
|
|
==========
|
|
|
|
|
|
2016-11-12 22:51:14 +01:00
|
|
|
|
Address Mapping
|
|
|
|
|
----------- ---------- ---------- --------------- ---------------
|
|
|
|
|
BUS TYPE START LAST DESCRIPTION NOTES
|
|
|
|
|
----------- ---------- ---------- --------------- ---------------
|
|
|
|
|
0x00000000 0x3F3FFFFF Reserved
|
|
|
|
|
Data 0x3F400000 0x3F7FFFFF External Memory
|
|
|
|
|
Data 0x3F800000 0x3FBFFFFF External Memory
|
|
|
|
|
0x3FC00000 0x3FEFFFFF Reserved
|
|
|
|
|
Data 0x3FF00000 0x3FF7FFFF Peripheral
|
|
|
|
|
Data 0x3FF80000 0x3FFFFFFF Embedded Memory
|
|
|
|
|
Instruction 0x40000000 0x400C1FFF Embedded Memory
|
|
|
|
|
Instruction 0x400C2000 0x40BFFFFF External Memory
|
|
|
|
|
0x40C00000 0x4FFFFFFF Reserved
|
|
|
|
|
Data / 0x50000000 0x50001FFF Embedded Memory
|
|
|
|
|
Instruction
|
|
|
|
|
0x50002000 0xFFFFFFFF Reserved
|
|
|
|
|
|
2016-11-12 22:10:23 +01:00
|
|
|
|
Embedded Memory
|
2016-11-12 22:51:14 +01:00
|
|
|
|
----------- ---------- ---------- --------------- ---------------
|
2016-11-12 22:10:23 +01:00
|
|
|
|
BUS TYPE START LAST DESCRIPTION NOTES
|
2016-11-12 22:51:14 +01:00
|
|
|
|
----------- ---------- ---------- --------------- ---------------
|
2016-11-12 22:10:23 +01:00
|
|
|
|
Data 0x3ff80000 0x3ff81fff RTC FAST Memory PRO_CPU Only
|
|
|
|
|
0x3ff82000 0x3ff8ffff Reserved
|
|
|
|
|
Data 0x3ff90000 0x3ff9ffff Internal ROM 1
|
|
|
|
|
0x3ffa0000 0x3ffadfff Reserved
|
|
|
|
|
Data 0x3ffae000 0x3ffdffff Internal SRAM 2 DMA
|
|
|
|
|
Data 0x3ffe0000 0x3fffffff Internal SRAM 1 DMA
|
|
|
|
|
|
|
|
|
|
Boundary Address
|
2016-11-12 22:51:14 +01:00
|
|
|
|
----------- ---------- ---------- --------------- ---------------
|
2016-11-12 22:10:23 +01:00
|
|
|
|
BUS TYPE START LAST DESCRIPTION NOTES
|
2016-11-12 22:51:14 +01:00
|
|
|
|
----------- ---------- ---------- --------------- ---------------
|
2016-11-12 22:10:23 +01:00
|
|
|
|
Instruction 0x40000000 0x40007fff Internal ROM 0 Remap
|
|
|
|
|
Instruction 0x40008000 0x4005ffff Internal ROM 0
|
|
|
|
|
0x40060000 0x4006ffff Reserved
|
|
|
|
|
Instruction 0x40070000 0x4007ffff Internal SRAM 0 Cache
|
|
|
|
|
Instruction 0x40080000 0x4009ffff Internal SRAM 0
|
|
|
|
|
Instruction 0x400a0000 0x400affff Internal SRAM 1
|
|
|
|
|
Instruction 0x400b0000 0x400b7FFF Internal SRAM 1 Remap
|
|
|
|
|
Instruction 0x400b8000 0x400bffff Internal SRAM 1
|
|
|
|
|
Instruction 0x400c0000 0x400c1FFF RTC FAST Memory PRO_CPU Only
|
|
|
|
|
Data / 0x50000000 0x50001fff RTC SLOW Memory
|
|
|
|
|
Instruction
|
|
|
|
|
|
|
|
|
|
External Memory
|
2016-11-12 22:51:14 +01:00
|
|
|
|
----------- ---------- ---------- --------------- ---------------
|
2016-11-12 22:10:23 +01:00
|
|
|
|
BUS TYPE START LAST DESCRIPTION NOTES
|
2016-11-12 22:51:14 +01:00
|
|
|
|
----------- ---------- ---------- --------------- ---------------
|
2016-11-12 22:10:23 +01:00
|
|
|
|
Data 0x3f400000 0x3f7fffff External Flash Read
|
|
|
|
|
Data 0x3f800000 0x3fbfffff External SRAM Read and Write
|
|
|
|
|
|
|
|
|
|
Boundary Address
|
|
|
|
|
----------------
|
|
|
|
|
Instruction 0x400c2000 0x40bfffff 11512 KB External Flash Read
|
|
|
|
|
|
|
|
|
|
Linker Segments
|
2016-11-12 22:51:14 +01:00
|
|
|
|
------------------ ---------- ---------- ---- ----------------------------
|
|
|
|
|
DESCRIPTION START END ATTR LINKER SEGMENT NAME
|
|
|
|
|
------------------ ---------- ---------- ---- ----------------------------
|
2016-11-13 16:30:45 +01:00
|
|
|
|
FLASH mapped data: 0x3f400010 0x3fc00010 R drom0_0_seg
|
|
|
|
|
- .rodata
|
|
|
|
|
- Constructors/destructors
|
|
|
|
|
COMMON data RAM: 0x3ffb0000 0x40000000 RW dram0_0_seg (NOTE 1,2)
|
|
|
|
|
- .bss/.data
|
2016-11-12 22:51:14 +01:00
|
|
|
|
IRAM for PRO cpu: 0x40080000 0x400a0000 RX iram0_0_seg
|
2016-11-13 16:30:45 +01:00
|
|
|
|
- Interrupt Vectors
|
|
|
|
|
- Low level handlers
|
2020-04-08 14:45:35 +02:00
|
|
|
|
- Xtensa/Espressif libraries
|
2016-11-13 16:30:45 +01:00
|
|
|
|
RTC fast memory: 0x400c0000 0x400c2000 RWX rtc_iram_seg (PRO_CPU only)
|
|
|
|
|
- .rtc.text (unused?)
|
|
|
|
|
FLASH: 0x400d0018 0x40400018 RX iram0_2_seg (actually FLASH)
|
|
|
|
|
- .text
|
2016-11-12 22:51:14 +01:00
|
|
|
|
RTC slow memory: 0x50000000 0x50001000 RW rtc_slow_seg (NOTE 3)
|
2016-11-13 16:30:45 +01:00
|
|
|
|
- .rtc.data/rodata (unused?)
|
2016-11-12 22:10:23 +01:00
|
|
|
|
|
2016-11-13 14:55:34 +01:00
|
|
|
|
NOTE 1: Linker script will reserve space at the beginning of the segment
|
2016-11-12 22:10:23 +01:00
|
|
|
|
for BT and at the end for trace memory.
|
2016-11-13 16:30:45 +01:00
|
|
|
|
NOTE 2: Heap enads at the top of dram_0_seg
|
2016-11-13 14:55:34 +01:00
|
|
|
|
NOTE 3: Linker script will reserve space at the beginning of the segment
|
2016-11-12 22:10:23 +01:00
|
|
|
|
for co-processor reserve memory and at the end for ULP coprocessor
|
|
|
|
|
reserve memory.
|
|
|
|
|
|
2016-10-15 22:57:06 +02:00
|
|
|
|
Serial Console
|
|
|
|
|
==============
|
|
|
|
|
|
2016-11-15 14:28:37 +01:00
|
|
|
|
UART0 is, by default, the serial console. It connects to the on-board
|
2016-10-24 22:09:47 +02:00
|
|
|
|
CP2102 converter and is available on the USB connector USB CON8 (J1).
|
2016-10-15 22:57:06 +02:00
|
|
|
|
|
2016-12-14 19:34:11 +01:00
|
|
|
|
It will show up as /dev/ttypUSB[n] where [n] will probably be 0 (is it 1
|
|
|
|
|
on my PC because I have a another device at ttyUSB0).
|
|
|
|
|
|
2016-10-15 22:57:06 +02:00
|
|
|
|
Buttons and LEDs
|
|
|
|
|
================
|
|
|
|
|
|
|
|
|
|
Buttons
|
|
|
|
|
-------
|
2016-10-21 15:35:56 +02:00
|
|
|
|
There are two buttons labeled Boot and EN. The EN button is not available
|
|
|
|
|
to software. It pulls the chip enable line that doubles as a reset line.
|
|
|
|
|
|
|
|
|
|
The BOOT button is connected to IO0. On reset it is used as a strapping
|
|
|
|
|
pin to determine whether the chip boots normally or into the serial
|
|
|
|
|
bootloader. After reset, however, the BOOT button can be used for software
|
|
|
|
|
input.
|
2016-10-15 22:57:06 +02:00
|
|
|
|
|
|
|
|
|
LEDs
|
2016-10-21 15:35:56 +02:00
|
|
|
|
----
|
|
|
|
|
There are several on-board LEDs for that indicate the presence of power
|
2019-01-16 20:09:52 +01:00
|
|
|
|
and USB activity. None of these are available for use by software.
|
2016-10-15 22:57:06 +02:00
|
|
|
|
|
2020-08-06 19:50:44 +02:00
|
|
|
|
Ethernet
|
|
|
|
|
========
|
|
|
|
|
|
|
|
|
|
ESP32 has a 802.11 hardware MAC, so just connects to external PHY chip.
|
2020-11-05 13:35:51 +01:00
|
|
|
|
Due to the limited number of GPIOs in ESP32, it's recommended to use RMII to
|
|
|
|
|
connect to an external PHY chip. Current driver also only supports RMII option.
|
2020-08-06 19:50:44 +02:00
|
|
|
|
|
|
|
|
|
The RMII GPIO pins are fixed, but the SMI and functional GPIO pins are optional.
|
2020-11-28 05:03:51 +01:00
|
|
|
|
|
2020-08-06 19:50:44 +02:00
|
|
|
|
RMII GPIO pins are as following:
|
|
|
|
|
|
|
|
|
|
ESP32 GPIO PHY Chip GPIO
|
|
|
|
|
IO25 <--> RXD[0]
|
|
|
|
|
IO26 <--> RXD[1]
|
|
|
|
|
IO27 <--> CRS_DV
|
|
|
|
|
IO0 <--> REF_CLK
|
|
|
|
|
IO19 <--> TXD[0]
|
|
|
|
|
IO21 <--> TX_EN
|
|
|
|
|
IO22 <--> TXD[1]
|
|
|
|
|
|
|
|
|
|
SMI GPIO pins (default option) are as following:
|
|
|
|
|
|
|
|
|
|
ESP32 GPIO PHY Chip GPIO
|
|
|
|
|
IO18 <--> MDIO
|
|
|
|
|
IO23 <--> MDC
|
|
|
|
|
|
|
|
|
|
Functional GPIO pins(default option) are as following:
|
|
|
|
|
|
|
|
|
|
ESP32 GPIO PHY Chip GPIO
|
|
|
|
|
IO5 <--> Reset_N
|
|
|
|
|
|
|
|
|
|
Espressif has an offcial Ethernet development board:
|
|
|
|
|
|
|
|
|
|
https://docs.espressif.com/projects/esp-idf/en/latest/esp32/hw-reference/esp32/get-started-ethernet-kit.html
|
|
|
|
|
|
|
|
|
|
This driver has been tested according to this board and ESP32 core
|
|
|
|
|
board + LAN8720 module. If users have some issue about using this driver,
|
|
|
|
|
please refer the upper official document, specially the issue that GPIO0
|
|
|
|
|
causes failing to bring the ESP32 chip up.
|
|
|
|
|
|
2020-11-05 13:35:51 +01:00
|
|
|
|
64-bit Timers
|
|
|
|
|
=============
|
|
|
|
|
|
|
|
|
|
ESP32 has 4 generic timers of 64 bits (2 from Group 0 and 2 from Group 1). They're
|
|
|
|
|
acessible as character drivers, the configuration along with a guidance on how
|
|
|
|
|
to run the example and the description of the application level interface can be found here:
|
|
|
|
|
|
2020-11-28 05:03:51 +01:00
|
|
|
|
https://nuttx.apache.org/docs/latest/components/drivers/character/timer.html
|
2020-11-05 13:35:51 +01:00
|
|
|
|
|
|
|
|
|
Watchdog Timers
|
|
|
|
|
===============
|
|
|
|
|
|
2020-11-28 05:03:51 +01:00
|
|
|
|
ESP32 has 3 WDTs. 2 MWDTS from the Timers Module and 1 RWDT from the RTC Module
|
2020-11-05 13:35:51 +01:00
|
|
|
|
(Currently not supported yet). They're acessible as character drivers,
|
|
|
|
|
The configuration along with a guidance on how to run the example and the description
|
|
|
|
|
of the application level interface can be found here:
|
|
|
|
|
|
|
|
|
|
https://nuttx.apache.org/docs/latest/components/drivers/character/watchdog.html
|
|
|
|
|
|
2016-10-31 15:29:28 +01:00
|
|
|
|
SMP
|
|
|
|
|
===
|
|
|
|
|
|
|
|
|
|
The ESP32 has 2 CPUs. Support is included for testing an SMP configuration.
|
|
|
|
|
That configuration is still not yet ready for usage but can be enabled with
|
|
|
|
|
the following configuration settings:
|
|
|
|
|
|
|
|
|
|
RTOS Features -> Tasks and Scheduling
|
|
|
|
|
CONFIG_SPINLOCK=y
|
|
|
|
|
CONFIG_SMP=y
|
|
|
|
|
CONFIG_SMP_NCPUS=2
|
2016-12-24 15:55:24 +01:00
|
|
|
|
CONFIG_SMP_IDLETHREAD_STACKSIZE=3072
|
2016-10-31 15:29:28 +01:00
|
|
|
|
|
2016-12-20 17:03:48 +01:00
|
|
|
|
Debug Tip: During debug session, OpenOCD may mysteriously switch from one
|
|
|
|
|
CPU to another. This behavior can be eliminated by uncommenting one of the
|
|
|
|
|
following in scripts/esp32.cfg
|
|
|
|
|
|
|
|
|
|
# Only configure the PRO CPU
|
|
|
|
|
#set ESP32_ONLYCPU 1
|
|
|
|
|
# Only configure the APP CPU
|
|
|
|
|
#set ESP32_ONLYCPU 2
|
|
|
|
|
|
2016-10-31 15:29:28 +01:00
|
|
|
|
Open Issues:
|
|
|
|
|
|
2020-02-28 10:06:00 +01:00
|
|
|
|
1. Cache Issues. I have not thought about this yet, but certainly caching is
|
2016-10-31 15:29:28 +01:00
|
|
|
|
an issue in an SMP system:
|
|
|
|
|
|
|
|
|
|
- Cache coherency. Are there separate caches for each CPU? Or a single
|
|
|
|
|
shared cache? If the are separate then keep the caches coherent will
|
|
|
|
|
be an issue.
|
|
|
|
|
- Caching MAY interfere with spinlocks as they are currently implemented.
|
|
|
|
|
Waiting on a cached copy of the spinlock may result in a hang or a
|
|
|
|
|
failure to wait.
|
|
|
|
|
|
2017-08-13 16:14:06 +02:00
|
|
|
|
2. Assertions. On a fatal assertions, other CPUs need to be stopped.
|
2016-10-31 15:29:28 +01:00
|
|
|
|
|
2016-12-19 00:30:30 +01:00
|
|
|
|
OpenOCD for the ESP32
|
2016-11-15 00:51:50 +01:00
|
|
|
|
=====================
|
2016-11-07 18:03:01 +01:00
|
|
|
|
|
2016-11-14 18:52:33 +01:00
|
|
|
|
First you in need some debug environment which would be a JTAG emulator
|
|
|
|
|
and the ESP32 OpenOCD software which is available here:
|
|
|
|
|
https://github.com/espressif/openocd-esp32
|
2016-11-13 16:30:45 +01:00
|
|
|
|
|
2016-11-14 18:52:33 +01:00
|
|
|
|
OpenOCD Documentation
|
|
|
|
|
---------------------
|
|
|
|
|
There is on overiew of the use of OpenOCD here:
|
|
|
|
|
https://dl.espressif.com/doc/esp-idf/latest/openocd.html
|
|
|
|
|
This document is also available in ESP-IDF source tree in docs
|
|
|
|
|
directory (https://github.com/espressif/esp-idf).
|
|
|
|
|
|
|
|
|
|
OpenOCD Configuration File
|
|
|
|
|
--------------------------
|
|
|
|
|
A template ESP32 OpenOCD configuration file is provided in
|
|
|
|
|
ESP-IDF docs directory (esp32.cfg). Since you are not using
|
2016-11-14 19:54:29 +01:00
|
|
|
|
FreeRTOS, you will need to uncomment the line:
|
2016-11-14 18:52:33 +01:00
|
|
|
|
|
2016-11-14 19:54:29 +01:00
|
|
|
|
set ESP32_RTOS none
|
2016-11-14 18:52:33 +01:00
|
|
|
|
|
2016-11-14 19:54:29 +01:00
|
|
|
|
in the OpenOCD configuration file. You will also need to change
|
|
|
|
|
the source line from:
|
|
|
|
|
|
|
|
|
|
find interface/ftdi/tumpa.cfg
|
2016-11-14 18:52:33 +01:00
|
|
|
|
|
|
|
|
|
to reflect the physical JTAG adapter connected.
|
|
|
|
|
|
2016-11-14 19:54:29 +01:00
|
|
|
|
NOTE: A copy of this OpenOCD configuration file available in the NuttX
|
2019-09-20 19:57:36 +02:00
|
|
|
|
source tree at nuttx/boards/xtensa/esp32/esp32-core/scripts/esp32.cfg . It has these
|
2016-11-14 19:54:29 +01:00
|
|
|
|
modifications:
|
|
|
|
|
|
|
|
|
|
- The referenced "set ESP32_RTOS none" line has been uncommented
|
2019-01-16 20:09:52 +01:00
|
|
|
|
- The "find interface/ftdi/tumpa.cfg". This means that you will
|
2016-11-14 19:54:29 +01:00
|
|
|
|
need to specify the interface configuration file on the OpenOCD
|
|
|
|
|
command line.
|
2016-11-14 18:52:33 +01:00
|
|
|
|
|
2020-03-30 06:23:52 +02:00
|
|
|
|
NOTE: Another OpenOCD configuration file is available in the NuttX
|
|
|
|
|
source tree at
|
|
|
|
|
nuttx/boards/xtensa/esp32/esp32-core/scripts/esp32-ft232h.cfg .
|
|
|
|
|
It has been tested with:
|
|
|
|
|
|
|
|
|
|
- ESP32-DevKitC V4
|
|
|
|
|
|
|
|
|
|
https://docs.espressif.com/projects/esp-idf/en/latest/esp32/hw-reference/esp32/get-started-devkitc.html
|
|
|
|
|
|
2020-03-30 07:15:19 +02:00
|
|
|
|
- Akizukidenshi's FT232HL, a FT232H based JTAG adapter
|
2020-03-30 06:23:52 +02:00
|
|
|
|
|
|
|
|
|
http://akizukidenshi.com/catalog/g/gK-06503/
|
|
|
|
|
|
2020-03-30 07:15:19 +02:00
|
|
|
|
With JP3 and JP4 closed, and connected to ESP32 as:
|
|
|
|
|
|
|
|
|
|
---------------- -------
|
|
|
|
|
ESP32-DevKitC V4 FT232HL
|
|
|
|
|
---------------- -------
|
|
|
|
|
J2 J3 J2
|
|
|
|
|
-------- ------- -------
|
|
|
|
|
IO13 AD0 (TCK)
|
|
|
|
|
IO12 AD1 (TDI)
|
|
|
|
|
IO15 AD2 (TDO)
|
|
|
|
|
IO14 AD3 (TMS)
|
|
|
|
|
GND GND
|
|
|
|
|
-------- ------- -------
|
|
|
|
|
|
2020-03-30 06:23:52 +02:00
|
|
|
|
- The following version of OpenOCD from ESP-IDF (macOS version)
|
|
|
|
|
|
|
|
|
|
% openocd --version
|
|
|
|
|
Open On-Chip Debugger v0.10.0-esp32-20191114 (2019-11-14-14:19)
|
|
|
|
|
Licensed under GNU GPL v2
|
|
|
|
|
For bug reports, read
|
|
|
|
|
http://openocd.org/doc/doxygen/bugs.html
|
|
|
|
|
%
|
|
|
|
|
|
2016-11-14 18:52:33 +01:00
|
|
|
|
General OpenOCD build instructions
|
|
|
|
|
----------------------------------
|
|
|
|
|
Installing OpenOCD. The sources for the ESP32-enabled variant of
|
|
|
|
|
OpenOCD are available from Espressifs Github. To download the source,
|
|
|
|
|
use the following commands:
|
|
|
|
|
|
|
|
|
|
git clone https://github.com/espressif/openocd-esp32.git
|
|
|
|
|
cd openocd-esp32
|
|
|
|
|
git submodule init
|
|
|
|
|
git submodule update
|
|
|
|
|
|
2016-11-14 19:54:29 +01:00
|
|
|
|
Then look at the README and the docs/INSTALL.txt files in the
|
|
|
|
|
openocd-esp32 directory for further instructions. There area
|
2018-06-01 21:25:50 +02:00
|
|
|
|
separate README files for Linux/Cygwin, macOS, and Windows. Here
|
2016-11-14 19:54:29 +01:00
|
|
|
|
is what I ended up doing (under Linux):
|
|
|
|
|
|
|
|
|
|
cd openocd-esp32
|
|
|
|
|
./bootstrap
|
|
|
|
|
./configure
|
|
|
|
|
make
|
|
|
|
|
|
|
|
|
|
If you do not do the install step, then you will have a localhost
|
|
|
|
|
version of the OpenOCD binary at openocd-esp32/src.
|
2016-11-14 18:52:33 +01:00
|
|
|
|
|
2016-11-15 20:25:30 +01:00
|
|
|
|
Starting the OpenOCD Server
|
|
|
|
|
---------------------------
|
2016-11-14 18:52:33 +01:00
|
|
|
|
|
2016-11-14 19:54:29 +01:00
|
|
|
|
- cd to openocd-esp32 directory
|
|
|
|
|
- copy the modified esp32.cfg script to this directory
|
|
|
|
|
|
|
|
|
|
Then start OpenOCD by executing a command like the following. Here
|
|
|
|
|
I assume that:
|
|
|
|
|
|
2019-01-16 20:09:52 +01:00
|
|
|
|
- You did not install OpenOCD; binaries are available at
|
2016-11-14 19:54:29 +01:00
|
|
|
|
openocd-esp32/src and interface scripts are in
|
|
|
|
|
openocd-eps32/tcl/interface
|
|
|
|
|
- I select the configuration for the Olimex ARM-USB-OCD
|
|
|
|
|
debugger.
|
|
|
|
|
|
|
|
|
|
Then the command to start OpenOCD is:
|
|
|
|
|
|
|
|
|
|
sudo ./src/openocd -s ./tcl -f tcl/interface/ftdi/olimex-arm-usb-ocd.cfg -f ./esp32.cfg
|
2016-11-14 18:52:33 +01:00
|
|
|
|
|
2016-11-14 20:29:08 +01:00
|
|
|
|
I then see:
|
|
|
|
|
|
|
|
|
|
Open On-Chip Debugger 0.10.0-dev-g3098897 (2016-11-14-12:19)
|
|
|
|
|
Licensed under GNU GPL v2
|
|
|
|
|
For bug reports, read
|
|
|
|
|
http://openocd.org/doc/doxygen/bugs.html
|
|
|
|
|
adapter speed: 200 kHz
|
|
|
|
|
force hard breakpoints
|
|
|
|
|
Info : clock speed 200 kHz
|
|
|
|
|
Info : JTAG tap: esp32.cpu0 tap/device found: 0x120034e5 (mfg: 0x272 (Tensilica), part: 0x2003, ver: 0x1)
|
|
|
|
|
Info : JTAG tap: esp32.cpu1 tap/device found: 0x120034e5 (mfg: 0x272 (Tensilica), part: 0x2003, ver: 0x1)
|
|
|
|
|
Info : esp32.cpu0: Debug controller was reset (pwrstat=0x5F, after clear 0x0F).
|
|
|
|
|
Info : esp32.cpu0: Core was reset (pwrstat=0x5F, after clear 0x0F).
|
|
|
|
|
|
2016-11-14 18:52:33 +01:00
|
|
|
|
Connecting a debugger to OpenOCD
|
|
|
|
|
--------------------------------
|
|
|
|
|
OpenOCD should now be ready to accept gdb connections. If you have
|
|
|
|
|
compiled the ESP32 toolchain using Crosstool-NG, or if you have
|
|
|
|
|
downloaded a precompiled toolchain from the Espressif website, you
|
|
|
|
|
should already have xtensa-esp32-elf-gdb, a version of gdb that can
|
|
|
|
|
be used for this
|
|
|
|
|
|
|
|
|
|
First, make sure the project you want to debug is compiled and
|
|
|
|
|
flashed into the ESP32’s SPI flash. Then, in a different console
|
|
|
|
|
than OpenOCD is running in, invoke gdb. For example, for the
|
|
|
|
|
template app, you would do this like such:
|
|
|
|
|
|
2016-11-14 20:41:30 +01:00
|
|
|
|
cd nuttx
|
|
|
|
|
xtensa-esp32-elf-gdb -ex 'target remote localhost:3333' nuttx
|
2016-11-14 20:29:08 +01:00
|
|
|
|
|
|
|
|
|
This should give you a gdb prompt.
|
2016-11-14 18:52:33 +01:00
|
|
|
|
|
2016-11-15 00:51:50 +01:00
|
|
|
|
Breakpoints
|
|
|
|
|
-----------
|
|
|
|
|
You can set up to 2 hardware breakpoints, which can be anywhere in the
|
|
|
|
|
address space. Also 2 hardware watchpoints.
|
|
|
|
|
|
|
|
|
|
The openocd esp32.cfg file currently forces gdb to use hardware
|
|
|
|
|
breakpoints, I believe because software breakpoints (or, at least, the
|
|
|
|
|
memory map for automatically choosing them) aren't implemented yet
|
|
|
|
|
(as of 2016-11-14).
|
|
|
|
|
|
2016-11-14 18:52:33 +01:00
|
|
|
|
JTAG Emulator
|
|
|
|
|
-------------
|
|
|
|
|
The documentation indicates that you need to use an external JTAG
|
|
|
|
|
like the TIAO USB Multi-protocol Adapter and the Flyswatter2.
|
|
|
|
|
The instructions at http://www.esp32.com/viewtopic.php?t=381 show
|
|
|
|
|
use of an FTDI C232HM-DDHSL-0 USB 2.0 high speed to MPSSE cable.
|
|
|
|
|
|
|
|
|
|
The ESP32 Core v2 board has no on board JTAG connector. It will
|
|
|
|
|
be necessary to make a cable or some other board to connect a JTAG
|
|
|
|
|
emulator. Refer to http://www.esp32.com/viewtopic.php?t=381 "How
|
|
|
|
|
to debug ESP32 with JTAG / OpenOCD / GDB 1st part connect the
|
|
|
|
|
hardware."
|
|
|
|
|
|
|
|
|
|
Relevant pin-out:
|
|
|
|
|
|
|
|
|
|
-------- ----------
|
|
|
|
|
PIN JTAG
|
|
|
|
|
LABEL FUNCTION
|
|
|
|
|
-------- ----------
|
|
|
|
|
IO14 TMS
|
|
|
|
|
IO12 TDI
|
|
|
|
|
GND GND
|
|
|
|
|
IO13 TCK
|
|
|
|
|
-------- ----------
|
|
|
|
|
IO15 TDO
|
|
|
|
|
-------- ----------
|
|
|
|
|
|
|
|
|
|
You can find the mapping of JTAG signals to ESP32 GPIO numbers in
|
|
|
|
|
"ESP32 Pin List" document found here:
|
|
|
|
|
http://espressif.com/en/support/download/documents?keys=&field_type_tid%5B%5D=13
|
|
|
|
|
|
|
|
|
|
I put the ESP32 on a prototyping board and used a standard JTAG 20-pin
|
|
|
|
|
connector with an older Olimex JTAG that I had. Here is how I wired
|
|
|
|
|
the 20-pin connector:
|
|
|
|
|
|
|
|
|
|
----------------- ----------
|
|
|
|
|
20-PIN JTAG ESP32 PIN
|
|
|
|
|
CONNECTOR LABEL
|
|
|
|
|
----------------- ----------
|
|
|
|
|
1 VREF INPUT 3V3
|
|
|
|
|
3 nTRST OUTPUT N/C
|
|
|
|
|
5 TDI OUTPUT IO12
|
|
|
|
|
7 TMS OUTPUT IO14
|
|
|
|
|
9 TCLK OUTPUT IO13
|
|
|
|
|
11 RTCK INPUT N/C
|
|
|
|
|
13 TDO INPUT IO15
|
|
|
|
|
15 RESET I/O N/C
|
|
|
|
|
17 DBGRQ OUTPUT N/C
|
|
|
|
|
19 5V OUTPUT N/C
|
|
|
|
|
------------ ----------
|
|
|
|
|
2 VCC INPUT 3V3
|
|
|
|
|
4 GND N/A GND
|
|
|
|
|
6 GND N/A GND
|
|
|
|
|
8 GND N/A GND
|
|
|
|
|
10 GND N/A GND
|
|
|
|
|
12 GND N/A GND
|
|
|
|
|
14 GND N/A GND
|
|
|
|
|
16 GND N/A GND
|
|
|
|
|
18 GND N/A GND
|
|
|
|
|
20 GND N/A GND
|
|
|
|
|
------------ ----------
|
|
|
|
|
|
2016-11-15 00:51:50 +01:00
|
|
|
|
Executing and Debugging from FLASH and IRAM
|
|
|
|
|
===========================================
|
|
|
|
|
|
2016-11-15 20:25:30 +01:00
|
|
|
|
Enable Debug Symbols
|
|
|
|
|
--------------------
|
|
|
|
|
To debug with GDB, you will need to enable symbols in the build. You do this
|
|
|
|
|
with 'make menuconfig' then selecting:
|
|
|
|
|
|
|
|
|
|
- "Build Setup" -> "Debug Options" -> "Generate Debug Symbols"
|
|
|
|
|
|
|
|
|
|
And, to make debugging easier, also disable optimizations. This will make
|
|
|
|
|
your code a lot bigger:
|
|
|
|
|
|
|
|
|
|
- "Build Setup" -> "Optimization Level" -> "Suppress Optimization"
|
|
|
|
|
|
2016-11-15 00:51:50 +01:00
|
|
|
|
FLASH
|
|
|
|
|
-----
|
|
|
|
|
OpenOCD currently doesn't have a FLASH driver for ESP32, so you can load
|
|
|
|
|
code into IRAM only via JTAG. FLASH-resident sections like .FLASH.rodata
|
2020-02-26 17:04:12 +01:00
|
|
|
|
will fail to load. The bootloader in ROM doesn't parse ELF, so any image
|
2016-11-15 00:51:50 +01:00
|
|
|
|
which is bootloaded from FLASH has to be converted into a custom image
|
|
|
|
|
format first.
|
|
|
|
|
|
|
|
|
|
The tool esp-idf uses for flashing is a command line Python tool called
|
|
|
|
|
"esptool.py" which talks to a serial bootloader in ROM. A version is
|
|
|
|
|
supplied in the esp-idf codebase in components/esptool_py/esptool, the
|
2019-01-16 20:09:52 +01:00
|
|
|
|
"upstream" for that tool is here and now supports ESP32.
|
2016-11-15 00:51:50 +01:00
|
|
|
|
|
2019-01-16 20:09:52 +01:00
|
|
|
|
https://github.com/espressif/esptool/
|
2016-11-14 18:52:33 +01:00
|
|
|
|
|
2016-11-15 00:51:50 +01:00
|
|
|
|
To FLASH an ELF via the command line is a two step process, something like
|
|
|
|
|
this:
|
2016-11-14 18:52:33 +01:00
|
|
|
|
|
2019-01-16 20:09:52 +01:00
|
|
|
|
esptool.py --chip esp32 elf2image --flash_mode dio --flash_size 4MB -o nuttx.bin nuttx
|
2020-03-18 07:50:24 +01:00
|
|
|
|
esptool.py --chip esp32 --port COMx write_flash 0x1000 bootloader.bin 0x8000 partition_table.bin 0x10000 nuttx.bin
|
2016-11-15 00:51:50 +01:00
|
|
|
|
|
|
|
|
|
The first step converts an ELF image into an ESP32-compatible binary
|
|
|
|
|
image format, and the second step flashes it (along with bootloader image and
|
|
|
|
|
partition table binary.)
|
2020-03-18 07:50:24 +01:00
|
|
|
|
The offset for the partition table may vary, depending on ESP-IDF
|
|
|
|
|
configuration, CONFIG_PARTITION_TABLE_OFFSET, which is by default 0x8000
|
|
|
|
|
as of writing this.
|
2016-11-15 00:51:50 +01:00
|
|
|
|
|
|
|
|
|
To put the ESP32 into serial flashing mode, it needs to be reset with IO0 held
|
|
|
|
|
low. On the Core boards this can be accomplished by holding the button marked
|
|
|
|
|
"Boot" and pressing then releasing the button marked "EN". Actually, esptool.py
|
|
|
|
|
can enter bootloader mode automatically (via RTS/DTR control lines), but
|
|
|
|
|
unfortunately a timing interaction between the Windows CP2012 driver and the
|
|
|
|
|
hardware means this doesn't currently work on Windows.
|
|
|
|
|
|
|
|
|
|
Secondary Boot Loader / Partition Table
|
|
|
|
|
---------------------------------------
|
2016-11-14 18:52:33 +01:00
|
|
|
|
See https://github.com/espressif/esp-idf/tree/master/components/bootloader
|
2019-01-16 20:09:52 +01:00
|
|
|
|
and https://github.com/espressif/esp-idf/tree/master/components/partition_table .
|
2016-11-14 18:52:33 +01:00
|
|
|
|
|
2020-03-16 15:19:59 +01:00
|
|
|
|
The secondary boot loader by default programs a RTC watchdog timer.
|
|
|
|
|
As NuttX doesn't know the timer, it reboots every ~9 seconds. You can
|
|
|
|
|
disable the timer by tweaking sdkconfig CONFIG_BOOTLOADER_WDT_ENABLE
|
|
|
|
|
and rebuild the boot loader.
|
|
|
|
|
|
2016-12-24 17:25:54 +01:00
|
|
|
|
Running from IRAM with OpenOCD
|
|
|
|
|
------------------------------
|
2016-12-19 00:30:30 +01:00
|
|
|
|
Running from IRAM is a good debug option. You should be able to load the
|
2016-12-24 17:25:54 +01:00
|
|
|
|
ELF directly via JTAG in this case, and you may not need the bootloader.
|
|
|
|
|
|
|
|
|
|
NuttX supports a configuration option, CONFIG_ESP32CORE_RUN_IRAM, that may be
|
|
|
|
|
selected for execution from IRAM. This option simply selects the correct
|
|
|
|
|
linker script for IRAM execution.
|
2016-11-15 00:51:50 +01:00
|
|
|
|
|
2016-12-24 17:25:54 +01:00
|
|
|
|
Skipping the Secondary Bootloader
|
|
|
|
|
---------------------------------
|
2016-11-13 16:30:45 +01:00
|
|
|
|
It is possible to skip the secondary bootloader and run out of IRAM using
|
|
|
|
|
only the primary bootloader if your application of small enough (< 128KiB code,
|
|
|
|
|
<180KiB data), then you can simplify initial bring-up by avoiding second stage
|
|
|
|
|
bootloader. Your application will be loaded into IRAM using first stage
|
|
|
|
|
bootloader present in ESP32 ROM. To achieve this, you need two things:
|
|
|
|
|
|
2016-11-15 00:51:50 +01:00
|
|
|
|
1. Have a linker script which places all code into IRAM and all data into
|
|
|
|
|
IRAM/DRAM
|
2016-11-13 16:30:45 +01:00
|
|
|
|
|
2016-11-15 00:51:50 +01:00
|
|
|
|
2. Use "esptool.py" utility found in ESP-IDF to convert application .elf
|
|
|
|
|
file into binary format which can be loaded by first stage bootloader.
|
2016-11-13 16:30:45 +01:00
|
|
|
|
|
2016-11-15 00:51:50 +01:00
|
|
|
|
Again you would need to link the ELF file and convert it to binary format suitable
|
|
|
|
|
for flashing into the board. The command should to convert ELF file to binary
|
|
|
|
|
image looks as follows:
|
2016-11-13 16:30:45 +01:00
|
|
|
|
|
2016-11-15 20:25:30 +01:00
|
|
|
|
python esp-idf/components/esptool_py/esptool/esptool.py --chip esp32 elf2image --flash_mode "dio" --flash_freq "40m" --flash_size "2MB" -o nuttx.bin nuttx
|
2016-11-13 16:30:45 +01:00
|
|
|
|
|
|
|
|
|
To flash binary image to your development board, use the same esptool.py utility:
|
|
|
|
|
|
2016-11-15 20:25:30 +01:00
|
|
|
|
python esp-idf/components/esptool_py/esptool/esptool.py --chip esp32 --port /dev/ttyUSB0 --baud 921600 write_flash -z --flash_mode dio --flash_freq 40m --flash_size 2MB 0x1000 nuttx.bin
|
2016-11-13 16:30:45 +01:00
|
|
|
|
|
|
|
|
|
The argument before app.bin (0x1000) indicates the offset in flash where binary
|
|
|
|
|
will be written. ROM bootloader expects to find an application (or second stage
|
|
|
|
|
bootloader) image at offset 0x1000, so we are writing the binary there.
|
2016-11-07 18:03:01 +01:00
|
|
|
|
|
2016-11-14 18:52:33 +01:00
|
|
|
|
Clocking
|
|
|
|
|
--------
|
2016-11-07 18:03:01 +01:00
|
|
|
|
Right now, the NuttX port depends on the bootloader to initialize hardware,
|
|
|
|
|
including basic (slow) clocking. If I had the clock configuration logic,
|
|
|
|
|
would I be able to run directly out of IRAM without a bootloader? That
|
|
|
|
|
might be a simpler bring-up.
|
|
|
|
|
|
2016-12-24 17:25:54 +01:00
|
|
|
|
Sample OpenOCD Debug Steps
|
|
|
|
|
--------------------------
|
2016-12-14 19:34:11 +01:00
|
|
|
|
I did the initial bring-up using the IRAM configuration and OpenOCD. Here
|
|
|
|
|
is a synopsis of my debug steps:
|
|
|
|
|
|
2019-08-09 15:22:39 +02:00
|
|
|
|
boards/xtensa/esp32/esp32-core/configs/nsh with
|
2016-12-14 19:34:11 +01:00
|
|
|
|
|
|
|
|
|
CONFIG_DEBUG_ASSERTIONS=y
|
|
|
|
|
CONFIG_DEBUG_FEATURES=y
|
|
|
|
|
CONFIG_DEBUG_SYMBOLS=y
|
|
|
|
|
CONFIG_ESP32CORE_RUN_IRAM=y
|
|
|
|
|
|
2018-08-19 23:38:06 +02:00
|
|
|
|
I also made this change configuration which will eliminate all attempts to
|
|
|
|
|
re-configure serial. It will just use the serial settings as they were left
|
|
|
|
|
by the bootloader:
|
|
|
|
|
|
|
|
|
|
CONFIG_SUPPRESS_UART_CONFIG=y
|
2016-12-14 19:34:11 +01:00
|
|
|
|
|
|
|
|
|
Start OpenOCD:
|
|
|
|
|
|
|
|
|
|
cd ../openocde-esp32
|
2019-08-09 15:22:39 +02:00
|
|
|
|
cp ../nuttx/boards/xtensa/esp32/esp32-core/scripts/esp32.cfg .
|
2016-12-14 19:34:11 +01:00
|
|
|
|
sudo ./src/openocd -s ./tcl/ -f tcl/interface/ftdi/olimex-arm-usb-ocd.cfg -f ./esp32.cfg
|
|
|
|
|
|
|
|
|
|
Start GDB and load code:
|
|
|
|
|
|
|
|
|
|
cd ../nuttx
|
|
|
|
|
xtensa-esp32-elf-gdb -ex 'target remote localhost:3333' nuttx
|
|
|
|
|
(gdb) load nuttx
|
|
|
|
|
(gdb) mon reg pc [value report by load for entry point]
|
|
|
|
|
(gdb) s
|
|
|
|
|
|
2016-12-14 21:57:43 +01:00
|
|
|
|
Single stepping works fine for me as do breakpoints:
|
2016-12-14 19:34:11 +01:00
|
|
|
|
|
2020-02-07 08:14:06 +01:00
|
|
|
|
Breakpoint 1, up_timer_initialize () at chip/esp32_timerisr.c:172
|
2016-12-14 19:34:11 +01:00
|
|
|
|
72 {
|
|
|
|
|
(gdb) n
|
|
|
|
|
esp32.cpu0: Target halted, pc=0x400835BF
|
|
|
|
|
187 g_tick_divisor = divisor;
|
|
|
|
|
(gdb) ...
|
2017-06-28 21:18:41 +02:00
|
|
|
|
|
2016-10-15 22:57:06 +02:00
|
|
|
|
Configurations
|
|
|
|
|
==============
|
|
|
|
|
|
|
|
|
|
Common Configuration Information
|
|
|
|
|
--------------------------------
|
|
|
|
|
Each ESP32 core configuration is maintained in sub-directories and
|
|
|
|
|
can be selected as follow:
|
|
|
|
|
|
2019-08-06 00:53:39 +02:00
|
|
|
|
tools/configure.sh esp32-core:<subdir>
|
2016-10-15 22:57:06 +02:00
|
|
|
|
make oldconfig
|
|
|
|
|
|
2017-04-26 18:12:13 +02:00
|
|
|
|
Before building, make sure the PATH environment variable includes the
|
|
|
|
|
correct path to the directory than holds your toolchain binaries.
|
2016-10-15 22:57:06 +02:00
|
|
|
|
|
|
|
|
|
If this is a Windows native build, then configure.bat should be used
|
|
|
|
|
instead of configure.sh:
|
|
|
|
|
|
|
|
|
|
configure.bat esp32-core\<subdir>
|
|
|
|
|
|
|
|
|
|
And then build NuttX by simply typing the following. At the conclusion of
|
|
|
|
|
the make, the nuttx binary will reside in an ELF file called, simply,
|
|
|
|
|
nuttx.
|
|
|
|
|
|
|
|
|
|
make oldconfig
|
|
|
|
|
make
|
|
|
|
|
|
|
|
|
|
The <subdir> that is provided above as an argument to the
|
|
|
|
|
tools/configure.sh must be is one of the directories listed below.
|
|
|
|
|
|
|
|
|
|
NOTES:
|
|
|
|
|
|
|
|
|
|
1. These configurations use the mconf-based configuration tool. To
|
|
|
|
|
change any of these configurations using that tool, you should:
|
|
|
|
|
|
2016-11-15 14:28:37 +01:00
|
|
|
|
a. Build and install the kconfig-mconf tool. See nuttx/README.txt
|
|
|
|
|
see additional README.txt files in the NuttX tools repository.
|
2016-10-15 22:57:06 +02:00
|
|
|
|
|
2016-11-15 14:28:37 +01:00
|
|
|
|
b. Execute 'make menuconfig' in nuttx/ in order to start the
|
|
|
|
|
reconfiguration process.
|
2016-10-15 22:57:06 +02:00
|
|
|
|
|
|
|
|
|
2. Unless stated otherwise, all configurations generate console
|
2016-11-15 14:28:37 +01:00
|
|
|
|
output on UART0 (see the "Serial Console" section above).
|
|
|
|
|
|
|
|
|
|
3. By default, these configurations assume a 40MHz crystal on-
|
|
|
|
|
board:
|
|
|
|
|
|
|
|
|
|
CONFIG_ESP32CORE_XTAL_40MZ=y
|
|
|
|
|
# CONFIG_ESP32CORE_XTAL_26MHz is not set
|
|
|
|
|
|
|
|
|
|
4. Default configurations are set to run from FLASH. You will need
|
|
|
|
|
to set CONFIG_ESP32CORE_RUN_IRAM=y for now (see the " Executing
|
|
|
|
|
and Debugging from FLASH and IRAM" section above).
|
2016-10-15 22:57:06 +02:00
|
|
|
|
|
2016-11-15 20:25:30 +01:00
|
|
|
|
To select this option, do 'make menuconfig'. Then you can find
|
|
|
|
|
the selection under the "Board Selection" menu as "Run from IRAM".
|
|
|
|
|
|
2016-10-15 22:57:06 +02:00
|
|
|
|
Configuration sub-directories
|
|
|
|
|
-----------------------------
|
|
|
|
|
|
|
|
|
|
nsh:
|
|
|
|
|
|
|
|
|
|
Configures the NuttShell (nsh) located at apps/examples/nsh.
|
|
|
|
|
|
|
|
|
|
NOTES:
|
2016-10-29 22:56:07 +02:00
|
|
|
|
|
2016-12-20 16:00:04 +01:00
|
|
|
|
1. Uses the CP2102 USB/Serial converter for the serial console.
|
|
|
|
|
|
|
|
|
|
2. I have only tested this in IRAM with UART reconfiguration disabled.
|
|
|
|
|
See "Sample Debug Steps". In that case, NuttX is started via GDB.
|
|
|
|
|
It has, however, been reported to me that this configuration also
|
|
|
|
|
runs when written to address 0x1000 of FLASH with the esptool.py
|
|
|
|
|
(as described above). Then NuttX is started via the second level
|
|
|
|
|
bootloader. I cannot vouch for that since I have never tried it.
|
|
|
|
|
|
|
|
|
|
3. There are open clocking issues. Currently clock configuration
|
|
|
|
|
logic is disabled because I don't have the technical information
|
|
|
|
|
to provide that logic -- hopefully that is coming. As a
|
|
|
|
|
consequence, whatever clock setup was left when NuttX started is
|
|
|
|
|
used. For the case of execution out of IRAM with GDB, the
|
2019-08-09 15:22:39 +02:00
|
|
|
|
settings in boards/xtensa/esp32/esp32-core/include/board.h work.
|
|
|
|
|
To check the timing, I use a stop watch and:
|
2016-12-20 16:00:04 +01:00
|
|
|
|
|
|
|
|
|
nsh> sleep 60
|
|
|
|
|
|
|
|
|
|
If the timing is correct in the board.h header file, the value
|
|
|
|
|
timed with the stop watch should be about 60 seconds. If not,
|
|
|
|
|
change the frequency in the board.h header file.
|
|
|
|
|
|
2016-10-29 22:56:07 +02:00
|
|
|
|
smp:
|
|
|
|
|
|
|
|
|
|
Another NSH configuration, similar to nsh, but also enables
|
2016-12-22 15:20:05 +01:00
|
|
|
|
SMP operation. It differs from the nsh configuration only in these
|
2020-02-22 19:31:14 +01:00
|
|
|
|
additional settings:
|
2016-12-22 15:20:05 +01:00
|
|
|
|
|
2016-12-22 16:34:39 +01:00
|
|
|
|
SMP is enabled:
|
2016-12-22 15:20:05 +01:00
|
|
|
|
|
|
|
|
|
CONFIG_SMP=y
|
2016-12-24 15:55:24 +01:00
|
|
|
|
CONFIG_SMP_IDLETHREAD_STACKSIZE=3072
|
2016-12-22 15:20:05 +01:00
|
|
|
|
CONFIG_SMP_NCPUS=2
|
|
|
|
|
CONFIG_SPINLOCK=y
|
|
|
|
|
|
2019-01-23 21:39:10 +01:00
|
|
|
|
The apps/testing/smp test is included:
|
2016-12-22 16:34:39 +01:00
|
|
|
|
|
2019-01-23 21:39:10 +01:00
|
|
|
|
CONFIG_TESTING_SMP=y
|
|
|
|
|
CONFIG_TESTING_SMP_NBARRIER_THREADS=8
|
|
|
|
|
CONFIG_TESTING_SMP_PRIORITY=100
|
|
|
|
|
CONFIG_TESTING_SMP_STACKSIZE=2048
|
2016-12-22 16:34:39 +01:00
|
|
|
|
|
2016-12-22 15:20:05 +01:00
|
|
|
|
NOTES:
|
2016-12-22 16:34:39 +01:00
|
|
|
|
1. See NOTES for the nsh configuration.
|
2016-12-22 15:20:05 +01:00
|
|
|
|
|
|
|
|
|
ostest:
|
|
|
|
|
|
|
|
|
|
This is the NuttX test at apps/examples/ostest that is run against all new
|
|
|
|
|
architecture ports to assure a correct implementation of the OS. The default
|
|
|
|
|
version is for a single CPU but can be modified for an SMP test by adding:
|
|
|
|
|
|
|
|
|
|
CONFIG_SMP=y
|
|
|
|
|
CONFIG_SMP_IDLETHREAD_STACKSIZE=2048
|
|
|
|
|
CONFIG_SMP_NCPUS=2
|
|
|
|
|
CONFIG_SPINLOCK=y
|
2016-10-29 22:56:07 +02:00
|
|
|
|
|
|
|
|
|
NOTES:
|
2016-12-22 16:34:39 +01:00
|
|
|
|
1. See NOTES for the nsh configuration.
|
2016-12-22 18:19:38 +01:00
|
|
|
|
2. 2016-12-23: Test appears to be fully functional in the single CPU mode.
|
2016-12-24 17:25:54 +01:00
|
|
|
|
3. 2016-12-24: But when SMP is enabled, there is a consistent, repeatable
|
|
|
|
|
crash in the waitpid() test. At the time of the crash, there is
|
2019-10-08 16:01:30 +02:00
|
|
|
|
extensive memory corruption and a user exception occurs (cause=28).
|
2016-11-01 22:12:30 +01:00
|
|
|
|
|
2020-09-04 00:05:55 +02:00
|
|
|
|
mmcsdspi:
|
|
|
|
|
|
|
|
|
|
This config tests the SPI driver by connecting an SD Card reader over SPI.
|
|
|
|
|
SPI2 is used and kept with the default IOMUX pins, i.e.:
|
|
|
|
|
CS --> 15
|
|
|
|
|
SCK --> 14
|
|
|
|
|
MOSI --> 13
|
|
|
|
|
MISO --> 12
|
|
|
|
|
Once booted the following command is used to mount a FAT file system:
|
|
|
|
|
mount -t vfat /dev/mmcsd0 /mnt
|
|
|
|
|
|
2020-09-11 14:05:43 +02:00
|
|
|
|
spiflash:
|
|
|
|
|
|
|
|
|
|
This config tests the external SPI that comes with an ESP32 module connected
|
|
|
|
|
through SPI1.
|
|
|
|
|
|
|
|
|
|
By default a SmartFS file system is selected.
|
|
|
|
|
Once booted you can use the following commands to mount the file system:
|
|
|
|
|
mksmartfs /dev/smart0
|
|
|
|
|
mount -t smartfs /dev/smart0 /mnt
|
|
|
|
|
|
|
|
|
|
Note that mksmartfs is only needed the first time.
|
|
|
|
|
|
2020-10-08 21:27:36 +02:00
|
|
|
|
psram:
|
|
|
|
|
|
|
|
|
|
This config tests the PSRAM driver over SPIRAM interface.
|
|
|
|
|
You can use the ramtest command to test the PSRAM memory. We are testing
|
|
|
|
|
only 64KB on this example (64 * 1024), but you can change this number to
|
|
|
|
|
2MB or 4MB depending on PSRAM chip used on your board:
|
|
|
|
|
|
|
|
|
|
nsh> ramtest -w 0x3F800000 65536
|
2020-11-28 05:03:51 +01:00
|
|
|
|
RAMTest: Marching ones: 3f800000 65536
|
|
|
|
|
RAMTest: Marching zeroes: 3f800000 65536
|
2020-10-08 21:27:36 +02:00
|
|
|
|
RAMTest: Pattern test: 3f800000 65536 55555555 aaaaaaaa
|
2020-11-28 05:03:51 +01:00
|
|
|
|
RAMTest: Pattern test: 3f800000 65536 66666666 99999999
|
|
|
|
|
RAMTest: Pattern test: 3f800000 65536 33333333 cccccccc
|
2020-10-08 21:27:36 +02:00
|
|
|
|
RAMTest: Address-in-address test: 3f800000 65536
|
|
|
|
|
|
2020-11-05 13:35:51 +01:00
|
|
|
|
timer:
|
|
|
|
|
|
|
|
|
|
This config test the general use purpose timers. It includes the 4 timers,
|
|
|
|
|
adds driver support, registers the timers as devices and includes the timer
|
2020-11-28 05:03:51 +01:00
|
|
|
|
example.
|
2020-11-05 13:35:51 +01:00
|
|
|
|
|
|
|
|
|
To test it, just run the following:
|
|
|
|
|
|
|
|
|
|
`nsh> timer -d /dev/timerx`
|
|
|
|
|
|
2020-11-28 05:03:51 +01:00
|
|
|
|
Where x in the timer instance.
|
2020-11-05 13:35:51 +01:00
|
|
|
|
|
|
|
|
|
watchdog:
|
|
|
|
|
|
|
|
|
|
This config test the watchdog timers. It includes the 2 MWDTS,
|
|
|
|
|
adds driver support, registers the WDTs as devices and includes the watchdog
|
2020-11-28 05:03:51 +01:00
|
|
|
|
example.
|
2020-11-05 13:35:51 +01:00
|
|
|
|
|
|
|
|
|
To test it, just run the following:
|
|
|
|
|
|
|
|
|
|
`nsh> wdog -d /dev/watchdogx`
|
|
|
|
|
|
2020-11-28 05:03:51 +01:00
|
|
|
|
Where x in the watchdog instance.
|
2020-11-05 13:35:51 +01:00
|
|
|
|
|
2016-11-01 22:12:30 +01:00
|
|
|
|
Things to Do
|
|
|
|
|
============
|
|
|
|
|
|
|
|
|
|
1. There is no support for an interrupt stack yet.
|
2016-11-13 14:55:34 +01:00
|
|
|
|
|
2019-08-04 22:50:28 +02:00
|
|
|
|
2. There is no clock initialization logic in place. This depends on logic in
|
2020-04-08 14:45:35 +02:00
|
|
|
|
Espressif libraries. The board comes up using that basic 40 MHz crystal
|
2016-11-07 18:03:01 +01:00
|
|
|
|
for clocking. Getting to 80 MHz will require clocking initialization in
|
|
|
|
|
esp32_clockconfig.c.
|
2016-11-13 14:55:34 +01:00
|
|
|
|
|
2016-11-07 18:03:01 +01:00
|
|
|
|
3. I did not implement the lazy co-processor save logic supported by Xtensa.
|
|
|
|
|
That logic works like this:
|
|
|
|
|
|
|
|
|
|
a. CPENABLE is set to zero on each context switch, disabling all co-
|
|
|
|
|
processors.
|
|
|
|
|
b. If/when the task attempts to use the disabled co-processor, an
|
|
|
|
|
exception occurs
|
2016-11-01 22:12:30 +01:00
|
|
|
|
c. The co-processor exception handler re-enables the co-processor.
|
|
|
|
|
|
2016-11-07 18:03:01 +01:00
|
|
|
|
Instead, the NuttX logic saves and restores CPENABLE on each context
|
2016-11-13 14:55:34 +01:00
|
|
|
|
switch. This has disadvantages in that (1) co-processor context will
|
|
|
|
|
be saved and restored even if the co-processor was never used, and (2)
|
|
|
|
|
tasks must explicitly enable and disable co-processors.
|
2016-11-07 18:03:01 +01:00
|
|
|
|
|
|
|
|
|
4. Currently the Xtensa port copies register state save information from
|
|
|
|
|
the stack into the TCB. A more efficient alternative would be to just
|
|
|
|
|
save a pointer to a register state save area in the TCB. This would
|
2017-05-11 21:35:56 +02:00
|
|
|
|
add some complexity to signal handling and also also the
|
2016-11-07 18:03:01 +01:00
|
|
|
|
up_initialstate(). But the performance improvement might be worth
|
|
|
|
|
the effort.
|
2016-11-01 22:12:30 +01:00
|
|
|
|
|
2016-11-07 18:03:01 +01:00
|
|
|
|
5. See SMP-related issues above
|
2016-11-01 22:12:30 +01:00
|
|
|
|
|
2016-11-15 00:51:50 +01:00
|
|
|
|
6. See OpenOCD for the ESP32 above
|
2016-12-22 16:34:39 +01:00
|
|
|
|
|
|
|
|
|
7. Currently will not boot unless serial port initialization is disabled.
|
|
|
|
|
This will use the serial port settings as left by the preceding
|
|
|
|
|
bootloader:
|
|
|
|
|
|
2018-08-19 23:38:06 +02:00
|
|
|
|
I also made this change configuration which will eliminate all attempts to
|
|
|
|
|
re-configure serial. It will just use the serial settings as they were left
|
|
|
|
|
by the bootloader:
|
|
|
|
|
|
|
|
|
|
CONFIG_SUPPRESS_UART_CONFIG=y
|
2016-12-22 16:34:39 +01:00
|
|
|
|
|
|
|
|
|
I have not debugged this in detail, but this appears to be an issue with the
|
2020-02-23 09:50:23 +01:00
|
|
|
|
implementation of esp32_configgpio() and/or gpio_matrix_out() when called from
|
2016-12-22 16:34:39 +01:00
|
|
|
|
the setup logic in arch/xtensa/src/esp32/esp32_serial.c. I am not inclined
|
|
|
|
|
to invest a lot in driver debug until the clock configuration is finalized.
|
2017-08-13 16:14:06 +02:00
|
|
|
|
|
|
|
|
|
UPDATE: This may have been fixed with PR 457:
|
|
|
|
|
|
|
|
|
|
https://bitbucket.org/nuttx/nuttx/pull-requests/457/
|
|
|
|
|
fix-esp32-gpio-enable-reg-and-default-uart/diff
|
|
|
|
|
|
|
|
|
|
That has not yet been verified.
|