[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <20130717211649.GA5619@merkur.ravnborg.org>
Date: Wed, 17 Jul 2013 23:16:49 +0200
From: Sam Ravnborg <sam@...nborg.org>
To: "Yann E. MORIN" <yann.morin.1998@...e.fr>
Cc: Andrew Morton <akpm@...ux-foundation.org>,
"H. Peter Anvin" <hpa@...or.com>, Ingo Molnar <mingo@...nel.org>,
Kyungsik Lee <kyungsik.lee@....com>,
Michal Marek <mmarek@...e.cz>, linux-kernel@...r.kernel.org,
linux-kbuild@...r.kernel.org, x86@...nel.org,
celinux-dev@...ts.celinuxforum.org,
linux-arm-kernel@...ts.infradead.org, hyojun.im@....com,
chan.jeong@....com, raphael.andy.lee@...il.com,
Ingo Molnar <mingo@...e.hu>,
Thomas Gleixner <tglx@...utronix.de>,
Russell King <rmk@....linux.org.uk>,
Borislav Petkov <bp@...en8.de>,
Florian Fainelli <florian@...nwrt.org>,
Yann Collet <yann.collet.73@...il.com>,
Chanho Min <chanho.min@....com>
Subject: Re: [PATCH -next 2/2] kbuild: fix for updated LZ4 tool with the
new streaming format
>
> We could extend the symbol option part to retreive values from a binary.
> Something like this:
>
> config FOOBAR
> bool
> option exec="true"
>
> FOOBAR would assume the value "y" if the command true has exit code == 0, otherwise "n".
> And similar conversions for other types.
>
> This only extendt Kconfig slightly - using an already present method to import
> external values.
>
> The drawback I see with this approach is that we may execute a lot of small programs
> where the value is never used.
Following is a quick patch implmenting this idea.
You need to run gperf manually to enable this.
"gperf -C scripts/kconfig/zconf.gperf > scripts/kconfig/zconf.hash.c"
I did not figure out how to use the built-in rules to generate this file :-(
I have tested this lightly - as we should discuss if this is a viable way forward.
For now I used popen() - so return value of the executed program are ignored.
To test this I used:
config FOOBAR
bool
option exec="echo y"
config FOOBAR_SELECTOR
bool
default FOOBAR
Nothing fancy - but it shows the idea.
Sam
diff --git a/scripts/kconfig/expr.h b/scripts/kconfig/expr.h
index df198a5..a68258b 100644
--- a/scripts/kconfig/expr.h
+++ b/scripts/kconfig/expr.h
@@ -133,6 +133,7 @@ enum prop_type {
P_SELECT, /* select BAR */
P_RANGE, /* range 7..100 (for a symbol) */
P_ENV, /* value from environment variable */
+ P_EXEC, /* value from executable (using symbol option) */
P_SYMBOL, /* where a symbol is defined */
};
diff --git a/scripts/kconfig/lkc.h b/scripts/kconfig/lkc.h
index 09f4edf..371f73b 100644
--- a/scripts/kconfig/lkc.h
+++ b/scripts/kconfig/lkc.h
@@ -61,6 +61,7 @@ enum conf_def_mode {
#define T_OPT_MODULES 1
#define T_OPT_DEFCONFIG_LIST 2
#define T_OPT_ENV 3
+#define T_OPT_EXEC 4
struct kconf_id {
int name;
diff --git a/scripts/kconfig/menu.c b/scripts/kconfig/menu.c
index 7e233a6..cfa7aaa 100644
--- a/scripts/kconfig/menu.c
+++ b/scripts/kconfig/menu.c
@@ -213,6 +213,9 @@ void menu_add_option(int token, char *arg)
case T_OPT_ENV:
prop_add_env(arg);
break;
+ case T_OPT_EXEC:
+ prop_add_exec(arg);
+ break;
}
}
diff --git a/scripts/kconfig/symbol.c b/scripts/kconfig/symbol.c
index d550300..b7179a6 100644
--- a/scripts/kconfig/symbol.c
+++ b/scripts/kconfig/symbol.c
@@ -1331,6 +1331,8 @@ const char *prop_get_type_name(enum prop_type type)
return "prompt";
case P_ENV:
return "env";
+ case P_EXEC:
+ return "exec";
case P_COMMENT:
return "comment";
case P_MENU:
@@ -1379,3 +1381,56 @@ static void prop_add_env(const char *env)
else
menu_warn(current_entry, "environment variable %s undefined", env);
}
+
+static void exec_command(const char *command, struct symbol *sym)
+{
+ char buffer[2048];
+ FILE *stream;
+
+ stream = popen(command, "r");
+
+ if (stream != NULL) {
+ if (fgets(buffer, sizeof(buffer), stream) != NULL) {
+ int i;
+
+ buffer[sizeof(buffer) - 1] = '\0';
+
+ /* Drop any trialing newlines */
+ i = strlen(buffer);
+ while (i > 0 && buffer[i - 1] == '\n') {
+ buffer[i - 1] = '\0';
+ i--;
+ }
+ /* Validate the output of the command */
+ if (strlen(buffer) == 0) {
+ menu_warn(current_entry,
+ "command '%s' - invalid (empty?) return value: \"%s\"",
+ command, buffer);
+ return;
+ }
+
+ menu_warn(current_entry, "default: %s", buffer);
+ sym_add_default(sym, buffer);
+ } else {
+ menu_warn(current_entry, "command '%s' - empty return value", command);
+ }
+ pclose(stream);
+ } else {
+ menu_warn(current_entry, "command '%s' failed to execute", command);
+ }
+}
+
+static void prop_add_exec(const char *command)
+{
+ struct property *prop;
+ struct symbol *sym;
+
+ sym = current_entry->sym;
+ sym->flags |= SYMBOL_AUTO;
+
+ prop = prop_alloc(P_EXEC, sym);
+ prop->expr = expr_alloc_symbol(sym_lookup(command, SYMBOL_CONST));
+
+ exec_command(command, sym);
+}
+
diff --git a/scripts/kconfig/zconf.gperf b/scripts/kconfig/zconf.gperf
index f14ab41..02c6a59 100644
--- a/scripts/kconfig/zconf.gperf
+++ b/scripts/kconfig/zconf.gperf
@@ -44,4 +44,5 @@ on, T_ON, TF_PARAM
modules, T_OPT_MODULES, TF_OPTION
defconfig_list, T_OPT_DEFCONFIG_LIST,TF_OPTION
env, T_OPT_ENV, TF_OPTION
+exec, T_OPT_EXEC, TF_OPTION
%%
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists