/proc用户和内核之间通信

常用函数

 19 extern struct proc_dir_entry *proc_mkdir(const char *, struct proc_dir_entry *);
 20 extern struct proc_dir_entry *proc_mkdir_data(const char *, umode_t,
 21                           struct proc_dir_entry *, void *);
 
 30 static inline struct proc_dir_entry *proc_create(                                                            
 31     const char *name, umode_t mode, struct proc_dir_entry *parent,
 32     const struct file_operations *proc_fops)
 33 {    
 34     return proc_create_data(name, mode, parent, proc_fops, NULL); 
 35 } 

海思代码举例

 826 #define FHDRV_CREATE_PROC_ENTRY(NAME, FUNC) \                                                               
 827         proc_create(NAME, 0, NULL, &FUNC);

 733 static int fhdrv_kdrv_bootflag_proc_show(struct seq_file *seq, void *v)                                     
 734 {
 	...//业务逻辑代码
 }
 //实现接口
 767 static int fhdrv_kdrv_bootflag_proc_open(struct inode *inode, struct file *file)                            
 768 {
 769     return single_open(file, fhdrv_kdrv_bootflag_proc_show, NULL);
 770 }
 
 //填写file_operation结构体
 810 static const struct file_operations fhdrv_kdrv_bootflag_proc_func = {
 811     .owner      = THIS_MODULE,
 812     .open       = fhdrv_kdrv_bootflag_proc_open,
 813     .read       = seq_read,                                                                                 
 814     .llseek     = seq_lseek,
 815     .release    = single_release,
 816 };
 
 858 int add_mtd_partitions(struct mtd_info *master,
 859                const struct mtd_partition *parts,
 860                int nbparts)
 861 { 
 //创建proc目录
 891     p = proc_mkdir("driver/fhdrv_kdrv", NULL);
 892     if (!p) {
 893         printk(KERN_ERR "Failed to create <%s> !\n", "driver/fhdrv_kdrv");
 894         return 0;
 895     }
 896     res = FHDRV_CREATE_PROC_ENTRY("driver/fhdrv_kdrv/bootflag",fhdrv_kdrv_bootflag_proc_func);
 897     if ( NULL == res ) {
 898         printk(KERN_ERR "Failed to create /proc/driver/fhdrv_kdrv/bootflag.\n");
 899         goto fail_flag;
 900     }
 }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Linux中的proc文件系统是一种虚拟文件系统,它将系统内核中的信息以文件的形式呈现给用户空间。用户可以通过读取和写入这些文件来与内核进行通信proc文件系统中的文件包含了系统的各种信息,如进程信息、内存信息、网络信息等。用户可以通过读取这些文件来获取系统的状态信息,也可以通过写入这些文件来修改系统的配置参数。因此,proc文件系统是实现用户内核通信的一种重要方式。 ### 回答2: Linux中的proc文件系统是一种特殊的文件系统,它将系统中的进程信息以文件的形式暴露出来,使用户空间和内核空间可以通过文件访问的方式进行通信。 在proc文件系统中,每个进程都被视为一个目录,目录的名称为进程的PID(进程标识符)。每个PID目录下都包含了一系列的文件,这些文件用于描述进程的不同属性和状态。 用户空间可以通过读取proc文件系统中的文件来获取进程的信息。例如,/proc/<PID>/status文件中包含了关于进程的各种状态信息,如进程的PID、父进程的PID、进程运行状态等等。用户可以通过读取这个文件来了解进程的当前状态。 此外,proc文件系统中的一些文件可以被用户写入,以改变进程的一些属性或执行一些操作。例如,/proc/<PID>/oom_adj文件可以被用户写入一个整数值,以调整进程在系统内存不足时被杀死的优先级。用户可以通过写入这个文件来改变进程的oom_adj优先级。 而在内核空间中,内核可以通过proc文件系统来与用户空间通信内核可以通过创建和修改proc文件系统中的文件,向用户空间提供系统的信息或接收用户空间的请求。 总之,proc文件系统通过文件的形式提供了用户空间和内核空间之间通信接口。用户空间可以通过读取和写入proc文件系统中的文件来获取和控制进程的信息,而内核空间则可以通过创建和修改proc文件系统中的文件来与用户空间进行通信。这种基于文件的通信方式使得用户内核之间通信更加灵活和方便。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值