blob: e666a98db7cd21ce888c307d734c475fe72a17f7 [file] [log] [blame]
Thomas Gleixner57844a82009-08-19 14:48:38 +02001/*
2 * Copyright (C) 2009 Thomas Gleixner <tglx@linutronix.de>
3 *
4 * For licencing details see kernel-base/COPYING
5 */
6#include <linux/init.h>
7
Thomas Gleixner816c25e2009-08-19 14:36:27 +02008#include <asm/bios_ebda.h>
Thomas Gleixner6f30c1a2009-08-20 13:19:57 +02009#include <asm/paravirt.h>
Thomas Gleixnerfd6c6662009-08-20 10:41:58 +020010#include <asm/mpspec.h>
Thomas Gleixner8fee6972009-08-19 14:55:50 +020011#include <asm/setup.h>
Thomas Gleixner736deca2009-08-19 12:35:53 +020012#include <asm/apic.h>
Thomas Gleixner6b18ae32009-08-20 10:19:54 +020013#include <asm/e820.h>
Thomas Gleixnerd9112f42009-08-20 09:41:38 +020014#include <asm/irq.h>
Thomas Gleixner57844a82009-08-19 14:48:38 +020015
16void __cpuinit x86_init_noop(void) { }
Thomas Gleixnerf4848472009-08-20 12:05:01 +020017void __init x86_init_uint_noop(unsigned int unused) { }
Thomas Gleixner030cb6c2009-08-20 14:30:02 +020018void __init x86_init_pgd_noop(pgd_t *unused) { }
Thomas Gleixner57844a82009-08-19 14:48:38 +020019
20/*
21 * The platform setup functions are preset with the default functions
22 * for standard PC hardware.
23 */
24struct __initdata x86_init_ops x86_init = {
Thomas Gleixnerf7cf5a52009-08-19 14:43:56 +020025
26 .resources = {
27 .probe_roms = x86_init_noop,
Thomas Gleixner8fee6972009-08-19 14:55:50 +020028 .reserve_resources = reserve_standard_io_resources,
Thomas Gleixner816c25e2009-08-19 14:36:27 +020029 .reserve_ebda_region = reserve_ebda_region,
Thomas Gleixner6b18ae32009-08-20 10:19:54 +020030 .memory_setup = default_machine_specific_memory_setup,
Thomas Gleixnerf7cf5a52009-08-19 14:43:56 +020031 },
Thomas Gleixnerf4848472009-08-20 12:05:01 +020032
33 .mpparse = {
34 .mpc_record = x86_init_uint_noop,
Thomas Gleixnerde934102009-08-20 09:27:29 +020035 .setup_ioapic_ids = x86_init_noop,
Thomas Gleixnerfd6c6662009-08-20 10:41:58 +020036 .mpc_apic_id = default_mpc_apic_id,
Thomas Gleixner72302142009-08-20 12:18:32 +020037 .smp_read_mpc_oem = default_smp_read_mpc_oem,
Thomas Gleixner90e1c692009-08-20 12:34:47 +020038 .mpc_oem_bus_info = default_mpc_oem_bus_info,
Thomas Gleixnerb3f1b612009-08-20 11:11:52 +020039 .find_smp_config = default_find_smp_config,
40 .get_smp_config = default_get_smp_config,
Thomas Gleixnerf4848472009-08-20 12:05:01 +020041 },
Thomas Gleixnerd9112f42009-08-20 09:41:38 +020042
43 .irqs = {
44 .pre_vector_init = init_ISA_irqs,
Thomas Gleixner66bcaf02009-08-20 09:59:09 +020045 .intr_init = native_init_IRQ,
Thomas Gleixner428cf902009-08-20 10:35:46 +020046 .trap_init = x86_init_noop,
Thomas Gleixnerd9112f42009-08-20 09:41:38 +020047 },
Thomas Gleixner42bbdb42009-08-20 13:04:10 +020048
49 .oem = {
50 .arch_setup = x86_init_noop,
Thomas Gleixner6f30c1a2009-08-20 13:19:57 +020051 .banner = default_banner,
Thomas Gleixner42bbdb42009-08-20 13:04:10 +020052 },
Thomas Gleixner030cb6c2009-08-20 14:30:02 +020053
54 .paging = {
55 .pagetable_setup_start = native_pagetable_setup_start,
56 .pagetable_setup_done = native_pagetable_setup_done,
57 },
Thomas Gleixner736deca2009-08-19 12:35:53 +020058
59 .timers = {
60 .setup_percpu_clockev = setup_boot_APIC_clock,
61 },
62};
63
64__cpuinitdata struct x86_cpuinit_ops x86_cpuinit = {
65 .setup_percpu_clockev = setup_secondary_APIC_clock,
Thomas Gleixner57844a82009-08-19 14:48:38 +020066};