安装mtd相关命令

手动安装mtd-utils,根据系统自行选择

mtd交叉编译:https://blog.csdn.net/zhangxuechao_/article/details/52124424

系统flash操作命令

# cat /proc/mtd
dev: size erasesize name
mtd0: 00080000 00020000 "boot"
mtd1: 00100000 00020000 "kernel"
mtd2: 00580000 00020000 "roofs"
mtd3: 00900000 00020000 "app"
# flash_erase device [start] [cnt]
# flash_erase /dev/mtd0 0×40000 5

start:起始位置。必须为0x20000(128K)的整数倍

cnt:块数

# flash_eraseall [OPTION] device
# flash_eraseall -j /dev/mtd0

-j,jffs2:jffs2格式化分区

-q,quiet:不显示打印信息

# flash_eraseall -j -q /dev/mtd0 = flash_erase /dev/mtd0 0 0

新版擦除整个设备,已建议使用flash_erase

# mount -t jffs2 /dev/mtdblock0 /mnt

挂载mtd设备。mtdblock只用于挂载,/dev/mtd操作实际就是操作/dev/mtdblock

# flashcp <filename> <device>
# flashcp fs.jffs2 /dev/mtd0
# mtd_debug info <device>
# mtd_debug info /dev/mtd0
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
# mtd_debug read /dev/mtd2 0 100 file.dest

uboot flash操作

对Nand flash对应mtd分区擦除时。擦除要擦除整个设备大小;写要写jffs2文件系统大小。不然数据可能会有问题,可能原因是jffs2格式写入位置

# nand erase 0x4100000 0x200000 //擦除整个mtd分区2M
# nand write 0x6000000 0x4100000 0x20000 //写入128K

uboot flash按分区操作

> mtd

device nand0 <nandflash0>, # parts = 4
#: name size offset mask_flags
0: bootloader 0x00040000 0x00000000 0
1: params 0x00020000 0x00040000 0
2: kernel 0x00200000 0x00060000 0
3: root 0x0fda0000 0x00260000 0 > nand erase root NAND erase: device 0 offset 0x260000, size 0xfda0000
Erasing at 0xffe0000 -- 100% complete.
OK > nand write.jffs2 0x3000000 root NAND write: device 0 offset 0x260000, size 0xfda0000
0xfda0000 bytes written: OK

filesize文件大小

> nand write.jffs2 0x3000000 0x260000 $(filesize)

NAND write: device 0 offset 0x260000, size 0x15787a8

Writing data at 0x17f8000 -- 100% complete.
22513576 bytes written: OK

举例

#include <fcntl.h>
#include <sys/ioctl.h>
#include <sys/mount.h>
#include "mtd-user.h" int non_region_erase(int fd, int start, int count, int unlock)
{
mtd_info_t meminfo; if(ioctl(fd, MEMGETINFO, &meminfo) == 0)
{
erase_info_t erase;
erase.start = start;
erase.length = meminfo.erasesize; for(; count > 0; count--)
{
printf("\rPerforming Flash Erase of length %u at offset 0x%x\n", erase.length, erase.start); fflush(stdout); if(unlock != 0)
{
//unlock the sector first
printf("\rPerforming Flash unlock at offset 0x%x\n", erase.start); if(ioctl(fd, MEMUNLOCK, &erase) != 0)
{
perror("MTD Unlock failure");
close(fd);
return -1;
}
} if(ioctl(fd, MEMERASE, &erase) != 0)
{
perror("MTD Erase failure");
close(fd);
return -1;
} erase.start += meminfo.erasesize;
} printf("done!\n");
} return 0;
} int main(int argc, char *argv[])
{
int fd, ret, i;
struct mtd_info_user info; // Open the device
if((fd = open("/dev/mtd5", O_RDWR)) < 0)
{
fprintf(stderr, "File open error\n");
return -1;
}
else
{
ioctl(fd, MEMGETINFO, &info);
printf("info.size=%d\n", info.size);
printf("info.erasesize=%d\n", info.erasesize);
printf("info.writesize=%d\n", info.writesize);
printf("info.oobsize=%d\n", info.oobsize);
} struct stat st; //check is a char device
ret = fstat(fd, &st); if(ret < 0)
{
printf("fstat %s failed!\n", FLASH_DEV_NAME);
close(fd);
return -1;
} if(!S_ISCHR(st.st_mode))
{
printf("%s: not a char device\n", FLASH_DEV_NAME);
close(fd);
return -1;
} #if 0 ret = non_region_erase(fd, 0, 1, 0); if(ret < 0)
{
return -1;
} #endif char *pReadBuf;
int nReadBytes; nReadBytes = info.erasesize;
pReadBuf = malloc(nReadBytes);
memset(pReadBuf, 0, nReadBytes);
ret = read(fd, pReadBuf, 256);
printf("%s--read %d bytes from mtd\n", __func__, ret); for(i = 0; i < ret; i++)
{
printf("%02x,", *(pReadBuf + i));
} printf("\n"); free(pReadBuf);
}

详细操作,参考mtd源码mtd_debug.c

mtd设备操作、jffs2的更多相关文章

  1. 已有 JFFs2文件系统的修改

    项目应用中,对于前人留下的JFFS2的文件,有时候我们需要修改,但是苦于没有源文件,实际操作很多时候无所适从.每次支持生产之后再进行人为的升级.这样费时费力,也给生产人员增加了负担. 为了解决这个问题 ...

  2. Linux UBI子系统设计初探

    问题领域 flash存储设备存在如下特点: 存在坏块 使用寿命较短 存储介质不稳定 读写速度慢 不支持随机访问(nand) 只能通过擦除将0改成1 最小读写单位为page or sub-page 便宜 ...

  3. 嵌入式设备上的 Linux 系统开发

    转载:http://www.ibm.com/developerworks/cn/linux/embed/embdev/index.html   如果您刚接触嵌入式开发,那么大量可用的引导装载程序(bo ...

  4. 关于linux下的嵌入式文件系统以及flash文件系统选择

    嵌入式linux下常见的文件系统 • RomFS:只读文件系统,可以放在ROM空间,也 可以在系统的RAM中,嵌入式linux中常用来作 根文件系统 • RamFS:利用VFS自身结构而形成的内存文件 ...

  5. ltp-ddt 加入sram 需要修改的部分

    ./platform/fmxx-psoc-db add sram 将nor部分移植过来 # @name NOR read write test using dd # @desc Perform NOR ...

  6. linux内核中mtd架构分析

    一. 引言 MTD(memory technology device内存技术设备)是用于访问memory设备(RAM.ROM.flash)的Linux的子系统.MTD的主要目的是为了使新的memory ...

  7. jffs2文件系统制作

    内核:                linux-3.0 uboot:             2010.09 开发板:             fl2440 交叉编译器:         2011. ...

  8. 嵌入式: jffs2,yaffs2,logfs,ubifs文件系统性能分析

    在嵌入式领域,FLASH是一种常用的存储介质,由于其特殊的硬件结构,所以普通的文件系统如ext2,ext3等都不适合在其上使用,于是就出现了专门针对FLASH的文件系统,比较常用的有jffs2,yaf ...

  9. s3c2440 移值u-boot-2016.03 第6篇 支持mtd yaffs 烧写

    1, 解决启动时的错误 Warning - bad CRC, using default environment 搜索发现 在 /tools/env/fw_env.c 中 /* 放在NAND FLAS ...

随机推荐

  1. Python3基础 yield send 变量名= yield i

             Python : 3.7.3          OS : Ubuntu 18.04.2 LTS         IDE : pycharm-community-2019.1.3    ...

  2. (转)Python3的四舍五入round()函数坑爹?不,更科学!

    原文:https://blog.csdn.net/lly1122334/article/details/80596026 Python3的四舍五入round()函数坑爹?不,更科学!Python2中, ...

  3. spring boot集成mybatis分页插件

    mybatis的分页插件能省事,本章记录的是 spring boot整合mybatis分页插件. 1.引入依赖 <!-- 分页插件pagehelper --> <dependency ...

  4. js 类型判断

  5. springmvc中跨域问题

    对于web框架中的跨域问题是一个非常普遍的问题,常见的解决方案也有很多,如:jsonp.cros.websocket等.下面是最近处理springmvc中使用cors解决跨域问题的一些总结. Filt ...

  6. 自动化运维工具之SaltStack简介与安装

    1.SaltStack简介 官方网址:http://www.saltstack.com官方文档:http://docs.saltstack.comGitHub:https:github.com/sal ...

  7. mac自带ssh在哪

    打开Finder,前往> 前往文件夹,输入 ~/.ssh 回车就到ssh目录了. 点击Mac顶部菜单-->“苹果”图标-->最近使用的项目-->终端--输入 open ~/.s ...

  8. 2019暑假牛客多校训练-第八场-C-CDMA(递归、水题)

    观察前3组可以推出递归规律,生成下一个类型时,每行copy自身与自身相反. 题目描述 Gromah and LZR have entered the third level. There is a b ...

  9. linux svn开机自动启动服务

    SVN设置开机自动启动 usr/lib/systemd/system/添加svn.service文件 home/sdbdatasvn/svnrepos(换成绝对路径) 如果出现权限问题,请chmod  ...

  10. [hdu 1062] Text Reverse | STL-stack

    原题 题目大意: t组数据,每组为一行,遇到空格时讲前面的单词反转输出. 题解: 显然的栈题,遇到空格时将当前栈输出清空即可 #include<cstdio> #include<st ...