• 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
    
    // 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
    ", (unsigned long long) get_jiffies_64());
    	seq_printf(m, "str is %s
    ", 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

    測试结果:


    版权声明:本文博客原创文章,博客,未经同意,不得转载。

  • 相关阅读:
    day08作业
    Python进制之间的转换
    day07作业
    Python之深浅拷贝详解
    day06作业
    Python流程控制-循环语句for、while
    Python条件语句-if
    Python变量类型之可变/不可变类型
    Cross platform
    Windows version PE System Key
  • 原文地址:https://www.cnblogs.com/hrhguanli/p/4648149.html
Copyright © 2020-2023  润新知