【Android驱动】创建proc文件节点的例子

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

#if 1
    #define chao_debug(x, ...)         printk(KERN_ALERT x, ##_VARGS_)
#else
    #define chao_debug(x, ...)         do{ } while(0)
#endif


struct proc_dir_entry *chao_proc_file = NULL;
struct proc_dir_entry *chao_proc_file = NULL;

#define MEM_SIZE                        100
static char mem[MEM_SIZE];

static ssize_t chao_file_read(struct file *flip, char *buf, size_t count, loff_t *pos)
{
    int ret = 0;
    
    chao_debug("qyc, count == %d, ppos = %d", count, *pos);
    ret = simple_read_from_buffer(buf, count, pos, mem, sizoef(mem));

    chao_debug("qyc -- %s--%s\n", __func__, mem);

    return ret;
    
}

static ssize_t chao_file_write(struct file* flip, const char *buf, size_t len, loff_t *pos)
{
    int ret = 0;

    if (len > MEM_SIZE)
        len = MEM_SIZE;

    chao_debug("chao_file_write len == %d\n", len);

    if(copy_from_user(mem, buf, len))
        return -EFAULT;
    else
        return len;

    chao_debug("qyc, ---%s---%s\n", __func__, mem);

    return ret;
}


static struct file_operations chao_file_ops = {
    
    .owner = THIS_MODULE,
    .read = chao_file_read,
    .write = chao_file_write,
};


/*
 * proc/android_chao/chao_file
 *
 */
#define CHAO_PROC_DIE                "android_chao"
#define CHAO_PROC_FILE                "chao_file"

static int __init proc_demo_init()
{
    memset(mem, 0, MEM_SIZE);

    chao_proc_file = proc_mkdir(CHAO_PROC_DIR, NULL);
    if (chao_proc_file == NULL) {
        chao_debug("chao proc dir create failed, %s\n", __func__);
        goto err_dir;
    }

    chao_proc_file = proc_create(CHAO_PROC_FILE, S_IWUSR|S_IRUSR, chao_proc_dir, &chao_file_ops);

    if(chao_proc_file == NULL) {
        chao_debug("%s, proc file crate failed !\n", __func__);
        goto err_file;
    }

err_dir:
    remove_proc_entry(CHAO_PROC_DIR, chao_proc_dir);
err_file:
    remove_proc_entry(CHAO_PROC_FILE, chao_proc_file);
}


static void __exit proc_demo_exit()
{
    if (chao_pric_dir == NULL)
        remove_proc_entry(CHAO_PROC_DIR, chao_proc_dir);;
    if(chao_proc_file == NULL)
        remove_proc_entry(CHAO_PROC_FILE, chao_proc_file);
}

MODULE_LICENSE("GPL");
MODULE_AUTHOR("qyichao");
module_init(proc_demo_init);
modulle_exit(proc_demo_exit);

  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在Linux系统中,/proc文件是一种虚拟文件系统,用于提供内核和进程信息的访问接口。驱动程序可以通过读取/proc文件来获取系统的运行状态、内核参数、硬件信息等。 首先,驱动程序需要打开/proc文件并读取其中的内容。在Linux内核中,可以使用标准的文件操作函数(如open、read和close)来完成这个操作。驱动程序可以通过指定/proc文件的路径,并调用open函数来打开文件。通过read函数可以读取文件的内容,并将结果存储在缓冲区中。最后,通过close函数关闭/proc文件。 读取/proc文件时,驱动程序必须以只读模式打开文件,并按照文档中所描述的格式解析文件内容。每个/proc文件都有一个特定的格式,常见的包括以换行符分隔的多行文本、键值对等。驱动程序需要按照相应的格式解析内容,并将所需的信息提取出来。 例如,驱动程序可以读取/proc/cpuinfo文件来获取CPU的相关信息,如型号、频率、核心数等。读取/proc/meminfo文件可以获取系统内存的使用情况。另外,还可以通过读取/proc/modules文件来获取加载的内核模块列表。 在读取/proc文件时,驱动程序需要注意文件的并发访问。由于/proc文件是全局资源,可能会被其他进程或驱动程序同时访问。为了保证数据的一致性和安全性,驱动程序可以采用互斥锁或读写信号量来进行同步操作。 总之,在Linux驱动程序中,通过读取/proc文件可以获取内核和进程的各种信息。驱动程序需要打开/proc文件、读取文件内容,并按照文件格式解析所需的信息。同时,需要注意并发访问的情况,保证数据的一致性和安全性。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值