调试手段之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里成长,我的领路人就是窝窝,这里对他表示感谢!!

评论(3) 浏览(16218)

Copyright @ 2013-2015 蜗窝科技 All rights reserved. Powered by emlog