在使用cat 命令读取proc 文件时,奇怪的发现读函数被执行了三次
proc 读函数代码片断(直接读取内核模块的某个变量值)
int proc_read_hello(char *page, char **start, off_t off, int count, int *eof,
void *data) {
len = sprintf(page, “hello\n”); //把global_buffer的内容显示给访问者
printk("aaaa\n");
*eof = 1;
return len;
}
执行dmesg发现会有3次打印
[40861.961063] aaaa
[40861.961093] aaaa
[40861.961115] aaaa
而hello只有一次
注意这个proc read 函数的原型,其中有一个变量 *eof,如果不将其置1,它会多触发一次读操作,将*eof 置1后,就会少一次执行。
另外两次打印是因为cat的执行过程调用了两次read操作
查看cat 命令的系统调用,可以用strace 命令查看,发现调用了两次read 函数,第一次读取所有的数据,第二次读到的长度为0,因为有两次读,所以会触发两次,如果自己写一个文件读函数,仅仅调用一次read 函数,则只会触发proc 读一次