kernel的调试方法一般常用的有jtag ,printk,proc,sys ,debugfile.. 关于这些的对比准备专门写一个,这里就主要介绍proc的调试方法。
/proc文件系统是一种特殊的,由软件创建的文件系统,内核使用它向外界导出信息。 /proc下面的每个文件都绑定一个内核函数,用户读取其中的文件时,该函数动态的生成文件的“内容”。
这样其实是给了我们一个函数的接口,在这个接口我们可以调用底层我们自己写的驱动函数,可以在其中加入自己想的打印什么的。有了这个接口我们就可以将驱动运行产生的中间值,局部变量输出出来供debug实用。他的缺点也很明显 已存在大量文件,不能调用太大的文件打印 函数必须已经写入到要调试的驱动中去。对比与产生的哈出这些缺点他的调试方法还是又存在的价值的。毕竟提供了一个上下层联系的接口。
proc 自己定义了读写函数,定义了注册函数,这些都是全局的。
int (*read_proc)(char *page, char **start, off_t offset, int count,
int *eof, void *data);
参数说明:
page : 用来写入数据的缓冲区;也就是说从/proc文件中读到的数据都写入到page指向的缓冲区中.
start: 用于指定实际的数据写入到page指向的内存页的具体的那个位置.
offset : 和read参数中的相同
count : 和read函数中的参数意义相同
eof : 当没有数据返回时,必须设置该参数为一个整数,例如: *eof = 1;
data : 该参数是内核提供给驱动程序的专用指针,可以用于内部记录
*创建只读/proc文件的函数
struct proc_dir_entry *create_proc_read_entry(const char *name,
mode_t mode, struct proc_dir_entry *base,
read_proc_t *read_proc, void * data)
参数说明:
name : 要创建的/proc下的文件名
mode : 创建的文件权限的掩码,若为0,则使用系统默认的权限
base : 该文件所在的父目录,若该参数为null,则该文件将会被创建在/proc的根目录下
read_proc : 读取/proc下的文件时调用的函数,也就是前面讲解的那个函数
data : 内核会忽略data,但会把该参数传递给read_proc函数
删除/proc系统文件的函数
void remove_proc_entry(const char *name, struct proc_dir_entry *parent)
参数说明:
name : 在/proc文件系统中创建的文件名
parent : 父目录名
参照上面的介绍我们就可以看是我们创造自己的proc/proc_test了
// test proc
#include <linux/module.h>
#include <linux/kernel.h>
#include <linux/proc_fs.h>
int proc_read_memory_drv(char *page, char **start, off_t off, int count,
int *eof, void *data);
void memory_drv_exit(void);
int memory_drv_init(void);
module_init(memory_drv_init);
module_exit(memory_drv_exit);
struct proc_dir_entry *memory_drv_file;
int proc_read_memory_drv(char *page, char **start, off_t off, int count,
int *eof, void *data)
{
int len;
len = sprintf(page, "test ok");
return len;
}
int memory_drv_init(void)
{
memory_drv_file = create_proc_entry("proc_test", S_IRUGO, NULL);
memory_drv_file->read_proc = proc_read_memory_drv;
return 0;
}
void memory_drv_exit(void)
{
remove_proc_entry("proc_test", NULL);
}
这样我们就完成了proc/proc_test 文件的建立
这样我们就可以把它加在我们想调试的驱动文件里面了
然后进入rootfs
进入proc
cd proc
列出文件
ll
可以看到proc_test
cat proc_test
就可以显示出来了我们打印的内容
test ok