Home | History | Annotate | Line # | Download | only in fdt
      1  1.1  thorpej /*	$NetBSD: fdt_intr.h,v 1.1 2025/09/06 20:11:30 thorpej Exp $	*/
      2  1.1  thorpej 
      3  1.1  thorpej /*-
      4  1.1  thorpej  * Copyright (c) 2015-2018 Jared McNeill <jmcneill (at) invisible.ca>
      5  1.1  thorpej  * All rights reserved.
      6  1.1  thorpej  *
      7  1.1  thorpej  * Redistribution and use in source and binary forms, with or without
      8  1.1  thorpej  * modification, are permitted provided that the following conditions
      9  1.1  thorpej  * are met:
     10  1.1  thorpej  * 1. Redistributions of source code must retain the above copyright
     11  1.1  thorpej  *    notice, this list of conditions and the following disclaimer.
     12  1.1  thorpej  * 2. Redistributions in binary form must reproduce the above copyright
     13  1.1  thorpej  *    notice, this list of conditions and the following disclaimer in the
     14  1.1  thorpej  *    documentation and/or other materials provided with the distribution.
     15  1.1  thorpej  *
     16  1.1  thorpej  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
     17  1.1  thorpej  * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
     18  1.1  thorpej  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
     19  1.1  thorpej  * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
     20  1.1  thorpej  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
     21  1.1  thorpej  * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
     22  1.1  thorpej  * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
     23  1.1  thorpej  * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
     24  1.1  thorpej  * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
     25  1.1  thorpej  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
     26  1.1  thorpej  * SUCH DAMAGE.
     27  1.1  thorpej  */
     28  1.1  thorpej 
     29  1.1  thorpej #ifndef _DEV_FDT_FDT_INTR_H_
     30  1.1  thorpej #define	_DEV_FDT_FDT_INTR_H_
     31  1.1  thorpej 
     32  1.1  thorpej #include <sys/device.h>
     33  1.1  thorpej 
     34  1.1  thorpej /* flags for fdtbus_intr_establish */
     35  1.1  thorpej #define	FDT_INTR_MPSAFE			__BIT(0)
     36  1.1  thorpej 
     37  1.1  thorpej /* Interrupt trigger types defined by the FDT "interrupts" bindings. */
     38  1.1  thorpej #define	FDT_INTR_TYPE_POS_EDGE		__BIT(0)
     39  1.1  thorpej #define	FDT_INTR_TYPE_NEG_EDGE		__BIT(1)
     40  1.1  thorpej #define	FDT_INTR_TYPE_DOUBLE_EDGE	(FDT_INTR_TYPE_POS_EDGE | \
     41  1.1  thorpej 					 FDT_INTR_TYPE_NEG_EDGE)
     42  1.1  thorpej #define	FDT_INTR_TYPE_HIGH_LEVEL	__BIT(2)
     43  1.1  thorpej #define	FDT_INTR_TYPE_LOW_LEVEL		__BIT(3)
     44  1.1  thorpej 
     45  1.1  thorpej struct fdtbus_interrupt_controller_func {
     46  1.1  thorpej 	void *	(*establish)(device_t, u_int *, int, int,
     47  1.1  thorpej 			     int (*)(void *), void *, const char *);
     48  1.1  thorpej 	void	(*disestablish)(device_t, void *);
     49  1.1  thorpej 	bool	(*intrstr)(device_t, u_int *, char *, size_t);
     50  1.1  thorpej 	void	(*mask)(device_t, void *);
     51  1.1  thorpej 	void	(*unmask)(device_t, void *);
     52  1.1  thorpej };
     53  1.1  thorpej 
     54  1.1  thorpej int		fdtbus_register_interrupt_controller(device_t, int,
     55  1.1  thorpej 		    const struct fdtbus_interrupt_controller_func *);
     56  1.1  thorpej 
     57  1.1  thorpej void *		fdtbus_intr_establish(int, u_int, int, int,
     58  1.1  thorpej 		    int (*func)(void *), void *arg);
     59  1.1  thorpej void *		fdtbus_intr_establish_xname(int, u_int, int, int,
     60  1.1  thorpej 		    int (*func)(void *), void *arg, const char *);
     61  1.1  thorpej void *		fdtbus_intr_establish_byname(int, const char *, int, int,
     62  1.1  thorpej 		    int (*func)(void *), void *arg, const char *);
     63  1.1  thorpej void *		fdtbus_intr_establish_raw(int, const u_int *, int, int,
     64  1.1  thorpej 		    int (*func)(void *), void *arg, const char *);
     65  1.1  thorpej void		fdtbus_intr_mask(int, void *);
     66  1.1  thorpej void		fdtbus_intr_unmask(int, void *);
     67  1.1  thorpej void		fdtbus_intr_disestablish(int, void *);
     68  1.1  thorpej bool		fdtbus_intr_str(int, u_int, char *, size_t);
     69  1.1  thorpej bool		fdtbus_intr_str_raw(int, const u_int *, char *, size_t);
     70  1.1  thorpej int		fdtbus_intr_parent(int);
     71  1.1  thorpej 
     72  1.1  thorpej #endif /* _DEV_FDT_FDT_INTR_H_ */
     73