第10章 嵌入式Linux 的调试技术
10.1 打印内核调试信息:printk
printk位函数运行在内核空间, printf函数运行在用户空间。也就是说,像Linux 驱动这样的Linux内核程序只能使用printk函数输出调试信息。
printk 函数的原型
asmlinkage int printk(const char * fmt, ... )
printk 函数至少要有1个参数(格式字符串),如果格式字符串中包含有占位符,后由必须跟与占位符相等数量的参数,以便一一对应传入printk 函数如果想让printk 函数将消息输出到控制台.还需要另外一个条件,就是要求在字符界面下操作,printk 函数只有用在字符界面的控制台上才能正常输出消息.虽然使用printk 函数可以很方便地将消息写入日志文件或控制台。但大量使用printk 函数频繁操作日志文件或控制台设备文件会严重影响Linux 驱动的性能,后期要删除printk函数。
查询Ubuntu Linux的日志消息:
# cat /var/log/syslog
当日志文件内容很多时,可以使用grep或tail命令过滤显示的内容
# dmesg | grep printk
# cat /var/log/syslog | grep printk
# tail –n 10 /var/log/syslog
10.2 防止printk函数降低Linux驱动性能
printk 函数在控制台(也称为终端)显示消息是通过/dev/console 设备文件实现的。该设备文件只在字符界面的控制台下才起作用,所以printk 函数只有用在字符界面的控制台上才能正常输出消息。
10.3 通过虚拟文件系统(/proc)进行数据交互
在Linux 文件系统中,/proc 经常被用来作为内核空间与用户空间进行数据交换的工具。/proc 文件系统和/dev 文件系统一样,也需要设置访问文件的动作处理函数(主要是读写操作)。/dev 文件系统通过且le_operations.read 和file_operations. write 函数指针变量设置读写设备文件的读写作处理函数。而/proc 文件系统主要通过proc_dir_entry.read_proc 和proc_dir_entry.read_write 函数指针来设置读写/proc 目录中的虚拟文件的动作处理函数。
有四个函数 proc_mkdir create_proc_entry create_proc_read_entry remove _proc _ entry
create _proc _read_ entry 函数在内部是通过调用create_proc _ entry函数实现的。
Linux 文件的读写由属性决定.在程序中可以用八进制表示,例如0666 表示八进制的666,也就是二进制的110110110。如果查看文件属性,会看到文件开头是-rw-rw-rw-.而将文件属性设为0444 ,贝lj文件属性是-r--r--r--,表示只读。
删除虚拟目录之前, 要先删除虚拟自录中的虚拟文件。
10.4 调试工具
Linux 系统中提供了一类工具,可以使用工具逐行跟踪程序的代码,这些工具包含用于调试用户空间程序的gdb、gdbserver 和调试内核空间程序的kgdb。
gdb 可以跟踪调试用户空间的程序。
使用gdbserver可以测试运行在开发板、手机或Android 模拟器上的程序gdbserver 是一个可以运行在ARM 架构上的服务端程序。也就是说,在开发板上使用gdbserver 打开要测试的程序,然后通过串口、有线或无线网络可以在PC 上进行调试。
用kgdb 远程调试内核程序,Kgdb 除了提供类似printk 函数的日志输出功能,还允许开发人员直接在PC 上通过GDB 链接目标设备,Kgdb 包含了两部分: kgdb 内核和一牵连接接口。
第10章 嵌入式Linux 的调试技术的更多相关文章
- 第10章 嵌入式Linux的调试技术
printk函数运行在内核空间,printf函数运行在用户空间.也就是说像Linux驱动这样的Linux内核程序只能使用printk函数输出调试信息.printk函数在控制台(也称终端)显示消息是通过 ...
- 嵌入式Linux的调试技术
本节我们研究嵌入式Linux的调试技术,对于复杂的Linux驱动及HAL等程序库,需要使用各种方法对其进行调试.刚开始讲了打印内核调试信息:printk,这个函数的用法与printf函数类似,只不过p ...
- 第十章 嵌入式Linux的调试技术
对调试工具进行简介.Linux中提供了一类工具,通过这些工具可以逐行跟踪程序的代码,用于测试用户空间程序的gdb.gdbserver和调试内核空间程序的kgdb. 用gdb调试用户空间程序:gdb可跟 ...
- 高性能Linux服务器 第10章 基于Linux服务器的性能分析与优化
高性能Linux服务器 第10章 基于Linux服务器的性能分析与优化 作为一名Linux系统管理员,最主要的工作是优化系统配置,使应用在系统上以最优的状态运行.但硬件问题.软件问题.网络环境等 ...
- Linux kprobe调试技术使用
kprobe调试技术是为了便于跟踪内核函数执行状态所设计的一种轻量级内核调试技术. 利用kprobe技术,可以在内核绝大多数函数中动态插入探测点,收集调试状态所需信息而基本不影响原有执行流程. kpr ...
- Linux内核调试技术——jprobe使用与实现
前一篇博文介绍了kprobes的原理与kprobe的使用与实现方式,本文介绍kprobes中的另外一种探測技术jprobe.它基于kprobe实现,不能在函数的任何位置插入探測点,仅仅能在函数的入口处 ...
- linux内核调试技术之printk
原创博客:欢迎转载,转载请注明出处https://i.cnblogs.com/EditPosts.aspx?postid=6218383 1.简介(基于s3c2440 linux) 在内核调试技术之中 ...
- linux应用调试技术之GDB和GDBServer
1.调试原理 GDB调试是应用程序在开发板上运行,然后在PC机上对开发板上得应用程序进行调试,PC机运行GDB,开发板上运行GDBServer.在应用程序调试的时候,pc机上的gdb向开发板上的GDB ...
- linux内核调试技术之修改内核定时器来定位系统僵死问题
1.简介 在内核调试中,会经常出现内核僵死的问题,也就是发生死循环,内核不能产生调度.导致内核失去响应.这种情况下我们可以采用修改系统内核中的系统时钟的中断来定位发生僵死的进程和函数名称.因为内核系统 ...
随机推荐
- wpf学习20180606
对象元素的子元素 有三类子元素:内容属性.集合项.值(类型转换) ------------------------------------------------------------------- ...
- mybatis_03_ mapper代理方式实现MyBatis的Dao编写
不是用mapper代理方式也能够实现,但是不推荐 Mapper代理的开发方式,程序员只需要编写mapper接口(相当于dao接口)即可.Mybatis会自动的为mapper接口生成动态代理实现类. 不 ...
- Java_冒泡排序_原理及优化
冒泡排序及其优化 一.原理及优化原理 1.原理讲解 冒泡排序即:第一个数与第二个数进行比较,如果满足条件位置不变,再把第二个数与第三个数进行比较.不满足条件则替换位置,再把第二个数与第三个数进行比较, ...
- java反射知识相关的文章
整理的反射相关的文章: (1).通俗理解反射(知乎):学习java应该如何理解反射? (2).关于反射比较深入的博文地址:深入解析Java反射(1) - 基础 贴出我反射调用代码:(craw,dept ...
- 7. Callable 创建线程的方式三
package com.gf.demo06; import java.util.concurrent.Callable; import java.util.concurrent.ExecutionEx ...
- Codeforces389D(SummerTrainingDay01-J)
D. Fox and Minimal path time limit per test:1 second memory limit per test:256 megabytes input:stand ...
- C# dev SearchLookUpEdit 和 RepositoryItemSearchLookUpEdit 测试
一.searchLookUpEdit 绑定数据源 DataTable DtCompany = new DataTable();//数据源表,自己写数据. searchLookUpEditCus_no. ...
- IIS服务器被配置为不列出此目录的内容
使用 IIS 管理器启用目录浏览. 打开 IIS 管理器. 在“功能”视图中,双击“目录浏览”. 在“目录浏览”页上,在“操作”窗格中单击“启用”.
- vue2 兼容ie8
推荐这个 https://cdn.jsdelivr.net/npm/ractive
- vue从入门到进阶:计算属性computed与侦听器watch(三)
计算属性computed 模板内的表达式非常便利,但是设计它们的初衷是用于简单运算的.在模板中放入太多的逻辑会让模板过重且难以维护.例如: <div id="example" ...