RISC-V生态全景解析(八):平头哥玄铁CPU调试系统介绍

简介: 编辑语:芯片开放社区(OCC)面向开发者推出RISC-V系列内容,通过多角度、全方位解读RISC-V,系统性梳理总结相关理论知识,构建RISC-V知识图谱,促进开发者对RISC-V生态全貌的了解。

编辑语:

芯片开放社区(OCC)面向开发者推出RISC-V系列内容,通过多角度、全方位解读RISC-V,系统性梳理总结相关理论知识,构建RISC-V知识图谱,促进开发者对RISC-V生态全貌的了解。

上期内容提到,RISC-V工具链由众多基础工具组成,其中包含调试系统。在嵌入式开发中,调试工作将耗费大量时间,且随着如今的SoC均内置多颗CPU内核与集群,调试的复杂度也日益攀升。一款高效、高性能的调试系统将有效提升开发效率。

本期【技术解码】将介绍玄铁CPU的调试系统,带大家深入了解剑池系列工具链。

# 引言

对于开发人员来说,顺畅的调试系统和高效的调试方法将有效降低开发过程中的信息误差,提升开发效率。本文将介绍玄铁CPU的调试系统组成,分为如下两大部分:

  • 调试系统的基本介绍
  • 玄铁CPU调试系统简介

希望通过本文的介绍,能使用户对玄铁CPU的调试系统有一定的理解、了解玄铁CPU配套的调试工具的使用。同时方便大家更容易理解后续介绍的调试方法。

01 调试系统的基本介绍

截屏2021-11-22 下午6.22.03.png

图1 典型的MCU调试系统中

调试系统是一套为基于硬件调试模块,结合软件调试工具,为开发者提供解决软硬件bug的技术系统。软件调试部分包括调试工具、link及其固件。硬件调试部分包括调试模块(Debug Module)。

例如图1所示,在典型的MCU调试系统中:

  • 调试工具(Debug Tools)是面向开发者调试的软件工具,一般运行在开发人员的主机、服务器等场景下。常见的有调试工具有GDB、IDE等,如T-HEAD的riscv工具链中的gdb,CDK,DebugServer等工具。开发者使用这类工具进行软件程序的调试、分析工作;

  • 由于调试主机无法直接与CPU上的调试单元连接,因此需要link作为中间转换工具,使得调试工具的操作能够真实地作用在CPU上,比如平头哥的CkLink,Segger的JLink等等;

  • CPU上的调试模块(Debug Module)是支持大部分调试手段的基础,实现对CPU的控制和读写寄存器、读写内存等功能。

02 玄铁CPU调试系统总览

截屏2021-11-22 下午6.22.35.png

图 2.1 玄铁调试系统概览

如图2.1所示,玄铁CPU调试系统主要由以下几部分组成:

  • 软件运行环境,指软件运行的实际环境,包括模拟器、普通硬件环境(Bare Metal)、基于Linux内核的环境;

  • Debug Monitor,主要指配合调试工具,对被调试程序进行调试控制的工具,包括DebugServer/OpenOCD/GDBServer等。对于实际开发板来说,往往还需要在线仿真调试工具(cable/link),如CkLink, JLink等;

  • 调试/Profiling工具,是开发者经常使用的用于调试程序的工具,主要包括GDB、perf、CPF、Trace、Flash Programmer等;

  • 用户接口,是用户直接接触到的操作界面,主要是命令行工具(CMD Line)、剑池CDK、剑池CDS等。其中大部分调试/profiling工具大部分都支持命令行方式呈现。剑池CDK、剑池CDS相比命令行工具,有友好的界面,具有更好开发体验。

本章节主要介绍玄铁CPU的硬件调试框架,以及部分软件调试工具、Profiling工具的简介。

2.1 玄铁CPU的硬件调试框架

在玄铁CPU的硬件设计上,调试功能集中在调试模块(Debug Module)中基本结构如图2.2所示。基于该架构,调试模块的各个功能可以覆盖各种IOT设备领域的CPU,包括低功耗、音频处理、视频处理、计算型等领域的CPU。

截屏2021-11-22 下午6.23.03.png

图2.2 RISC-V调试框架总览

玄铁CPU中的调试模块,是基于《RISC-V Debug Spec v0.13.2》实现的,实现的功能包括:复位及调试控制、寄存器访问、内存访问、断点等功能。

关于调试模块中具体的功能及其操作接口,请查阅《RISC-V Debug Spec v0.13.2》,附链接:https://github.com/riscv/riscv-debug-spec

基本的调试功能介绍:

  • Break-Point功能:Break-Point功能俗称断点功能,即插入断点,使CPU运行到断点位置后停住。开发人员可在断点位置继续进行其他调试手段操作,如读写内存、读写寄存器等。

  • Watch-Point功能:Watch-Point功能是一种对数据访问的调试手段。可以观测某个内存地址是否发生了数据读写行为。

  • 寄存器访问:访问CPU的寄存器能力,包括通用寄存器,控制寄存器等。

  • 内存访问:访问总线上内存以及外设区的能力,可以读写内存上的数据,外设的控制/数据寄存器。

  • 调试控制:指的是单步执行指令、使CPU进入调试模式、全速运行等功能。

2.2 玄铁CPU的软件调试工具

如图2.1所示,玄铁CPU配套有诸多调试工具,本章节将分别介绍几个典型调试工具,如表2.1所示:

表2.1 玄铁调试工具

调试工具 描述
DebugServer 是一种Debug Monitor软件,用于和玄铁CPU的调试模块进行交互,完成调试操作。
GDB 开源GDB软件,支持玄铁CPU体系结构,包括玄铁8系列、9系列CPU
剑池CDK 平头哥推出的玄铁CPU集成开发环境
Perf Perf是Linux上强大的性能分析工具集合。结合PMU事件可对程序热点采样,cycle、指令数统计等。
CPF T-HEAD研发的性能分析工具,能真实反映CPU 的运行轨迹(目前仅在t-head qemu上支持)

2.1.1 DebugServer

DebugServer是平头哥自行设计实现的调试工具。其目的是为了配合GDB完成对CPU的软件调试,其中包含一套GDB Remote Serial Protocol的实现,并解析该协议,通过USB操作link完成协议的执行。同时DebugServer也实现了一套CLI,完成一些简单的调试功能,如复位、指令单步,读写寄存器、读写内存等。

截屏2021-11-22 下午6.23.33.png

图 2.3 DebugServer Console版本界面

2.2.2 GDB

GDB是一个软件调试工具,是GNU组织维护的开源软件:https://www.gnu.org/software/gdb/。GDB支持不同的后端体系架构,目前GDB的发布的源码版本中已经支持玄铁8系列、9系列CPU。能够满足玄铁CPU的日常开发需求。

通过一段简单示例看一下GDB使用。

截屏2021-11-22 下午6.24.10.png

图 2.4 RISC-V GDB使用示例

GDB详细手册参考:

https://www.gnu.org/software/gdb/documentation/

2.2.3 剑池CDK

剑池CDK是玄铁CPU的开发环境,集成了编辑、编译、调试等功能,便于开发者使用。本章节简要介绍一下剑池CDK的调试功能,如下图所示:

截屏2021-11-22 下午6.24.41.png

图 2.5 剑池CDK调试界面

截图中基本上涵盖了日常使用到的调试功能:

  • 寄存器读写
  • 反汇编查看
  • 源码对应
  • 断点管理
  • 变量查看
  • 调试控制等

详细调试手册请查看剑池CDK帮助文档.

2.2.4 CPF

CPF(C-SKY Profiling analysis utils)是一套针对玄铁CPU应用程序的性能分析工具,包含了一系列记录和分析的工具。CPF基于T-Head trace(目前仅T-Head qemu支持T-Head trace功能)进行分析,通过T-Headtrace 硬件能够非侵入式的获取CPU运行时的信息,真实反映CPU 的运行轨迹。借助于CPF,开发者可以提高开发效率,优化系统设计。

截屏2021-11-22 下午6.25.10.png

图 2.6 CPF report结果

如图2.6所示,这是一个helloworld的打印输出示例程序,通过CPF工具,可以直观的看出该程序各函数在执行工程中的耗时占比,除此之外,还能看到程序执行的cycle数、指令数,被调用的次数等。

2.2.5 PERF

Perf是一系列强大的性能分析工具集合。在Linux 2.6.31版本引入,至今tool/perf目录拥有1万多个提交,是内核开发中最活跃的几个领域之一,通过perf可以使用一到两行命令就完成像程序热点采样,接口调用分析,阻塞分析。

玄铁CPU的PMU单元支持了大量硬件事件计数器,包含了指令数,周期数,cache访问,分支预测等等,图2.7 以memcpy为例演示perf通过PMU或者程序执行的指令数、周期数。

tst-mem2比tst-mem具有更大的循环拷贝次数。

截屏2021-11-22 下午6.25.43.png

图 2.7 perf stat –e instructions, cycles tst-mem

关于平头哥玄铁CPU的调试系统介绍就到这里。其他关于玄铁CPU调试系统的文档请参考:

① RISC-V Debug Sepc:

https://github.com/riscv/riscv-debug-spec

② GDB用户手册:

https://www.gnu.org/software/gdb/documentation/

③ 玄铁CPU调试技巧:

https://occ.t-head.cn/community/download?id=3854517824420909056

④ 剑池CDK用户手册:

https://occ.t-head.cn/development/series/download?spm=a2cl5.14290816.0.0.d3ef180f9g3GPH&id=3864775351511420928&type=kind&softPlatformType=4#sticky

后续我们还将为大家介绍基于玄铁CPU的生态芯片,如何对RISC-V开发板进行调试。

03 下期预告

玄铁CPU的调试系统是剑池系列工具链的组成之一,下期内容我们将为大家介绍剑池系列工具链的另一基础工具——剑池CDK。欢迎广大开发者持续关注芯片开放社区RISC-V系列内容。

相关文章
一文解析!Java进程CPU100%打满
背景 最近发现测试服务器经常触发CPU90%报警,这次有空了,决定上服务器分析一下,居然发现是最近新上线的日志收集服务消耗大量CPU: top 资源消耗分析, shift + p 根据CPU消耗排序,shift + m 根据内存消耗排序 一个进程CPU消耗超过90%CPU,第一眼感觉不正常,因此进行了一番分析。 CPU分析 1.使用 top -p 命令(为Java进程的id号)查看Java进程的cpu占用: top -p 29595 查看指定进程资源使用情况 2.使用 top -Hp 命令(为Java进程的id号)查看该Java进程内所有线程的资源占用情况 top -Hp 2
|
4月前
|
KVM 虚拟化
计算虚拟化之CPU——qemu解析
【9月更文挑战10天】本文介绍了QEMU命令行参数的解析过程及其在KVM虚拟化中的应用。展示了QEMU通过多个`qemu_add_opts`函数调用处理不同类型设备和配置选项的方式,并附上了OpenStack生成的一个复杂KVM参数实例。
|
8月前
|
存储 缓存 C语言
内存与CPU:计算机默契交互的关键解析
内存与CPU之间的密切互动是计算机运行的关键。从RAM到Cache,内存的物理结构和读写过程都影响着计算机的性能。指针在内存中的作用至关重要,就像楼房模型和数组一样,帮助我们理解内存的工作原理。了解内存的重要性,是深入了解计算机运行的第一步。
169 1
内存与CPU:计算机默契交互的关键解析
|
人工智能 弹性计算 Cloud Native
平头哥杨平超:倚天CPU架构以及产品特性介绍
2023年8月8日,【倚天实例迁移课程】首节课程《倚天CPU架构以及产品特性介绍》正式上线,由平头哥倚天解决方案架构师杨平超主讲,内容涵盖:倚天710芯片概述;倚天710的主要特点;倚天710应用落地介绍,本期节目也在阿里云官网、阿里云微信视频号、阿里云钉钉视频号、InfoQ官网、阿里云开发者微信视频号、阿里云创新中心直播平台&微信视频号同步播出。
平头哥杨平超:倚天CPU架构以及产品特性介绍
|
存储 缓存 监控
Java 经典面试解析:服务器卡顿、CPU飙升、接口负载剧增
解决这个问题的关键是要找到Java代码的位置。下面分享一下排查思路,以CentOS为例,总结为4步。 第1步,使用top命令找到占用CPU高的进程。 第2步,使用ps –mp命令找到进程下占用CPU高的线程ID。 第3步,使用printf命令将线程ID转换成十六进制数。 第4步,使用jstack命令输出线程运行状态的日志信息。
305 0
|
缓存 Java 大数据
深入解析JVM调优:解决OutOfMemoryError、内存泄露、线程死锁、锁争用和高CPU消耗问题
深入解析JVM调优:解决OutOfMemoryError、内存泄露、线程死锁、锁争用和高CPU消耗问题
262 0
|
存储 缓存 固态存储
Linux系统之Wait CPU time解析
上篇文章我们简要解析了用户CPU时间相关概念及应用实践,具体可参考链接🔗: Linux系统之User CPU time解析。 回顾之前的内容:在Linux操作系统中,通常采用8个不同的指标来研究Linux / Unix操作系统中的CPU消耗:用户CPU时间(us)、系统CPU时间(sy)、良好的CPU时间(ni)、空闲CPU时间(id)、等待CPU时间(wa)、硬件中断CPU时间(hi),软件中断CPU时间(si),被盗CPU时间(st)。在本文中,我们主要针对“等待CPU时间”进行解析。
238 0
Linux系统之Wait CPU time解析
|
存储 Unix Linux
Linux系统之 Steal CPU time解析
正如之前文章讲过:在 Unix / Linux 体系中,常常使用“用户” CPU 时间(us)、“系统” CPU 时间(sy)、“良好”的 CPU 时间(ni)、“空闲” CPU 时间(id)、“等待”CPU 时间(wa)、“硬件中断” CPU 时间(hi)、“软件中断” CPU 时间(si)以及“被盗” CPU 时间(st)等 8 个不同的指标来评判操作系统的 CPU 资源使用情况。
591 0
|
Java Unix Linux
Linux系统之User CPU time解析
在Linux操作系统中,通常采用8个不同的指标来研究Unix / Linux操作系统中的CPU消耗:用户CPU时间(us)、系统CPU时间(sy)、良好的CPU时间(ni)、空闲CPU时间(id)、等待CPU时间(wa)、硬件中断CPU时间(hi),软件中断CPU时间(si),被盗CPU时间(st)。在本文中,我们主要对“用户CPU时间”进行解析。
579 0
|
芯片 开发者
今天,由阿里巴巴平头哥举办的「首届玄铁RISC-V生态大会」在上海举行。
今天,由阿里巴巴平头哥举办的「首届玄铁RISC-V生态大会」在上海举行。
210 0