Linux MTD 子系统
一、MTD子系统概述
MTD(Memory Technology Device, 内存技术设备)是用于访问memory 设备 (ROM、FLASH)的Linux子系统。
主要目的是为了使新的memory设备的驱动更加简单,为此MTD在硬件和上层之间提供了一个抽象的接口。
Linux系统中,MTD设备分为四层:设备节点、MTD设备层、MTD原始设备层、硬件驱动层
1.1 FLASH硬件设备层
主要为FLASH芯片提供最底层的硬件驱动。此层提供了3个重要结构体:
(1) struct map info
用来描述具体芯片的基本信息,主要包括芯片名字、大小、位宽、芯片、在系统中的起始物理地址等,在具体的芯片驱动文件中定义。
(2) struct mtd partition
用来描述具体芯片的分区信息, 主要包括分区名字起始地址和分区的大小,在其体的芯片驱动文件中定义。
(3) struct mtd chip driver.
用于描述具体FLASH芯片的驱动数据结构,分别代表遵循具体标准的FLASH芯片驱动。
1.2 MTD原始设备层
MTD原始设备层主要源码文件为mtd/mtdcore.c、 mtd/mtdpart.c
MTD原始设备层主要提供此公共接口函数供其他MTD子系统模块调用,例如,add_mtd_device、 register_mtd_user等函数。
描述MTD原始设备的数据结构体为struct mtd_info,mtd_table则表示所有的MTD原始设备列表。
1.3 MTD设备层
为了使上层应用程序更方使地访问MTD原始设备,Linux 系统基于MTD原始设备定义了MTD的块设备(主设备号31)和字符设备(设备号90),
这样上层应用程序就可以像访间字符设备或块设备样访问 MTD原始设备,也就是可以把Nor FLASH或Nor FLASH的一个分区当做字符设备或块设备来访问。
MTD设备层的源码文件主要有mtd/mtdchar.c、mtd/mtd_blkdevs.c、 mtd/mtdblock.c
1.4 MTD字符设备
MTD字符设备层的源码文件为md/mtdcha.c.
该源码文件为MTD原始设备提供了一个字符设备访间接口,使得上层应用程序可以以字符设备的方式来访问MID原始设备。
mtd/mdchar.c 和其他的字符设备驱动文件一样, 主要定义了一个字符设备访问文件操作函数和向内核注册了一个字符设备,MTD字符设备的主设备号为90,源码如下:
#define MTD_CHAR_MAJOR 90
#define MTD_BLOCK_MAJOR 31 static const struct file_operations mtd_fops = {
.owner = THIS_MODULE,
.llseek = mtd_lseek,
.read = mtd_read,
.write = mtd_write,
.ioctl = mtd_ioctl,
.open = mtd_open,
.release = mtd_close,
};
以上代码定义了一个MTD字符设备的设备文件接口操作函数,接着在模块初始化函数中注册MTD字符设备:
static int __init init_mtdchar(void)
{
if (register_chrdev(MTD_CHAR_MAJOR, "mtd", &mtd_fops)) {
printk(KERN_NOTICE "Can't allocate major number %d for Memory Technology Devices.\n",
MTD_CHAR_MAJOR);
return -EAGAIN;
} register_mtd_user(¬ifier);
return ;
}
1.5 MTD 块设备
Mtd/mtd_blkdevs.c 源码文件提供了MTD转换层与块设备之间的接口。
该文件定义了块设备访问接口函数:
struct block_device_operations mtd_blktrans_ops = {
.owner = THIS_MODULE,
.open = blktrans_open,
.release = blktrans_release,
.ioctl = blktrans_ioctl,
.getgeo = blktrans_getgeo,
};
Add_mtd_blktrans_dev函数用来将一个 MTD转换层设备注册到内核中,每一个MTD转换层设备都对应个通用磁盘设备,Add_mtd_blktrans_dev 函数针对一个MTD转换层设备分配了一个磁盘设备结构体,并调用函数add_disk 注册磁盘设备到内核中。
块设备、磁盘设备、MTD转换层设备、MTD原始设备的关系如下图所示。
从图中可以看出,MTD转换层设备包含了MTD原始设备,磁盘设备包含了转换层设备,块设备又包含了磁盘设备。它们之间是一种类似的继承关系。
Mtd/mtdblock.c源码文件实现了MTD块设备层驱动,下面分析该源码文件的架构。
mtdblock.c主要定义了一个转换层设备操作函数接口,代码如下:
static struct mtd_blktrans_ops mtdblock_tr = {
.name = "mtdblock",
.major = ,
.part_bits = ,
.blksize = ,
.open = mtdblock_open,
.flush = mtdblock_flush,
.release = mtdblock_release,
.readsect = mtdblock_readsect,
.writesect = mtdblock_writesect,
.add_mtd = mtdblock_add_mtd,
.remove_dev = mtdblock_remove_dev,
.owner = THIS_MODULE,
};
然后在入口函数中调用register_mtd_blktrans(&mtdblock_tr) 注册一个转换层设备。
static int __init init_mtdblock(void)
{
return register_mtd_blktrans(&mtdblock_tr);
}
在register_mtd_blktrans函数中,对于每一个MTD原始设备,都会构造一个MTD转换层设备和对应的磁盘设备,然后把磁盘块设备注册到内核中(add_mtd_blktrans_devs)。
当应用程序访问MTD块设备时,先访问磁盘设备,然后找到对应的转换层设备,最终执行转换层设备对应的操作函数。
1.6 MTD块设备函数调用关系:
(1)应用程序通过open命令打开一个MTD块设备,如open(“mtdblock1”)。
(2)系统通过 struct block_device_operations mtd_blktrans_ops 操作接口找到对应的 open 函数为 blktrans_open,如执行blktrans_open函数。
(3)在blktrans_open 函数中,根据·块设备找到磁盘设备、MTD转换层设备,然后找到MTD转换层设备的操作函数 mtdblock_open。
(4)执行MTD转换层设备操作函数mtdblock_open。
二、MTD 子系统主要数据结构
重要的数据结构:
- mtd_info 表示mtd原始设备, 所有mtd_info结构体被存放在mtd_info数组mtd_table中
- mtd_part 表示MTD分区,其中包含了 mtd_info,每一个分区都是被看成一个MTD 原始设备
- map_info 描述芯片的基本信息,主要包括芯片名字,大小、位宽、起始地址
在mtd_table中,mtd_part.mtd_info中的大部分数据都从该分区的主分区mtd_part->master中获得
tip: master 不作为一个mtd原始设备加入 mtd_table
各层之间的交互如下图
Linux MTD 子系统的更多相关文章
- Linux MTD子系统 _从模型分析到Flash驱动模板
MTD(Memory Technology Device)即常说的Flash等使用存储芯片的存储设备,MTD子系统对应的是块设备驱动框架中的设备驱动层,可以说,MTD就是针对Flash设备设计的标准化 ...
- Linux MTD (Memory Technology Device) subsystem analysis -For Atheros char device
Linux MTD (Memory Technology Device) subsystem analysis For Atheros char device 读了Linux MTD 源代码分析 对这 ...
- linux输入子系统(input subsystem)之evdev.c事件处理过程
1.代码 input_subsys.drv.c 在linux输入子系统(input subsystem)之按键输入和LED控制的基础上有小改动,input_subsys_test.c不变. input ...
- Linux 网络子系统
今天记录一下Linux网络子系统相关的东西. 因为感觉对这一块还是有一个很大的空白,这件事情太可怕了. 摘抄多份博客进行总结一下Linux网络子系统的相关东西. 一. Linux网络子系统体系结构 L ...
- Linux时间子系统之六:高精度定时器(HRTIMER)的原理和实现
转自:http://blog.csdn.net/droidphone/article/details/8074892 上一篇文章,我介绍了传统的低分辨率定时器的实现原理.而随着内核的不断演进,大牛们已 ...
- Linux输入子系统(转)
Linux输入子系统(Input Subsystem) 1.1.input子系统概述 输入设备(如按键,键盘,触摸屏,鼠标等)是典型的字符设备,其一般的工作机制是低层在按键,触摸等动作发生时产生一个中 ...
- Linux VM子系统参数调整
Timesten数据库下的Linux page子系统参数调整 如果Timesten(TT)采用了Durablecommits或是share memory segment被lock的话,那么linux ...
- 【转】 linux iio子系统
原文网址:http://blog.csdn.net/tsy20100200/article/details/47101661 最近由于工作的需要,接触了Linux iio子系统,对于这个目录其实以前是 ...
- Linux输入子系统(Input Subsystem)
Linux输入子系统(Input Subsystem) http://blog.csdn.net/lbmygf/article/details/7360084 input子系统分析 http://b ...
随机推荐
- NSURLSession的作用
NSURLSession的作用: 1.全局配置: 2.任务生成与管理: 3.数据链接管理: po self.urlSession.delegateQueue.operations <__NSAr ...
- 使用 validate 进行输入验证
validate 官方教程网址: http://www.runoob.com/jquery/jquery-plugin-validate.html 在表单页面引入两个核心 js 文件 #官方的两个文件 ...
- letCode(771 Jewels and Stones )
问题描述: You're given strings J representing the types of stones that are jewels, and S representing th ...
- fuser ---显示出当前程序使用磁盘上的某个文件
fuser 可以显示出当前哪个程序在使用磁盘上的某个文件.挂载点.甚至网络端口,并给出程序进程的详细信息. fuser只把PID输出到标准输出,其他的都输出到标准错误输出. a 显示所有命令行中指定的 ...
- php异常处理的深入
引出 如果你调一个类,调用时数据验证时报了个错,你会以什么方式返回 数组,布尔值? 数组这个可以带错误原因回来,那布尔值呢? 返回了个 false, 报错时把错误放在类变量里?还是专门用一个获取错误的 ...
- Git学习总结(6)——作为一名程序员这些代码托管工具你都知道吗?
作为一名程序员这些代码托管工具你都知道吗? 作为一名优秀的开发者,大家都会用到代码托管,我本人用的是github,确实github里面有很多很多开源的项目,所以我们目前的创业项目程序员客栈www.pr ...
- 百度IOT
万物互联 http://www.jianshu.com/p/3d9846bf42bd 百度天工
- Java接口源码--System和应用程序进程间通信
本文參考<Android系统源代码情景分析>.作者罗升阳 一.架构代码: ~/Android/frameworks/base/core/java/android/os ----IInter ...
- vue11 vue实例方法
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- 暑假集训-WHUST 2015 Summer Contest #0.1
ID Origin Title 4 / 12 Problem A Gym 100589A Queries on the Tree 14 / 41 Problem B Gym 100589B Cou ...