Re: [PATCH] kconfig: untangle EXPERT and EMBEDDED

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Fri, Jan 13, 2012 at 02:53:27AM -0800, David Rientjes wrote:
> What would be helpful is if CONFIG_EMBEDDED actually meant what it 
> implies, i.e. for config options that only make sense on embedded devices 
> (similar to CONFIG_SMALLMEM I mentioned earlier, but more focused).

Agreed, but it's not the problem that this patch is attempting to solve.
You and I are looking at this patch (and its predecessor 6a108a14fa35)
from two different sides. I want CONFIG_EXPERT to work, and you want
CONFIG_EMBEDDED to mean what it should. I'm saying that fixing EXPERT now,
by reverting EMBEDDED back a bit, and then eventually fixing that later,
is the better way to go. You're saying you don't want me to touch
EMBEDDED, and thus far you've ignored the problem I'm attempting to solve.

> why it currently selects EXPERT, but we'd like to be able to separate 
> those out so they can make more sane decisions and introduce things like 
> "depends on EXPERT || EMBEDDED".

This patch is actually attempting to make progress in the separation of
the semantics for EXPERT and the old, insane EMBEDDED, which had the very
loose semantics. That's why it's called "untangle EXPERT and EMBEDDED".

> Don't think of 6a108a14fa35 as renaming CONFIG_EMBEDDED to CONFIG_EXPERT, 
> think of it as adding CONFIG_EXPERT which is what it really does and frees 

I do think of 6a108a14fa35 as adding CONFIG_EXPERT, and I like
CONFIG_EXPERT, but I also think of it as adding CONFIG_EXPERT incorrectly.

> That's bogus, config EMBEDDED was used to select the new EXPERT so there 
> was no backwards compatibility issue.  I'd agree with you that your patch 
> would be backwards compatible and doesn't suddenly, and silently, lose 
> config options that were previously enabled when running make oldconfig if 
> everybody in the world used defconfigs.  That's not the case, which is why 
> this is a non-starter.

The fact that this patch breaks backward compatibility is unfortunate, but
the only way to fix the problem that it's attempting to fix, without that
breakage, is to introduce yet another config option (EXPERT2 or
REALLY_EXPERT?). If I'm not mistaken and config variable backward
compliance isn't required, then I'd say breaking it makes much more sense
then adding something like REALLY_EXPERT and all the mess that'll come
with it.

It's not clear to me, that it's clear to everyone else, what this patch is
really trying to fix. Below is a fun way to try and express it. It's done
in dialog form. Hopefully it'll be entertaining as well as get the point
across.

Developers Alice and Bob work on subcomponent XYZ and are chatting

Alice> hey Bob, I think we need a new symbol to compile out some
code that not all of our customers want
Bob> really? Ugh, The XYZ config menu already has tons of options,
and most have defaults that should really never be touched anyway.
I sure hate adding yet another...
Alice> hmm... Oh, I remember there's this nifty CONFIG_EXPERT that
some options use in order to hide from the standard configmenu.
The options are only available to experts that turn on EXPERT
Bob> oh, that sounds cool. We can clean up our whole menu by adding
that to the options nobody should be touching. Then for those
special customers we can turn CONFIG_EXPERT on and override the
default of that new option to off
Alice> OK, Kconfigs updated, new config with CONFIG_EXPERT=y and
CONFIG_XYZ_SPECIAL=n created, load, cock, fire, release the code
to QA!

...some time later...

QA person> HEY! Why is the kernel missing important features from
other subcomponents?
Alice+Bob> err.. We don't know. Last update we did was only to
XYZ's Kconfig files. Oh, and we turned on that nifty CONFIG_EXPERT,
but that shouldn't do anything...

...Alice and Bob take a closer look...

Alice> CRAP! CONFIG_EXPERT doesn't just expose config options, it
actually turns stuff off too!!
Bob> Ugh, CONFIG_EXPERT is junk

--
To unsubscribe from this list: send the line "unsubscribe linux-arch" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html


[Index of Archives]     [Linux Kernel]     [Kernel Newbies]     [x86 Platform Driver]     [Netdev]     [Linux Wireless]     [Netfilter]     [Bugtraq]     [Linux Filesystems]     [Yosemite Discussion]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Samba]     [Device Mapper]

  Powered by Linux