英文缩写:MTD
英文全称:Month To Days
中文解释:月初到今日
编程领域
MTD(memory technology device内存技术设备)是用于访问memory设备(ROM、flash)的Linux的子系统。MTD的主要目的是为了使新的memory设备的驱动更加简单,为此它在硬件和上层之间提供了一个抽象的接口。MTD的所有源代码在/drivers/mtd子目录下。我将CFI接口的MTD设备分为四层(从设备节点直到底层硬件驱动),这四层从上到下依次是:设备节点、MTD设备层、MTD原始设备层和硬件驱动层。
mtd是字符设备,mtdblock是块设备可以看看dd命令的实现,在busybox里有补充:/dev/mtd/* 或者 /dev/mtd* 这两种表示方式一般表示的是字符设备/dev/mtdblock/* 或者 /dev/mtdblock* 这两种是块设备的表示方式mount 的一般都是块设备貌似dd只对字符设备进行 *** 作举例:The mtd0 is char device of mtdblock0. Create char mtd devices >>mknod /dev/mtd0 c 90 0>mknod /dev/mtd1 c 90 2 Linux系统中/dev/mtd与/dev/mtdblock的区别,即MTD字符设备和块设备的区别1. /dev/mtdN 是Linux 中的MTD架构中,系统自己实现的mtd分区所对应的字符设备,其里面添加了一些ioctl,支持很多命令,如MEMGETINFO,MEMERASE等。而mtd-util中的flash_eraseall等工具,就是以这些ioctl为基础而实现的工具,实现一些关于Flash的 *** 作。比如,mtd 工具中的 flash_eraseall中的:if (ioctl(fd, MEMGETINFO, &meminfo) != 0) { fprintf(stderr, "%s: %s: unable to get MTD device info\n", exe_name, mtd_device) return 1}其中,MEMGETINFO,就是Linux MTD中的drivers/mtd/nand/mtdchar.c中的:static int mtd_ioctl(struct inode *inode, struct file *file, u_int cmd, u_long arg){。。。。。case MEMGETINFO: info.type = mtd->type info.flags = mtd->flags info.size = mtd->size info.erasesize = mtd->erasesize info.writesize = mtd->writesize info.oobsize = mtd->oobsize /* The below fields are obsolete */ info.ecctype = -1 info.eccsize = 0 if (copy_to_user(argp, &info, sizeof(struct mtd_info_user)))return -EFAULT break。。。}而/dev/mtdblockN,是Nand Flash驱动中,驱动在用add_mtd_partitions()添加MTD设备分区,而生成的对应的块设备。根据以上内容,也就更加明白,为什么不能用nandwrite,flash_eraseall,flash_erase等工具去对/dev/mtdblockN去 *** 作了。因为/dev/mtdblock中不包含对应的ioctl,不支持你这么 *** 作。2. mtd char 设备的主设备号是90,而mtd block设备的主设备号是31:# ls /dev/mtd? -l crw-r-----1 root root 90, 0 May 30 2007 /dev/mtd0crw-r-----1 root root 90, 2 May 30 2007 /dev/mtd1crw-r-----1 root root 90, 4 Jul 17 2009 /dev/mtd2crw-r-----1 root root 90, 6 May 30 2007 /dev/mtd3crwxrwxrwx1 root root 90, 8 May 30 2007 /dev/mtd4crwxrwxrwx1 root root 90, 10 May 30 2007 /dev/mtd5crwxrwxrwx1 root root 90, 12 May 30 2007 /dev/mtd6crwxrwxrwx1 root root 90, 14 May 30 2007 /dev/mtd7crwxrwxrwx1 root root 90, 16 May 30 2007 /dev/mtd8crwxrwxrwx1 root root 90, 18 May 30 2007 /dev/mtd9# ls /dev/mtdblock? -lbrw-r-----1 root root 31, 0 May 30 2007 /dev/mtdblock0brw-r-----1 root root 31, 1 May 30 2007 /dev/mtdblock1brw-r-----1 root root 31, 2 May 30 2007 /dev/mtdblock2brw-r-----1 root root 31, 3 May 30 2007 /dev/mtdblock3brwxrwxrwx1 root root 31, 4 May 30 2007 /dev/mtdblock4brwxrwxrwx1 root root 31, 5 May 30 2007 /dev/mtdblock5brwxrwxrwx1 root root 31, 6 May 30 2007 /dev/mtdblock6brwxrwxrwx1 root root 31, 7 May 30 2007 /dev/mtdblock7brwxrwxrwx1 root root 31, 8 May 30 2007 /dev/mtdblock8brwxrwxrwx1 root root 31, 9 May 30 2007 /dev/mtdblock9此设备号,定义在/include/linux/mtd/mtd.h中 :#define MTD_CHAR_MAJOR 90#define MTD_BLOCK_MAJOR 313. 其中,mtd的块设备的大小,可以通过查看分区信息获得:# cat /proc/partitionsmajor minor #blocks name31 0 1024 mtdblock031 1 8192 mtdblock131 2 204800 mtdblock231 3 65536 mtdblock331 4 225280 mtdblock4上面中显示的块设备大小,是block的数目,每个block是1KB。而每个字符设备,其实就是对应着上面的每个块设备。即/dev/mtd0对应/dev/mtdblock0,其他以此类推。换句话说,mtdblockN的一些属性,也就是mtdN的属性,比如大小。4。对每个mtd字符设备的 *** 作,比如利用nandwrite去对/dev/mtd0写数据,实际就是 *** 作/dev/mtdblock0。而这些 *** 作里面涉及到的偏移量offset,都指的是此mtd 分区内的偏移。比如向/dev/mtd1的offset为0的位置写入数据,实际 *** 作的是物理偏移offset=/dev/mtd0的大小=1MB=0x100000。如何挂载ubi文件系统
Linux 系统中有关mtd和ubi的接口:
(1) cat /proc/mtd:可以看到当前系统的各个mtd情况,
(2) cat /proc/partitions: 分区信息,有上面的类似
(3) cat /sys/class/ubi/ubi0/*:当前系系统的ubi情况
(4) ls /dev/*, 查看设备节点
假设我们想在mtdblock1上加载ubifs文件系统,步骤如下:
(1)./ubiformat /dev/mtd1 -----格式化mtdblock1
(2)./ubiattach /dev/ubi_ctrl -m 1 -----将mtdblock1与ubi建立连接,命令输出如下:
[ 977.342492] UBI: attaching mtd1 to ubi2
[ 977.346417] UBI: physical eraseblock size: 131072 bytes (128 KiB)
[ 977.352631] UBI: logical eraseblock size:126976 bytes
[ 977.357948] UBI: smallest flash I/O unit:2048
UBI device number 2, total 2000 LEBs (253952000 bytes, 242.2 MiB), available 1976 LEBs (250904576 bytes, 239.3 MiB), LEB size 126976 bytes (124.0 KiB)
系统自动将mtd1关连到ubi2上,假设系统中已经存在ubi0, ubi1了。
(3) ls /sys/class/ubi/ -----可以看到该目录下增加了一个ubi2的子目录
(4) cat /sys/class/ubi/ubi2/dev -----可以得到该ubi2设备的主次设备号,如249:0
(5) cat /sys/class/ubi/ubi2/volumes_count -----结果为0,表示该ubi上没有任何volume
(6) ls /dev/ubi* -----如果/dev中没有ubi2, 则手工创建“mknod /dev/ubi2 c 249 0”
(7) ./ubimkvol /dev/ubi2 -s 100MiB -N my_ubi_vol -----在ubi2上创建一个volume
(8) ls /sys/class/ubi/ -----可以看到该目录下增加一个ubi2_0的目录,代表ubi2上的第一个volume,如果哦“cat /sys/class/ubi/ubi2_0/name”, 你可以得到“my_ubi_vol”,这就是(7)中的名字。
(9) cat /sys/class/ubi/ubi2_0/dev -----得到该volume的主次设备号,如249:1
(10) mknod /dev/ubi2_0 c 249 1 -----如果/dev中没有ubi2_0, 则需要手工创建
(11) mount -t ubifs ubi2_0 /mnt -----将ubi2_0挂载到本地目录 /mnt上,
(12) mount -----可以看到ubi2_0成功挂载在/mnt上。
至此ubifs 装载成功。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)