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 ...
 
随机推荐
- CF209C Trails and Glades(欧拉路)
			
题意 最少添加多少条边,使无向图有欧拉回路. n,m≤106 题解 求出每个点的度数 奇度数点需要连一条新边 仅有偶度数点的连通块需要连两条新边 答案为上面统计的新边数 / 2 注意:此题默认以1为起 ...
 - 监控mysqld服务
			
#!/bin/bash #监控mysqld服务 #telnet 192.168.122.171 3306 | grep Connected | wc -l #远程检查 #num=`netstat -n ...
 - 新人   记录VUE中分页实现
			
关于函数传值 this.getPurchaseHistoryData(index, num,timeType);第一位是显示的页数,第二是控制首页4上一页-1下一页是2末页是5 第三是是对昨天是1,今 ...
 - 【深度学习大讲堂】首期第一讲:人工智能的ABCDE 第二部分:简谈当前AI技术与发展趋势
			
(完)
 - subline 快捷键与功能解释
			
选择类 Ctrl+D 选中光标所占的文本,继续操作则会选中下一个相同的文本. Alt+F3 选中文本按下快捷键,即可一次性选择全部的相同文本进行同时编辑.举个栗子:快速选中并更改所有相同的变量名.函数 ...
 - 【Codeforces Round #239 (Div. 1) B】 Long Path
			
[链接] 我是链接,点我呀:) [题意] 在这里输入题意 [题解] DP,设f[i]表示第一次到i这个房间的时候传送的次数. f[1] = 0,f[2] = 2 考虑第i个位置的情况. 它肯定是从i- ...
 - Thrift 基础教程(一)安装篇
			
1.Thrift简单介绍 Thrift是一款由Fackbook开发的可伸缩.跨语言的服务开发框架,该框架已经开源而且增加的Apache项目.Thrift主要功能是:通过自己定义的Interface D ...
 - C++语言笔记系列之十——静态成员
			
1.静态成员 (1)由keywordstatic修饰 静态变量定义语句在编译阶段就运行,运行过程中不再运行. (2)分类:静态数据成员.静态成员函数. (3)静态成员时类的全部对象共享的成员,而不是某 ...
 - Effective C++ 条款13
			
以对象管理资源 资源的种类非常多,动态分配的内存.文件描写叙述器.相互排斥锁.图像界面中画刷.数据库连接.网络socket等. 资源通常是有限的.当你不用时,必须释放.不然就会造成资源浪费.更严重的情 ...
 - Spring Security 4 Method security using @PreAuthorize,@PostAuthorize, @Secured, EL--转
			
原文地址:http://websystique.com/spring-security/spring-security-4-method-security-using-preauthorize-pos ...