/* $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