I have an idea that I could implement through Google's "Summer of Code" project, but as I have little experience with stuff it involves (kernel programming / disks / filesystem optimization), so I expect any answer from "It won't work" or "It's useless" to "It can't be done". :)

The idea is this: to implement sort of GEOM-layer disk data journaling system. I imagine it to be a GEOM class using two "lower-level" devices: one for data and one for the "journal" (this way, the journal device can be on a fast and small disk). Such journaled device could be used to host any filesystem, probably mounted with synchronoues-access, and it will result in faster write access by keeping the writes sequential in the "journal" device. Journal information will be commited to the data disk periodically by a separate log-writer thread, or when it gets full. The "data disk" will be consistent so it can be used without it's "journal" part (after a clean disconnect/rebuild) if needed. At the worst case, I think this will help performance in cases when there's a burst of write activity followed by a period of IO idleness.

I've made the above idea more-or-less from my head in one afternoon, so it's perfectly possible that I'm missing some vital point or that it's complete nonsense :)

Does it make sense to do it this way? Is it worth applying for the SoC?

_______________________________________________
freebsd-hackers@freebsd.org mailing list
http://lists.freebsd.org/mailman/listinfo/freebsd-hackers
To unsubscribe, send any mail to "[EMAIL PROTECTED]"

Reply via email to