1 /*
2  * arch/arm/mach-tegra/include/mach/irqs.h
3  *
4  * Copyright (C) 2010 Google, Inc.
5  *
6  * Author:
7  *	Colin Cross <ccross@google.com>
8  *	Erik Gilling <konkers@google.com>
9  *
10  * This software is licensed under the terms of the GNU General Public
11  * License version 2, as published by the Free Software Foundation, and
12  * may be copied, distributed, and modified under those terms.
13  *
14  * This program is distributed in the hope that it will be useful,
15  * but WITHOUT ANY WARRANTY; without even the implied warranty of
16  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
17  * GNU General Public License for more details.
18  *
19  */
20 
21 #ifndef __MACH_TEGRA_IRQS_H
22 #define __MACH_TEGRA_IRQS_H
23 
24 #define INT_GIC_BASE			0
25 
26 #define IRQ_LOCALTIMER                  29
27 
28 #ifdef CONFIG_ARCH_TEGRA_2x_SOC
29 /* Primary Interrupt Controller */
30 #define INT_PRI_BASE			(INT_GIC_BASE + 32)
31 #define INT_TMR1			(INT_PRI_BASE + 0)
32 #define INT_TMR2			(INT_PRI_BASE + 1)
33 #define INT_RTC				(INT_PRI_BASE + 2)
34 #define INT_I2S2			(INT_PRI_BASE + 3)
35 #define INT_SHR_SEM_INBOX_IBF		(INT_PRI_BASE + 4)
36 #define INT_SHR_SEM_INBOX_IBE		(INT_PRI_BASE + 5)
37 #define INT_SHR_SEM_OUTBOX_IBF		(INT_PRI_BASE + 6)
38 #define INT_SHR_SEM_OUTBOX_IBE		(INT_PRI_BASE + 7)
39 #define INT_VDE_UCQ_ERROR		(INT_PRI_BASE + 8)
40 #define INT_VDE_SYNC_TOKEN		(INT_PRI_BASE + 9)
41 #define INT_VDE_BSE_V			(INT_PRI_BASE + 10)
42 #define INT_VDE_BSE_A			(INT_PRI_BASE + 11)
43 #define INT_VDE_SXE			(INT_PRI_BASE + 12)
44 #define INT_I2S1			(INT_PRI_BASE + 13)
45 #define INT_SDMMC1			(INT_PRI_BASE + 14)
46 #define INT_SDMMC2			(INT_PRI_BASE + 15)
47 #define INT_XIO				(INT_PRI_BASE + 16)
48 #define INT_VDE				(INT_PRI_BASE + 17)
49 #define INT_AVP_UCQ			(INT_PRI_BASE + 18)
50 #define INT_SDMMC3			(INT_PRI_BASE + 19)
51 #define INT_USB				(INT_PRI_BASE + 20)
52 #define INT_USB2			(INT_PRI_BASE + 21)
53 #define INT_PRI_RES_22			(INT_PRI_BASE + 22)
54 #define INT_EIDE			(INT_PRI_BASE + 23)
55 #define INT_NANDFLASH			(INT_PRI_BASE + 24)
56 #define INT_VCP				(INT_PRI_BASE + 25)
57 #define INT_APB_DMA			(INT_PRI_BASE + 26)
58 #define INT_AHB_DMA			(INT_PRI_BASE + 27)
59 #define INT_GNT_0			(INT_PRI_BASE + 28)
60 #define INT_GNT_1			(INT_PRI_BASE + 29)
61 #define INT_OWR				(INT_PRI_BASE + 30)
62 #define INT_SDMMC4			(INT_PRI_BASE + 31)
63 
64 /* Secondary Interrupt Controller */
65 #define INT_SEC_BASE			(INT_PRI_BASE + 32)
66 #define INT_GPIO1			(INT_SEC_BASE + 0)
67 #define INT_GPIO2			(INT_SEC_BASE + 1)
68 #define INT_GPIO3			(INT_SEC_BASE + 2)
69 #define INT_GPIO4			(INT_SEC_BASE + 3)
70 #define INT_UARTA			(INT_SEC_BASE + 4)
71 #define INT_UARTB			(INT_SEC_BASE + 5)
72 #define INT_I2C				(INT_SEC_BASE + 6)
73 #define INT_SPI				(INT_SEC_BASE + 7)
74 #define INT_TWC				(INT_SEC_BASE + 8)
75 #define INT_TMR3			(INT_SEC_BASE + 9)
76 #define INT_TMR4			(INT_SEC_BASE + 10)
77 #define INT_FLOW_RSM0			(INT_SEC_BASE + 11)
78 #define INT_FLOW_RSM1			(INT_SEC_BASE + 12)
79 #define INT_SPDIF			(INT_SEC_BASE + 13)
80 #define INT_UARTC			(INT_SEC_BASE + 14)
81 #define INT_MIPI			(INT_SEC_BASE + 15)
82 #define INT_EVENTA			(INT_SEC_BASE + 16)
83 #define INT_EVENTB			(INT_SEC_BASE + 17)
84 #define INT_EVENTC			(INT_SEC_BASE + 18)
85 #define INT_EVENTD			(INT_SEC_BASE + 19)
86 #define INT_VFIR			(INT_SEC_BASE + 20)
87 #define INT_DVC				(INT_SEC_BASE + 21)
88 #define INT_SYS_STATS_MON		(INT_SEC_BASE + 22)
89 #define INT_GPIO5			(INT_SEC_BASE + 23)
90 #define INT_CPU0_PMU_INTR		(INT_SEC_BASE + 24)
91 #define INT_CPU1_PMU_INTR		(INT_SEC_BASE + 25)
92 #define INT_SEC_RES_26			(INT_SEC_BASE + 26)
93 #define INT_S_LINK1			(INT_SEC_BASE + 27)
94 #define INT_APB_DMA_COP			(INT_SEC_BASE + 28)
95 #define INT_AHB_DMA_COP			(INT_SEC_BASE + 29)
96 #define INT_DMA_TX			(INT_SEC_BASE + 30)
97 #define INT_DMA_RX			(INT_SEC_BASE + 31)
98 
99 /* Tertiary Interrupt Controller */
100 #define INT_TRI_BASE			(INT_SEC_BASE + 32)
101 #define INT_HOST1X_COP_SYNCPT		(INT_TRI_BASE + 0)
102 #define INT_HOST1X_MPCORE_SYNCPT	(INT_TRI_BASE + 1)
103 #define INT_HOST1X_COP_GENERAL		(INT_TRI_BASE + 2)
104 #define INT_HOST1X_MPCORE_GENERAL	(INT_TRI_BASE + 3)
105 #define INT_MPE_GENERAL			(INT_TRI_BASE + 4)
106 #define INT_VI_GENERAL			(INT_TRI_BASE + 5)
107 #define INT_EPP_GENERAL			(INT_TRI_BASE + 6)
108 #define INT_ISP_GENERAL			(INT_TRI_BASE + 7)
109 #define INT_2D_GENERAL			(INT_TRI_BASE + 8)
110 #define INT_DISPLAY_GENERAL		(INT_TRI_BASE + 9)
111 #define INT_DISPLAY_B_GENERAL		(INT_TRI_BASE + 10)
112 #define INT_HDMI			(INT_TRI_BASE + 11)
113 #define INT_TVO_GENERAL			(INT_TRI_BASE + 12)
114 #define INT_MC_GENERAL			(INT_TRI_BASE + 13)
115 #define INT_EMC_GENERAL			(INT_TRI_BASE + 14)
116 #define INT_TRI_RES_15			(INT_TRI_BASE + 15)
117 #define INT_TRI_RES_16			(INT_TRI_BASE + 16)
118 #define INT_AC97			(INT_TRI_BASE + 17)
119 #define INT_SPI_2			(INT_TRI_BASE + 18)
120 #define INT_SPI_3			(INT_TRI_BASE + 19)
121 #define INT_I2C2			(INT_TRI_BASE + 20)
122 #define INT_KBC				(INT_TRI_BASE + 21)
123 #define INT_EXTERNAL_PMU		(INT_TRI_BASE + 22)
124 #define INT_GPIO6			(INT_TRI_BASE + 23)
125 #define INT_TVDAC			(INT_TRI_BASE + 24)
126 #define INT_GPIO7			(INT_TRI_BASE + 25)
127 #define INT_UARTD			(INT_TRI_BASE + 26)
128 #define INT_UARTE			(INT_TRI_BASE + 27)
129 #define INT_I2C3			(INT_TRI_BASE + 28)
130 #define INT_SPI_4			(INT_TRI_BASE + 29)
131 #define INT_TRI_RES_30			(INT_TRI_BASE + 30)
132 #define INT_SW_RESERVED			(INT_TRI_BASE + 31)
133 
134 /* Quaternary Interrupt Controller */
135 #define INT_QUAD_BASE			(INT_TRI_BASE + 32)
136 #define INT_SNOR			(INT_QUAD_BASE + 0)
137 #define INT_USB3			(INT_QUAD_BASE + 1)
138 #define INT_PCIE_INTR			(INT_QUAD_BASE + 2)
139 #define INT_PCIE_MSI			(INT_QUAD_BASE + 3)
140 #define INT_QUAD_RES_4			(INT_QUAD_BASE + 4)
141 #define INT_QUAD_RES_5			(INT_QUAD_BASE + 5)
142 #define INT_QUAD_RES_6			(INT_QUAD_BASE + 6)
143 #define INT_QUAD_RES_7			(INT_QUAD_BASE + 7)
144 #define INT_APB_DMA_CH0			(INT_QUAD_BASE + 8)
145 #define INT_APB_DMA_CH1			(INT_QUAD_BASE + 9)
146 #define INT_APB_DMA_CH2			(INT_QUAD_BASE + 10)
147 #define INT_APB_DMA_CH3			(INT_QUAD_BASE + 11)
148 #define INT_APB_DMA_CH4			(INT_QUAD_BASE + 12)
149 #define INT_APB_DMA_CH5			(INT_QUAD_BASE + 13)
150 #define INT_APB_DMA_CH6			(INT_QUAD_BASE + 14)
151 #define INT_APB_DMA_CH7			(INT_QUAD_BASE + 15)
152 #define INT_APB_DMA_CH8			(INT_QUAD_BASE + 16)
153 #define INT_APB_DMA_CH9			(INT_QUAD_BASE + 17)
154 #define INT_APB_DMA_CH10		(INT_QUAD_BASE + 18)
155 #define INT_APB_DMA_CH11		(INT_QUAD_BASE + 19)
156 #define INT_APB_DMA_CH12		(INT_QUAD_BASE + 20)
157 #define INT_APB_DMA_CH13		(INT_QUAD_BASE + 21)
158 #define INT_APB_DMA_CH14		(INT_QUAD_BASE + 22)
159 #define INT_APB_DMA_CH15		(INT_QUAD_BASE + 23)
160 #define INT_QUAD_RES_24			(INT_QUAD_BASE + 24)
161 #define INT_QUAD_RES_25			(INT_QUAD_BASE + 25)
162 #define INT_QUAD_RES_26			(INT_QUAD_BASE + 26)
163 #define INT_QUAD_RES_27			(INT_QUAD_BASE + 27)
164 #define INT_QUAD_RES_28			(INT_QUAD_BASE + 28)
165 #define INT_QUAD_RES_29			(INT_QUAD_BASE + 29)
166 #define INT_QUAD_RES_30			(INT_QUAD_BASE + 30)
167 #define INT_QUAD_RES_31			(INT_QUAD_BASE + 31)
168 
169 #define INT_MAIN_NR			(INT_QUAD_BASE + 32 - INT_PRI_BASE)
170 
171 #define INT_GPIO_BASE			(INT_PRI_BASE + INT_MAIN_NR)
172 
173 #define INT_GPIO_NR			(28 * 8)
174 
175 #define TEGRA_NR_IRQS			(INT_GPIO_BASE + INT_GPIO_NR)
176 
177 #define INT_BOARD_BASE			TEGRA_NR_IRQS
178 #define NR_BOARD_IRQS			32
179 
180 #define NR_IRQS				(INT_BOARD_BASE + NR_BOARD_IRQS)
181 #endif
182 
183 #endif
184