[<prev] [next>] [day] [month] [year] [list]
Message-ID: <20080803142251.GA16487@lenovo>
Date:	Sun, 3 Aug 2008 18:22:51 +0400
From:	Cyrill Gorcunov <gorcunov@...il.com>
To:	Andi Kleen <andi@...stfloor.org>,
	David Miller <davem@...emloft.net>,
	"H. Peter Anvin" <hpa@...or.com>,
	Alexander Viro <aviro@...hat.com>,
	Thomas Gleixner <tglx@...utronix.de>,
	Ingo Molnar <mingo@...e.hu>,
	Andrew Morton <akpm@...ux-foundation.org>
Cc:	LKML <linux-kernel@...r.kernel.org>
Subject: [RFC] init: introduce boot param alias
By introducing the macroses __setup_alias and early_param_alias
we are allowed to use boot param aliases.
Here is an example:
static int __init parse_func(char *arg)
{
	/* set some flag or do something */
	return 0;
}
early_param("param1", parse_func);
early_param_alias("param1-alias", parse_func);
Signed-off-by: Cyrill Gorcunov <gorcunov@...il.com>
---
I found it usefull while was looking for APIC code merging.
Please review! Any comments are _quite_welcome_!!!
I use __LINE__ macro to define salt for names. Not sure
if this is really that good way to produce unique names.
But anyway i think it's better then define different functions
with same functionallity.
I'm on really slow GPRS connection now and can't reply fast so
forgive me for that :)
Index: linux-2.6.git/include/linux/init.h
===================================================================
--- linux-2.6.git.orig/include/linux/init.h	2008-08-03 17:32:25.000000000 +0400
+++ linux-2.6.git/include/linux/init.h	2008-08-03 18:02:48.000000000 +0400
@@ -247,6 +247,25 @@ struct obs_kernel_param {
 #define early_param(str, fn)					\
 	__setup_param(str, fn, fn, 1)
 
+/*
+ * Sometimes we need to define boot parameter alias
+ * ie different boot options with the same functionality
+ * so we could use one parsing function for all of them
+ * NOTE: these macroses _MUST_ be placed on different lines
+ */
+#define __setup_param_alias(str, unique_id, salt, fn, early)		\
+	static char __setup_str_##unique_id##salt[] __initdata __aligned(1) = str; \
+	static struct obs_kernel_param __setup_##unique_id##salt	\
+		__used __section(.init.setup)				\
+		__attribute__((aligned((sizeof(long)))))		\
+		= { __setup_str_##unique_id##salt, fn, early }
+
+#define __setup_alias(str, fn)				\
+	__setup_param_alias(str, fn, __LINE__, fn, 0)
+
+#define early_param_alias(str, fn)			\
+	__setup_param_alias(str, fn, __LINE__, fn, 1)
+
 /* Relies on boot_command_line being set */
 void __init parse_early_param(void);
 #endif /* __ASSEMBLY__ */
--
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
 
