| #ifndef __ASM_MACH_APIC_H |
| #define __ASM_MACH_APIC_H |
| |
| #define APIC_DFR_VALUE (APIC_DFR_FLAT) |
| |
| #ifdef CONFIG_SMP |
| #define TARGET_CPUS (cpu_online_map) |
| #else |
| #define TARGET_CPUS 0x01 |
| #endif |
| |
| #define no_balance_irq (0) |
| |
| #define APIC_BROADCAST_ID 0x0F |
| #define check_apicid_used(bitmap, apicid) (bitmap & (1 << apicid)) |
| |
| static inline int apic_id_registered(void) |
| { |
| return (test_bit(GET_APIC_ID(apic_read(APIC_ID)), |
| &phys_cpu_present_map)); |
| } |
| |
| /* |
| * Set up the logical destination ID. |
| * |
| * Intel recommends to set DFR, LDR and TPR before enabling |
| * an APIC. See e.g. "AP-388 82489DX User's Manual" (Intel |
| * document number 292116). So here it goes... |
| */ |
| static inline void init_apic_ldr(void) |
| { |
| unsigned long val; |
| |
| apic_write_around(APIC_DFR, APIC_DFR_VALUE); |
| val = apic_read(APIC_LDR) & ~APIC_LDR_MASK; |
| val |= SET_APIC_LOGICAL_ID(1UL << smp_processor_id()); |
| apic_write_around(APIC_LDR, val); |
| } |
| |
| static inline ulong ioapic_phys_id_map(ulong phys_map) |
| { |
| return phys_map; |
| } |
| |
| static inline void clustered_apic_check(void) |
| { |
| printk("Enabling APIC mode: %s. Using %d I/O APICs\n", |
| "Flat", nr_ioapics); |
| } |
| |
| static inline int multi_timer_check(int apic, int irq) |
| { |
| return 0; |
| } |
| |
| static inline int cpu_present_to_apicid(int mps_cpu) |
| { |
| return mps_cpu; |
| } |
| |
| static inline unsigned long apicid_to_cpu_present(int phys_apicid) |
| { |
| return (1ul << phys_apicid); |
| } |
| |
| static inline int mpc_apic_id(struct mpc_config_processor *m, int quad) |
| { |
| printk("Processor #%d %ld:%ld APIC version %d\n", |
| m->mpc_apicid, |
| (m->mpc_cpufeature & CPU_FAMILY_MASK) >> 8, |
| (m->mpc_cpufeature & CPU_MODEL_MASK) >> 4, |
| m->mpc_apicver); |
| return (m->mpc_apicid); |
| } |
| |
| #define WAKE_SECONDARY_VIA_INIT |
| |
| static inline void setup_portio_remap(void) |
| { |
| } |
| |
| #endif /* __ASM_MACH_APIC_H */ |