您的位置:首页 > 运维架构 > Linux

ubuntu/linux mint 创建proc文件的三种方法(两)

2015-07-15 14:04 696 查看
在这样做的内核驱动程序的开发时间。可以使用/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

// global var
static char *str = NULL;

// seq_operations -> show
static int jif_show(struct seq_file *m, void *v)
{
seq_printf(m, "current kernel time is %llu\n", (unsigned long long) get_jiffies_64());
seq_printf(m, "str is %s\n", str);

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

測试结果:

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: