linux驱动访问文件

简述:
使用filp_open()和struct file可以在驱动模块中访问其他文件。

定义的头文件:

#include <linux/fs.h>

例子:

#include <linux/fs.h>
#include <asm/uaccess.h>
static char buf[100];
static int __init dopen()
{
    mm_segment_t old_fs;
    ssize_t ret;
    struct file *filp = NULL;

    filp = filp_open(FILE_DIR, O_RDWR | O_CREAT, 0644);

    //    if(!filp)
    if(IS_ERR(filp))
        printk("open error...\n");

    old_fs = get_fs();//保存fs
    set_fs(get_ds());

    filp->f_op->write(filp, buff, strlen(buff), &filp->f_pos);

    filp->f_op->llseek(filp,0,0);
    ret = filp->f_op->read(filp, tmp, strlen(buff), &filp->f_pos);

    set_fs(old_fs);//恢复fs,

    if(ret > 0)
        printk("%s\n",tmp);
    else if(ret == 0)
        printk("read nothing.............\n");
    else
        {
            printk("read error\n");
            return -1;
        }
    return 0;
}

注意:
在调用filp->f_op->read和filp->f_op->write等对文件的操作之前,应该先设置FS(old_fs)。
默认情况下,filp->f_op->read或者filp->f_op->write会对传进来的参数buff进行指针检查。如果不是在用户空间会拒绝访问。因为是在内核模块中,所以buff肯定不在用户空间,所以要增大其寻址范围。

拿filp->f_op->write为例来说明:
filp->f_op->write最终会调用access_ok ==> range_ok.
而range_ok会判断访问的地址是否在0 ~ addr_limit之间。如果在,则ok,继续。如果不在,则禁止访问。而内核空间传过来的buff肯定大于addr_limit。所以要set_fs(get_ds())。
这些函数在asm/uaccess.h中定义。以下是这个头文件中的部分内容:

#define MAKE_MM_SEG(s)    ((mm_segment_t) { (s) })

#define KERNEL_DS    MAKE_MM_SEG(-1UL)
#define USER_DS        MAKE_MM_SEG(PAGE_OFFSET)

#define get_ds()    (KERNEL_DS)
#define get_fs()    (current_thread_info()->addr_limit)
#define set_fs(x)    (current_thread_info()->addr_limit = (x))

#define segment_eq(a, b)    ((a).seg == (b).seg)

可以看到set_fs(get_ds())改变了addr_limit的值。这样就使得从模块中传递进去的参数也可以正常使用了。

在写测试模块的时候,要实现的功能是写进去什么,然后读出来放在tmp数组中。但写完了以后filp->f_ops已经在末尾了,这个时候读是什么也读不到的,如果想要读到数据,则应该改变filp->f-ops的值,这就要用到filp->f_op->llseek函数了。

参考博客:
用户空间的open,read,write,llseek等函数在内核中对应的函数

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 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、付费专栏及课程。

余额充值