ubi_wl_get_peb: Unable to get a free PEB from user WL pool

Jörg Krause joerg.krause at embedded.rocks
Thu Aug 6 01:10:03 PDT 2015


On Do, 2015-08-06 at 09:30 +0200, Richard Weinberger wrote:
> Jörg,
> 
> Am 06.08.2015 um 00:17 schrieb Jörg Krause:
> > > > > Then just disable it. :)
> > > > 
> > > > I did :) I thought fastmap is used automatically by the UBI 
> > > > driver?
> > > 
> > > It will *use* fastmap automatically but not convert non-fastmap 
> > > UBI 
> > > images
> > > to fastmap.
> > > You can enable ubi.fm_autoconvert to do so.
> > 
> > Sorry for asking, but how do I create an UBI image with fastmap
> > support? I've never read something about this.
> 
> You have to use the ubi.fm_autoconvert parameter. The UBI will 
> automatically
> write down a fastmap if needed.
> 
> Currently it is not possible to create a fastmap-enabled UBI image
> using ubinize.
> The reason is that fastmap stores the LEB->PEB mappings to allow
> a fast attach. ubinize cannot know which PEBs are bad.
> So, we'd need a tool which creates the fastmap while flashing to the 
> nand.
> 

I see!

> > > > > Meanwhile I'll find out what exactly is going on.
> > > > 
> > > > Many thanks!
> > > 
> > > Can you please apply the attached debug patch?
> > > I wonder why exactly the auto resize function is failing.
> > 
> > autoresize: cannot auto-resize volume 0: -28
> 
> I have good and bad news.
> The good news is that I know what is going on, the bad one
> is that I don't have an good solution for it.
> 
> UBI is requesting a new PEB but your system is still busy with
> erasing them. With fastmap disabled UBI can use produce_free_peb()
> and wait for a new erased PEB.
> But fastmap cannot use this helper as it releases ->wl_lock
> and would lead to a inconsistent fastmap state.
> Kernels < 4.1 did so and faced interesting fastmap corruptions.
> I hoped using the current retry logic the issue you're facing cannot
> happen. But as it seems I was wrong.
> 
> Can you please give the attached patch a try?
> 

I tried the "dirty hack", but it does not solves the problem. I also
tested with 100 retries, but the error remains.

I will turn fastmap off for now, but feel free to send more patches to
try.

Jörg




More information about the linux-mtd mailing list