Re: [RFC PATCH 2/3] Add generation of Module.ksymb file in streamline_config.pl
From: Julia Lawall
Date: Mon Aug 08 2016 - 16:33:01 EST
On Mon, 8 Aug 2016, Luis R. Rodriguez wrote:
> On Sun, Jul 31, 2016 at 05:33:51PM +0200, Cristina Moraru wrote:
> > Add generation of ./scripts/mod/Module.ksymb file containing
> > associations of driver file names and corresponding CONFIG_*
> > symbol.
> >
> > This file will be used by modpost to peg kconfig CONFIG_*
> > symbol to its corresponding module. This information will
> > be further exposed in userspace for extracting build options
> > for the required modules.
> >
> > This approach faces the following limitations:
> > * in some cases there are more than one CONFIG_* option
> > for certain objects. This happens for the objects that are
> > part of more CONFIGs. Thus, all configs are returned for
> > this object names. For example, the mapping for clk_div6 is
> > CONFIG_ARCH_R8A73A4, CONFIG_ARCH_R8A7793 and many others.
>
> Ah, indeed so for instance:
>
> drivers/clk/renesas/Makefile:
> ...
> obj-$(CONFIG_ARCH_R8A73A4) += clk-r8a73a4.o clk-div6.o
> obj-$(CONFIG_ARCH_R8A7740) += clk-r8a7740.o clk-div6.o
> ...
>
> So in this case there is no particular unique CONFIG_* symbols that
> only associates itself to clk-div6.
>
> Given that the purpose here is to help compile a .config that is sufficient to
> build a kernel with that module, I do believe using both config symbols would
> be the appropriate solution in this case to ensure a build suffices based only
> on this information. This is only possible of course *iff* both symbols are
> not mutually exclusive, so in this case an issue would be if for instance
> CONFIG_ARCH_R8A73A4's kconfig entry negates CONFIG_ARCH_R8A7740. They do not
> in this case so using both suffices. I can imagine doing this secondary logic
> is cumbersome, so perhaps its best we avoid these sorts of situations as it
> would imply doing more work going barkwards -- from modules loaded to modules
> to symbols.
>
> I'd bet this would not be the only kconfig issue that could arise from this
> loose practice in kconfig.
>
> Anyway, if we determine that both kconfig options should be enabled for a build
> to select this driver -- that would increase the build size, perhaps with no
> need for it. So this strategy of course would not yield optimal builds.
Do you care? I guess no one would want clk-div6 for actual execution. I
haven't looked at the file, but from the make information, it looks like a
library that is shared by two drivers and has no independent interest. If
the goal is just to be sure that the code is compiled, for sanity checking
purposes, then wouldn't it be fine to either pick one option, or pick both
(giving perhaps a little more confidence at a small cost).
julia
> So we
> should just expand the kconfig documentation indicating pitfalls of this use
> of kconfig, given the deterministic gains we want of mapping between modules
> to config symbols.
>
> It'd be curious to see metrically how many symbols we have like this which are
> modules and if there is a benefit to add a respective first class config symbol
> to each. Is that too much to ask to hunt quantitatively ? Based on this we can
> determine if a tree-wide cleaning is in order. If folks already know this is
> outright dumb please let me know. Additionally -- are there other areas in the
> kernel that suffer from the lack of direct deterministic relationship between
> modules and a kconfig symbol ? Or how about the other way around: is there any
> valid hard requirement to enable this loose practice on the kernel ? If we
> remove this loose semantic, do we loose anything ? So far I see only gains:
>
> o Once you have modules loaded, have the ability to do a deterministic
> set of .config symbol entries you know you need for an optimal smaller build
> for your device. If you have a direct mapping a tool that scrapes this
> list can be kconfig language stupid, and does not need to inspect your other
> symbols or upstream Kconfig entry for issues with other symbols
>
> o Having a direct mapping means selecting only the real configuration options
> needed
>
> o Forcing a bit of documenting (through the configuration menu) more clearly
> what this module does
>
> > * in some cases the driver file name does not match the
> > registered name for the module. For example:
> >
> > Driver filename Module name
> > -----------------------------------
> > lineage-pem[.o] lineage_pem
> >
> > phy-ab8500-usb[.o] abx5x0-usb
> >
> > ehci-mxc[.o] mxc-ehci
> > etc.
>
> To be clear you mean here for instance:
>
> drivers/usb/phy/phy-ab8500-usb.c
> ...
> static struct platform_driver ab8500_usb_driver = {
> .probe = ab8500_usb_probe,
> .remove = ab8500_usb_remove,
> .id_table = ab8500_usb_devtype,
> .driver = {
> .name = "abx5x0-usb",
> },
> };
> ...
>
> The .ko filename should I think typically match the respective principle
> object filename, would that help? So for instance while the name above
> is abx5x0-usb, the ko file should still be drivers/usb/phy/phy-ab8500-usb.ko
>
> There may be some exceptions to this but this probably is not that common?
>
> > There is no naming rule / standard between the driver
> > name and the registered module name.
>
> This seems true. In this case the module name should match the
> target object typically.
>
> > This patch is part of a research project within
> > Google Summer of Code of porting 'make localmodconfig'
> > for backported drivers.
> >
> > Signed-off-by: Cristina Moraru <cristina.moraru09@xxxxxxxxx>
> > ---
> > scripts/kconfig/streamline_config.pl | 20 ++++++++++++++++++++
> > 1 file changed, 20 insertions(+)
> >
> > diff --git a/scripts/kconfig/streamline_config.pl b/scripts/kconfig/streamline_config.pl
> > index b8c7b29..4833ede 100755
> > --- a/scripts/kconfig/streamline_config.pl
> > +++ b/scripts/kconfig/streamline_config.pl
> > @@ -147,6 +147,7 @@ my %objects;
> > my $var;
> > my $iflevel = 0;
> > my @ifdeps;
> > +my @drv_objs;
> >
> > # prevent recursion
> > my %read_kconfigs;
> > @@ -341,6 +342,10 @@ foreach my $makefile (@makefiles) {
> > # The objects have a hash mapping to a reference
> > # of an array of configs.
> > $objects{$1} = \@arr;
> > + # Save objects corresponding to driver Makefiles
> > + if (index($makefile, "./drivers/") == 0) {
> > + push(@drv_objs, substr($obj, 0, -2));
> > + }
> > }
> > }
> > }
> > @@ -348,6 +353,21 @@ foreach my $makefile (@makefiles) {
> > close($infile);
> > }
> >
> > +sub gen_module_kconfigs {
> > +
> > + my $module_ksymb = $ENV{'objtree'}."/scripts/mod/Module.ksymb";
> > + my $key;
> > +
> > + open(my $ksymbfile, '>', $module_ksymb) || die "Can not open $module_ksymb for writing";
> > +
> > + foreach (@drv_objs) {
> > + print $ksymbfile "$_ " . "@{$objects{$_}}\n";
> > + }
> > + close $ksymbfile;
> > +}
> > +
> > +gen_module_kconfigs();
> > +
> > my %modules;
> > my $linfile;
>
> It would be good to see how we could not rely on scripts/kconfig/streamline_config.pl
> for this purpose. That should only be used for helping with localmodconfig. In this
> case we want to make the kconfig symbol available to all modules when possible, so
> we do not want to depend on scripts/kconfig/streamline_config.pl generically.
>
> Luis
>