ESPlane
  • Introduction
  • 语言/language
    • 中文
    • English
  • Operater Guide
    • 01 ESPlane Operater Get Started
    • 02 CFclient User Guid
    • 03 Calibration And Commissioning Methods
    • 04 Flight Mode Introduction
    • 05 Pid Tuning
    • 06 Multi-user Mode
    • 07 Load And Endurance Test
  • Developer Guide
    • 01 ESPlane Developer Get Started
    • 02 Code Architecture And Startup Process
    • 03 Sensor Angle Fusion
    • 04 Sensor Calibration
    • 05 Control System
    • 06 Gyro and Accelerometer MPU6050 Driver
    • 07 Laser Sensor Vl53l1x Driver
    • 08 Barometer MS5611 Driver
    • 09 Magnetic Compass HMC5883l Driver
    • 10 Brushed Motor Driver
    • 11 Optical Flow Sensor Pmw3901 Driver
    • 12 Variable Unified Management
    • 13 Crtp Protocol Introduction
    • 14 Crtp Protocol Library - Cflib
    • 15 Compatible With ESPilot APP
    • 16 Height-hold Mode Development
    • 17 Positon-hold Mode Development
  • Research on Crazyflie
    • 01 Crazyflie Project Preview
    • 02 Crazyflie Source Preview
    • 03 Crazyflie Code Modularization Method
    • Discussion On Private-Improvement Scheme
    • Private-1.0 Code Debug Record
    • Private-Research On Commercial Micro Drone Products
    • Well-Known Drone Open Source Solutions
  • ESP32 Development notes
    • ESP32 Chip Naming Rules
    • ESP32 Pin Resource Allocation And Usage Recommendations
    • 01 ESP32-Hardware Preparation-ESP32-DevKitC V2 board
    • 02 ESP32-Environment Setup-Compilation And Programming
    • 03 ESP-IDF-Directory Structure-Template Engineering Analysis Notes
    • 04 ESP32-Code Debugging-Summary Of Several Debugging Methods
    • 05 ESP32 Event Loop
    • 14 ESP32 SPI Use Memo
    • 15 ESP32 GPIO Use Memo
  • Reference
    • bitcraze.io
    • esp-idf-release-v3.3
由 GitBook 提供支持
在本页
  • 一、JTAG调试
  • 1. 官方文档
  • 2. 硬件准备
  • 3. JTAG调试笔记

这有帮助吗?

  1. ESP32 Development notes

04 ESP32-Code Debugging-Summary Of Several Debugging Methods

上一页03 ESP-IDF-Directory Structure-Template Engineering Analysis Notes下一页05 ESP32 Event Loop

最后更新于5年前

这有帮助吗?

* 工欲善其事,必先利其器.

一. JTAG 二. 日志系统 三. Core Dump

一、JTAG调试

这里先介绍第一种调试方法-JTAG调试,JTAG是从STM32转过来的开发者的第一反应,这里放在最前面介绍.但是对于双核多任务的ESP32应用程序,并非最优的调试方法.

1. 官方文档

关于调试环境的搭建,参考乐鑫官方文档即可,有中文版详细配置过程:

  • Eclipse调试环境搭建

  • JTAG 调试

  • 调试范例

2. 硬件准备

2.1 ESP32 WROVER KIT

ESP-WROVER-KIT板载了JTAG功能(FT2232),但是需要连接4个跳线帽接通线路,如下图:

使能ESP32 JTAG

FT2232 是多协议 USB 转串口桥接器.在这里替换了cp2102,并且可以同时提供 USB-to-JTAG ,USB-to-Serial 接口功能,便利开发人员的应用开发与调试.具体配置信息可以查阅 ESP-WROVER-KIT V4.1 入门指南

2.2. ESP32 Core Board V2

ESP32 Core Board V2 没有JTAG插口,如果需要硬件调试,需要准备:

  1. JTAG 适配器与杜邦线

  2. OpenOCD 软件包

  3. ESP32 目标板

按照如下方式连接:

|   | ESP32 引脚    | JTAG 信号 |
| 1 | CHIP_PU       | TRST_N    |
| 2 | MTDO / GPIO15 | TDO       |
| 3 | MTDI / GPIO12 | TDI       |
| 4 | MTCK / GPIO13 | TCK       |
| 5 | MTMS / GPIO14 | TMS       |
| 6 | GND           | GND       |

ESP32 使用标准的 JTAG 接口,支持STM32常用的J-Link,如何使用 J-Link 调试 ESP32,但是不支持ST-Link,也不支持SWD接口:

官方描述: 在软件方面,OpenOCD 支持相当多数量的 JTAG 适配器,可以参阅 OpenOCD 支持的适配器列表 (尽管上面显示的器件不太完整),这个页面还列出了兼容 SWD 接口的适配器,但是请注意,ESP32 目前并不支持 SWD.此外那些被硬编码为只支持特定产品线的 JTAG 适配器也不能在 ESP32 上工作,比如用于 STM32 产品家族的 ST-LINK 适配器.

3. JTAG调试笔记

3.1. 开启openOCD

cd ~/esp/openocd-esp32      
bin/openocd -s share/openocd/scripts -f interface/ftdi/esp32_devkitj_v1.cfg -f board/esp-wroom-32.cfg  #在openocd安装目录执行,开启openOCD server

3.2. 运行xtensa-esp32-elf-gdb

cd ~/esp/esp-idf-v3.2.2/examples/get-started/blink
xtensa-esp32-elf-gdb -x gdbinit build/blink.elf  #在工程目录执行,连接openOCD

3.3. 输入gdb命令,进行调试

  • 断点设置:

    break N:在第N行设置断点
    delete N:删除第N行的断点
    info break:查看已设置的断点
  • 调试运行

    s(或step):单步调试,可以跳入函数内部
    n(或next):单步调试,不跳入函数内部
    c:Continue,继续运行,到断点处停止
    Ctrl+C:随机停止
    q:结束会话
  • 查看、修改内存

    x /1wx 0x3FF44004 #查看0x3FF44004内存位置内容
    0x3ff44004: 0x00000000
    set {unsigned int}0x3FF44004=0x000010 #设置0x3FF44004内存位置内容
  • 查看代码

    ```

    i threads:查看当前所有线程

    thread N:查看编号N线程的代码

    bt(或backtrace):查看上一层,查看当前函数调用处(仅查看,未跳出)

    l:打印停止点处代码

    l 30, 40:打印第30-40行代码

* 查看帮助

help xxx:查看指令xxx的帮助

具体可以查看:[使用命令行的调试示例](https://docs.espressif.com/projects/esp-idf/zh_CN/latest/api-guides/jtag-debugging/debugging-examples.html#jtag-debugging-examples-command-line)
***

## 二、日志系统

* 
* 
***

## 三、Core Dump

* 
* 


***

## 四、其他讨论

### 附1:通过gdb命令点亮LED灯

ESP32 WROVER KIT 自带RGB指示灯,分别接入了IO0、IO2、IO4,注意IO0、IO2的特殊作用.

| ESP32管脚 | RGB LED |
|:--------:|-----:|
| GPIO0 | 红色|
| GPIO2 | 绿色|
| GPIO4 | 蓝色|

*  查找到GPIO 0-31 output register的地址0x3FF44004
该寄存器可以用来控制(设置或者清除)某个 GPIO 的电平
![寄存器列表](https://img-blog.csdnimg.cn/2019072519594793.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3FxXzIwNTE1NDYx,size_16,color_FFFFFF,t_70)
查询当前寄存器值:

(gdb) x /1wx 0x3FF44004 0x3ff44004: 0x00000000 #返回0x00000000

设置GPIO2对应的寄存器标志位为1,点亮LED:

(gdb) set {unsigned int}0x3FF44004=0x00000004

==遗留问题:== 只有写入0x00000004(对应IO2)才能正常点亮,IO0、IO4直接写GPIO_OUT_REG(GPIO 0-31 output register: 0x3FF44004 ),无法实现灯的操作.怀疑受到其他寄存器钳制.




***

### 附2: openOCD与xtensa-esp32-elf-gdb关系?


==无论先使用命令行还是eclipse调试,都需要先打开openOCD,关系图如下:==

cd ~/esp/openocd-esp32 bin/openocd -s share/openocd/scripts -f interface/ftdi/esp32_devkitj_v1.cfg -f board/esp-wroom-32.cfg

```

  • OpenOCD:

    • 创建一个Server接收 gdb debugger 的连接请求

    • 通过JTAG适配器与ESP32 交互,控制设备运行状态

  • xtensa-esp32-elf-gdb debugger:

    • 作为一个client,连接OpenOCD

    • 与用户交互,接收用户的 debug 命令(s\n等指令),发送到OpenOCD

  • eclipse

    -图形化方式调用xtensa-esp32-elf-gdb debugger,包装命令行

  • openOCD是硬件层次的调试,gdb是源码层次的调试.

  • 在gdb中可以使用monitor发送openOCD的命令,例如monitor reset;halt

JTAGt调试
1545202874386