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

一、打印内核调试信息:printk

  Printk函数用法与printf函数类似,只不过printk函数运行在内核空间,printf函数运行在用户空间,printk函数在printk.c文件中实现。

  Printk函数的原型如下:asmlinkage int printk(const char *fmt,...)

  第1个参数表示格式字符串,后面是可变参数。第一个参数值前面加尖括号包含的数字表示输出的日志级别,共有8个级别,在linux/kernel.h头文件中定义。

  不管消息级别是多少,所有通过printk函数发出的消息都会输出到日志文件(就算有的消息输出到控制台,也会同时输出到日志文件)。可以通过如下的命令查询日志

消息  #dmesg

二、防止printk函数降低Linux驱动性能

  虽然使用printk函数可以很方便地将消息写入日志文件或控制台。但大量使用printk函数频繁操作日志问阿金或控制台设备文件会严重影响Linux驱动的性能。因此,这就要求Linux驱动只在开发阶段使用printk函数输出消息,在正式发布Linux驱动时将可能影响性能的printk函数去掉。最好的方法无疑是利用C语言中的编译指令。(#if、#else、#endif等)。

  如果不想使用printk输出消息,只要将#if中的1改为0即可不使用printk输出消息。

三、通过虚拟文件系统(/pron)进行数据交互

  /pron用来作为内核空间与用户空间进行数据交互的工具,它的文件系统的行为凡是与设备文件系统(/dev)类似。/pron是虚拟文件系统,是内存映射,所有读写/pron的操纵都是对内存的读写,因此,它也可以作为Linux驱动与用户空间程序交互的工具。

  /pron 文件系统主要通过proc_dir_entry.read_proc和proc_dir_entry.read_write函数指针来设置读写/pron目录中的虚拟文件的动作处理函数,proc_dir_entry结构体代表一个虚拟目录或文件

四、调试工具

  Linux系统中提供了一类工具,这些工具可以逐行跟踪程序的代码,这些工具包含用于调试用户空间程序的gdb、gdbserver和调试内核空间程序的kgdb

  1. gdb调试用户空间程序

    gdb可以跟踪调试用户空间的程序,只能在PC上进行测试

  2.gdbserver远程调试用户空间程序

    用gdbserver 测试运行在开发板、手机或Android模拟器上的程序。gdbserver是一个可以运行在ARM架构上的服务端程序,在开发板上使用gdbserver打开要测试的程序,然后通过串口、有线或无线网络可以在PC上进行调试

  3.kgdb远程调试内核程序

    最好的内核调试工具。提供类似printk函数的复制输出功能,允许开发人员直接在PC上通过GDB链接目标设备

http://www.cnblogs.com/JOKERLAU/

时间: 2024-10-09 22:43:01

第十章:嵌入式Linux的调试技术的相关文章

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

本章的主要内容是嵌入式Linux的调试技术.对于复杂的Linux驱动及HAL等程序库,需要使用各种方法对其进行调试. 一.打印内核调试信息:printk 该函数的用法与printf函数类似,只不过printk函数运行在内核空间,printf函数运行在用户空间.像Linux驱动这样的Linux内核程序只能使用printk函数输出调试信息.Printk函数在printk.c文件中实现,该文件的路径:/root/kernel/linux_kernel_2.6.36/kernel/printk.c. 二

Android深度探索(卷1)HAL与驱动开发 第十章 嵌入式Linux的调试技术 读书笔记

对于复杂的Linux驱动以及HAL等程序库,需要使用各种方法对其进行测试.如设置断点,逐步跟踪代码,输出调试信息等.本章主要讲述了如何利用开发板.Android模拟器以及一些函数.工具调试嵌入式Linux内核模块.可执行程序和共享库. 1.打印内核调试信息:printk 该函数的用法和printf函数类似,只不过printk函数运行在内核空间,printf函数运行在用户空间.函数原型: asmlinkage printk(const char *fmt, ...) 第一个参数表示格式字符串.后面

第十章 嵌入式linux的调试技术 心得笔记

1.主要讲了对于复杂的Linux驱动以及HAL等程序库,需要使用各种方法对其进行调试.例如,设置断点.逐步跟踪代码.输出调试信息等. 2.打印内核调试信息:printk printk 函数的用法与printf 函数类似,只不过printk函数运行在内核空间, printf函数运行在用户空间.也就是说,像Linux 驱动这样的Linux内核程序只能使用printk函数输出调试信息. 3.防止printk函数降低Linux驱动性能 虽然使用printk 函数可以很方便地将消息写入日志文件或控制台.但

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

对于复杂的Linux驱动及HAL等程序库,需要使用各种方法对其进行调试,例如,设置断点.逐步跟踪代码.输出调试信息等.Printk函数运行在内核空间,printf函数运行在用户空间. 初始化Linux驱动 Static int _init printk_demo_init(void) 卸载Linux驱动 Static void _exit printk_demo_exit(void) 使用printk函数可以很方便地将消息写入日志文件或控制台,但大量使用printk函数操作日志文件或控制台设备文

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

1.对于复杂的Linux驱动及HAL等程序库,需要使用各种方法对其进行调试,例如,设置断点.逐步跟踪代码.输出调试信息等. 2.Printk函数运行在内核空间,printf函数运行在用户空间. 3.初始化Linux驱动 Static int _init printk_demo_init(void) 4.卸载Linux驱动 Static void _exit printk_demo_exit(void) 5.使用printk函数可以很方便地将消息写入日志文件或控制台,但大量使用printk函数操作

Android深度探索(卷1)HAL与驱动开发 心得体会 第十章 嵌入式Linux的调用技术

Android深度探索(卷1)HAL与驱动开发 心得体会 第十章  嵌入式Linux的调用技术 对于复杂的Linux驱动以及HAL等程序库,需要使用各种方法对其进行调试.例如,设置断点,逐步跟踪代码.输出调试信息等.虽然嵌入式Linux在调试方面并没有Visual Studio.Delphi.Eclipse这些可视化工具方便,但是学习一些这方面的技术无疑更有助于开发强大而稳定的Linux内核模块. 对于嵌入式Linux内核模块,可执行程序.代码库的调试可能更要复杂些.因为在大多数时候需要至少两台

嵌入式Linux的调试技术

嵌入式Linux的调试技术对于复杂的Linux驱动以及HAL等程序库,需要使用各种方法对其进行调试.例如,设置断点.逐步跟踪代码.输出调试信息等. Printk函数的用法与printf函数类似,只不过printk函数运行在内核空间,printf函数运行在用户空间.也就是说,像Linux驱动这样的Linux内核程序只能使用printk函数输出调试信息.Printk函数在printk.c文件中实现. 虽然使用printk函数可以很方便的将消息写入日志文件或控制台.但大量使用printk函数频繁操作日

第10章 嵌入式Linux的调试技术 学习心得

第10章嵌入式Linux的调试技术 心得体会 这一章主要概括的介绍了嵌入式Linux的调试技术的主要内容.通过对第10章的学习,使我对嵌入式Linux的调试技术的方法以及操作步骤有了一个基本的认识. 一 调试前的准备 在调试一个bug之前,我们所要做的准备工作有: 有一个被确认的bug. 包含这个bug的内核版本号,需要分析出这个bug在哪一个版本被引入,这个对于解决问题有极大的帮助.可以采用二分查找法来逐步锁定bug引入版本号. 对内核代码理解越深刻越好,同时还需要一点点运气. 该bug可以复

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

通过对本章节的学习我学到了如下知识点: 嵌入式Linux调用技术 (1)调试方法:设置断点.逐步跟踪代码.输出调试信息. (2)打印内核调试信息:printk,printk函数运行在内核空间,printk函数运行在用户空间,Linux驱动这样的Linux内核程序只能使用printk函数输出调试信息. Asmlinkage int printk(const char *fmt, …)第一个参数表示格式字符串,后面是可变参数. 虽然使用printk函数可以很方便的将纤细写入日志文件或控制台,但是大量

嵌入式 Linux 的调试技术读书笔记

对于复杂的 Linux 驱动及 HAL等程序库,需要使用各种方法对其进行调试. 例如,设置断点. 逐步跟踪代码.-输出调试值息等.虽然撒入式Linux在调试方面并没有 Visual Studio. Delphi. Eclipse 这些可视偌工其荒便,但学习一些这方面的技术无疑更奇脚手亮发强款而稳定的 Linux 内核模块对于嵌入式 Linux 俞核模块.可fA,衍程庄. 央事库的调试可能要更复杂一些.因为在失多赞时候需要至 少两台机器开发机和目标机. 在 Linux 文件系统中, /proc 经