debugfs调试学习

#include <linux/module.h>
#include <linux/kernel.h>
#include <linux/debugfs.h>
#include<linux/pci.h>
#include<linux/init.h>
#include<linux/debugfs.h>
#include<linux/dim.h>

static struct dentry *dir = NULL;
static unsigned int debugfs_hello;
static u32 sum = 0;

static int
add_write(void *data, u64 value)
{
    sum += value;
    return 0;
}

DEFINE_SIMPLE_ATTRIBUTE(add_ops, NULL, add_write, "%llu\n");

static __init int init(void)
{
    struct dentry *tmp_dir = NULL;
    dir = debugfs_create_dir("debugfs_hello", NULL);
    if (!dir) {
        printk(KERN_ALERT "debugfs_create_dir failed\n");
        return -1;
    }
    /*mode: rw*/
    debugfs_create_u32("hello", 0666, dir, &debugfs_hello);
    /*mode: w*/
    debugfs_create_file("add", 0222, dir, NULL, &add_ops);
    /*mode: r*/
    debugfs_create_u32("sum", 0444, dir, &sum);
    return 0;
}

static void __exit exit(void)
{
    printk(KERN_INFO "Exit debugfs_hello module\n");
    debugfs_remove_recursive(dir);
    dir = NULL;
}

module_init(init);
module_exit(exit);

MODULE_LICENSE("Dual BSD/GPL");
MODULE_DESCRIPTION("Debugfs hello examle");
/*
0666:
第一位0表示是一个8进制数
第二个数6是文件拥有者的读写,执行权限。
第三个数6是文件拥有者同组用户读写,执行权限
第三个数6是其它用户读写,执行权限

6:
二进制0110

第一位在权限中总是0,
第二位在权限中为0表示文件不可以被读,为1表示可以被读。
第三位在权限中为0表示文件不可以被写,为1表示可以被写。
第四位在权限中为0表示文件不可以被执行,为1表示可以被执行。
*/

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值