xref: /rk3399_ARM-atf/include/drivers/arm/gic_common.h (revision 38a7861450409b6b234e12f15b8b516aa71b6610)
1df373737SAchin Gupta /*
2*38a78614SSoby Mathew  * Copyright (c) 2015-2016, ARM Limited and Contributors. All rights reserved.
3df373737SAchin Gupta  *
4df373737SAchin Gupta  * Redistribution and use in source and binary forms, with or without
5df373737SAchin Gupta  * modification, are permitted provided that the following conditions are met:
6df373737SAchin Gupta  *
7df373737SAchin Gupta  * Redistributions of source code must retain the above copyright notice, this
8df373737SAchin Gupta  * list of conditions and the following disclaimer.
9df373737SAchin Gupta  *
10df373737SAchin Gupta  * Redistributions in binary form must reproduce the above copyright notice,
11df373737SAchin Gupta  * this list of conditions and the following disclaimer in the documentation
12df373737SAchin Gupta  * and/or other materials provided with the distribution.
13df373737SAchin Gupta  *
14df373737SAchin Gupta  * Neither the name of ARM nor the names of its contributors may be used
15df373737SAchin Gupta  * to endorse or promote products derived from this software without specific
16df373737SAchin Gupta  * prior written permission.
17df373737SAchin Gupta  *
18df373737SAchin Gupta  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
19df373737SAchin Gupta  * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
20df373737SAchin Gupta  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
21df373737SAchin Gupta  * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
22df373737SAchin Gupta  * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
23df373737SAchin Gupta  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
24df373737SAchin Gupta  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
25df373737SAchin Gupta  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
26df373737SAchin Gupta  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
27df373737SAchin Gupta  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
28df373737SAchin Gupta  * POSSIBILITY OF SUCH DAMAGE.
29df373737SAchin Gupta  */
30df373737SAchin Gupta 
31df373737SAchin Gupta #ifndef __GIC_COMMON_H__
32df373737SAchin Gupta #define __GIC_COMMON_H__
33df373737SAchin Gupta 
34df373737SAchin Gupta /*******************************************************************************
35df373737SAchin Gupta  * GIC Distributor interface general definitions
36df373737SAchin Gupta  ******************************************************************************/
37df373737SAchin Gupta /* Constants to categorise interrupts */
38df373737SAchin Gupta #define MIN_SGI_ID		0
39df373737SAchin Gupta #define MIN_PPI_ID		16
40df373737SAchin Gupta #define MIN_SPI_ID		32
41df373737SAchin Gupta 
42df373737SAchin Gupta /* Mask for the priority field common to all GIC interfaces */
43df373737SAchin Gupta #define GIC_PRI_MASK			0xff
44df373737SAchin Gupta 
45df373737SAchin Gupta /* Constant to indicate a spurious interrupt in all GIC versions */
46df373737SAchin Gupta #define GIC_SPURIOUS_INTERRUPT		1023
47df373737SAchin Gupta 
48df373737SAchin Gupta /* Constants to categorise priorities */
49df373737SAchin Gupta #define GIC_HIGHEST_SEC_PRIORITY	0
50df373737SAchin Gupta #define GIC_LOWEST_SEC_PRIORITY		127
51df373737SAchin Gupta #define GIC_HIGHEST_NS_PRIORITY		128
52df373737SAchin Gupta #define GIC_LOWEST_NS_PRIORITY		254 /* 255 would disable an interrupt */
53df373737SAchin Gupta 
54df373737SAchin Gupta /*******************************************************************************
55df373737SAchin Gupta  * GIC Distributor interface register offsets that are common to GICv3 & GICv2
56df373737SAchin Gupta  ******************************************************************************/
57df373737SAchin Gupta #define GICD_CTLR		0x0
58df373737SAchin Gupta #define GICD_TYPER		0x4
59df373737SAchin Gupta #define GICD_IIDR		0x8
60df373737SAchin Gupta #define GICD_IGROUPR		0x80
61df373737SAchin Gupta #define GICD_ISENABLER		0x100
62df373737SAchin Gupta #define GICD_ICENABLER		0x180
63df373737SAchin Gupta #define GICD_ISPENDR		0x200
64df373737SAchin Gupta #define GICD_ICPENDR		0x280
65df373737SAchin Gupta #define GICD_ISACTIVER		0x300
66df373737SAchin Gupta #define GICD_ICACTIVER		0x380
67df373737SAchin Gupta #define GICD_IPRIORITYR		0x400
68df373737SAchin Gupta #define GICD_ICFGR		0xc00
69df373737SAchin Gupta #define GICD_NSACR		0xe00
70df373737SAchin Gupta 
71df373737SAchin Gupta /* GICD_CTLR bit definitions */
72df373737SAchin Gupta #define CTLR_ENABLE_G0_SHIFT		0
73df373737SAchin Gupta #define CTLR_ENABLE_G0_MASK		0x1
74df373737SAchin Gupta #define CTLR_ENABLE_G0_BIT		(1 << CTLR_ENABLE_G0_SHIFT)
75df373737SAchin Gupta 
76df373737SAchin Gupta 
77df373737SAchin Gupta /*******************************************************************************
78df373737SAchin Gupta  * GIC Distributor interface register constants that are common to GICv3 & GICv2
79df373737SAchin Gupta  ******************************************************************************/
80df373737SAchin Gupta #define PIDR2_ARCH_REV_SHIFT	4
81df373737SAchin Gupta #define PIDR2_ARCH_REV_MASK	0xf
82df373737SAchin Gupta 
83df373737SAchin Gupta /* GICv3 revision as reported by the PIDR2 register */
84df373737SAchin Gupta #define ARCH_REV_GICV3		0x3
85df373737SAchin Gupta /* GICv2 revision as reported by the PIDR2 register */
86df373737SAchin Gupta #define ARCH_REV_GICV2		0x2
87df373737SAchin Gupta 
88df373737SAchin Gupta #define IGROUPR_SHIFT		5
89df373737SAchin Gupta #define ISENABLER_SHIFT		5
90df373737SAchin Gupta #define ICENABLER_SHIFT		ISENABLER_SHIFT
91df373737SAchin Gupta #define ISPENDR_SHIFT		5
92df373737SAchin Gupta #define ICPENDR_SHIFT		ISPENDR_SHIFT
93df373737SAchin Gupta #define ISACTIVER_SHIFT		5
94df373737SAchin Gupta #define ICACTIVER_SHIFT		ISACTIVER_SHIFT
95df373737SAchin Gupta #define IPRIORITYR_SHIFT	2
96df373737SAchin Gupta #define ICFGR_SHIFT		4
97df373737SAchin Gupta #define NSACR_SHIFT		4
98df373737SAchin Gupta 
99df373737SAchin Gupta /* GICD_TYPER shifts and masks */
100df373737SAchin Gupta #define TYPER_IT_LINES_NO_SHIFT	0
101df373737SAchin Gupta #define TYPER_IT_LINES_NO_MASK	0x1f
102df373737SAchin Gupta 
103df373737SAchin Gupta /* Value used to initialize Normal world interrupt priorities four at a time */
104df373737SAchin Gupta #define GICD_IPRIORITYR_DEF_VAL			\
105df373737SAchin Gupta 	(GIC_HIGHEST_NS_PRIORITY	|	\
106df373737SAchin Gupta 	(GIC_HIGHEST_NS_PRIORITY << 8)	|	\
107df373737SAchin Gupta 	(GIC_HIGHEST_NS_PRIORITY << 16)	|	\
108df373737SAchin Gupta 	(GIC_HIGHEST_NS_PRIORITY << 24))
109df373737SAchin Gupta 
110df373737SAchin Gupta #ifndef __ASSEMBLY__
111df373737SAchin Gupta 
112df373737SAchin Gupta #include <mmio.h>
113df373737SAchin Gupta #include <stdint.h>
114df373737SAchin Gupta 
115df373737SAchin Gupta /*******************************************************************************
116df373737SAchin Gupta  * GIC Distributor interface register accessors that are common to GICv3 & GICv2
117df373737SAchin Gupta  ******************************************************************************/
118df373737SAchin Gupta static inline unsigned int gicd_read_ctlr(uintptr_t base)
119df373737SAchin Gupta {
120df373737SAchin Gupta 	return mmio_read_32(base + GICD_CTLR);
121df373737SAchin Gupta }
122df373737SAchin Gupta 
123df373737SAchin Gupta static inline unsigned int gicd_read_typer(uintptr_t base)
124df373737SAchin Gupta {
125df373737SAchin Gupta 	return mmio_read_32(base + GICD_TYPER);
126df373737SAchin Gupta }
127df373737SAchin Gupta 
128df373737SAchin Gupta static inline unsigned int gicd_read_iidr(uintptr_t base)
129df373737SAchin Gupta {
130df373737SAchin Gupta 	return mmio_read_32(base + GICD_IIDR);
131df373737SAchin Gupta }
132df373737SAchin Gupta 
133df373737SAchin Gupta static inline void gicd_write_ctlr(uintptr_t base, unsigned int val)
134df373737SAchin Gupta {
135df373737SAchin Gupta 	mmio_write_32(base + GICD_CTLR, val);
136df373737SAchin Gupta }
137df373737SAchin Gupta 
138df373737SAchin Gupta /*******************************************************************************
139df373737SAchin Gupta  * GIC Distributor function prototypes
140df373737SAchin Gupta  ******************************************************************************/
141df373737SAchin Gupta unsigned int gicd_read_igroupr(uintptr_t base, unsigned int id);
142df373737SAchin Gupta unsigned int gicd_read_isenabler(uintptr_t base, unsigned int id);
143df373737SAchin Gupta unsigned int gicd_read_icenabler(uintptr_t base, unsigned int id);
144df373737SAchin Gupta unsigned int gicd_read_ispendr(uintptr_t base, unsigned int id);
145df373737SAchin Gupta unsigned int gicd_read_icpendr(uintptr_t base, unsigned int id);
146df373737SAchin Gupta unsigned int gicd_read_isactiver(uintptr_t base, unsigned int id);
147df373737SAchin Gupta unsigned int gicd_read_icactiver(uintptr_t base, unsigned int id);
148df373737SAchin Gupta unsigned int gicd_read_ipriorityr(uintptr_t base, unsigned int id);
149df373737SAchin Gupta unsigned int gicd_read_icfgr(uintptr_t base, unsigned int id);
150df373737SAchin Gupta unsigned int gicd_read_nsacr(uintptr_t base, unsigned int id);
151df373737SAchin Gupta void gicd_write_igroupr(uintptr_t base, unsigned int id, unsigned int val);
152df373737SAchin Gupta void gicd_write_isenabler(uintptr_t base, unsigned int id, unsigned int val);
153df373737SAchin Gupta void gicd_write_icenabler(uintptr_t base, unsigned int id, unsigned int val);
154df373737SAchin Gupta void gicd_write_ispendr(uintptr_t base, unsigned int id, unsigned int val);
155df373737SAchin Gupta void gicd_write_icpendr(uintptr_t base, unsigned int id, unsigned int val);
156df373737SAchin Gupta void gicd_write_isactiver(uintptr_t base, unsigned int id, unsigned int val);
157df373737SAchin Gupta void gicd_write_icactiver(uintptr_t base, unsigned int id, unsigned int val);
158df373737SAchin Gupta void gicd_write_ipriorityr(uintptr_t base, unsigned int id, unsigned int val);
159df373737SAchin Gupta void gicd_write_icfgr(uintptr_t base, unsigned int id, unsigned int val);
160df373737SAchin Gupta void gicd_write_nsacr(uintptr_t base, unsigned int id, unsigned int val);
161df373737SAchin Gupta unsigned int gicd_get_igroupr(uintptr_t base, unsigned int id);
162df373737SAchin Gupta void gicd_set_igroupr(uintptr_t base, unsigned int id);
163df373737SAchin Gupta void gicd_clr_igroupr(uintptr_t base, unsigned int id);
164df373737SAchin Gupta void gicd_set_isenabler(uintptr_t base, unsigned int id);
165df373737SAchin Gupta void gicd_set_icenabler(uintptr_t base, unsigned int id);
166df373737SAchin Gupta void gicd_set_ispendr(uintptr_t base, unsigned int id);
167df373737SAchin Gupta void gicd_set_icpendr(uintptr_t base, unsigned int id);
168df373737SAchin Gupta void gicd_set_isactiver(uintptr_t base, unsigned int id);
169df373737SAchin Gupta void gicd_set_icactiver(uintptr_t base, unsigned int id);
170*38a78614SSoby Mathew void gicd_set_ipriorityr(uintptr_t base, unsigned int id, unsigned int pri);
171df373737SAchin Gupta 
172df373737SAchin Gupta 
173df373737SAchin Gupta #endif /* __ASSEMBLY__ */
174df373737SAchin Gupta #endif /* __GIC_COMMON_H__ */
175