xref: /freebsd/sys/powerpc/powermac/hrowpicvar.h (revision 95ee2897e98f5d444f26ed2334cc7c439f9c16c6)
160727d8bSWarner Losh /*-
2*71e3c308SPedro F. Giffuni  * SPDX-License-Identifier: BSD-3-Clause
3*71e3c308SPedro F. Giffuni  *
4bd687ebfSPeter Grehan  * Copyright 2003 by Peter Grehan. All rights reserved.
5bd687ebfSPeter Grehan  *
6bd687ebfSPeter Grehan  * Redistribution and use in source and binary forms, with or without
7bd687ebfSPeter Grehan  * modification, are permitted provided that the following conditions
8bd687ebfSPeter Grehan  * are met:
9bd687ebfSPeter Grehan  * 1. Redistributions of source code must retain the above copyright
10bd687ebfSPeter Grehan  *    notice, this list of conditions and the following disclaimer.
11bd687ebfSPeter Grehan  * 2. Redistributions in binary form must reproduce the above copyright
12bd687ebfSPeter Grehan  *    notice, this list of conditions and the following disclaimer in the
13bd687ebfSPeter Grehan  *    documentation and/or other materials provided with the distribution.
14bd687ebfSPeter Grehan  * 3. The name of the author may not be used to endorse or promote products
15bd687ebfSPeter Grehan  *    derived from this software without specific prior written permission.
16bd687ebfSPeter Grehan  *
17bd687ebfSPeter Grehan  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
18bd687ebfSPeter Grehan  * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
19bd687ebfSPeter Grehan  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
20bd687ebfSPeter Grehan  * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
21bd687ebfSPeter Grehan  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
22bd687ebfSPeter Grehan  * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
23bd687ebfSPeter Grehan  * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
24bd687ebfSPeter Grehan  * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
25bd687ebfSPeter Grehan  * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
26bd687ebfSPeter Grehan  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
27bd687ebfSPeter Grehan  * SUCH DAMAGE.
28bd687ebfSPeter Grehan  */
29bd687ebfSPeter Grehan 
30bd687ebfSPeter Grehan #ifndef  _POWERPC_POWERMAC_HROWPICVAR_H_
31bd687ebfSPeter Grehan #define  _POWERPC_POWERMAC_HROWPICVAR_H_
32bd687ebfSPeter Grehan 
33bd687ebfSPeter Grehan #define HROWPIC_IRQMAX	64
34bd687ebfSPeter Grehan #define HROWPIC_IRQ_REGNUM	32	/* irqs per register */
35bd687ebfSPeter Grehan #define HROWPIC_IRQ_SHIFT	5	/* high or low irq word */
36bd687ebfSPeter Grehan #define HROWPIC_IRQ_MASK ((HROWPIC_IRQMAX-1) >> 1)  /* irq bit pos in word */
37bd687ebfSPeter Grehan 
38bd687ebfSPeter Grehan /*
39bd687ebfSPeter Grehan  * Register offsets within bank. There are two identical banks,
40bd687ebfSPeter Grehan  * separated by 16 bytes. Interrupts 0->31 are processed in the
41bd687ebfSPeter Grehan  * second bank, and 32->63 in the first bank.
42bd687ebfSPeter Grehan  */
43bd687ebfSPeter Grehan #define  HPIC_STATUS	0x00		/* active interrupt sources */
44bd687ebfSPeter Grehan #define  HPIC_ENABLE	0x04		/* interrupt asserts ppc EXTINT */
45bd687ebfSPeter Grehan #define  HPIC_CLEAR	0x08		/* clear int source */
46bd687ebfSPeter Grehan #define  HPIC_TRIGGER	0x0c		/* edge/level int trigger */
47bd687ebfSPeter Grehan 
48bd687ebfSPeter Grehan #define HPIC_PRIMARY	1	/* primary register bank */
49bd687ebfSPeter Grehan #define HPIC_SECONDARY  0       /* secondary register bank */
50bd687ebfSPeter Grehan 
51bd687ebfSPeter Grehan /*
52bd687ebfSPeter Grehan  * Convert an interrupt into a prim/sec bank number
53bd687ebfSPeter Grehan  */
54bd687ebfSPeter Grehan #define HPIC_INT_TO_BANK(x) \
55bd687ebfSPeter Grehan 	(((x) >> HROWPIC_IRQ_SHIFT) ^ 1)
56bd687ebfSPeter Grehan 
57bd687ebfSPeter Grehan /*
58bd687ebfSPeter Grehan  * Convert an interrupt into the bit number within a bank register
59bd687ebfSPeter Grehan  */
60bd687ebfSPeter Grehan #define HPIC_INT_TO_REGBIT(x) \
61bd687ebfSPeter Grehan 	((x) & HROWPIC_IRQ_MASK)
62bd687ebfSPeter Grehan 
63bd687ebfSPeter Grehan #define  HPIC_1ST_OFFSET  0x10		/* offset to primary reg bank */
64bd687ebfSPeter Grehan 
65bd687ebfSPeter Grehan struct hrowpic_softc {
6677d40ffdSMarcel Moolenaar 	device_t	sc_dev;			/* macio device */
6777d40ffdSMarcel Moolenaar 	struct resource *sc_rres;		/* macio bus resource */
68bd687ebfSPeter Grehan 	bus_space_tag_t sc_bt;			/* macio bus tag/handle */
69bd687ebfSPeter Grehan 	bus_space_handle_t sc_bh;
7077d40ffdSMarcel Moolenaar 	int		sc_rrid;
7177d40ffdSMarcel Moolenaar 	uint32_t	sc_softreg[2];		/* ENABLE reg copy */
7277d40ffdSMarcel Moolenaar 	u_int		sc_vector[HROWPIC_IRQMAX];
73bd687ebfSPeter Grehan };
74bd687ebfSPeter Grehan 
75bd687ebfSPeter Grehan #endif  /* _POWERPC_POWERMAC_HROWPICVAR_H_ */
76