精化问题
如何从擦除块大小为零的MTD SRAM设备中读取和写入文本信息?
备注:
libmtd
无法处理擦除块大小为零的操作。echo >
和cat
用于mtdblock
的尝试只会产生垃圾。原始我正在尝试读写一个连接到运行Linux的ARM处理器上的芯片。我不在乎是否像文件、串行设备或内存分区那样与SRAM接口。SRAM芯片的现有设备驱动程序将该设备注册为MTD。我通过检查/proc/mtd
验证了这一点
~# cat /proc/mtd
dev: size erasesize name
mtd0: 00020000 00000000 "spi1.0"
我找到了一个使用MTD实用程序格式化MTD的教程。我遇到的问题是,我无法与SRAM/MTD设备接口,因为当查看此设备时,所有的用户空间MTD/UBI/JFF2 2工具都会崩溃,IE:
~# mtdinfo
Count of MTD devices: 1
Floating point exception (core dumped)
出现此异常似乎是因为所有MTD实用程序都使用libmtd。libmtd中的mtd_get_dev_info1
函数除以擦除块大小,在我的示例中擦除块大小为零。
mtd->eb_cnt = mtd->size / mtd->eb_size;
即使这个芯片有一个MTD驱动程序,我不认为写周期是一个问题,这就是为什么擦除块是零。因此,我的问题如下:
libmtd
以忽略零擦除块大小吗?如果是这样,我应该将eb_cnt
设置为什么?其他注意事项:
echo test > /dev/mtdblock0
和cat /dev/mtdblock0
,除了垃圾什么都没有。更新10/20将驱动程序中的擦除块大小更改为1(我希望将其更改为4000,但不确定单元)。MTD Utils不再抛出以前给出的异常。
~# mtdinfo
Count of MTD devices: 1
Present MTD devices: mtd0
Sysfs interface supported: yes
然而,泛格式确实失败了:
~# ubiformat /dev/mtd0
ubiformat: mtd0 (ram), size 131072 bytes (128.0 KiB), 131072 eraseblocks of
1 bytes, min. I/O size 1 bytes
libscan: scanning eraseblock 0 -- 0 % complete libmtd: error!: bad offset
0 or length 64, mtd0 eraseblock size is 1
ubiformat: error!: failed to scan mtd0 (/dev/mtd0)
更新#2 10/20不幸地将擦除块大小设置为4000 (实际上是0x4000)导致内核在运行泛格式后崩溃
~# ubiformat /dev/mtd0
ubiformat: mtd0 (ram), size 131072 bytes (128.0 KiB), 8 eraseblocks of 16384
bytes (16.0 KiB), min. I/O size 1 bytes
libscan: scanning erasebUnable to handle kernel NULL pointer dereference at
virtual address 00000000
libscanpgd = 8cc6c000te
libscan: scanning eras[00000000] *pgd=8cbbb835, *pte=00000000, *ppte=00000000
libscan: scanning eInternal error: Oops: 80000007 [#1] PREEMPT SMP ARM
Update 10/23 I试图正常使用fdisk格式化驱动器,但由于缺少柱面,似乎出现了错误:
:~# fdisk /dev/mtdblock0
...
Command (m for help): p
Disk /dev/mtdblock0: 0 MB, 131072 bytes
255 heads, 63 sectors/track, 0 cylinders
Units = cylinders of 16065 * 512 = 8225280 bytes
Device Boot Start End Blocks Id System
Command (m for help): n
Unknown value(s) for: cylinders (settable in the extra functions menu)
发布于 2017-10-26 19:17:22
存在一个底层硬件问题,一旦修复,就允许从/dev/mtdblock0
设备中写入和读取数据。通过使用echo TEST > /dev/mtdblock0
编写和cat /dev/mtdblock
读取验证了这一点。
以下是在研究这个问题时发现的其他bug的总结
cat /dev/mtdblock0
调用中产生正确的输出量。输出将是相同的,而实际未初始化的芯片输出将是随机的。libmtd
的应用程序,包括所有mtd-utils
,在处理擦除块大小为零的MTD设备时都会出错。fdisk
会出错(可以使用专家模式绕开)https://stackoverflow.com/questions/46815796
复制相似问题