ubuntu/linux mint 创建proc文件的三种方法(二)
在做内核驱动开发的时候,可以使用/proc下的文件,获取相应的信息,以便调试。
大多数/proc下的文件是只读的,但为了示例的完整性,都提供了写方法。
方法一:使用create_proc_entry创建proc文件(简单,但写操作有缓冲区溢出的危险);
方法二:使用proc_create和seq_file创建proc文件(较方法三简洁);
方法三:使用proc_create_data和seq_file创建proc文件(较麻烦,但比较完整);
示例四:在proc文件中使用内核链表的一个示例(用的方法三)。
--------------------------------------------------------------------------------------------------------------------
二、
proc_test02.c 源码
#include <linux/module.h> #include <linux/init.h> #include <linux/kernel.h> #include <linux/fs.h> // for basic filesystem #include <linux/proc_fs.h> // for the proc filesystem #include <linux/seq_file.h> // for sequence files #include <linux/jiffies.h> // for jiffies #include <linux/slab.h> // for kzalloc, kfree #include <linux/uaccess.h> // for copy_from_user #define BUF_SIZE 128 // global var static char *str = NULL; // seq_operations -> show static int jif_show(struct seq_file *m, void *v) { char buf[BUF_SIZE]; int ret = 0; ret = sprintf(buf, "current kernel time is %llu\n", (unsigned long long) get_jiffies_64()); ret += sprintf(buf + ret, "str is %s\n", str); seq_printf(m, "%s", buf); return 0; //!! must be 0, or will show nothing T.T } // file_operations -> write static ssize_t jif_write(struct file *file, const char __user *buffer, size_t count, loff_t *f_pos) { //分配临时缓冲区 char *tmp = kzalloc((count+1), GFP_KERNEL); if (!tmp) return -ENOMEM; //将用户态write的字符串拷贝到内核空间 //copy_to|from_user(to,from,cnt) if (copy_from_user(tmp, buffer, count)) { kfree(tmp); return -EFAULT; } //将str的旧空间释放,然后将tmp赋值给str kfree(str); str = tmp; return count; } // seq_operations -> open static int jif_open(struct inode *inode, struct file *file) { return single_open(file, jif_show, NULL); } static const struct file_operations jif_fops = { .owner = THIS_MODULE, .open = jif_open, .read = seq_read, .write = jif_write, .llseek = seq_lseek, .release = single_release, }; // module init static int __init jif_init(void) { struct proc_dir_entry* jif_file; jif_file = proc_create("jif", 0, NULL, &jif_fops); if (NULL == jif_file) { return -ENOMEM; } return 0; } // module exit static void __exit jif_exit(void) { remove_proc_entry("jif", NULL); kfree(str); } module_init(jif_init); module_exit(jif_exit); MODULE_AUTHOR("aran"); MODULE_LICENSE("GPL");
Makefile文件:
obj-m := proc_test02.o KERNEL := /lib/modules/`uname -r`/build #for mint/ubuntu #KERNEL := /lib/modules/`uname -r`/source #for redhat all: make -C $(KERNEL) M=`pwd` modules install: make -C $(KERNEL) M=`pwd` modules_install depmod -A clean: make -C $(KERNEL) M=`pwd` clean
测试结果:
郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。