Speeding up the loader(8).
Artem Belevich
art at freebsd.org
Tue Jan 24 18:47:56 UTC 2012
2012/1/23 Edward Tomasz Napierała <trasz at freebsd.org>:
> Some time ago I've spent some time on trying to speed up loading
> modules by the loader(8). Result can be found at:
>
> http://people.freebsd.org/~trasz/fast-loader-3.diff
>
> This patch solves three issues:
>
> 1. As it is now, the code in biosdisk.c tries very hard to split
> reasonably sized (up to 64kB, IIRC) requests into smaller ones.
>
> 2. The code in biosdisk.c rereads the partition table and probably
> some filesystem metadata every time a file gets opened, i.e.
> for every module. These reads bypass the bcache.
>
> 3. The code in bcache.c doesn't really implement an LRU - it implements
> 'least recently added' algorithm, i.e. a kind of queue. Not that
> it matters much, since it flushes the elements two seconds after
> caching them anyway. I replaced it with Least Frequently Used.
> LRU didn't behave well, as it tended to replace metadata with data
> used only once.
4. it flushes cache on access to a different drive which means that
cache does not help on multi-disk ZFS setups.
I've posted a patch some time back. See
http://lists.freebsd.org/pipermail/freebsd-fs/2011-September/012527.html
Feel free to combine the changes.
--Artem
>
> In my tests under VMWare Fusion, this cut the modules loading time
> by half. I don't intend to commit the patch as-is - the first part
> looks dangerous (the splitting was probably done for a reason),
> the second is hackish, and the third doesn't improve anything by itself.
> I'm working on something else at a moment; feel free to pick this up.
>
> --
> If you cut off my head, what would I say? Me and my head, or me and my body?
> _______________________________________________
> freebsd-hackers at freebsd.org mailing list
> http://lists.freebsd.org/mailman/listinfo/freebsd-hackers
> To unsubscribe, send any mail to "freebsd-hackers-unsubscribe at freebsd.org"
More information about the freebsd-hackers
mailing list