Linux内核设备驱动之虚拟文件系统笔记整理

/********************
 * 虚拟文件系统VFS
 ********************/

(1)VFS介绍

虚拟文件系统VFS作为内核的子系统,为用户空间程序提供了文件系统的相关接口。

VFS使得用户可以直接使用open()等系统调用而无需考虑具体文件系统和实际物理介质。

VFS提供了一个通用的文件系统模型,该模型囊括了我们所能想到的文件系统的常用功能和行为。通过这个抽象层,就可以实现利用通用接口对所有类新的文件系统进行操作。

a.调用模型

write(): 用户空间 -->

sys_write(): VFS -->

文件系统的写方法: 文件系统 -->

物理介质

(2)VFS采用的主要对象

VFS采用了面向对象的思路,采用一组数据结构来代表通用的文件对象。

这些结构体在包含数据的同时也包含了操作这些数据的指针。

VFS中包括了四个主要的对象类型。

a.超级块对象super_block

所有文件系统都必须实现超级块,该对象用于存储特定文件系统的信息,通常存储在磁盘的特定扇区中,每个文件系统只有一个超级块。

对于不基于磁盘的文件系统,比如基于内存的文件系统sysfs,linux会在使用现场创建超级块并将其保存到内存中。

超级块的结构体为super_block,定义在<linux/fs.h>。

超级块的操作方法结构体为super_operations,也定义在fs.h中。

创建、管理和销毁超级块对象的代码位于/fs/super.c。

在文件系统安装时,内核会调用alloc_super()函数从磁盘读取文件系统超级块,并将其信息填充到内存中的超级块对象中。

b.索引节点对象inode

索引节点对象包含了内核在操作文件或目录是需要的全部信息,如文件的访问控制权限,大小,拥有者,创建时间等。

系统把这些信息存储在一个单独的数据结构中,称为索引节点。

一个文件在内存中只有一个索引节点对象,特殊文件(比如管道和设备文件)也有其对应的索引节点。

inode结构体定义在<linux/fs.h>,其对应的操作函数结构体为inode_operations

c.目录项对象dentry

每个目录项对象代表一个路径中的特定部分,比如路径/bin/vi,/、bin和vi都属于目录项对象。

目录项对象没有对应的磁盘结构,VFS根据字符串形式的路径名现场创建。每个文件只对应一个dentry对象。

dentry结构体定义在<linux/dcache.h>中,对应的目录项操作函数结构体dentry_operations也定义在<linux/dcache.h>中。

d.文件对象file

文件对象表示进程已经打开的文件。这个对象在open的时候创建,在close的时候销毁。

因为多个进程可以同时打开和操作一个文件,所以一个文件可能在内存中有多个file对象。

文件对象由file结构体表示,定义在<linux/fs.h>中。file对象的操作函数结构体为file_operations,定义在<linux/fs.h>中。

这个函数集非常重要,其中包括了对文件的实际操作函数,用户空间调用write,最终会调用到file_operations里的write。

我们要实现一个char类型的字符设备,也就是要实现file_operations中支持的函数。

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对我们的支持。如果你想了解更多相关内容请查看下面相关链接

(0)

相关推荐

  • Linux中查看指定文件夹内各个子文件夹内的文件数量

    count脚本 #!/bin/sh numOfArgs=$# if [ $numOfArgs -ne 1 ]; then echo -e "Usage: \nbash $0 dirForCount" exit -1 fi # args ROOTDIR=$1 # core part find $ROOTDIR -maxdepth 1 -type d | sort | while read dir; do count=$(find "$dir" -type f | wc

  • 你可能不知道的一些linux文件权限管理方法

    为什么需要权限管理? 1.计算机资源有限,我们需要合理的分配计算机资源. 2.Linux是一个多用户系统,对于每一个用户来说,个人隐私的保护是十分重要的 目录的 rwx 权限 当前用户:vagrant:vagrant 创建 testdir 目录,进入 testdir 目录内.创建文件 test. $ mkdir testdir $ cd testdir $ touch test 修改 testdir 权限为 000,尝试执行 ls testdir $ chmod 000 testdir $ ls

  • python 读取Linux服务器上的文件方法

    使用Python语句,读取Linux远端服务器上的文件打印到控制台的代码实现: 下载包:paramiko import paramiko #服务器信息,主机名(IP地址).端口号.用户名及密码 hostname = "" port = 22 username = "" password = "" client = paramiko.SSHClient() client.set_missing_host_key_policy(paramiko.Au

  • Linux awk将文件某列按照逗号分隔的例子

    概述 当我们在处理线上故障的时候,经常会从数据库表查询出某个列. select product_id from order where user_id = 111; 查询出来的结果形式如下: 1 2 3 4 5 这个时候,我们通常会以 product_id in (1,2,3,4,5) 的形式去查找商品表,找出商品的详细信息.那么如何得到这个(1,2,3,4,5)呢.一种简单的做法就是利用awk. cat temp.txt | awk 'BEGIN{ORS=","} {print $0

  • Linux下制作给ARM开发板使用的文件系统

    1.Busybox源码请网上自行下载,编译方法请参考百度. 2.交叉编译工具链的设置也请先设置好. 如果以上1.2没有问题,那么可以使用以下脚本,制作一个给ARM开发板使用的文件系统. 可以自行定制使用,加入自己的Test demo. #!/bin/bash #yuanxin.yang develop 2015-07-05 #文件系统和Busybox的路径====>可自己定制 FILESYSTEM=/Softwave/filesystem #定义自己制作的文件系统存放的位置 BUSYBOX=/S

  • Linux shell查找文件显示行号和对应区间的内容

    概述 有时候我们需要在一个文件大小不断变化的日志文件里,找寻一些错误信息.这个时候我们可以用如下的小技巧,找出错误日志的内容. CAT的时候显示行号 cat -n cart.log | grep "支付失败" SED找到错误日志的内容 sed -n '1000,2000p' cart.log 由于我们通过CAT命令已经知道行号了,只需要使用SED,输入一个行号的大概范围,就可以详细的展示上下文的日志内容了. 小技巧 如果公司里没有完善的查看日志的工具,例如ELK.那么借助上面的小工具,

  • Linux命令行快速技巧之定位一个文件的方法

    我们都会有文件存储在电脑里 -- 目录.相片.源代码等等.它们是如此之多.也无疑超出了我的记忆范围.要是毫无目标,找到正确的那一个可能会很费时间.在这篇文章里我们来看一下如何在命令行里找到需要的文件,特别是快速找到你想要的那一个. 好消息是 Linux 命令行专门设计了很多非常有用的命令行工具在你的电脑上查找文件.下面我们看一下它们其中三个:ls.tree 和 find. ls 如果你知道文件在哪里,你只需要列出它们或者查看有关它们的信息,ls 就是为此而生的. 只需运行 ls 就可以列出当下目

  • Linux内核设备驱动之proc文件系统笔记整理

    /***************** * proc文件系统 *****************/ (1)/proc文件系统的特点和/proc文件的说明 /proc文件系统是一种特殊的.由软件创建的文件系统,内核使用它向外界导出信息,/proc系统只存在内存当中,而不占用外存空间. /proc下面的每个文件都绑定于一个内核函数,用户读取文件时,该函数动态地生成文件的内容.也可以通过写/proc文件修改内核参数 /proc目录下的文件分析  /proc/$pid 关于进程$pid的信息目录.每个进程

  • Python通过paramiko远程下载Linux服务器上的文件实例

    如下所示: #!/usr/local/bin/python # encoding:utf-8 import paramiko import os HOST_IP='59.110.12.72' REMOTE_PATH='/proc' REMOTE_FILENAME='meminfo' LOCAL_PATH='./proc' USERNAME='niu' PASSWORD='123456' def remote_scp(host_ip,remote_path,local_path,file_name

  • Linux系统中 /etc/fstab 文件的深入解读

    前言 [root@localhost ~]# cat /etc/fstab # # /etc/fstab # Created by anaconda on Sat Nov 3 12:03:31 2018 # # Accessible filesystems, by reference, are maintained under '/dev/disk' # See man pages fstab(5), findfs(8), mount(8) and/or blkid(8) for more in

随机推荐