ä 2011å12æ13æ 05:30, Scott Wood åé:I found it's too complex to do the migration in Linux driver.On 12/12/2011 03:19 PM, Artem Bityutskiy wrote:OK, I try to do this. Wait for a couple of days.On Mon, 2011-12-12 at 15:15 -0600, Scott Wood wrote:That's the kind of answer I was hoping to get from Shuo. :-)NAND chips come from the factory with bad blocks marked at a certainAh, I see, thanks. Are you planning to implement in-kernel migration or
offset into each page. This offset is normally in the OOB area, but
since we change the layout from "4k data, 128 byte oob" to "2k data, 64
byte oob, 2k data, 64 byte oob" the marker is no longer in the oob. On
first use we need to migrate the markers so that they are still in the oob.
use a user-space tool?
-LiuShuo
Most likely is a firmware-based tool, but I'd like there to be some way
for the tool to mark that this has happened, so that the Linux driver
can refuse to do non-raw accesses to a chip that isn't marked as having
been migrated (or at least yell loudly in the log).
Speaking of raw accesses, these are currently broken in the eLBC
driver... we need some way for the generic layer to tell us what kind of
access it is before the transaction starts, not once it wants to read
out the buffer (unless we add more hacks to delay the start of a read
transaction until first buffer access...). We'd be better off with a
high-level "read page/write page" function that does the whole thing
(not just buffer access, but command issuance as well).
-Scott