Some time ago, I was playing with logfs, a scalable flash filesystem. It’s interesting because of at least three reasons:
- it can compress data transparently,
- it provides wear leveling,
- it works with block devices.
In other words, a perfect filesystem to use for all flash-based devices, like USB-sticks.
Any filesystem should aim for high reliability, no doubt about it. But how to test it? Linux kernel provides a nice feature called “fault injection”. If Documentation/fault-injection/fault-injection.txt isn’t clear for you after the first read, here’s a quick help.
You need fault injection and debugfs compiled in the kernel.
First, mount debugfs:
data:image/s3,"s3://crabby-images/96e98/96e98d336bd6a993441934aa506b6268ec8c152c" alt=""
Then, set up fault injection:
data:image/s3,"s3://crabby-images/0d3f5/0d3f554171daa08ba163f1c459e27e1d419f70eb" alt=""
Mount the filesystem on the device, start copying files etc. and then, make the device fail:
data:image/s3,"s3://crabby-images/edda6/edda6955f31aa9722f9fe9110064d23b02270fb7" alt=""
Logfs was working for some time, but eventually, it failed – we can blame a proprietary nvidia module which tainted the kernel, of course 🙂FAULT_INJECTION:
data:image/s3,"s3://crabby-images/a1f31/a1f3177b34e20cb16b6a25a50fb1ea652dc00155" alt=""
data:image/s3,"s3://crabby-images/8bcb8/8bcb81bc38ab2736c8b1c1f9a5ac28d250b95cd1" alt=""
Hopefully, the bug is not there anymore, as I notified the logfs’ author, Jörn Engel. He also fixed some other bugs I found.
I wonder if and how easy other filesystems can be abused with the fault injection?