Home | History | Annotate | Line # | Download | only in include
pic.h revision 1.5
      1  1.5  drochner /*	$NetBSD: pic.h,v 1.5 2008/07/03 14:02:25 drochner Exp $	*/
      2  1.1      fvdl 
      3  1.1      fvdl #ifndef _X86_PIC_H
      4  1.1      fvdl #define _X86_PIC_H
      5  1.1      fvdl 
      6  1.1      fvdl #include <sys/device.h>
      7  1.1      fvdl 
      8  1.1      fvdl struct cpu_info;
      9  1.1      fvdl 
     10  1.1      fvdl /*
     11  1.1      fvdl  * Structure common to all PIC softcs
     12  1.1      fvdl  */
     13  1.1      fvdl struct pic {
     14  1.5  drochner 	const char *pic_name;
     15  1.5  drochner 	int pic_type;
     16  1.2  christos 	int pic_vecbase;
     17  1.2  christos 	int pic_apicid;
     18  1.1      fvdl 	__cpu_simple_lock_t pic_lock;
     19  1.5  drochner 	void (*pic_hwmask)(struct pic *, int);
     20  1.5  drochner 	void (*pic_hwunmask)(struct pic *, int);
     21  1.1      fvdl 	void (*pic_addroute)(struct pic *, struct cpu_info *, int, int, int);
     22  1.1      fvdl 	void (*pic_delroute)(struct pic *, struct cpu_info *, int, int, int);
     23  1.1      fvdl 	struct intrstub *pic_level_stubs;
     24  1.1      fvdl 	struct intrstub *pic_edge_stubs;
     25  1.5  drochner 	struct ioapic_softc *pic_ioapic; /* if pic_type == PIC_IOAPIC */
     26  1.1      fvdl };
     27  1.1      fvdl 
     28  1.1      fvdl /*
     29  1.1      fvdl  * PIC types.
     30  1.1      fvdl  */
     31  1.1      fvdl #define PIC_I8259	0
     32  1.1      fvdl #define PIC_IOAPIC	1
     33  1.1      fvdl #define PIC_LAPIC	2
     34  1.1      fvdl #define PIC_SOFT	3
     35  1.1      fvdl 
     36  1.1      fvdl extern struct pic i8259_pic;
     37  1.1      fvdl extern struct pic local_pic;
     38  1.1      fvdl extern struct pic softintr_pic;
     39  1.1      fvdl #endif
     40