From: Johannes Berg <johannes@sipsolutions.net>
To: "Luis R. Rodriguez" <mcgrof@suse.com>
Cc: Stefan Assmann <sassmann@kpanic.de>,
"Luis R. Rodriguez" <mcgrof@do-not-panic.com>,
backports@vger.kernel.org, linux-kernel@vger.kernel.org,
yann.morin.1998@free.fr, mmarek@suse.cz
Subject: Re: [RFC v2 4/4] backports: add kernl integration support to gentree.py
Date: Fri, 31 Oct 2014 08:50:51 +0100 [thread overview]
Message-ID: <1414741851.3014.13.camel@jlt4.sipsolutions.net> (raw)
In-Reply-To: <20141029160003.GW28966@wotan.suse.de> (sfid-20141029_170034_600454_10CE6011)
On Wed, 2014-10-29 at 17:00 +0100, Luis R. Rodriguez wrote:
> backport/Kconfig | 54 --------
> backport/Kconfig.package | 31 +++++
> backport/Kconfig.sources | 23 ++++
I think you should do this split as a separate patch.
> +# these will be generated
> +source "$BACKPORT_DIR/Kconfig.kernel"
> +source "$BACKPORT_DIR/Kconfig.versions"
> +source "$BACKPORT_DIR/Kconfig.sources"
Not true - Kconfig.sources exists below?
> +ifneq ($(BACKPORT_PACKAGE),)
I think it'd be easier to understand if you called this
BACKPORT_INTEGRATED
and inverted the logic.
> + # Only the kconfig 'mainmenu' entries grok variables, we want to keep
> + # this the main Kconfig as part of our program to be able to give it
> + # enough dynamic information
> + k = open(os.path.join(args.outdir, 'Kconfig'), 'w')
> + k.write('config BACKPORT_DIR\n')
> + k.write('\tstring\n')
> + k.write('\tdefault "backports/"\n')
> + k.write('config BACKPORTS_VERSION\n')
> + k.write('\tstring\n')
> + k.write('\tdefault "%s"\n' % backports_version)
> + k.write('config BACKPORTED_KERNEL_VERSION\n')
> + k.write('\tstring\n')
> + k.write('\tdefault "%s"\n' % kernel_version)
> + k.write('config BACKPORTED_KERNEL_NAME\n')
> + k.write('\tstring\n')
> + k.write('\tdefault "%s"\n' % args.base_name)
> + k.write('\n')
> + k.write('menuconfig BACKPORT_LINUX\n')
> + k.write('\tbool "Backport %s %s (backports %s)"\n' % (args.base_name, kernel_version, backports_version))
> + k.write('\tdefault n\n')
> + k.write('\t---help--- \n')
> + k.write('\t Enabling this will let give you the opportunity to use\n')
> + k.write('\t features and drivers backported from %s %s\n' % (args.base_name, kernel_version))
> + k.write('\t on the kernel your are using. This is experimental and you should\n')
> + k.write('\t say no unless you\'d like to help test things.\n')
> + k.write('\n')
> + k.write('if BACKPORT_LINUX\n')
> + k.write('\n')
> + k.write('source "$BACKPORT_DIR/Kconfig.versions"\n')
> + k.write('source "$BACKPORT_DIR/Kconfig.sources"\n')
> + k.write('\n')
> + k.write('endif # BACKPORT_LINUX\n')
This is really really ugly - please just have a file template, and maybe
replace some things in it or provide them as env variables through the
Makefile or so.
> + if args.integrate:
> + f = open(os.path.join(args.outdir, '../arch/x86/Kconfig'), 'a')
> + f.write('source "backports/Kconfig"\n')
That seems like a bad idea - maybe better integrate it under some
arch-independent file?
> + f.close()
> + git_debug_snapshot(args, "hooked backport Kconfig to supported architectures")
> +
> + f = open(os.path.join(args.outdir, '../MAINTAINERS'), 'a')
> + f.write('M:\tHauke Mehrtens <hauke@hauke-m.de>\n')
> + f.write('M:\tLuis R. Rodriguez <mcgrof@do-not-panic.com>\n')
> + f.write('L:\tbackports@vger.kernel.org\n')
> + f.write('T:\tgit://git.kernel.org/pub/scm/linux/kernel/git/backports/backports.git\n')
> + f.write('F:\tbackports/\n')
> + f.close()
That's ... odd? doesn't even fit the MAINTAINERS file style? Anyway I
think it's probably not necessary.
> + git_debug_snapshot(args, "add backport maintainers entry")
> +
> + f = open(os.path.join(args.outdir, '../Makefile'), 'a')
> + f.write('ifeq ($(KBUILD_EXTMOD),)\n')
> + f.write('backports-y := backports/\n')
> + f.write('vmlinux-dirs += $(patsubst %/,%,$(filter %/, $(backports-y) $(backports-m)))\n')
> + f.write('vmlinux-alldirs += $(patsubst %/,%,$(filter %/, $(backports-n) $(backports-)))\n')
> + f.write('backports-y := $(patsubst %/, %/built-in.o, $(backports-y))\n')
> + f.write('KBUILD_VMLINUX_MAIN += $(backports-y)\n')
> + f.write('endif\n')
> + f.close()
That could be a template file again that you just copy.
[... I need more time to review, don't have much this morning ...]
johannes
next prev parent reply other threads:[~2014-10-31 7:51 UTC|newest]
Thread overview: 24+ messages / expand[flat|nested] mbox.gz Atom feed top
2014-10-29 8:21 [RFC v2 0/4] backports: kernel integration support Luis R. Rodriguez
2014-10-29 8:21 ` [RFC v2 1/4] backports: replace CPTCFG prefix for CONFIG_BACKPORT Luis R. Rodriguez
2014-10-31 7:41 ` Johannes Berg
2014-10-31 19:34 ` Luis R. Rodriguez
2014-10-31 20:22 ` Johannes Berg
2014-10-31 20:33 ` Luis R. Rodriguez
2014-11-03 19:30 ` Luis R. Rodriguez
2014-11-03 19:40 ` Johannes Berg
2014-11-03 19:56 ` Luis R. Rodriguez
2014-11-03 20:20 ` Johannes Berg
2014-11-03 20:21 ` Luis R. Rodriguez
2014-11-03 20:24 ` Johannes Berg
2014-11-03 20:26 ` Luis R. Rodriguez
2014-10-29 8:21 ` [RFC v2 2/4] backports: replace BACKPORT_PWD with BACKPORT_DIR Luis R. Rodriguez
2014-10-31 7:41 ` Johannes Berg
2014-10-31 19:35 ` Luis R. Rodriguez
2014-10-29 8:21 ` [RFC v2 3/4] backports: use BACKPORT_DIR prefix on kconfig sources Luis R. Rodriguez
2014-10-31 7:46 ` Johannes Berg
2014-10-31 20:03 ` Luis R. Rodriguez
2014-10-29 8:21 ` [RFC v2 4/4] backports: add kernl integration support to gentree.py Luis R. Rodriguez
2014-10-29 15:36 ` Stefan Assmann
2014-10-29 16:00 ` Luis R. Rodriguez
2014-10-31 7:50 ` Johannes Berg [this message]
2014-10-31 20:10 ` Luis R. Rodriguez
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=1414741851.3014.13.camel@jlt4.sipsolutions.net \
--to=johannes@sipsolutions.net \
--cc=backports@vger.kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=mcgrof@do-not-panic.com \
--cc=mcgrof@suse.com \
--cc=mmarek@suse.cz \
--cc=sassmann@kpanic.de \
--cc=yann.morin.1998@free.fr \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox