Am 02.10.2014 15:42, schrieb Tanya Brokhman:
> On 10/2/2014 4:24 PM, Richard Weinberger wrote:
>> Am 02.10.2014 14:50, schrieb Tanya Brokhman:
>>>> Consider the case where you have a board with a fastmap enabled bootloader 
>>>> and a Linux OS.
>>>> The bootloader does a fastmap attach and boots the kernel from UBI and the 
>>>> kernel it self has the rootfs
>>>> on UBI too. If you install a new kernel with your changes applied it will 
>>>> write the fastmap in a different
>>>> format and the bootloader will fail badly. In worst case the board bricks, 
>>>> in best case the bootloader can fall back
>>>> to scanning mode but it will be slow and the customer unhappy.
>>>>
>>>
>>> Ok, I understand the problem now. I wanted to discuss a possible solution 
>>> before implementing it:
>>> We have a "fastmap version" in fm_sb. At the moment UBI_FM_FMT_VERSION = 1 
>>> and any other is not supported. We can use that; Add another fm version 
>>> (UBI_FM_FMT_VERSION_RD = 2) and
>>> then decide according to it. Meaning, if during attach process we find fm 
>>> superblock we check it's version, if it's != UBI_FM_FMT_VERSION_RD, we fall 
>>> back to full scan. The next
>>> fastmap will be written with the new layout (and new version number) so 
>>> second boot will attach from fastmap without any issues.
>>
>> Yes, if we change the fastmap on-disk layout we need to change 
>> UBI_FM_FMT_VERSION.
>> Then other fastmap implementations will notice the change and can hopefully 
>> recover.
>> Implementations which do not evaluate UBI_FM_FMT_VERSION deserve breaking. 
>> ;-)
> 
> good. will work on the fix and upload a new set when ready&tested.
> 
>>
>> That said, I'll not block a layout change but we have to be sure that it is 
>> *really* needed.
> 
> In order to support read-disturb, I think its really needed. There is no 
> other way to save read counter per PEB but in fastmap.

The question is, do we really need all this values on-flash?
You could create a simple sysfs or ioctl() interface to pass these values to 
userspace.
Then you can hack up an userspace daemon which monitors the counters and 
triggers a check if needed.
The daemon can also store the counter into a flat file. If think you don't need 
exact counters,
there it does not hurt if the daemon does not store the most current values at 
a power cut.

Thanks,
//richard
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Reply via email to