Adrian Bunk wrote: > It seems to be always me who asks the controversial questions...: > > Does the linux-tiny approach of adding a kconfig variable for each 5kB > of code actually make sense? I'm asking since an exploding amount of > kconfig variables and their interdependencies have a not so small > maintainance impact in the long term. Others have expressed similar concerns. Andi Kleen has brought this up in the past, and highlighted another aspect of this that I think is important - fragmenting the configuration space for testing. That is, if different combinations of options are used, then the testing results from different users may not be directly comparable. This makes it harder to track down bugs. In practice, I think these types of switches tend to get turned on/off together. This tends to ameliorate the testing and maintenance issues. It might be worthwhile to coalesce these into fewer options. I'd be fine with overloading this particular onto CONFIG_BASE_FULL, but I don't know what other people think. Keeping the option separate means you have more flexibility - so that you can, for example, turn off all but one feature that's important to you. (This seems like a pretty common > And I'm wondering whether it's the best approach for reaching > measurable results. E.g. my small patch that removed > -maccumulate-outgoing-args on 32-bit x86 reduced the kernel size > there for the CONFIG_CC_OPTIMIZE_FOR_SIZE=y case by at about 2.5% (sic) > without adding any kconfig variables or #ifdef's. These are certainly nice, but there's a limited number of whole-kernel reduction options. Kernel size accumulates by both wasteful compiler output, and by the introduction or preservation of individual features that are useless for embedded devices. I think it's worthwhile to attack both problems. > Can you take a reasonable (best-case) .config for an existing device and > get the following numbers: > - Ignoring patches that came from linux-tiny, by how many percent did > the size of the kernel increase or decrease between 2.6.16 and 2.6.26? Well, an initial comparison is at: http://www.selenic.com/bloatwatch/?cmd=compare&part=%2F&v1=2.6.16&v2=2.6.25-rc2 This shows a size difference of 1.8 meg, but I'm pretty sure this is with a default config (not optimized) and is not controlled very well for changes in the config. I can do a more controlled comparison if you're interested. > - By how many percent did the kernel size decrease due to patches from > the linux-tiny project that added such kconfig options for a few kB > of code in the same timeframe? I'm not sure that's a good comparison, since Linux-tiny hasn't been very active in that time period. I would guess only about 3 or 4 Linux-tiny patches have made it into the kernel since 2.6.16. The big wins for Linux-tiny were in the 2.6.10/11 kernels, where most of the low-hanging fruit (size-wise) was gleaned. But to address your point, you're right that no existing Linux-tiny patch gets 2.5% reduction for the kernel. In my own testing at Sony, the 30 or so Linux-tiny patches that I use get me about 110k of reductions. For me, this is about 5% of my kernel size. Note that my choice of options to achieve reductions is pretty conservative. There are diminishing returns here, and at some point it doesn't make sense to continue. I have a nagging feeling, though, that there are a few more things where the bloat is pronounced (glances at procfs and sysfs). > My gut feeling is that the influence of this kind of linux-tiny patches > is hardly noticably compared to the overall code size development, but > if you have numbers that prove me wrong just point me to them and I'll > stand corrected. It *does* feel a bit like fighting the tide with a teaspoon. -- Tim ============================= Tim Bird Architecture Group Chair, CE Linux Forum Senior Staff Engineer, Sony Corporation of America ============================= -- To unsubscribe from this list: send the line "unsubscribe linux-embedded" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html