创建一个简单的debugfs文件系统节点

2024-05-27 11:58

本文主要是介绍创建一个简单的debugfs文件系统节点,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

有时为了调试方便,需要创建一个文件节点,供上层调用,下面是一个较简单的例子;

可以在其基础上,稍加修改名字,即可使用。

static ssize_t usb_hnp_show(struct file *file, char __user *user_buf,size_t count, loff_t *ppos)
{
//	char *buf;ssize_t ret;struct usb_device *udev = global_usb_device;if (udev == NULL){printk(KERN_ERR "%s:the usb_device is NULL\n", __func__);return -EFAULT;}dev_err(&udev->dev, "zsm %s\n", __func__);return ret;
}static ssize_t usb_hnp_store(struct file *file,const char __user *user_buf, size_t count,loff_t *ppos)
{char buf[32];ssize_t buf_size;struct usb_device *udev = global_usb_device;if (udev == NULL){printk(KERN_ERR "%s:the usb_device is NULL\n", __func__);return -EFAULT;}dev_err(&udev->dev, "zsm %s\n", __func__);buf_size = min(count, (size_t)(sizeof(buf)-1));if (copy_from_user(buf, user_buf, buf_size)) {dev_err(&udev->dev, "Failed to copy from user\n");return -EFAULT;}buf[buf_size] = 0;return buf_size;
}static const struct file_operations usb_hnp_node_fops = {.owner = THIS_MODULE,.open = simple_open,.read = usb_hnp_show,.write = usb_hnp_store,
};

注册部分代码可以放在一个probe函数里,如下:

	struct dentry *usb_hnp_dentry;usb_hnp_dentry = debugfs_create_file("enable_usb_hnp",S_IRUGO, NULL, NULL, &usb_hnp_node_fops);


编译运行后,生成的目录在

/sys/kernel/debug/ 下。


这篇关于创建一个简单的debugfs文件系统节点的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1007417

相关文章

【前端学习】AntV G6-08 深入图形与图形分组、自定义节点、节点动画(下)

【课程链接】 AntV G6:深入图形与图形分组、自定义节点、节点动画(下)_哔哩哔哩_bilibili 本章十吾老师讲解了一个复杂的自定义节点中,应该怎样去计算和绘制图形,如何给一个图形制作不间断的动画,以及在鼠标事件之后产生动画。(有点难,需要好好理解) <!DOCTYPE html><html><head><meta charset="UTF-8"><title>06

csu 1446 Problem J Modified LCS (扩展欧几里得算法的简单应用)

这是一道扩展欧几里得算法的简单应用题,这题是在湖南多校训练赛中队友ac的一道题,在比赛之后请教了队友,然后自己把它a掉 这也是自己独自做扩展欧几里得算法的题目 题意:把题意转变下就变成了:求d1*x - d2*y = f2 - f1的解,很明显用exgcd来解 下面介绍一下exgcd的一些知识点:求ax + by = c的解 一、首先求ax + by = gcd(a,b)的解 这个

hdu2289(简单二分)

虽说是简单二分,但是我还是wa死了  题意:已知圆台的体积,求高度 首先要知道圆台体积怎么求:设上下底的半径分别为r1,r2,高为h,V = PI*(r1*r1+r1*r2+r2*r2)*h/3 然后以h进行二分 代码如下: #include<iostream>#include<algorithm>#include<cstring>#include<stack>#includ

【Python编程】Linux创建虚拟环境并配置与notebook相连接

1.创建 使用 venv 创建虚拟环境。例如,在当前目录下创建一个名为 myenv 的虚拟环境: python3 -m venv myenv 2.激活 激活虚拟环境使其成为当前终端会话的活动环境。运行: source myenv/bin/activate 3.与notebook连接 在虚拟环境中,使用 pip 安装 Jupyter 和 ipykernel: pip instal

usaco 1.3 Prime Cryptarithm(简单哈希表暴搜剪枝)

思路: 1. 用一个 hash[ ] 数组存放输入的数字,令 hash[ tmp ]=1 。 2. 一个自定义函数 check( ) ,检查各位是否为输入的数字。 3. 暴搜。第一行数从 100到999,第二行数从 10到99。 4. 剪枝。 代码: /*ID: who jayLANG: C++TASK: crypt1*/#include<stdio.h>bool h

在cscode中通过maven创建java项目

在cscode中创建java项目 可以通过博客完成maven的导入 建立maven项目 使用快捷键 Ctrl + Shift + P 建立一个 Maven 项目 1 Ctrl + Shift + P 打开输入框2 输入 "> java create"3 选择 maven4 选择 No Archetype5 输入 域名6 输入项目名称7 建立一个文件目录存放项目,文件名一般为项目名8 确定

uva 10387 Billiard(简单几何)

题意是一个球从矩形的中点出发,告诉你小球与矩形两条边的碰撞次数与小球回到原点的时间,求小球出发时的角度和小球的速度。 简单的几何问题,小球每与竖边碰撞一次,向右扩展一个相同的矩形;每与横边碰撞一次,向上扩展一个相同的矩形。 可以发现,扩展矩形的路径和在当前矩形中的每一段路径相同,当小球回到出发点时,一条直线的路径刚好经过最后一个扩展矩形的中心点。 最后扩展的路径和横边竖边恰好组成一个直

day-51 合并零之间的节点

思路 直接遍历链表即可,遇到val=0跳过,val非零则加在一起,最后返回即可 解题过程 返回链表可以有头结点,方便插入,返回head.next Code /*** Definition for singly-linked list.* public class ListNode {* int val;* ListNode next;* ListNode() {}*

poj 1113 凸包+简单几何计算

题意: 给N个平面上的点,现在要在离点外L米处建城墙,使得城墙把所有点都包含进去且城墙的长度最短。 解析: 韬哥出的某次训练赛上A出的第一道计算几何,算是大水题吧。 用convexhull算法把凸包求出来,然后加加减减就A了。 计算见下图: 好久没玩画图了啊好开心。 代码: #include <iostream>#include <cstdio>#inclu

uva 10130 简单背包

题意: 背包和 代码: #include <iostream>#include <cstdio>#include <cstdlib>#include <algorithm>#include <cstring>#include <cmath>#include <stack>#include <vector>#include <queue>#include <map>