Home | History | Annotate | Line # | Download | only in include
irqhandler.h revision 1.1.4.2
      1 /*	$NetBSD: irqhandler.h,v 1.1.4.2 2001/03/12 13:28:26 bouyer Exp $	*/
      2 
      3 /*
      4  * Copyright (c) 1994-1996 Mark Brinicombe.
      5  * Copyright (c) 1994 Brini.
      6  * All rights reserved.
      7  *
      8  * This code is derived from software written for Brini by Mark Brinicombe
      9  *
     10  * Redistribution and use in source and binary forms, with or without
     11  * modification, are permitted provided that the following conditions
     12  * are met:
     13  * 1. Redistributions of source code must retain the above copyright
     14  *    notice, this list of conditions and the following disclaimer.
     15  * 2. Redistributions in binary form must reproduce the above copyright
     16  *    notice, this list of conditions and the following disclaimer in the
     17  *    documentation and/or other materials provided with the distribution.
     18  * 3. All advertising materials mentioning features or use of this software
     19  *    must display the following acknowledgement:
     20  *	This product includes software developed by Mark Brinicombe
     21  *	for the NetBSD Project.
     22  * 4. The name of the company nor the name of the author may be used to
     23  *    endorse or promote products derived from this software without specific
     24  *    prior written permission.
     25  *
     26  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR IMPLIED
     27  * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
     28  * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
     29  * IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT,
     30  * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
     31  * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
     32  * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
     33  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
     34  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
     35  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
     36  * SUCH DAMAGE.
     37  *
     38  * IRQ related stuff (defines + structures)
     39  *
     40  * Created      : 30/09/94
     41  */
     42 
     43 #ifndef _ARM32_IRQHANDLER_H_
     44 #define _ARM32_IRQHANDLER_H_
     45 
     46 #if defined(_KERNEL) && !defined(_LKM)
     47 #include "opt_cputypes.h"
     48 #endif
     49 
     50 #ifndef _LOCORE
     51 #include <sys/types.h>
     52 #endif /* _LOCORE */
     53 
     54 /* Define the IRQ bits */
     55 
     56 #define IRQ_VSYNC	IRQ_FLYBACK	/* Aliased */
     57 #define IRQ_NETSLOT	IRQ_EXTENDED
     58 
     59 #define IRQ_INSTRUCT	-1
     60 /* XXX ICU_LEN is used for the same purpose. Either one should be nuked */
     61 #define NIRQS		0x20
     62 
     63 #include <machine/intr.h>
     64 
     65 #ifndef _LOCORE
     66 typedef struct irqhandler {
     67 	int (*ih_func) __P((void *arg));/* handler function */
     68 	void *ih_arg;			/* Argument to handler */
     69 	int ih_level;			/* Interrupt level */
     70 	int ih_count;			/* Interrupt number (for accounting) */
     71 	int ih_irq;			/* Interrupt register pin */
     72 	const char *ih_name;		/* Name of interrupt (for vmstat -i) */
     73 	u_int ih_flags;			/* Interrupt flags */
     74 	u_int ih_maskaddr;		/* mask address for expansion cards */
     75 	u_int ih_maskbits;		/* interrupt bit for expansion cards */
     76 	struct irqhandler *ih_next;	/* next handler */
     77 } irqhandler_t;
     78 
     79 #ifdef _KERNEL
     80 extern u_int imask[NIPL];
     81 extern irqhandler_t *irqhandlers[NIRQS];
     82 
     83 void irq_init __P((void));
     84 void irq_setmasks __P((void));
     85 void disable_irq __P((int));
     86 void enable_irq __P((int));
     87 #endif	/* _KERNEL */
     88 #endif	/* _LOCORE */
     89 
     90 #define IRQ_FLAG_ACTIVE 0x00000001	/* This is the active handler in list */
     91 
     92 #ifndef _LOCORE
     93 typedef struct fiqhandler {
     94 	void (*fh_func) __P((void));/* handler function */
     95 	u_int fh_size;		/* Size of handler function */
     96 	u_int fh_mask;		/* FIQ mask */
     97 	u_int fh_r8;		/* FIQ mode r8 */
     98 	u_int fh_r9;		/* FIQ mode r9 */
     99 	u_int fh_r10;		/* FIQ mode r10 */
    100 	u_int fh_r11;		/* FIQ mode r11 */
    101 	u_int fh_r12;		/* FIQ mode r12 */
    102 	u_int fh_r13;		/* FIQ mode r13 */
    103 } fiqhandler_t;
    104 
    105 #endif	/* _LOCORE */
    106 
    107 #endif	/* _ARM32_IRQHANDLER_H_ */
    108 
    109 /* End of irqhandler.h */
    110