gpt4 book ai didi

c - 删除 Flash NOR : ioctl(MEMUNLOCK) return status?

转载 作者:太空狗 更新时间:2023-10-29 17:23:43 32 4
gpt4 key购买 nike

我正在尝试使用 C 中的 Linux MTD 驱动程序删除 NOR 闪存...

我对 ioctl(MEMUNLOCK) 调用的返回状态感到困惑,它返回错误,即使 ioctl(MEMERASE) 在它之后成功。

以下代码显示警告消息但有效(即闪存 block 已被删除):

int erase_MTD_Pages(int fd, size_t size, off_t offset)
{
mtd_info_t mtd_info;
erase_info_t ei;

ioctl(fd, MEMGETINFO, &mtd_info);
ei.length = mtd_info.erasesize;

for(ei.start = offset; ei.start < (offset+size); ei.start += mtd_info.erasesize) {
if(ioctl(fd, MEMUNLOCK, &ei) < 0)
{
// logPrintf(FAILURE, "[Flash] Can not unlock MTD (MEMUNLOCK, errno=%d)!\n", errno);
// return RETURN_FILE_ERROR;
logPrintf(WARNING, "[Flash] Can not unlock MTD (MEMUNLOCK, errno=%d)!\n", errno);

}
if(ioctl(fd, MEMERASE, &ei) < 0)
{
logPrintf(FAILURE, "[Flash] Can not erase MTD (MEMERASE, errno=%d)!\n", errno);
return RETURN_FILE_ERROR;
}
}
return RETURN_SUCCESS;
}

当我在网上查看一些 C 代码时,并不总是检查 MEMUNLOCK 的返回状态(例如来自 mtc.c ):

ioctl(fd, MEMUNLOCK, &mtdEraseInfo);
if(ioctl(fd, MEMERASE, &mtdEraseInfo)) {
fprintf(stderr, "Could not erase MTD device: %s\n", mtd);
close(fd);
exit(1);
}

flash_unlock 也返回一个错误:

root $ cat /proc/mtd
dev: size erasesize name
mtd0: 00020000 00020000 "X-Loader-NOR"
mtd1: 000a0000 00020000 "U-Boot-NOR"
mtd2: 00040000 00020000 "Boot Env-NOR"
mtd3: 00400000 00020000 "Kernel-NOR"
mtd4: 03b00000 00020000 "File System-NOR"

root $ mtd_debug info /dev/mtd3
mtd.type = MTD_NORFLASH
mtd.flags = MTD_CAP_NORFLASH
mtd.size = 4194304 (4M)
mtd.erasesize = 131072 (128K)
mtd.writesize = 1
mtd.oobsize = 0
regions = 0

root $ flash_unlock /dev/mtd3
Could not unlock MTD device: /dev/mtd3

我错过了什么吗?某些配置的 MEMUNLOCK 出错是否正常?

注释/环境:

  • 中的只读标志 (MTD_WRITEABLE) 在 mtd3 分区上设置(仅在 mtd0mtd1).
  • flash_lock 也返回同样的错误。
  • TI AM3505(ARM Cortex A8、OMAP34)。
  • Linux 2.6.37。
  • 闪存 NOR Spansion S29GL512S12DHIV1。

内核日志:

mtdoops: mtd device (mtddev=name/number) must be supplied
physmap platform flash device: 08000000 at 08000000
physmap-flash.0: Found 1 x16 devices at 0x0 in 16-bit bank. Manufacturer ID 0x000001 Chip ID 0x002301
Amd/Fujitsu Extended Query Table at 0x0040
Amd/Fujitsu Extended Query version 1.5.
Silicon revision: 14
Address sensitive unlock: Required
Erase Suspend: Read/write
Block protection: 1 sectors per group
Temporary block unprotect: Not supported
Block protect/unprotect scheme: 8
Number of simultaneous operations: 0
Burst mode: Not supported
Page mode: 12 word page
Vpp Supply Minimum Program/Erase Voltage: 0.0 V
Vpp Supply Maximum Program/Erase Voltage: 0.0 V
Top/Bottom Boot Block: Uniform, Top WP
number of CFI chips: 1
RedBoot partition parsing not available
Using physmap partition information
Creating 5 MTD partitions on "physmap-flash.0":
0x000000000000-0x000000020000 : "X-Loader-NOR"
0x000000020000-0x0000000c0000 : "U-Boot-NOR"
0x0000000c0000-0x000000100000 : "Boot Env-NOR"
0x000000100000-0x000000500000 : "Kernel-NOR"
0x000000500000-0x000004000000 : "File System-NOR"

最佳答案

对于我开发的闪存芯片 (drivers/mtd/devices/m25p80.c),我发现未实现 UNLOCK。驱动程序的 ioctl(UNLOCK) 返回 -EOPNOTSUPP=95。正如您所发现的,代码检查显示 mtd_unlock 返回状态被丢弃在地板上。

这些意味着在 m25p80 驱动程序中假设闪存永远不会被锁定,而在 mtd 驱动程序中设备驱动程序可以忽略 UNLOCK。在我工作的板上,闪存在每次写入后都被 u-boot 锁定,因此从 linux 删除和重新编程根本不起作用。我查看了 u-boot 驱动程序和设备数据表,得到了一些实现 m25p80_lock 和 m25p80_unlock 的代码,知道是怎么回事后,这并不难。我没有上游。

芯片驱动程序没有实现这些似乎确实是一个缺陷。

顺便说一下,Mousstix,在这个问题上提供了完整的信息,做得非常好。

关于c - 删除 Flash NOR : ioctl(MEMUNLOCK) return status?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19706584/

32 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com