Linux驱动中创建procfs接口的方法

上篇介绍了linux驱动中sysfs接口的创建,今天介绍procfs接口的创建。
procfs:可实现类似cat /proc/cpuinfo的操作
procfs接口创建实现效果:
例如, 在/proc下创建一个clk节点,通过cat /proc/clk可查看内容:
代码实现:
系统内核版本
linux 4.9.88
在驱动中添加以下代码:
#include #include #include #include #include struct proc_dir_entry *my_proc_entry;static int proc_clk_show(struct seq_file *m, void *v){ //cat显示的内容 seq_printf(m, pll0: %u mhz\\n pll1: %u mhz\\n pll2: %u mhz\\n, 100, 200, 300); return 0;}static int clk_info_open(struct inode *inode, struct file *filp){ return single_open(filp, proc_clk_show, null);}static struct file_operations myops = { .owner = this_module, .open = clk_info_open, .read = seq_read, .llseek = seq_lseek, .release = seq_release,};static int __init my_module_init(void){ //注册proc接口 my_proc_entry = proc_create(clk, 0644, null, &myops); return 0;}static void __exit my_module_exit(void){ //注销proc接口 proc_remove(my_proc_entry);}module_init(my_module_init);module_exit(my_module_exit);module_license(gpl);procfs接口的创建,主要是实现struct file_operations结构体,然后通过proc_create函数进行注册,通过proc_remove函数进行注销。
procfs通常是用来获取cpu、内存、进程等各种信息,例如cat /proc/cpuinfo、cat /proc/meminfo,所以我们只需要实现.open成员函数。 当使用cat命令查看/proc下的信息时,会调用到.open对应的实现函数。
这里我们使用了seq_file接口,需要记住的是, procfs通常会和seq_file接口一起使用 。 seq_file是一个序列文件接口, 当我们创建的proc数据内容由一系列数据顺序组合而成或者是比较大的proc文件系统时,都建议使用seq_file接口 ,例如cat /proc/meminfo就会显示很多内容。
seq_file接口主要就是解决proc接口编程存在的问题, 推荐在proc接口编程时使用seq_file接口 ,另外.read、.llseek、.release成员函数也可以直接用seq_read、seq_lseek和seq_release。
proc新接口注意,在较新版本的内核中,procfs的函数接口有所变化。
系统内核版本
linux 5.10.111
在驱动中添加以下代码:
#include #include #include #include #include struct proc_dir_entry *my_proc_entry;static int proc_clk_show(struct seq_file *m, void *v){ seq_printf(m, pll0: %lu mhz\\n pll1: %lu mhz\\n pll2: %lu mhz\\n, 100, 200, 300); return 0;}static int clk_info_open(struct inode *inode, struct file *filp){ return single_open(filp, proc_clk_show, null);}static const struct proc_ops clk_stat_proc_fops = { .proc_open = clk_info_open, .proc_read = seq_read, .proc_lseek = seq_lseek, .proc_release = seq_release,};static int __init my_module_init(void){ my_proc_entry = proc_create(clk, 0, null, &clk_stat_proc_fops); return 0;}static void __exit my_module_exit(void){ proc_remove(my_proc_entry);}module_init(my_module_init);module_exit(my_module_exit);module_license(gpl);新的proc接口中,将原来的struct file_operations换成了struct proc_ops,其中成员函数也添加了对应的前缀proc,但本质还是一样的,只是换了名字,更加规范了一些。

一体成型贴片电感封装尺寸和什么有关
关于“十四五”规划在三个方面布局人工智能的发展方向
浅谈一下无铅锡膏焊接后残留杂物与湿度之间的关系?
基于ZigBee的可穿戴脉搏心率采集设计
一套优质的MES系统,应该具备哪些特质?
Linux驱动中创建procfs接口的方法
MTK6737和MTK6739 LTE通信模块开发套件
蒲公英医疗监管平台方案
协作机器人拥有巨大优势,有望占领市场
低噪声运算放大器LMR1802G-LB及USB_2.0高速PCB设计要点
iPhone 12的A14处理器由台积电5nm工艺代工
CEVA授权许可奥迪康在助听器中用低功耗蓝牙技术
软密封蝶阀的特征_软密封蝶阀适用介质
应用分享 | “功耗低,唤醒快” — 这款 MCU 谁想要!
KT6368A双模蓝牙模块芯片修改蓝牙名_波特率_等等需要记忆的参数重要说明
传音控股入选2022广东省民营企业100强
大电流升压电路图
这届CES展会上获得了创新奖的工业AR产品长什么样?
深度解析交流单相电源滤波器:功效、应用与选购
开发一个VR网络浏览器需要注意以下这些事项