[PATCH] scan.c
David Woodhouse
dwmw2 at infradead.org
Mon Jun 17 08:45:40 EDT 2002
joakim.tjernlund at lumentis.se said:
> Why do you still want to scan them? It's safe not to by design. Maybe
> as a debug opion?
It's safe in theory. I want it robust in practice. Shit happens.
> yes, this is what I tested(skipping the crc32 check) some time ago
> and I noticed a big improvement. I also noticed that adler32 was much
> faster than crc32(btw you should not use 0 as start seed to the crc32
> since that will yield a correct csum(0) on a zeroed buffer).
It's not safe to just skip it -- I just did that to see how it affected the
profiling results. We can only skip it if we make sure we do it later.
The reason we build up all the fragment lists for each inode at boot, and
hence the reason we had to check all the crcs, is because we need to know
which nodes are obsolete, so we can build up accurate information about free/
dirty space per block. But we don't really _need_ that information until we
start to garbage-collect, so there's no real reason for us to do it at boot
time.
What I did was just disable the CRC32 check and still build up the fragment
lists as if the CRC32 was OK -- so nodes with bad CRC could still obsolete
good nodes, causing corruption. It was only done as a test. The real way
forward would be to skip the building up of the per-inode fragment list
_too_, and just make sure it's done for all inodes by the time we start to
do GC, later.
> Is it safe to do skip the CRC check in the 2.4 branch as well?
The above will be quite intrusive ,and I would rather not change the 2.4
branch. If you want optimisations, you should really be using the
development branch -- it shouldn't really any less stable in general than
the 2.4 branch was until we branched it.
Don't think of them as stable and development, in the same way as the 2.4
and 2.5 Linux kernel trees -- think of them more as paranoia and stable,
respectively; more like 2.2 and 2.4.
> I have an addon idea: Add a new flag to node.nodetype. This flag is
> set when a node is first written to the flash. The first time the node
> is read the CRC is calculated and if the CRC:s match, clear the CRC
> flag(on the flash as well). The next time the same node is read you
> don't have to check the CRC again since it has already been verified.
> That will save a lot of CPU cycles during file I/O as well.
But what if the act of clearing the CRC flag is just enough to trigger a
nearby bit to flip, in an ageing flash chip? Also, how does this increase
the probability of random data being interpreted as a real node? The CRC
gives us a fairly small probability of that.
I'd be more willing to entertain the possibility of having such a flag in
_memory_, so we don't check the CRC32 more than once per mount cycle.
> 128! In my 2.4.2 kernel(from Montavista) I can not go higher than 13,
> then it Oops on me.
Sounds like you don't have the jffs2_sb in the superblock union, so when
the JFFS2 superblock info gets larger than the existing size of the union,
the union doesn't grow to accommodate it.
For 2.5 kernels this isn't a problem because we allocate our own fs-private
superblock info anyway, but for 2.4 we should probably allocate the hash
table separately if we want it that large -- otherwise _all_ superblocks
will have enough space for it.
In fact, we should probably allocate the hash table dynamically anyway, and
vary its size according to the size of the flash device.
I'd be willing to let that into the 2.4 branch, as it's so obviously
correct and makes such a difference.
--
dwmw2
More information about the linux-mtd
mailing list