mtdlinux
⑴ 在linux的MTD中,函数int add_mtd_device(struct mtd_info *mtd)函数调用了:down(&mtd_table_mutex);
没弄过MTD,不过,mtd_table_mutex 从字面上看,这是一个锁。
up和down的作用是,在这期间,只能有一个访问。
保证一个互斥的作用。保护锁之间的资源。
详细,可以参考自旋锁、互斥锁等。
⑵ 在 LINUX/MTD 的驱动中,nand_chip *chip = mtd->priv
nand_chip结构体中包含了nand硬件相关的函数和变量。
“使用 MTD的原始设备结构体访问 NAND的硬件设备”指的是通过调用mtd结构体中元素nand_chip所包含的硬件相关函数来操作nand(读写、校验、坏块标记等)。
那个priv指的是private,本MTD结构体辖下的nand_chip。
⑶ linux里,如果我要在应用里读写在mtd下已经配置好的norflash时,怎么访问啊使用fread(),fwrite()吗
如果你的norflash分区没有被系统中其他模块使用,裸设备/dev/mtdx可以用fread()/fwrite()直接访问。
⑷ 在linux里面,如果在mtd里添加新的NorFlash驱动,那么新的NorFlash驱动的名字mtdX,x怎么确定,是动态的
add_mtd_partitions-->add_one_partition,这里面创建的。
内核结构一般是先初始化nor,然后初始化nand,
如果nandflash和norflash都用mtd分区,比如nor是两个,那就是mtd0和mtd1,
接着,是nand,依次增加。
⑸ 在Linux的MTD驱动程序中, 一个CFI的Flash具体是怎么由MTD驱动程序驱动的啊具体过程是什么啊
drivers/mtd/这个目录是MTD驱动的源码,结合书本看,
网上资料也有一些:http://www.cublog.cn/u/22617/showart_298745.html
⑹ linux mtd下已配置好nor flash,我在应用中怎么对nor flash进行读写
linux下的操作都是对文件的的操作,系统启动后通过挂载进行读写操作。如果在uboot阶段可以直接写地址的,
[email protected];
⑺ linux mtd 分区什么意思
日常用语
英文缩写:MTD
英文全称:Month To Days
中文解释:月初到今日
编程领域
MTD(memory technology device内存技术设备)是用于访问memory设备(ROM、flash)的Linux的子系统。MTD的主要目的是为了使新的memory设备的驱动更加简单,为此它在硬件和上层之间提供了一个抽象的接口。MTD的所有源代码在/drivers/mtd子目录下。我将CFI接口的MTD设备分为四层(从设备节点直到底层硬件驱动),这四层从上到下依次是:设备节点、MTD设备层、MTD原始设备层和硬件驱动层。
⑻ 嵌入式linux nand flash分区和mtd分区有什么不同
你可以发flash分成2个分区,root文件系统放系统文件,usr文件系统放程序文件
⑼ linux 中mtd设备一般用来干啥的 mtdblock呢,又是干啥的
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 (_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/mtd3crwxrwxrwx 1 root root 90, 8 May 30 2007 /dev/mtd4crwxrwxrwx 1 root root 90, 10 May 30 2007 /dev/mtd5crwxrwxrwx 1 root root 90, 12 May 30 2007 /dev/mtd6crwxrwxrwx 1 root root 90, 14 May 30 2007 /dev/mtd7crwxrwxrwx 1 root root 90, 16 May 30 2007 /dev/mtd8crwxrwxrwx 1 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/mtdblock3brwxrwxrwx 1 root root 31, 4 May 30 2007 /dev/mtdblock4brwxrwxrwx 1 root root 31, 5 May 30 2007 /dev/mtdblock5brwxrwxrwx 1 root root 31, 6 May 30 2007 /dev/mtdblock6brwxrwxrwx 1 root root 31, 7 May 30 2007 /dev/mtdblock7brwxrwxrwx 1 root root 31, 8 May 30 2007 /dev/mtdblock8brwxrwxrwx 1 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。
⑽ 在linux下用C怎么将“cat /proc/mtd”这条命令早终端打印出来,并执行该命令的结果。
根据你的意思,可以这样
#include<stdio.h>
#include<stdlib.h>
int main(){
system("./`cat /proc/mtd`");
return 0;
}
system() 函数就是调用shell。
`cat /proc/mtd` 就是取得这个命令的执行结果
./`cat /proc/mtd` 就是执行这个结果。
但是 在我的系统中执行cat /proc/mtd ,
cat: /proc/mtd: 没有那个文件或目录
所以没有办法测试,但是这个方法是对的。如果cat /proc/mtd的结果是很多个的话,最好加上cut命令 来作为取舍