📄 apic.h
字号:
#ifndef __ASM_APIC_H#define __ASM_APIC_H#include <xen/config.h>#include <asm/apicdef.h>#include <asm/system.h>#define Dprintk(x...)/* * Debugging macros */#define APIC_QUIET 0#define APIC_VERBOSE 1#define APIC_DEBUG 2extern int apic_verbosity;/* * Define the default level of output to be very little * This can be turned up by using apic=verbose for more * information and apic=debug for _lots_ of information. * apic_verbosity is defined in apic.c */#define apic_printk(v, s, a...) do { \ if ((v) <= apic_verbosity) \ printk(s, ##a); \ } while (0)#ifdef CONFIG_X86_LOCAL_APIC/* * Basic functions accessing APICs. */static __inline void apic_write(unsigned long reg, u32 v){ *((volatile u32 *)(APIC_BASE+reg)) = v;}static __inline void apic_write_atomic(unsigned long reg, u32 v){ (void)xchg((volatile u32 *)(APIC_BASE+reg), v);}static __inline u32 apic_read(unsigned long reg){ return *((volatile u32 *)(APIC_BASE+reg));}void apic_wait_icr_idle(void);int get_physical_broadcast(void);#ifdef CONFIG_X86_GOOD_APIC# define FORCE_READ_AROUND_WRITE 0# define apic_read_around(x)# define apic_write_around(x,y) apic_write((x),(y))#else# define FORCE_READ_AROUND_WRITE 1# define apic_read_around(x) apic_read(x)# define apic_write_around(x,y) apic_write_atomic((x),(y))#endifstatic inline void ack_APIC_irq(void){ /* * ack_APIC_irq() actually gets compiled as a single instruction: * - a single rmw on Pentium/82489DX * - a single write on P6+ cores (CONFIG_X86_GOOD_APIC) * ... yummie. */ /* Docs say use 0 for future compatibility */ apic_write_around(APIC_EOI, 0);}extern void (*wait_timer_tick)(void);extern int get_maxlvt(void);extern void clear_local_APIC(void);extern void connect_bsp_APIC (void);extern void disconnect_bsp_APIC (int virt_wire_setup);extern void disable_local_APIC (void);extern void lapic_shutdown (void);extern int verify_local_APIC (void);extern void cache_APIC_registers (void);extern void sync_Arb_IDs (void);extern void init_bsp_APIC (void);extern void setup_local_APIC (void);extern void init_apic_mappings (void);extern void smp_local_timer_interrupt (struct cpu_user_regs *regs);extern void setup_boot_APIC_clock (void);extern void setup_secondary_APIC_clock (void);extern void setup_apic_nmi_watchdog (void);extern int reserve_lapic_nmi(void);extern void release_lapic_nmi(void);extern void disable_timer_nmi_watchdog(void);extern void enable_timer_nmi_watchdog(void);extern void nmi_watchdog_tick (struct cpu_user_regs *regs);extern int APIC_init_uniprocessor (void);extern void disable_APIC_timer(void);extern void enable_APIC_timer(void);extern int lapic_suspend(void);extern int lapic_resume(void);extern int check_nmi_watchdog (void);extern void enable_NMI_through_LVT0 (void * dummy);extern void watchdog_disable(void);extern void watchdog_enable(void);extern unsigned int nmi_watchdog;#define NMI_NONE 0#define NMI_IO_APIC 1#define NMI_LOCAL_APIC 2#define NMI_INVALID 3#else /* !CONFIG_X86_LOCAL_APIC */static inline void lapic_shutdown(void) { }static inline int lapic_suspend(void) {return 0;}static inline int lapic_resume(void) {return 0;}#endif /* !CONFIG_X86_LOCAL_APIC */#endif /* __ASM_APIC_H */
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -