FLASH驱动框架
App open,read,write
--------------------------------------------------
VFS sys_open,sys_read,sys_write
--------------------------------------------------
FS ----------- Vfat,ext2,yaffs
|--------------------------------
字符设备驱动 块设备驱动
|--------------------------------
| | | MTD
|RAMBLOCK|硬盘 -----------------
| | |NAND | NOR
| | |协议 ----------- 协议层:知道往某地址写某数据来识别,擦除,烧写
| | | |jedec | cfi
| | | 硬件相关 最小差异:基地址,位宽
---------------------------------------------------
硬件
---------------------------------------------------
nand协议 知道发什么来擦除,R/W
硬件相关 知道怎么发命令/地址
MTD 知道怎么优化
NOR硬件相关:
① 分配 map_info 结构体
② 设置 phys,size,bankwidth,virt
③ 使用 do_map_probe,add_mtd_partitions
内核自带的NOR FLASH驱动 drivers\mtd\maps\physmap.c
测试1:通过配置内核支持NOR FLASH
1. make menuconfig
-> Device Drivers
-> Memory Technology Device (MTD) support
-> Mapping drivers for chip access
CFI Flash device in physical memory map
(0x0) Physical start address of flash mapping // 物理基地址
(0x1000000) Physical length of flash mapping // 长度 大于NOR FLASH的真实长度
(2) Bank width in octets (NEW) // 位宽
2. make modules
cp drivers/mtd/maps/physmap.ko /work/nfs_root/first_fs
3. 启动开发板
ls /dev/mtd*
insmod physmap.ko
ls /dev/mtd*
cat /proc/mtd
测试2: 使用自己写的驱动程序:
1. ls /dev/mtd*
2. insmod s3c_nor.ko
3. ls /dev/mtd*
4. 格式化: flash_eraseall -j /dev/mtd1
5. mount -t jffs2 /dev/mtdblock1 /mnt
在/mnt目录下操作文件
用内存模拟MTD ---- mtdram.c
NOR FLASH识别过程:
do_map_probe("cfi_probe", s3c_nor_map);
drv = get_mtd_chip_driver(name)
ret = drv->probe(map); // cfi_probe.c
cfi_probe
mtd_do_chip_probe(map, &cfi_chip_probe);
cfi = genprobe_ident_chips(map, cp);
genprobe_new_chip(map, cp, &cfi)
cp->probe_chip(map, 0, NULL, cfi)
cfi_probe_chip
// 进入CFI模式
cfi_send_gen_cmd(0x98, 0x55, base, map, cfi, cfi->device_type, NULL);
// 看是否能读出"QRY"
qry_present(map,base,cfi)
.....
do_map_probe("jedec_probe", s3c_nor_map);
drv = get_mtd_chip_driver(name)
ret = drv->probe(map); // jedec_probe
jedec_probe
mtd_do_chip_probe(map, &jedec_chip_probe);
genprobe_ident_chips(map, cp);
genprobe_new_chip(map, cp, &cfi)
cp->probe_chip(map, 0, NULL, cfi)
jedec_probe_chip
// 解锁
cfi_send_gen_cmd(0xaa, cfi->addr_unlock1, base, map, cfi, cfi->device_type, NULL);
cfi_send_gen_cmd(0x55, cfi->addr_unlock2, base, map, cfi, cfi->device_type, NULL);
// 读ID命令
cfi_send_gen_cmd(0x90, cfi->addr_unlock1, base, map, cfi, cfi->device_type, NULL);
// 得到厂家ID,设备ID
cfi->mfr = jedec_read_mfr(map, base, cfi);
cfi->id = jedec_read_id(map, base, cfi);
// 和数组比较
jedec_table
从uboot上读到的内容和该文件一样
实验截图
第一次是没有分区的:
第二次是有分区的:
往NOR FLASH中存放1.txt文件后重启系统依然存在并可用,表示NOR FLASH驱动成功
操作NOR FLASH所需的命令,正确的命令才能是NOR FLASH正常工作
http://blog.csdn.net/sanmaoljh/article/details/51103184