Sverdlin, Alexander (Nokia - DE/Ulm)
2018-11-13 16:58:22 UTC
Hello Tudor and all,
first of all, thank you for your work on SFDP support in Linux!
Unfortunately, I'm debugging a regression caused by 5390a8df769ec
"mtd: spi-nor: add support to non-uniform SFDP SPI NOR flash memories"
in [out of tree] support for S25FS128S.
The culprit is the following part of your patch:
/*
* For non-uniform SPI flash memory, set mtd->erasesize to the
* maximum erase sector size. No need to set nor->erase_opcode.
*/
for (i = SNOR_ERASE_TYPE_MAX - 1; i >= 0; i--) {
if (map->erase_type[i].size) {
erase = &map->erase_type[i];
break;
}
}
The problem in our case is, we have existing partitioning with 128k partitions
(the Flash itself supports 256k and 64k erasesize, depending on configuration).
The chip is configured for 64k erasesize, non-uniform mapping.
The mapping itself is being detected correctly, but when it comes to the code
snippet above, it selects the biggest erasesize from all sizes advertised in
SFDP, including 256k, which is not applicable to the current configuration.
Finally when mtd registers the partitions, they are forced read-only:
partition "..." doesn't start on an erase block boundary -- force read-only
So this change is not backwards compatible to the existing partitionings.
I cannot come with the justification for the above decision myself, so
I have to ask you guys, what is the reason for setting mtd->erasesize to
the *maximum* erase sector size?
I'd appreciate any ideas on the above, maybe I can convert them to a patch.
Or should mtdpart.c be updated to handle non-uniform erase regions?
But they seem to be spi-nor.c-specific currently...
first of all, thank you for your work on SFDP support in Linux!
Unfortunately, I'm debugging a regression caused by 5390a8df769ec
"mtd: spi-nor: add support to non-uniform SFDP SPI NOR flash memories"
in [out of tree] support for S25FS128S.
The culprit is the following part of your patch:
/*
* For non-uniform SPI flash memory, set mtd->erasesize to the
* maximum erase sector size. No need to set nor->erase_opcode.
*/
for (i = SNOR_ERASE_TYPE_MAX - 1; i >= 0; i--) {
if (map->erase_type[i].size) {
erase = &map->erase_type[i];
break;
}
}
The problem in our case is, we have existing partitioning with 128k partitions
(the Flash itself supports 256k and 64k erasesize, depending on configuration).
The chip is configured for 64k erasesize, non-uniform mapping.
The mapping itself is being detected correctly, but when it comes to the code
snippet above, it selects the biggest erasesize from all sizes advertised in
SFDP, including 256k, which is not applicable to the current configuration.
Finally when mtd registers the partitions, they are forced read-only:
partition "..." doesn't start on an erase block boundary -- force read-only
So this change is not backwards compatible to the existing partitionings.
I cannot come with the justification for the above decision myself, so
I have to ask you guys, what is the reason for setting mtd->erasesize to
the *maximum* erase sector size?
I'd appreciate any ideas on the above, maybe I can convert them to a patch.
Or should mtdpart.c be updated to handle non-uniform erase regions?
But they seem to be spi-nor.c-specific currently...
--
Best regards,
Alexander Sverdlin.
Best regards,
Alexander Sverdlin.