为啥打印不出linux内核调试信息

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了为啥打印不出linux内核调试信息相关的知识,希望对你有一定的参考价值。

参考技术A 用dmesg -c命令查看打印信息。 ctrl+alt+F1 切换到纯终端,可以在终端直接看到打印信息

第十章嵌入式Linux的调试技术

通过对本章节的学习我学到了如下知识点:

嵌入式Linux调用技术

(1)调试方法:设置断点、逐步跟踪代码、输出调试信息。

(2)打印内核调试信息:printk,printk函数运行在内核空间,printk函数运行在用户空间,Linux驱动这样的Linux内核程序只能使用printk函数输出调试信息。 Asmlinkage int printk(const char *fmt, …)第一个参数表示格式字符串,后面是可变参数。 虽然使用printk函数可以很方便的将纤细写入日志文件或控制台,但是大量使用printk函数频繁操作日志文件或控制台设备文件会严重影响Linux驱动的性能。防止printk函数降低Linux驱动的性能

(3)通过虚拟文件系统进行数据交互。在Linux文件系统中,/proc经常被用来作为内核空间与用户空间进行数据交互的工具。/proc并不是真正的文件系统,而是映射内存。所有读写/proc的操作都是对内存的读写,所以读写/proc文件系统的速度要远比读写/dev文件系统的速度快。因此,/proc文件系统也可以作为Linux驱动与用户空间程序交互的工具。有很多系统信息就是通过/proc文件系统由内核空间的程序向外界提供的。/proc文件系统和/dev文件系统一样,也需要设置访问文件的动作处理函数。

(4)Android模拟器只能通过端口映射的方式使用kgdbserver调试程序。但开发板除了可以通过ip连接到kgdbserver外还可以通过串口进行连接。开发板同样也带了kgdbserver程序,可直接运行。

(5)调试工具: 用gdb 调试用户空间程序、用gdbserver 远程调试用户空间程序、用kgdb 远程调试内核程序。 当发现某段代码的bug太多,很难通过printk函数输出信息找出,可以考虑使用kgdb用step by step的方式定位bug。

       name:虚拟文件名称

       mode:虚拟文件的访问权限,等同于Linux问价访问权限。

       base:虚拟文件父目录的proc_dir_entry结构体指针。    

       read_proc:处理读动作的函数指针。

data:用于虚拟文件系统的数据。该值就是proc_dir_entry.read_proc函数的最后一个参数值

remove_proc_entry

       name:要删除的虚拟文件的名称

       parent:虚拟文件父目录的proc_dir_entry结构体指针。

以上是关于为啥打印不出linux内核调试信息的主要内容,如果未能解决你的问题,请参考以下文章

linux内核printk调试手段,[Mini2440] 内核调试手段之 printk

linux内核调试工具之kprobe

第十章嵌入式Linux的调试技术

基于FS4412嵌入式系统移植 linux内核调试之printk

嵌入式linux的调试技术

Linux内核调试方法总结之反汇编