|
@@ -13,14 +13,6 @@
|
|
struct ia64_machine_vector ia64_mv;
|
|
struct ia64_machine_vector ia64_mv;
|
|
EXPORT_SYMBOL(ia64_mv);
|
|
EXPORT_SYMBOL(ia64_mv);
|
|
|
|
|
|
-static __initdata const char *mvec_name;
|
|
|
|
-static __init int setup_mvec(char *s)
|
|
|
|
-{
|
|
|
|
- mvec_name = s;
|
|
|
|
- return 0;
|
|
|
|
-}
|
|
|
|
-early_param("machvec", setup_mvec);
|
|
|
|
-
|
|
|
|
static struct ia64_machine_vector * __init
|
|
static struct ia64_machine_vector * __init
|
|
lookup_machvec (const char *name)
|
|
lookup_machvec (const char *name)
|
|
{
|
|
{
|
|
@@ -41,7 +33,7 @@ machvec_init (const char *name)
|
|
struct ia64_machine_vector *mv;
|
|
struct ia64_machine_vector *mv;
|
|
|
|
|
|
if (!name)
|
|
if (!name)
|
|
- name = mvec_name ? mvec_name : acpi_get_sysname();
|
|
|
|
|
|
+ name = acpi_get_sysname();
|
|
mv = lookup_machvec(name);
|
|
mv = lookup_machvec(name);
|
|
if (!mv)
|
|
if (!mv)
|
|
panic("generic kernel failed to find machine vector for"
|
|
panic("generic kernel failed to find machine vector for"
|
|
@@ -51,6 +43,23 @@ machvec_init (const char *name)
|
|
printk(KERN_INFO "booting generic kernel on platform %s\n", name);
|
|
printk(KERN_INFO "booting generic kernel on platform %s\n", name);
|
|
}
|
|
}
|
|
|
|
|
|
|
|
+void __init
|
|
|
|
+machvec_init_from_cmdline(const char *cmdline)
|
|
|
|
+{
|
|
|
|
+ char str[64];
|
|
|
|
+ const char *start;
|
|
|
|
+ char *end;
|
|
|
|
+
|
|
|
|
+ if (! (start = strstr(cmdline, "machvec=")) )
|
|
|
|
+ return machvec_init(NULL);
|
|
|
|
+
|
|
|
|
+ strlcpy(str, start + strlen("machvec="), sizeof(str));
|
|
|
|
+ if ( (end = strchr(str, ' ')) )
|
|
|
|
+ *end = '\0';
|
|
|
|
+
|
|
|
|
+ return machvec_init(str);
|
|
|
|
+}
|
|
|
|
+
|
|
#endif /* CONFIG_IA64_GENERIC */
|
|
#endif /* CONFIG_IA64_GENERIC */
|
|
|
|
|
|
void
|
|
void
|