On Tue, 4 Apr 2017, Tom Zanussi wrote: > On Tue, 2017-04-04 at 21:04 +0300, Andy Shevchenko wrote: > > I believe you did some research during time of that project… > > > > Yes, as a matter of fact I did, and just found some notes I took at the > time. I didn't dive into the code in detail - that level of analysis > was supposed to come later but I did have these notes mentioning that I > thought it would show the largest savings for a single item (outside of > networking) 'if we could do it': > > "- Largest is still drivers > > - drivers/tty and serial is the biggest obvious win if we can do it > - break down into granular config options > - leave simplest possible tty/serial functionality > - allow tailoring to specific hardware > - also helps in effort to get rid of char devices > - 65740/815190" > > Basically 65k out of an 800k text size could be partially or mostly > saved by addressing that one item, which looks like it pretty much > matches Nicolas' numbers... One thing on x86 that inflates the size is the 8250 driver itself. I'm looking at some ARM targets with their own UART whose driver is much smaller. > BTW, since I'm quoting my own notes on the subject, I thought I'd just > include the whole thing, which covers a bunch of other areas possibly > ripe for tinification, in case anyone might be interested (some of it > should be taken with a grain of salt though ;-) > [...] > > - 2nd largest is kernel > > - should be able to cut *something* from time and sched > - we have a handful of processes at most > - we have very simple time needs > - say 30000/815190 savings > > 150742 6376 8209 165327 285cf ./kernel/built-in.o > > 40951 1105 4720 46776 b6b8 ./kernel/time/built-in.o Commit baa73d9e47 allows for shaving off 25K here. More could probably be done. > 21760 1318 112 23190 5a96 ./kernel/sched/built-in.o I already have an alternative scheduler implementation that weights 9K. It is on the backburner for now though. But don't let the scheduler guys know just yet. ;-) Nicolas