您的位置:首页 > 其它

8bit校准测试工具mtd-utils的移植和使用

2016-09-21 17:04 405 查看
环境:

主机:ubuntu14.04

交叉编译工具链:4.2.2-eabi

测试文件系统:ubifs

1、源码
http://www.zlib.net/
下载zlib-1.2.8.tar.gz
http://www.oberhumer.com/opensource/lzo/download/
下载lzo-2.03.tar.gz
ftp://ftp.infradead.org/pub/mtd-utils/
下载mtd-utils-1.4.1.tar.bz2

我的资源里面也有

 说明:zlib和lzo是编译mtd-utils所需库文件,需提前交叉编译完成,以供mtd-utils编译时调用

 2、编译安装zlib:

root@:/home/#tar xvf zlib-1.2.8.tar.gz

root@:/home/#cd zlib-1.2.8

root@:/home/zlib-1.2.8# CC=arm-linux-gcc(自己的交叉编译工具)  ./configure --shared
--prefix=/home/install_zlib-1.2.8/(自己的安装目录--绝对路径)

root@:/home/zlib-1.2.8# make

root@:/home/zlib-1.2.8# make install  (在安装目录下生成 include lib share三个文件夹编译mtd-util时被用到)

 3、编译安装lzo:

root@:/home/#tar xvf lzo-2.03.tar.gz

root@:/home/# cd lzo-2.03/

root@:/home/lzo-2.03# CC=arm-linux-gcc(自己的交叉编译工具) ./configure --host=arm-linux --prefix=/home/install_lzo-2.03/(自己的安装目录--绝对路径)

root@:/home/lzo-2.03# make

root@:/home/lzo-2.03# make install    
(在安装目录下生成 include lib 三个文件夹编译mtd-util时被用到)

4、编译mtd-utils

root@:/home/#tar xvf mtd-utils-1.4.1.tar.bz2

root@:/home/#cd mtd-utils-1.4.1

root@:/home/mtd-utils-1.4.1#需要修改Makefile,
vi Makefile

CPPFLAGS += -I/home/install_lzo-2.03/include -I/home/install_zlib-1.2.8/include -I./include $(ZLIBCPPFLAGS) $(LZOCPPFLAGS)

(添加刚刚编译生成的lzo 和zlib的include目录绝对路径)

LDLIBS =-L/home/install_lzo-2.03/lib -llzo2 -L/home/install_zlib-1.2.8/lib -lz -L$(BUILDDIR)/lib -lmtd
(添加刚刚编译生成的lzo 和zlib的lib目录绝对路径)
root@:/home/mtd-utils-1.4.1# make
CROSS=arm-linux- (会在mtd-utils-1.4.1下生成)  WITHOUT_XATTR=1

指定WITHOUT_XATTR=1 是由于在编译 mkfs.jffs2使其不调用acl.h而是用zlib的库,否则会报错:

mkfs.jffs2.c:69:21: error: sys/acl.h: No such file or directory

mkfs.jffs2.c: In function ‘formalize_posix_acl’:
mkfs.jffs2.c:1118: error: ‘ACL_USER_OBJ’ undeclared (first use in this function)
mkfs.jffs2.c:1118: error: (Each undeclared identifier is reported only once
mkfs.jffs2.c:1118: error: for each function it appears in.)
mkfs.jffs2.c:1119: error: ‘ACL_GROUP_OBJ’ undeclared (first use in this function)
mkfs.jffs2.c:1120: error: ‘ACL_MASK’ undeclared (first use in this function)
mkfs.jffs2.c:1121: error: ‘ACL_OTHER’ undeclared (first use in this function)
mkfs.jffs2.c:1127: error: ‘ACL_USER’ undeclared (first use in this function)
mkfs.jffs2.c:1128: error: ‘ACL_GROUP’ undeclared (first use in this function)
make: *** [mkfs.jffs2.o] Error 1


 有人写到出现此错误需要安装libacl-dev,个人觉得如果指定WITHOUT_XATTR=1,就不需要安装!

编译

make CROSS=arm-linux- CFLAGS="-I/home/install_lzo-2.03/include  -I/home/install_zlib-1.2.8/include" 
LDFLAGS="-L/home/install_lzo-2.03/lib  -L/home/install_zlib-1.2.8/lib
"  WITHOUT_XATTR=1 (上面编译也可以这样不需要修改Makefile)

ls查看下生成目录,看生成什么文件

ls arm-linux/

compr_lzo.o    compr_zlib.o  doc_loadbios  flash_eraseall    flash_lock      flash_unlock  jffs2dump    mkfs.jffs     mtd_debug  nftldump     rfdformat

compr.o        crc32.o       flashcp       flash_eraseall.o  flash_otp_dump  ftl_check     jffs2dump.o  mkfs.jffs2    nanddump   nftl_format  sumtool

compr_rtime.o  docfdisk      flash_erase   flash_info        flash_otp_info  ftl_format    lib          mkfs.jffs2.o  nandwrite  rfddump      sumtool.o

上面的flash_erase  flash_eraseall  mkfs.jffs2 nanddump几个都是非常有用的工具。可以把这个目录copy到开发板就可以使用测试了。

二:mtd-util工具的使用

在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

 

(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的大小、名字等。其格式如小:

(10)ubiupdatevol: 向指定的volume上写数据

用法:./ubiupdatevol /dev/ubi2_0 myubi.img
转载:

使用命令前用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

命令:flash_erase

作用:擦出指定范围内flash的内容,如果不指定,默认擦出起始位置的第一块,使相应flash变为全1

用法:

flash_erase MTD-device [start] [cnt (# erase blocks)] [lock]

MTD-device:待擦出的分区,如/dev/mtd0

start:起始位置设置,这里必须设置为0×20000(128K)的整数倍

cnt: 从start开始计算,要擦出的块数

lock: 写保护

eg:  ./flash_erase /dev/mtd0 0×40000 5   //擦出mtd0分区上从0×40000开始的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 ] <filename> <device>

flashcp -h | –help

filename:待写入的数据

device: 写入的分区,如/dev/mtd0

eg:

filename制作:mkfs.jffs2 -e 0×20000 -d cq8401 -o cq8401.img  -n  //这里的-e 0×20000 必须更你芯片的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 <device>

mtd_debug read <device> <offset> <len> <dest-filename>

mtd_debug write <device> <offset> <len> <source-filename>

mtd_debug erase <device> <offset> <len>

eg:

#./mtd_debug info /dev/mtd0  // 输出/dev/mtd0上的一些信息,这里必须用mtdx

#./mtd_debug erase /dev/mtd0 0×0 0×40000  // 擦出/dev/mtd0 分区上 从0×0开始的  , 128K*2 大小的数据

#./mtd_debug write /dev/mtdblock0 ox0 0×360810 cq8401.img //向mtdblock0分区,写入 3.6M 大小的文件系统cq8401.img,这里最好用mtdblockx

#./mtd_debug read  /dev/mtdblock0 ox0 0×360810 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 0×0 0×40000  // 擦出/dev/mtd0 分区上 从0×0开始的  , 128K*2 大小的数据

step3:

#./mtd_debug write /dev/mtdblock0 ox0 0×360810 cq8401.img //向mtdblock0分区,写入 3.6M 大小的文件系统cq8401.img,这里最好用mtdblockx

step4:

#./mtd_debug read  /dev/mtdblock0 ox0 0×360810 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 0×20000 -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
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  mtd-util lzib lzo nandflash