提交 8fee697d 编写于 作者: T Thomas Gleixner

x86: Add request_standard_resources to x86_init

The 32bit and the 64bit code are slighty different in the reservation
of standard resources. Also the upcoming Moorestown support needs its
own version of that.

Add it to x86_init_ops and initialize it with the 64bit default. 32bit
overrides it in early boot. Now moorestown can add it's own override
w/o sprinkling the code with more #ifdefs
Signed-off-by: NThomas Gleixner <tglx@linutronix.de>
上级 f7cf5a5b
...@@ -88,6 +88,9 @@ extern unsigned long saved_video_mode; ...@@ -88,6 +88,9 @@ extern unsigned long saved_video_mode;
#define paravirt_post_allocator_init() do {} while (0) #define paravirt_post_allocator_init() do {} while (0)
#endif #endif
extern void reserve_standard_io_resources(void);
extern void i386_reserve_resources(void);
#ifndef _SETUP #ifndef _SETUP
/* /*
......
...@@ -4,10 +4,13 @@ ...@@ -4,10 +4,13 @@
/** /**
* struct x86_init_resources - platform specific resource related ops * struct x86_init_resources - platform specific resource related ops
* @probe_roms: probe BIOS roms * @probe_roms: probe BIOS roms
* @reserve_resources: reserve the standard resources for the
* platform
* *
*/ */
struct x86_init_resources { struct x86_init_resources {
void (*probe_roms)(void); void (*probe_roms)(void);
void (*reserve_resources)(void);
}; };
/** /**
......
...@@ -31,6 +31,7 @@ void __init i386_start_kernel(void) ...@@ -31,6 +31,7 @@ void __init i386_start_kernel(void)
#endif #endif
/* Initilize 32bit specific setup functions */ /* Initilize 32bit specific setup functions */
x86_init.resources.probe_roms = probe_roms; x86_init.resources.probe_roms = probe_roms;
x86_init.resources.reserve_resources = i386_reserve_resources;
reserve_ebda_region(); reserve_ebda_region();
......
...@@ -171,13 +171,6 @@ static struct resource bss_resource = { ...@@ -171,13 +171,6 @@ static struct resource bss_resource = {
#ifdef CONFIG_X86_32 #ifdef CONFIG_X86_32
static struct resource video_ram_resource = {
.name = "Video RAM area",
.start = 0xa0000,
.end = 0xbffff,
.flags = IORESOURCE_BUSY | IORESOURCE_MEM
};
/* cpu data as detected by the assembly code in head.S */ /* cpu data as detected by the assembly code in head.S */
struct cpuinfo_x86 new_cpu_data __cpuinitdata = {0, 0, 0, 0, -1, 1, 0, 0, -1}; struct cpuinfo_x86 new_cpu_data __cpuinitdata = {0, 0, 0, 0, -1, 1, 0, 0, -1};
/* common cpu data for all cpus */ /* common cpu data for all cpus */
...@@ -605,7 +598,7 @@ static struct resource standard_io_resources[] = { ...@@ -605,7 +598,7 @@ static struct resource standard_io_resources[] = {
.flags = IORESOURCE_BUSY | IORESOURCE_IO } .flags = IORESOURCE_BUSY | IORESOURCE_IO }
}; };
static void __init reserve_standard_io_resources(void) void __init reserve_standard_io_resources(void)
{ {
int i; int i;
...@@ -1013,10 +1006,7 @@ void __init setup_arch(char **cmdline_p) ...@@ -1013,10 +1006,7 @@ void __init setup_arch(char **cmdline_p)
e820_reserve_resources(); e820_reserve_resources();
e820_mark_nosave_regions(max_low_pfn); e820_mark_nosave_regions(max_low_pfn);
#ifdef CONFIG_X86_32 x86_init.resources.reserve_resources();
request_resource(&iomem_resource, &video_ram_resource);
#endif
reserve_standard_io_resources();
e820_setup_gap(); e820_setup_gap();
...@@ -1102,4 +1092,18 @@ void __init x86_quirk_time_init(void) ...@@ -1102,4 +1092,18 @@ void __init x86_quirk_time_init(void)
irq0.mask = cpumask_of_cpu(0); irq0.mask = cpumask_of_cpu(0);
setup_irq(0, &irq0); setup_irq(0, &irq0);
} }
static struct resource video_ram_resource = {
.name = "Video RAM area",
.start = 0xa0000,
.end = 0xbffff,
.flags = IORESOURCE_BUSY | IORESOURCE_MEM
};
void __init i386_reserve_resources(void)
{
request_resource(&iomem_resource, &video_ram_resource);
reserve_standard_io_resources();
}
#endif /* CONFIG_X86_32 */ #endif /* CONFIG_X86_32 */
...@@ -5,7 +5,7 @@ ...@@ -5,7 +5,7 @@
*/ */
#include <linux/init.h> #include <linux/init.h>
#include <asm/x86_init.h> #include <asm/setup.h>
void __cpuinit x86_init_noop(void) { } void __cpuinit x86_init_noop(void) { }
...@@ -17,5 +17,6 @@ struct __initdata x86_init_ops x86_init = { ...@@ -17,5 +17,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,
}, },
}; };
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册