/* $NetBSD: pic.h,v 1.10 2020/04/25 15:26:18 bouyer Exp $ */ #ifndef _X86_PIC_H #define _X86_PIC_H struct cpu_info; /* * Structure common to all PIC softcs */ struct pic { const char *pic_name; int pic_type; int pic_vecbase; int pic_apicid; __cpu_simple_lock_t pic_lock; void (*pic_hwmask)(struct pic *, int); void (*pic_hwunmask)(struct pic *, int); void (*pic_addroute)(struct pic *, struct cpu_info *, int, int, int); void (*pic_delroute)(struct pic *, struct cpu_info *, int, int, int); bool (*pic_trymask)(struct pic *, int); struct intrstub *pic_level_stubs; struct intrstub *pic_edge_stubs; struct ioapic_softc *pic_ioapic; /* if pic_type == PIC_IOAPIC */ struct msipic *pic_msipic; /* if (pic_type == PIC_MSI) || (pic_type == PIC_MSIX) */ /* interface for subr_interrupt.c */ void (*pic_intr_get_devname)(const char *, char *, size_t); void (*pic_intr_get_assigned)(const char *, kcpuset_t *); uint64_t (*pic_intr_get_count)(const char *, u_int); }; /* * PIC types. */ #define PIC_I8259 0 #define PIC_IOAPIC 1 #define PIC_LAPIC 2 #define PIC_MSI 3 #define PIC_MSIX 4 #define PIC_SOFT 5 #define PIC_XEN 6 extern struct pic i8259_pic; extern struct pic local_pic; extern struct pic softintr_pic; extern struct pic xen_pic; #endif