提交 47a3d5da 编写于 作者: T Thomas Gleixner

x86: Add early platform detection

Platforms like Moorestown require early setup and want to avoid the
call to reserve_ebda_region. The x86_init override is too late when
the MRST detection happens in setup_arch. Move the default i386
x86_init overrides and the call to reserve_ebda_region into a separate
function which is called as the default of a switch case depending on
the hardware_subarch id in boot params. This allows us to add a case
for MRST and let MRST have its own early setup function.
Signed-off-by: NThomas Gleixner <tglx@linutronix.de>
上级 dd0a70c8
...@@ -2,6 +2,7 @@ ...@@ -2,6 +2,7 @@
#define _ASM_X86_PLATFORM_H #define _ASM_X86_PLATFORM_H
#include <asm/pgtable_types.h> #include <asm/pgtable_types.h>
#include <asm/bootparam.h>
struct mpc_bus; struct mpc_bus;
struct mpc_cpu; struct mpc_cpu;
...@@ -34,14 +35,12 @@ struct x86_init_mpparse { ...@@ -34,14 +35,12 @@ struct x86_init_mpparse {
* @probe_roms: probe BIOS roms * @probe_roms: probe BIOS roms
* @reserve_resources: reserve the standard resources for the * @reserve_resources: reserve the standard resources for the
* platform * platform
* @reserve_ebda_region: reserve the extended bios data area
* @memory_setup: platform specific memory setup * @memory_setup: platform specific memory setup
* *
*/ */
struct x86_init_resources { struct x86_init_resources {
void (*probe_roms)(void); void (*probe_roms)(void);
void (*reserve_resources)(void); void (*reserve_resources)(void);
void (*reserve_ebda_region)(void);
char *(*memory_setup)(void); char *(*memory_setup)(void);
}; };
......
...@@ -15,6 +15,17 @@ ...@@ -15,6 +15,17 @@
#include <asm/trampoline.h> #include <asm/trampoline.h>
#include <asm/apic.h> #include <asm/apic.h>
#include <asm/io_apic.h> #include <asm/io_apic.h>
#include <asm/bios_ebda.h>
static void __init i386_default_early_setup(void)
{
/* Initilize 32bit specific setup functions */
x86_init.resources.probe_roms = probe_roms;
x86_init.resources.reserve_resources = i386_reserve_resources;
x86_init.mpparse.setup_ioapic_ids = setup_ioapic_ids_from_mpc;
reserve_ebda_region();
}
void __init i386_start_kernel(void) void __init i386_start_kernel(void)
{ {
...@@ -31,12 +42,13 @@ void __init i386_start_kernel(void) ...@@ -31,12 +42,13 @@ void __init i386_start_kernel(void)
reserve_early(ramdisk_image, ramdisk_end, "RAMDISK"); reserve_early(ramdisk_image, ramdisk_end, "RAMDISK");
} }
#endif #endif
/* Initilize 32bit specific setup functions */
x86_init.resources.probe_roms = probe_roms;
x86_init.resources.reserve_resources = i386_reserve_resources;
x86_init.mpparse.setup_ioapic_ids = setup_ioapic_ids_from_mpc;
x86_init.resources.reserve_ebda_region(); /* Call the subarch specific early setup function */
switch (boot_params.hdr.hardware_subarch) {
default:
i386_default_early_setup();
break;
}
/* /*
* At this point everything still needed from the boot loader * At this point everything still needed from the boot loader
......
...@@ -24,6 +24,7 @@ ...@@ -24,6 +24,7 @@
#include <asm/kdebug.h> #include <asm/kdebug.h>
#include <asm/e820.h> #include <asm/e820.h>
#include <asm/trampoline.h> #include <asm/trampoline.h>
#include <asm/bios_ebda.h>
static void __init zap_identity_mappings(void) static void __init zap_identity_mappings(void)
{ {
...@@ -111,7 +112,7 @@ void __init x86_64_start_reservations(char *real_mode_data) ...@@ -111,7 +112,7 @@ void __init x86_64_start_reservations(char *real_mode_data)
} }
#endif #endif
x86_init.resources.reserve_ebda_region(); reserve_ebda_region();
/* /*
* At this point everything still needed from the boot loader * At this point everything still needed from the boot loader
......
...@@ -28,7 +28,6 @@ struct __initdata x86_init_ops x86_init = { ...@@ -28,7 +28,6 @@ struct __initdata x86_init_ops x86_init = {
.resources = { .resources = {
.probe_roms = x86_init_noop, .probe_roms = x86_init_noop,
.reserve_resources = reserve_standard_io_resources, .reserve_resources = reserve_standard_io_resources,
.reserve_ebda_region = reserve_ebda_region,
.memory_setup = default_machine_specific_memory_setup, .memory_setup = default_machine_specific_memory_setup,
}, },
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册