调试手段之sys节点
作者:传奇不奇 发布于:2014-3-9 12:01 分类:Linux应用技巧
在我们调试自己驱动代码时,常用手段是日志输出,前面窝窝已说到,而且讲得比较深刻。这里我介绍另外一种调试方法,通过sys节点进行查看一些设备状态或者变量多少。通常一个版本release到测试部集成测试时,出现某个bug,还是偶现的,怎么办?不能说,我马上回去给个debug版本,让你重新测试吧,你不嫌麻烦,测试人员也会不高兴的,那么这里就可以把一些常用信息通过sys节点输出出来,现场查看。
例如,之前窝窝讲到print卡不能滥用,常用方式是宏开关重定义printk,来决定是否输出,或者输出到哪个地方。这个宏开关,可以是一个宏定义,那么在编译的bin文件不会出现,或者一个全局变量,在执行时走不同分支。这个全局变量就可以通过sys节点来进行控制。又比如,在一个模块中,我们需要知道该模块的运行状态,各个数据通路的状态发送了多少,接受多少等等,我们都可以从sys节点输出出来。
sys节点既然这么有用,我们怎么使用呢,以前linux常用的debugfs,在使用时需要mount一个debugfs,在usb 驱动核心里就提供了该方式的使用,而现在linux kernel 提供了更方便的,如果你只是想查看某个变量,你可以使用module_paramer 这中模块参数使用方法,该方法有几种方式,简单的查看设置该变量,则不需要提供set get 函数,如果除了设置该变量之外,还需要进行其他动作,那么可能需要你提供相应的get set 接口函数了。查看方式一般在/sys/module/XXXX/YYYY(XXXX为你的当前模块 名字,YYYY为你的变量名)。
另外一种是用方式,就是通过dev属性查看,窝窝已经讲到linux 2.6 以后提供了统一设备模型,整个就是dev和driver两条主线贯穿。而这里的调试方法就依赖于该设备了,通过dev 的attr来实现。这个dev在sys文件系统的路径,窝窝后续应该会提到,这里我也就不赘述。就是驱动要是没dev怎么 办,那么久创建一个dev,你创建的dev要是没父设备,也不属于某个class 或者某个bus,你只能在 /sys/phy_virl/下寻找了。这个单词应该有误,就是凡是无根的dev都以虚拟(伪)设备为它的父dev。sys节点在kernel中随处可见,有心的朋友都可以学学,我这里只是提供一个方向而已。
后续:
我从事linux时间不长,还需要继续在linux里成长,我的领路人就是窝窝,这里对他表示感谢!!

评论:
2014-03-10 10:36
我其实有计划在“linux内核分析”系列文章中,用一个专题分析内核的日志子系统,其实高版本内核的日志输出已经相当完善了,而且让人看着很爽,不像以前用着很别扭。
这个目标我们可以一起规划一下,看看怎么写。
PS:文中有一些错别字~~~
功能
最新评论
- wangjing
写得太好了 - wangjing
写得太好了! - DRAM
圖面都沒辦法顯示出來好像掛點了。 - Simbr
bus至少是不是还有个subsystem? - troy
@testtest:只要ldrex-modify-strex... - gh
Linux 内核在 sparse 内存模型基础上实现了vme...
文章分类
随机文章
文章存档
- 2025年4月(5)
- 2024年2月(1)
- 2023年5月(1)
- 2022年10月(1)
- 2022年8月(1)
- 2022年6月(1)
- 2022年5月(1)
- 2022年4月(2)
- 2022年2月(2)
- 2021年12月(1)
- 2021年11月(5)
- 2021年7月(1)
- 2021年6月(1)
- 2021年5月(3)
- 2020年3月(3)
- 2020年2月(2)
- 2020年1月(3)
- 2019年12月(3)
- 2019年5月(4)
- 2019年3月(1)
- 2019年1月(3)
- 2018年12月(2)
- 2018年11月(1)
- 2018年10月(2)
- 2018年8月(1)
- 2018年6月(1)
- 2018年5月(1)
- 2018年4月(7)
- 2018年2月(4)
- 2018年1月(5)
- 2017年12月(2)
- 2017年11月(2)
- 2017年10月(1)
- 2017年9月(5)
- 2017年8月(4)
- 2017年7月(4)
- 2017年6月(3)
- 2017年5月(3)
- 2017年4月(1)
- 2017年3月(8)
- 2017年2月(6)
- 2017年1月(5)
- 2016年12月(6)
- 2016年11月(11)
- 2016年10月(9)
- 2016年9月(6)
- 2016年8月(9)
- 2016年7月(5)
- 2016年6月(8)
- 2016年5月(8)
- 2016年4月(7)
- 2016年3月(5)
- 2016年2月(5)
- 2016年1月(6)
- 2015年12月(6)
- 2015年11月(9)
- 2015年10月(9)
- 2015年9月(4)
- 2015年8月(3)
- 2015年7月(7)
- 2015年6月(3)
- 2015年5月(6)
- 2015年4月(9)
- 2015年3月(9)
- 2015年2月(6)
- 2015年1月(6)
- 2014年12月(17)
- 2014年11月(8)
- 2014年10月(9)
- 2014年9月(7)
- 2014年8月(12)
- 2014年7月(6)
- 2014年6月(6)
- 2014年5月(9)
- 2014年4月(9)
- 2014年3月(7)
- 2014年2月(3)
- 2014年1月(4)
2014-03-10 14:31