mtd_debug
[root@xmos /root]# mtd_debug
usage: mtd_debug info <device>
mtd_debug read <device> <offset> <len> <dest-filename>
mtd_debug write <device> <offset> <len> <source-filename>
mtd_debug erase <device> <offset> <len>
mtd_debug info
可以查看flash類型,塊大小,mtd分區總大小,大小以10進制顯示,分區大小就是len
mtd_debug write
把文件寫入mtd,offset和len可以用十進制也可以用16進制,16進制要以0x作前綴
len要小於等於文件長度和mtd分區大小
寫入之前要erase mtd分區
mtd_debug read
把文件寫入mtd,offset和len可以用十進制也可以用16進制,16進制要以0x作前綴
len要小於等於mtd分區大小
mtd_debug erase
擦除mtd分區
offset和len可以用十進制也可以用16進制,16進制要以0x作前綴
len要小於等於mtd分區大小
例如
mtd_debug read /dev/mtd2 0x0 0x00900000 config.img
flashcp
用來把flash鏡像寫入mtd分區
flashcp -v rootfs.image /dev/mtd1
該命令把erase,write,校驗一塊完成了
mtd_debug和flashcp執行的時候cpu占用比較高,會導致系統響應緩慢甚至死機,執行完就好了
dd的時候不要使用mtdblock作為設備名,mtdblock是ftl層,ftl轉換的效率很低,而且不安全,操作ftl不需要erase操作,完全像block設備一樣
在mtd-utils/ubi-utils中生成的工具是針對UBIFS的,包含:
(1)mtdinfo: 輸出指定的mtd分區的信息, 該命令只對可讀的設備分區有效。
用法: ./mtdinfo /dev/mtd1
(2)ubinfo: 輸出指定的ubi設備的信息,不帶參數時,輸出系統所有的ubi設備以及ubi控制設備信息。ubi控制設備即/dev/ubi_ctrl是一個字符設備,在后面還將用到。
用法:./ubinfo
./ubinfo /dev/ubi0
(3)ubiformat:格式化指定的mtd分區, 參數使用的是mtd的字符設備
用法:./ubiformat /dev/mtd1
(4)ubiattach:將指定的mtd分區關聯到ubi上
用法:./ubiattach /dev/ubi_ctrl -m 1, 將mtd1關連ubi
(5)ubidetach:解除mtd與ubi的關聯
用法:./ubidetach /dev/ubi_ctrl -m 1
(6)ubimkvol:創建一個voluem,volume才是最終用戶掛載文件系統的地方。
用法:在ubi2上創建4個olume,每個大小是20M, 名字分別為my_vol_a, my_vol_b, my_vol_c, my_vol_d.
./ubimkvol /dev/ubi2 -s 20Mib -N my_vol_a
./ubimkvol /dev/ubi2 -s 20Mib -N my_vol_b
./ubimkvol /dev/ubi2 -s 20Mib -N my_vol_c
./ubimkvol /dev/ubi2 -s 20Mib -N my_vol_d
我用上面的方法試了試,不行。下面是我的做法:
如果要建的volume大小是100MiB,100*1024*1024=104857600
ubimkvol /dev/ubi0 -N peng -s 104857600
mount -t ubifs ubi0:peng /mnt
注意:我用mount -t ubifs /dev/uib0_1 /mnt 出現錯誤。
(7)ubirename: 更改ubi某個olume的名字,或者完成兩個volume的互換
用法:
(1)將ubi2上名字為my_vol_a的volume名字改為my_vol_newname
./ubirename /dev/ubi2 my_vol_a my_vol_newname
(2)將ubi2上名字為my_vol_b和my_vol_c的兩個volume互換,
./ubirename /dev/ubi2 my_vol_b my_vol_c my_vol_c my_vol_b
(8)ubirmvol: 刪除某個volume,可以通過名字或id指定具體的volume
用法: ./ubirmvol /dev/ubi2 -n 1
或./ubirmvol /dev/ubi2 -N my_vol_d
(9)ubinize: 創建ubi image。
用法: ./ubinize -o myubi.img -p 126976 -m 2048 my.ini
其中, -p, 指定的是目標flash的physical eraseblock的大小
-s, 指定的是目標flash的minimum input/output unit 的大小, 這兩個參數的值可以通過“cat /sys/class/ubi/ubi2/*”得到
my.ini是配置文件,其中指定了原文件,目標volume的大小、名字等。其格式如小:
[jffs2-volume]
mode=ubi
image=../jffs2.img
vol_id=1
vol_size=30MiB
vol_type=dynamic
vol_name=jffs2_volume
vol_flags=autoresize
vol_alignment=1
(10)ubiupdatevol: 向指定的volume上寫數據
用法:./ubiupdatevol /dev/ubi2_0 myubi.img
mtd-utils工具命令的使用
1)
使用命令前用cat /proc/mtd 查看一下mtdchar字符設備;或者用ls -l /dev/mtd*
#cat /proc/mtd
dev: size erasesize name
mtd0: 00c00000 00020000 "ROOTFS"
mtd1: 00200000 00020000 "BOOTLOADER"
mtd2: 00200000 00020000 "KERNEL"
mtd3: 03200000 00020000 "NAND ROOTFS partition"
mtd4: 04b00000 00020000 "NAND DATAFS partition"
為了更詳細了解分區信息用mtd_debug命令
#mtd_debug info /dev/mtdX (不能使用mtdblockX, mtdblockX 只是提供用來 mount 而已)
mtd.type = MTD_NORFLASH
mtd.flags =
mtd.size = 12582912 (12M)
mtd.erasesize = 131072 (128K)
mtd.oobblock = 1
mtd.oobsize = 0
mtd.ecctype = (unknown ECC type - new MTD API maybe?)
regions = 0
2)
命令:flash_erase
作用:擦出指定范圍內flash的內容,如果不指定,默認擦出起始位置的第一塊,使相應flash變為全1
用法:
flash_erase MTD-device [start] [cnt (# erase blocks)] [lock]
MTD-device:待擦出的分區,如/dev/mtd0
start:起始位置設置,這里必須設置為0x20000(128K)的整數倍
cnt: 從start開始計算,要擦出的塊數
lock: 寫保護
eg: ./flash_erase /dev/mtd0 0x40000 5 //擦出mtd0分區上從0x40000開始的5塊數據 ,128K/塊
命令:flash_eraseall
作用:擦出整個分區的數據,同時也會作壞塊檢測
用法:
flash_eraseall [OPTION] MTD_DEVICE
-q, --quiet 不顯示打印信息
-j, --jffs2 一jffs2 格式化分區
eg: ./flash_eraseall -j /dev/mtd0
命令:flashcp
作用:copy 數據到 flash 中
用法:
usage: flashcp [ -v | --verbose ]
flashcp -h | --help
filename:待寫入的數據
device: 寫入的分區,如/dev/mtd0
eg:
filename制作:mkfs.jffs2 -e 0x20000 -d cq8401 -o cq8401.img -n //這里的-e 0x20000 必須更你芯片的erasesize 相等
./flashcp cq8401.img /dev/mtd0 // copy cq8401.img文件系統到 /dev/mtd0分區中
當然這個命令的功能跟 dd if=/tmp/fs.img of=/dev/mtd0差不多
命令:nandwrite
作用:向nand flash中寫數據
用法:
nandwrite [OPTION] MTD_DEVICE INPUTFILE
-a, --autoplace Use auto oob layout
-j, --jffs2 force jffs2 oob layout (legacy support)
-y, --yaffs force yaffs oob layout (legacy support)
-f, --forcelegacy force legacy support on autoplacement enabled mtd device
-n, --noecc write without ecc
-o, --oob image contains oob data
-s addr, --start=addr set start address (default is 0)
-p, --pad pad to page size
-b, --blockalign=1|2|4 set multiple of eraseblocks to align to
-q, --quiet don't display progress messages
--help display this help and exit
--version output version information and exit
eg: ./nandwrite -p /dev/mtd0 /tmp/rootfs.jffs2
命令:nanddump
作用:dump出nand flash一些信息,如:block size,erasesize,oobblock 大小,oob data ,page data等;同時也會作壞塊檢測
用法:
nanddump [OPTIONS] MTD-device
--help display this help and exit
--version output version information and exit
-f file --file=file dump to file
-i --ignoreerrors ignore errors
-l length --length=length length
-o --omitoob omit oob data
-b --omitbad omit bad blocks from the dump
-p --prettyprint print nice (hexdump)
-s addr --startaddress=addr start address
eg:./nanddump -p -f nandinfo.txt /dev/mtd0 //dump出nand flash /dev/mtd0數據並保存到 nandinfo.txt
命令:mtd_debug
作用: 對mtd 調試作用
用法:
usage: mtd_debug info
mtd_debug read
mtd_debug write
mtd_debug erase
eg:
#./mtd_debug info /dev/mtd0 // 輸出/dev/mtd0上的一些信息,這里必須用mtdx
#./mtd_debug erase /dev/mtd0 0x0 0x40000 // 擦出/dev/mtd0 分區上 從0x0開始的 , 128K*2 大小的數據
#./mtd_debug write /dev/mtdblock0 ox0 0x360810 cq8401.img //向mtdblock0分區,寫入 3.6M 大小的文件系統cq8401.img,這里最好用mtdblockx
#./mtd_debug read /dev/mtdblock0 ox0 0x360810 read.img //從mtdblock0中讀出 3.6M 數據保存到read.img
# cmp -l cq8401.img read.img // 驗證write to flash 和 read from flash 中的數據是否一致;也可以使用diff命令來比較
另外針對nand flash,mtd_debug這個工具來測試mtd驅動也不是很好,用nandwrite和nanddump這兩個工具或許更好點。然后可以用cmp這個命令來比較一下nanddump出來的數據和nandwrite寫入的數據是否一致。
命令:ftl_format
解 釋:In order to use one of conventional file systems (Ext2, ext3, XFS, JFS, FAT) over an MTD device, you need a software layer which emulates a block device over the MTD device. These layers are often called Flash Translation Layers (FTLs).
例一:如何測試nor flash 驅動
step1:
#./mtd_debug info /dev/mtd0 // 輸出/dev/mtd0上的一些信息,這里必須用mtdx
step2:
#./mtd_debug erase /dev/mtd0 0x0 0x40000 // 擦出/dev/mtd0 分區上 從0x0開始的 , 128K*2 大小的數據
step3:
#./mtd_debug write /dev/mtdblock0 ox0 0x360810 cq8401.img //向mtdblock0分區,寫入 3.6M 大小的文件系統cq8401.img,這里最好用mtdblockx
step4:
#./mtd_debug read /dev/mtdblock0 ox0 0x360810 read.img //從mtdblock0中讀出 3.6M 數據保存到read.img,當然這里的長度應該相等
step5:
# cmp -l cq8401.img read.img // 驗證write to flash 和 read from flash 中的數據是否一致;也可以使用diff命令來比較
例二:如何測試nand flash 驅動
其實nand flash 驅動同樣可以用例一的方法測試,但既然有nandwrite,nanddump命令,為何不用呢!
step1:
#./flash_eraseall -j /dev/mtd1 //用jffs2格式化該分區
step2:
#./nanddump -p /dev/mtd1 //dump出nand flash /dev/mtd1數據,可以看到現在的數據全是ff
step3:
#./nandwrite -p /dev/mtd1 cq8401.img // 將cq8401.img文件系統寫入mtd0分區
step4:
#./nanddump -p /dev/mtd1 //dump出nand flash /dev/mtd1數據,可以看到現在的數據不再是全ff
例三:如何用mtd-util 工具向nand flash寫入文件系統jffs2.img,並修改啟動參數,使文件系統從nand flash 啟動;假設已分好區,mtd0為文件系統分區
方式一:
step1:
NFS起文件系統
#./flash_eraseall -j /dev/mtd0 //用jffs2格式化該分區
#./nandwrite -j -f -p -q /dev/mtd0 jffs2.img // 將jffs2.img文件系統寫入mtd0分區
step2:
然后再看看我們新寫入的JFFS2文件系統能不能mount上.
#mount -t jffs2 /dev/mtdblock0 /mnt
#ls /mnt
setp3:
重啟開發板,在U-BOOT里 設置啟動參數
#setenv bootargs 'mem=64M console=ttyS0,115200n8 ip=192.168.4.201:::::eth0:off root=/dev/mtdblock0 rootfstype=jffs2 rw'
#reset
方式二:
NAND 起內核,NAND起文件系統
1. 網起文件系統
nerase 0 55 && nprog 0 192.168.4.200 n-boot.bin.hg && nprog 128 192.168.4.200 zImage-6pci && reset
2.進入網起的文件系統
cat /proc/mtd
3. 制作JIFFS的文件系統
mkfs.jffs2 -e 0x20000 -d root-vw -o dvr20000.img -n
4.
cp dvr20000.img /dev/mtdblock1
5.修改NAND BOOT啟動參數 include/cq8401_board.h
修改NAND BOOT
setenv bootargs 'mem=64M console=ttyS0,115200n8 ip=192.168.4.201:::::eth0:off root=/dev/mtdblock1 rootfstype=jffs2 rw'
6. 從新燒寫
nerase 0 55 && nprog 0 192.168.4.200 n-boot.bin.local && nprog 128 192.168.4.200 zImage-6pci && reset
例四:
如何將一個 .tar.gz文件系統 寫到 nor 或者 nand flash中
target$ mkdir /mnt/flash
target$ mount -t jffs2 /dev/mtdblock0 /mnt/flash (mtdblockx只是用來掛載的)
target$ cd /mnt/flash
target$ tar zxvf rootfs.tar.gz