使用接口proc_create调试代码

#include <linux/module.h>
#include <linux/init.h>
#include <asm/uaccess.h>
#include <linux/kernel.h>
#include <linux/proc_fs.h>
#include <linux/moduleparam.h>

#define BUFSIZE  100

MODULE_LICENSE("Dual BSD/GPL");
MODULE_AUTHOR("Tan xujia");

static int irq = 20;
module_param(irq , int, 0660);
static int mode = 1;
module_param(mode , int, 0660);

static struct proc_dir_entry *ent;

static
ssize_t proc_write(struct file *file, const char __user *ubuf, size_t count, loff_t *ppos) 
{
    int num, ret, index, m;
    char buf[BUFSIZE];
    if(*ppos > 0 || count > BUFSIZE)
        return -EFAULT;
    if(copy_from_user(buf, ubuf, count))
        return -EFAULT;
    num = sscanf(buf, "%d %d",&index, &m);
    if(num != 2)
        return -EFAULT;
    irq = index; 
    mode = m;
    ret = strlen(buf);
    *ppos = ret;
    return ret;
}

static
ssize_t proc_read(struct file *file, char __user *ubuf,size_t count, loff_t *ppos) 
{
    char buf[BUFSIZE];
    int len = 0;
    if(*ppos > 0 || count < BUFSIZE)
        return 0;
    len += sprintf(buf,"irq = %d\n",irq);
    len += sprintf(buf + len,"mode = %d\n",mode);

    if(copy_to_user(ubuf,buf,len))
        return -EFAULT;
    *ppos = len;
    return len;
}

static struct file_operations proc_ops =
{
    .owner = THIS_MODULE,
    .read = proc_read,
    .write = proc_write,
};

static int proc_init(void)
{
    ent = proc_create("mydev", 0666, NULL, &proc_ops);
    if(!ent)
        printk("proc_create fail\n");
    printk("proc_init\n");
    return 0;
}

static
void proc_cleanup(void)
{
    if(ent)
    proc_remove(ent);
    printk("proc_cleanup\n");
}

module_init(proc_init);
module_exit(proc_cleanup);
obj-m := proc.o

proc-objs := proc_dev.o

all:
	make -C /usr/src/kernels/$(shell uname -r) M=$(shell pwd) modules

clean:
	make -C /lib/modules/$(shell uname -r)/build M=$(shell pwd) clean

在这里插入图片描述

在这里插入图片描述

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
`proc_create`是一个函数,用于在`/proc`目录下创建一个新的proc文件。它的语法如下: ```c struct proc_dir_entry *proc_create(const char *name, umode_t mode, struct proc_dir_entry *parent, const struct file_operations *proc_fops); ``` 其中,`name`是要创建的proc文件的名称,`mode`是文件的访问权限,`parent`是要将文件添加到的父目录,`proc_fops`是一个指向文件操作结构的指针,用于定义文件的操作。 下面是一个示例,演示如何使用`proc_create`函数创建一个名为`mytest`的proc文件: ```c #include <linux/module.h> #include <linux/proc_fs.h> #include <linux/uaccess.h> #define MYTEST_PROC_FILE "mytest" static struct proc_dir_entry *mytest_proc_file; static ssize_t mytest_proc_file_read(struct file *file, char __user *buf, size_t count, loff_t *ppos) { // 读取文件内容并将其写入用户空间缓冲区 return 0; } static ssize_t mytest_proc_file_write(struct file *file, const char __user *buf, size_t count, loff_t *ppos) { // 从用户空间缓冲区读取数据并将其写入文件 return count; } static const struct file_operations mytest_proc_file_fops = { .owner = THIS_MODULE, .read = mytest_proc_file_read, .write = mytest_proc_file_write, }; static int __init mytest_init(void) { // 在/proc目录下创建mytest文件 mytest_proc_file = proc_create(MYTEST_PROC_FILE, 0666, NULL, &mytest_proc_file_fops); if (!mytest_proc_file) { printk(KERN_ERR "Failed to create /proc/%s\n", MYTEST_PROC_FILE); return -ENOMEM; } printk(KERN_INFO "/proc/%s created\n", MYTEST_PROC_FILE); return 0; } static void __exit mytest_exit(void) { // 删除mytest文件 proc_remove(mytest_proc_file); printk(KERN_INFO "/proc/%s removed\n", MYTEST_PROC_FILE); } module_init(mytest_init); module_exit(mytest_exit); ```

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值