VELT-0.1.5开发:使用kgdb调试Linux内核【转】

简介:

转自:http://demo.netfoucs.com/lights_joy/article/details/44106589

VELT的全称是Visual EmbedLinuxTools,它是一个与visual gdb类似的visual studio插件,用以辅助完成Linux开发。利用这个插件,将可以在visual studio的IDE中进行Linux应用程序的开发(包括编译和调试),也可以进行uboot和linux内核的编译,并根据编译时的错误信息正确定位到源码。目前的版本是0.1.4,仅支持vs2013。此插件可以在CSDN下载频道下载(http://download.csdn.net/detail/lights_joy/8429771),安装过程参见《用vs2013+velt-0.1.4进行嵌入式开发:插件安装》。下面是它的基本功能:

  1. 支持x86 Linux,海思hi3516/hi3520,MinGW这几个平台,提供这几个平台的项目模板。

  2. 完成UBOOT的编译,并根据编译的错误信息自动定位到相应的文件位置。

  3. 完成LINUX内核的编译,并根据编译的错误信息自动定位到相应的文件位置。

  4. VS下完成Linux内核的配置。

  5. 不使用Makefile进行Linux应用程序的编译。

  6. 使用Makefile进行Linux应用程序的开发。

  7. 使用SSH连接目标机器并用gdb进行应用程序的调试。

  8. 使用Telnet连接目标机器并用gdb进行应用程序的调试。

  9. VS中集成Linux终端(Poderosa),支持SSH/Telnet/Com,在打开终端时自动将VS的变量导出为bash里的变量,如ProjectDir等。

 

接下来尝试通过串口调试Linux内核。

hi3520的内核为试验对象。

 

1.1  打开内核的调试开关

 

首先打开内核的调试开关:

 

加上内核的调试信息:

 

打开kgdb

 

 

1.2  引导参数配置

 

UBOOT下配置传递给内核的参数:

Kernel command line: mem=127m console=ttyAMA0,115200ip=192.168.110.10:::255.255.255.0::eth0: root=mtd:work02 init=/sbin/initmtdparts=hi_sfc:256K(uboot01),64K(env01),64K(sysinfo01),3712k(configs01),8M(boot01),20M(work01),256K(uboot02),64K(env02),64K(sysinfo02),3712k(configs02),8M(boot02),20M(work02)kgdboc=ttyAMA0,115200 kgdbwait

这里最重要的是kgdboc和kgdbwait两个参数,前一个参数指明要使用的串口参数,后一个参数让kgdb在内核启动的时候进行等待。

加载内核:

kgdb: Registered I/O driver kgdboc.

kgdb: Waiting for connection from remote gdb...

然后系统开始等待。

 

 

1.3  用MinGW gdb连接内核

 

直接用MinGW gdb打开编译内核时生成的vmlinux文件,

然后用

target remote COM1

连接串口,很遗憾,超时!

 

 

1.3  修改内核代码

 

检查了一下内核的代码,在等待连接时内核停在了下面的位置:

 

  1. static int gdbstub_read_wait(void){ int ret = dbg_io_ops->read_char();   while (ret == NO_POLL_CHAR)     ret = dbg_io_ops->read_char();   return ret;}  

 

它将不停地查询串口上是否有数据,刚开始时怀疑是串口参数配置不正确导致读取不到数据,但跟踪进去后发现这里的read_char可以正确地调用串口驱动(amba-pl011.c)中的查询函数:

 

  1. static int pl010_get_poll_char(struct uart_port *port){ struct uart_amba_port *uap = (struct uart_amba_port *)port; unsigned int status, ena_status;    status = readw(uap->port.membase + UART01x_FR);  ena_status = readw(uap->port.membase + UART011_CR);  if (status & UART01x_FR_RXFE)       return NO_POLL_CHAR;    return readw(uap->port.membase + UART01x_DR);}  

 

 

只不过在读取UART01x_FR寄存器时总是返回无数据的结果。

进一步的检查发现这个时候串口的接收使能是关闭的,而发送使能则是打开的!因此串口当然只能发送数据不能接收了!

不太想追究为什么会这样,直接在shutdown函数中打开接收使能:

 

  1. static void pl011_shutdown(struct uart_port *port){ struct uart_amba_port *uap = (struct uart_amba_port *)port; /*   * disable all interrupts    */ spin_lock_irq(&uap->port.lock);  uap->im = 0; writew(uap->im, uap->port.membase + UART011_IMSC);    writew(0xffff, uap->port.membase + UART011_ICR); spin_unlock_irq(&uap->port.lock);    pl011_dma_shutdown(uap);    /*   * Free the interrupt    */ free_irq(uap->port.irq, uap);    /*   * disable the port  */ uap->autorts = false;    writew(UART01x_CR_UARTEN | UART011_CR_TXE | UART011_CR_RXE, uap->port.membase + UART011_CR); /*   * disable break condition and fifos     */ pl011_shutdown_channel(uap, uap->lcrh_rx);   if (uap->lcrh_rx != uap->lcrh_tx)     pl011_shutdown_channel(uap, uap->lcrh_tx);   /*   * Shut down the clock producer  */ clk_disable(uap->clk);   if (uap->port.dev->platform_data) {       struct amba_pl011_data *plat;       plat = uap->port.dev->platform_data;      if (plat->exit)          plat->exit();    }}  

 

 

修改了这一行:

 

  1. writew(UART01x_CR_UARTEN | UART011_CR_TXE | UART011_CR_RXE, uap->port.membase + UART011_CR);  

 

原来的代码是这样的:

 

  1. writew(UART01x_CR_UARTEN | UART011_CR_TXE, uap->port.membase + UART011_CR);  

 

直接给上加上使能标记!

 

再执行gdb的target remote COM1命令,可以正常连接了!!

 

 

1.5  kdb

 

HI3520的内核中已经带了kdb的支持:



当选上最下面的那个选项时将启用kdb,这样我们就可以在目标机器上执行一些简单的调试命令了,也不需要依赖于主机上的gdb。

但由于我们希望通过gdb结合源码进行调试,因此不选择kdb,仅仅用kgdb。











本文转自张昺华-sky博客园博客,原文链接:http://www.cnblogs.com/sky-heaven/p/5034788.html,如需转载请自行联系原作者

相关实践学习
阿里云图数据库GDB入门与应用
图数据库(Graph Database,简称GDB)是一种支持Property Graph图模型、用于处理高度连接数据查询与存储的实时、可靠的在线数据库服务。它支持Apache TinkerPop Gremlin查询语言,可以帮您快速构建基于高度连接的数据集的应用程序。GDB非常适合社交网络、欺诈检测、推荐引擎、实时图谱、网络/IT运营这类高度互连数据集的场景。 GDB由阿里云自主研发,具备如下优势: 标准图查询语言:支持属性图,高度兼容Gremlin图查询语言。 高度优化的自研引擎:高度优化的自研图计算层和存储层,云盘多副本保障数据超高可靠,支持ACID事务。 服务高可用:支持高可用实例,节点故障迅速转移,保障业务连续性。 易运维:提供备份恢复、自动升级、监控告警、故障切换等丰富的运维功能,大幅降低运维成本。 产品主页:https://www.aliyun.com/product/gdb
相关文章
|
4月前
|
安全 网络协议 Linux
深入理解Linux内核模块:加载机制、参数传递与实战开发
本文深入解析了Linux内核模块的加载机制、参数传递方式及实战开发技巧。内容涵盖模块基础概念、加载与卸载流程、生命周期管理、参数配置方法,并通过“Hello World”模块和字符设备驱动实例,带领读者逐步掌握模块开发技能。同时,介绍了调试手段、常见问题排查、开发规范及高级特性,如内核线程、模块间通信与性能优化策略。适合希望深入理解Linux内核机制、提升系统编程能力的技术人员阅读与实践。
469 1
|
4月前
|
Ubuntu Linux
Ubuntu 23.04 用上 Linux 6.2 内核,预计下放到 22.04 LTS 版本
Linux 6.2 带来了多项内容更新,修复了 AMD 锐龙处理器设备在启用 fTPM 后的运行卡顿问题,还增强了文件系统。
|
4月前
|
Ubuntu Linux
Ubuntu 23.10 现在由Linux内核6.3提供支持
如果你想在你的个人电脑上测试一下Ubuntu 23.10的最新开发快照,你可以从官方下载服务器下载最新的每日构建ISO。然而,请记住,这是一个预发布版本,所以不要在生产机器上使用或安装它。
|
4月前
|
传感器 监控 Ubuntu
10 月发布,Ubuntu 23.10 已升级到 Linux Kernel 6.3 内核
硬件方面,Linux 6.3 引入了在 HID 中引入了原生的 Steam Deck 控制器接口,允许罗技 G923 Xbox 版赛车方向盘在 Linux 上运行;改善 8BitDo Pro 2 有线控制器的行为;并为一系列华硕 Ryzen 主板添加传感器监控。
|
4月前
|
Ubuntu Linux
Ubuntu24.04LTS默认采用Linux 6.8内核,实验性版本可通过PPA获得
IT之家提醒,当下的 Ubuntu 23.10 也是一个“短期支持版本”,该版本将在今年 7 月终止支持,而今年 4 月推出的 Ubuntu 24.04 LTS 长期支持版本将获得 5 年的更新支持。
|
4月前
|
监控 Ubuntu Linux
什么Linux,Linux内核及Linux操作系统
上面只是简单的介绍了一下Linux操作系统的几个核心组件,其实Linux的整体架构要复杂的多。单纯从Linux内核的角度,它要管理CPU、内存、网卡、硬盘和输入输出等设备,因此内核本身分为进程调度,内存管理,虚拟文件系统,网络接口等4个核心子系统。
358 0
|
4月前
|
Web App开发 缓存 Rust
|
4月前
|
Ubuntu 安全 Linux
Ubuntu 发行版更新 Linux 内核,修复 17 个安全漏洞
本地攻击者可以利用上述漏洞,攻击 Ubuntu 22.10、Ubuntu 22.04、Ubuntu 20.04 LTS 发行版,导致拒绝服务(系统崩溃)或执行任意代码。
|
4月前
|
Ubuntu 机器人 物联网
Linux Ubuntu 22.04 LTS 测试版实时内核已可申请
请注意,在启用实时内核后您需要手动配置 grub 以恢复到原始内核。更多内容请参考: