On Tue, 17 Mar 2009, Alain Kalker wrote: > Op vrijdag 13-03-2009 om 02:12 uur [tijdzone -0700], schreef Trent > Piepho: > > On Mon, 9 Mar 2009, Alain Kalker wrote: > > > Firstly: generating a .config with just one config variable for the > > > requested driver set to 'm' merged with the config for the kernel being > > > built for, and then doing a "make silentoldconfig". Big disatvantage is > > > that full kernel source is required for the 'silentoldconfig' target to > > > be available. > > > > Does that actually work? Figuring out that needs to be turned on to enable > > some config options is a hard problem. It's not just simple dependencies > > between modules, but complex expressions that need to be satisfied. E.g., > > something "depends on A || B", which do you turn on, A or B? There are > > multiple solutions so how does the code decide which is best? > > Well, make_kconfig.pl does quite a nice job trying to select as many > drivers without causing conflicts. What I did in make_kconfig.pl was just turn everything on, then recursively disable anything that has a failed dependency. There isn't any intelligence when it comes to choices where you can have driver set A or driver set B, but not both. Options that we want disabled, like some drivers' advanced debug controls, must be explicitly disabled in make_kconfig. Still, it ends up doing what we want in the end, which is to compile all the drivers that we can compile. > Anyway, you're quite right about this being a hard problem, and the > fact that the Kconfig system wasn't designed to be very helpful in > auto-selecting dependencies and resolving conflicts the same way modern > package managers are, doesn't make it any easier. >From what I can tell, solving the dependency problem is easily shown to be the same as the classical satisfiability problem, which is proven to be NP complete. Now, there are heuristics that can usually solve SAT problems quicker but finding the "best" solution quickly is quite a bit harder. > For the moment, I would suggest either to choose a default which works > for most people, or ask the user (using any Kconfig menu tool, if only > they didn't need write access to the kernel source, grrr!) to choose > among alternatives if no combination of options can be selected > automatically. You don't need write access to the kernel source. The kernel's config programs have to be built, but that can be done ahead of time. Once they are, then you can use that menu tool from v4l-dvb without write access to the kernel source. There is support for an alternate output directory for the kernel that can work too. In the kernel dir, run "make O=~/kernel-output-dir menuconfig". That should not require write access to the kernel source dir and will put the necessary config programs in ~/kernel-output-dir. Then point v4l-dvb at the kernel output dir, with "make release DIR=~/kernel-output-dir". See the explanation from my changeset that added this, http://linuxtv.org/hg/v4l-dvb/log/6331 Good thing I wrote this 17 months ago when I did the work, instead of just using some two word patch description, since I sure wouldn't remember how all that works today. -- To unsubscribe from this list: send the line "unsubscribe linux-media" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html