14 #include <linux/module.h>
15 #include <linux/string.h>
16 #include <linux/kernel.h>
17 #include <linux/ctype.h>
19 #include <linux/errno.h>
20 #include <asm/fixmap.h>
24 #include <asm/setup.h>
33 static void noop_init_apic_ldr(
void) { }
36 static void noop_send_IPI_allbutself(
int vector) { }
37 static void noop_send_IPI_all(
int vector) { }
38 static void noop_send_IPI_self(
int vector) { }
39 static void noop_apic_wait_icr_idle(
void) { }
40 static void noop_apic_icr_write(
u32 low,
u32 id) { }
42 static int noop_wakeup_secondary_cpu(
int apicid,
unsigned long start_eip)
47 static u32 noop_safe_apic_wait_icr_idle(
void)
52 static u64 noop_apic_icr_read(
void)
57 static int noop_phys_pkg_id(
int cpuid_apic,
int index_msb)
62 static unsigned int noop_get_apic_id(
unsigned long x)
67 static int noop_probe(
void)
76 static int noop_apic_id_registered(
void)
87 static const struct cpumask *noop_target_cpus(
void)
98 static unsigned long noop_check_apicid_present(
int bit)
103 static void noop_vector_allocation_domain(
int cpu,
struct cpumask *retmask,
107 pr_warning(
"APIC: Vector allocated for non-BSP cpu\n");
117 static void noop_apic_write(
u32 reg,
u32 v)
125 .acpi_madt_oem_check =
NULL,
127 .apic_id_valid = default_apic_id_valid,
128 .apic_id_registered = noop_apic_id_registered,
134 .target_cpus = noop_target_cpus,
137 .check_apicid_used = noop_check_apicid_used,
138 .check_apicid_present = noop_check_apicid_present,
140 .vector_allocation_domain = noop_vector_allocation_domain,
141 .init_apic_ldr = noop_init_apic_ldr,
143 .ioapic_phys_id_map = default_ioapic_phys_id_map,
144 .setup_apic_routing =
NULL,
145 .multi_timer_check =
NULL,
147 .cpu_present_to_apicid = default_cpu_present_to_apicid,
148 .apicid_to_cpu_present = physid_set_mask_of_physid,
150 .setup_portio_remap =
NULL,
151 .check_phys_apicid_present = default_check_phys_apicid_present,
152 .enable_apic_mode =
NULL,
154 .phys_pkg_id = noop_phys_pkg_id,
156 .mps_oem_check =
NULL,
158 .get_apic_id = noop_get_apic_id,
160 .apic_id_mask = 0x0F << 24,
162 .cpu_mask_to_apicid_and = flat_cpu_mask_to_apicid_and,
164 .send_IPI_mask = noop_send_IPI_mask,
165 .send_IPI_mask_allbutself = noop_send_IPI_mask_allbutself,
166 .send_IPI_allbutself = noop_send_IPI_allbutself,
167 .send_IPI_all = noop_send_IPI_all,
168 .send_IPI_self = noop_send_IPI_self,
170 .wakeup_secondary_cpu = noop_wakeup_secondary_cpu,
176 .wait_for_init_deassert =
NULL,
178 .smp_callin_clear_local_apic =
NULL,
179 .inquire_remote_apic =
NULL,
181 .read = noop_apic_read,
182 .write = noop_apic_write,
183 .eoi_write = noop_apic_write,
184 .icr_read = noop_apic_icr_read,
185 .icr_write = noop_apic_icr_write,
186 .wait_icr_idle = noop_apic_wait_icr_idle,
187 .safe_wait_icr_idle = noop_safe_apic_wait_icr_idle,
190 .x86_32_early_logical_apicid = noop_x86_32_early_logical_apicid,