123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290 |
- /*
- * Copyright (c) 2010-2012 Samsung Electronics Co., Ltd.
- * http://www.samsung.com
- *
- * EXYNOS - IRQ definitions
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License version 2 as
- * published by the Free Software Foundation.
- */
- #ifndef __ASM_ARCH_IRQS_H
- #define __ASM_ARCH_IRQS_H __FILE__
- #include <plat/irqs.h>
- /* PPI: Private Peripheral Interrupt */
- #define IRQ_PPI(x) (x + 16)
- /* SPI: Shared Peripheral Interrupt */
- #define IRQ_SPI(x) (x + 32)
- /* COMBINER */
- #define MAX_IRQ_IN_COMBINER 8
- #define COMBINER_GROUP(x) ((x) * MAX_IRQ_IN_COMBINER + IRQ_SPI(128))
- #define COMBINER_IRQ(x, y) (COMBINER_GROUP(x) + y)
- /* For EXYNOS4 and EXYNOS5 */
- #define EXYNOS_IRQ_MCT_LOCALTIMER IRQ_PPI(12)
- #define EXYNOS_IRQ_EINT16_31 IRQ_SPI(32)
- /* For EXYNOS4 SoCs */
- #define EXYNOS4_IRQ_EINT0 IRQ_SPI(16)
- #define EXYNOS4_IRQ_EINT1 IRQ_SPI(17)
- #define EXYNOS4_IRQ_EINT2 IRQ_SPI(18)
- #define EXYNOS4_IRQ_EINT3 IRQ_SPI(19)
- #define EXYNOS4_IRQ_EINT4 IRQ_SPI(20)
- #define EXYNOS4_IRQ_EINT5 IRQ_SPI(21)
- #define EXYNOS4_IRQ_EINT6 IRQ_SPI(22)
- #define EXYNOS4_IRQ_EINT7 IRQ_SPI(23)
- #define EXYNOS4_IRQ_EINT8 IRQ_SPI(24)
- #define EXYNOS4_IRQ_EINT9 IRQ_SPI(25)
- #define EXYNOS4_IRQ_EINT10 IRQ_SPI(26)
- #define EXYNOS4_IRQ_EINT11 IRQ_SPI(27)
- #define EXYNOS4_IRQ_EINT12 IRQ_SPI(28)
- #define EXYNOS4_IRQ_EINT13 IRQ_SPI(29)
- #define EXYNOS4_IRQ_EINT14 IRQ_SPI(30)
- #define EXYNOS4_IRQ_EINT15 IRQ_SPI(31)
- #define EXYNOS4_IRQ_MDMA0 IRQ_SPI(33)
- #define EXYNOS4_IRQ_MDMA1 IRQ_SPI(34)
- #define EXYNOS4_IRQ_PDMA0 IRQ_SPI(35)
- #define EXYNOS4_IRQ_PDMA1 IRQ_SPI(36)
- #define EXYNOS4_IRQ_TIMER0_VIC IRQ_SPI(37)
- #define EXYNOS4_IRQ_TIMER1_VIC IRQ_SPI(38)
- #define EXYNOS4_IRQ_TIMER2_VIC IRQ_SPI(39)
- #define EXYNOS4_IRQ_TIMER3_VIC IRQ_SPI(40)
- #define EXYNOS4_IRQ_TIMER4_VIC IRQ_SPI(41)
- #define EXYNOS4_IRQ_MCT_L0 IRQ_SPI(42)
- #define EXYNOS4_IRQ_WDT IRQ_SPI(43)
- #define EXYNOS4_IRQ_RTC_ALARM IRQ_SPI(44)
- #define EXYNOS4_IRQ_RTC_TIC IRQ_SPI(45)
- #define EXYNOS4_IRQ_GPIO_XB IRQ_SPI(46)
- #define EXYNOS4_IRQ_GPIO_XA IRQ_SPI(47)
- #define EXYNOS4_IRQ_MCT_L1 IRQ_SPI(48)
- #define EXYNOS4_IRQ_UART0 IRQ_SPI(52)
- #define EXYNOS4_IRQ_UART1 IRQ_SPI(53)
- #define EXYNOS4_IRQ_UART2 IRQ_SPI(54)
- #define EXYNOS4_IRQ_UART3 IRQ_SPI(55)
- #define EXYNOS4_IRQ_UART4 IRQ_SPI(56)
- #define EXYNOS4_IRQ_MCT_G0 IRQ_SPI(57)
- #define EXYNOS4_IRQ_IIC IRQ_SPI(58)
- #define EXYNOS4_IRQ_IIC1 IRQ_SPI(59)
- #define EXYNOS4_IRQ_IIC2 IRQ_SPI(60)
- #define EXYNOS4_IRQ_IIC3 IRQ_SPI(61)
- #define EXYNOS4_IRQ_IIC4 IRQ_SPI(62)
- #define EXYNOS4_IRQ_IIC5 IRQ_SPI(63)
- #define EXYNOS4_IRQ_IIC6 IRQ_SPI(64)
- #define EXYNOS4_IRQ_IIC7 IRQ_SPI(65)
- #define EXYNOS4_IRQ_SPI0 IRQ_SPI(66)
- #define EXYNOS4_IRQ_SPI1 IRQ_SPI(67)
- #define EXYNOS4_IRQ_SPI2 IRQ_SPI(68)
- #define EXYNOS4_IRQ_USB_HOST IRQ_SPI(70)
- #define EXYNOS4_IRQ_USB_HSOTG IRQ_SPI(71)
- #define EXYNOS4_IRQ_MODEM_IF IRQ_SPI(72)
- #define EXYNOS4_IRQ_HSMMC0 IRQ_SPI(73)
- #define EXYNOS4_IRQ_HSMMC1 IRQ_SPI(74)
- #define EXYNOS4_IRQ_HSMMC2 IRQ_SPI(75)
- #define EXYNOS4_IRQ_HSMMC3 IRQ_SPI(76)
- #define EXYNOS4_IRQ_DWMCI IRQ_SPI(77)
- #define EXYNOS4_IRQ_MIPI_CSIS0 IRQ_SPI(78)
- #define EXYNOS4_IRQ_MIPI_CSIS1 IRQ_SPI(80)
- #define EXYNOS4_IRQ_ONENAND_AUDI IRQ_SPI(82)
- #define EXYNOS4_IRQ_ROTATOR IRQ_SPI(83)
- #define EXYNOS4_IRQ_FIMC0 IRQ_SPI(84)
- #define EXYNOS4_IRQ_FIMC1 IRQ_SPI(85)
- #define EXYNOS4_IRQ_FIMC2 IRQ_SPI(86)
- #define EXYNOS4_IRQ_FIMC3 IRQ_SPI(87)
- #define EXYNOS4_IRQ_JPEG IRQ_SPI(88)
- #define EXYNOS4_IRQ_2D IRQ_SPI(89)
- #define EXYNOS4_IRQ_PCIE IRQ_SPI(90)
- #define EXYNOS4_IRQ_MIXER IRQ_SPI(91)
- #define EXYNOS4_IRQ_HDMI IRQ_SPI(92)
- #define EXYNOS4_IRQ_IIC_HDMIPHY IRQ_SPI(93)
- #define EXYNOS4_IRQ_MFC IRQ_SPI(94)
- #define EXYNOS4_IRQ_SDO IRQ_SPI(95)
- #define EXYNOS4_IRQ_AUDIO_SS IRQ_SPI(96)
- #define EXYNOS4_IRQ_I2S0 IRQ_SPI(97)
- #define EXYNOS4_IRQ_I2S1 IRQ_SPI(98)
- #define EXYNOS4_IRQ_I2S2 IRQ_SPI(99)
- #define EXYNOS4_IRQ_AC97 IRQ_SPI(100)
- #define EXYNOS4_IRQ_SPDIF IRQ_SPI(104)
- #define EXYNOS4_IRQ_ADC0 IRQ_SPI(105)
- #define EXYNOS4_IRQ_PEN0 IRQ_SPI(106)
- #define EXYNOS4_IRQ_ADC1 IRQ_SPI(107)
- #define EXYNOS4_IRQ_PEN1 IRQ_SPI(108)
- #define EXYNOS4_IRQ_KEYPAD IRQ_SPI(109)
- #define EXYNOS4_IRQ_PMU IRQ_SPI(110)
- #define EXYNOS4_IRQ_GPS IRQ_SPI(111)
- #define EXYNOS4_IRQ_INTFEEDCTRL_SSS IRQ_SPI(112)
- #define EXYNOS4_IRQ_SLIMBUS IRQ_SPI(113)
- #define EXYNOS4_IRQ_TSI IRQ_SPI(115)
- #define EXYNOS4_IRQ_SATA IRQ_SPI(116)
- #define EXYNOS4_IRQ_TMU_TRIG0 COMBINER_IRQ(2, 4)
- #define EXYNOS4_IRQ_TMU_TRIG1 COMBINER_IRQ(3, 4)
- #define EXYNOS4_IRQ_SYSMMU_MDMA0_0 COMBINER_IRQ(4, 0)
- #define EXYNOS4_IRQ_SYSMMU_SSS_0 COMBINER_IRQ(4, 1)
- #define EXYNOS4_IRQ_SYSMMU_FIMC0_0 COMBINER_IRQ(4, 2)
- #define EXYNOS4_IRQ_SYSMMU_FIMC1_0 COMBINER_IRQ(4, 3)
- #define EXYNOS4_IRQ_SYSMMU_FIMC2_0 COMBINER_IRQ(4, 4)
- #define EXYNOS4_IRQ_SYSMMU_FIMC3_0 COMBINER_IRQ(4, 5)
- #define EXYNOS4_IRQ_SYSMMU_JPEG_0 COMBINER_IRQ(4, 6)
- #define EXYNOS4_IRQ_SYSMMU_2D_0 COMBINER_IRQ(4, 7)
- #define EXYNOS4_IRQ_SYSMMU_ROTATOR_0 COMBINER_IRQ(5, 0)
- #define EXYNOS4_IRQ_SYSMMU_MDMA1_0 COMBINER_IRQ(5, 1)
- #define EXYNOS4_IRQ_SYSMMU_LCD0_M0_0 COMBINER_IRQ(5, 2)
- #define EXYNOS4_IRQ_SYSMMU_LCD1_M1_0 COMBINER_IRQ(5, 3)
- #define EXYNOS4_IRQ_SYSMMU_TV_M0_0 COMBINER_IRQ(5, 4)
- #define EXYNOS4_IRQ_SYSMMU_MFC_M0_0 COMBINER_IRQ(5, 5)
- #define EXYNOS4_IRQ_SYSMMU_MFC_M1_0 COMBINER_IRQ(5, 6)
- #define EXYNOS4_IRQ_SYSMMU_PCIE_0 COMBINER_IRQ(5, 7)
- #define EXYNOS4_IRQ_SYSMMU_FIMC_LITE0_0 COMBINER_IRQ(16, 0)
- #define EXYNOS4_IRQ_SYSMMU_FIMC_LITE1_0 COMBINER_IRQ(16, 1)
- #define EXYNOS4_IRQ_SYSMMU_FIMC_ISP_0 COMBINER_IRQ(16, 2)
- #define EXYNOS4_IRQ_SYSMMU_FIMC_DRC_0 COMBINER_IRQ(16, 3)
- #define EXYNOS4_IRQ_SYSMMU_FIMC_FD_0 COMBINER_IRQ(16, 4)
- #define EXYNOS4_IRQ_SYSMMU_FIMC_CX_0 COMBINER_IRQ(16, 5)
- #define EXYNOS4_IRQ_FIMD0_FIFO COMBINER_IRQ(11, 0)
- #define EXYNOS4_IRQ_FIMD0_VSYNC COMBINER_IRQ(11, 1)
- #define EXYNOS4_IRQ_FIMD0_SYSTEM COMBINER_IRQ(11, 2)
- #define EXYNOS4_MAX_COMBINER_NR 16
- #define EXYNOS4_IRQ_GPIO1_NR_GROUPS 16
- #define EXYNOS4_IRQ_GPIO2_NR_GROUPS 9
- /*
- * For Compatibility:
- * the default is for EXYNOS4, and
- * for exynos5, should be re-mapped at function
- */
- #define IRQ_TIMER0_VIC EXYNOS4_IRQ_TIMER0_VIC
- #define IRQ_TIMER1_VIC EXYNOS4_IRQ_TIMER1_VIC
- #define IRQ_TIMER2_VIC EXYNOS4_IRQ_TIMER2_VIC
- #define IRQ_TIMER3_VIC EXYNOS4_IRQ_TIMER3_VIC
- #define IRQ_TIMER4_VIC EXYNOS4_IRQ_TIMER4_VIC
- #define IRQ_WDT EXYNOS4_IRQ_WDT
- #define IRQ_RTC_ALARM EXYNOS4_IRQ_RTC_ALARM
- #define IRQ_RTC_TIC EXYNOS4_IRQ_RTC_TIC
- #define IRQ_GPIO_XB EXYNOS4_IRQ_GPIO_XB
- #define IRQ_GPIO_XA EXYNOS4_IRQ_GPIO_XA
- #define IRQ_IIC EXYNOS4_IRQ_IIC
- #define IRQ_IIC1 EXYNOS4_IRQ_IIC1
- #define IRQ_IIC3 EXYNOS4_IRQ_IIC3
- #define IRQ_IIC5 EXYNOS4_IRQ_IIC5
- #define IRQ_IIC6 EXYNOS4_IRQ_IIC6
- #define IRQ_IIC7 EXYNOS4_IRQ_IIC7
- #define IRQ_SPI0 EXYNOS4_IRQ_SPI0
- #define IRQ_SPI1 EXYNOS4_IRQ_SPI1
- #define IRQ_SPI2 EXYNOS4_IRQ_SPI2
- #define IRQ_USB_HOST EXYNOS4_IRQ_USB_HOST
- #define IRQ_OTG EXYNOS4_IRQ_USB_HSOTG
- #define IRQ_HSMMC0 EXYNOS4_IRQ_HSMMC0
- #define IRQ_HSMMC1 EXYNOS4_IRQ_HSMMC1
- #define IRQ_HSMMC2 EXYNOS4_IRQ_HSMMC2
- #define IRQ_HSMMC3 EXYNOS4_IRQ_HSMMC3
- #define IRQ_MIPI_CSIS0 EXYNOS4_IRQ_MIPI_CSIS0
- #define IRQ_ONENAND_AUDI EXYNOS4_IRQ_ONENAND_AUDI
- #define IRQ_FIMC0 EXYNOS4_IRQ_FIMC0
- #define IRQ_FIMC1 EXYNOS4_IRQ_FIMC1
- #define IRQ_FIMC2 EXYNOS4_IRQ_FIMC2
- #define IRQ_FIMC3 EXYNOS4_IRQ_FIMC3
- #define IRQ_JPEG EXYNOS4_IRQ_JPEG
- #define IRQ_2D EXYNOS4_IRQ_2D
- #define IRQ_MIXER EXYNOS4_IRQ_MIXER
- #define IRQ_HDMI EXYNOS4_IRQ_HDMI
- #define IRQ_IIC_HDMIPHY EXYNOS4_IRQ_IIC_HDMIPHY
- #define IRQ_MFC EXYNOS4_IRQ_MFC
- #define IRQ_SDO EXYNOS4_IRQ_SDO
- #define IRQ_I2S0 EXYNOS4_IRQ_I2S0
- #define IRQ_ADC EXYNOS4_IRQ_ADC0
- #define IRQ_TC EXYNOS4_IRQ_PEN0
- #define IRQ_KEYPAD EXYNOS4_IRQ_KEYPAD
- #define IRQ_PMU EXYNOS4_IRQ_PMU
- #define IRQ_FIMD0_FIFO EXYNOS4_IRQ_FIMD0_FIFO
- #define IRQ_FIMD0_VSYNC EXYNOS4_IRQ_FIMD0_VSYNC
- #define IRQ_FIMD0_SYSTEM EXYNOS4_IRQ_FIMD0_SYSTEM
- #define IRQ_GPIO1_NR_GROUPS EXYNOS4_IRQ_GPIO1_NR_GROUPS
- #define IRQ_GPIO2_NR_GROUPS EXYNOS4_IRQ_GPIO2_NR_GROUPS
- /* For EXYNOS5 SoCs */
- #define EXYNOS5_IRQ_MDMA0 IRQ_SPI(33)
- #define EXYNOS5_IRQ_PDMA0 IRQ_SPI(34)
- #define EXYNOS5_IRQ_PDMA1 IRQ_SPI(35)
- #define EXYNOS5_IRQ_TIMER0_VIC IRQ_SPI(36)
- #define EXYNOS5_IRQ_TIMER1_VIC IRQ_SPI(37)
- #define EXYNOS5_IRQ_TIMER2_VIC IRQ_SPI(38)
- #define EXYNOS5_IRQ_TIMER3_VIC IRQ_SPI(39)
- #define EXYNOS5_IRQ_TIMER4_VIC IRQ_SPI(40)
- #define EXYNOS5_IRQ_RTIC IRQ_SPI(41)
- #define EXYNOS5_IRQ_WDT IRQ_SPI(42)
- #define EXYNOS5_IRQ_RTC_ALARM IRQ_SPI(43)
- #define EXYNOS5_IRQ_RTC_TIC IRQ_SPI(44)
- #define EXYNOS5_IRQ_GPIO_XB IRQ_SPI(45)
- #define EXYNOS5_IRQ_GPIO_XA IRQ_SPI(46)
- #define EXYNOS5_IRQ_GPIO IRQ_SPI(47)
- #define EXYNOS5_IRQ_IEM_IEC IRQ_SPI(48)
- #define EXYNOS5_IRQ_IEM_APC IRQ_SPI(49)
- #define EXYNOS5_IRQ_GPIO_C2C IRQ_SPI(50)
- #define EXYNOS5_IRQ_IIC IRQ_SPI(56)
- #define EXYNOS5_IRQ_IIC1 IRQ_SPI(57)
- #define EXYNOS5_IRQ_IIC2 IRQ_SPI(58)
- #define EXYNOS5_IRQ_IIC3 IRQ_SPI(59)
- #define EXYNOS5_IRQ_IIC4 IRQ_SPI(60)
- #define EXYNOS5_IRQ_IIC5 IRQ_SPI(61)
- #define EXYNOS5_IRQ_IIC6 IRQ_SPI(62)
- #define EXYNOS5_IRQ_IIC7 IRQ_SPI(63)
- #define EXYNOS5_IRQ_IIC_HDMIPHY IRQ_SPI(64)
- #define EXYNOS5_IRQ_TMU IRQ_SPI(65)
- #define EXYNOS5_IRQ_FIQ_0 IRQ_SPI(66)
- #define EXYNOS5_IRQ_FIQ_1 IRQ_SPI(67)
- #define EXYNOS5_IRQ_SPI0 IRQ_SPI(68)
- #define EXYNOS5_IRQ_SPI1 IRQ_SPI(69)
- #define EXYNOS5_IRQ_SPI2 IRQ_SPI(70)
- #define EXYNOS5_IRQ_USB_HOST IRQ_SPI(71)
- #define EXYNOS5_IRQ_USB3_DRD IRQ_SPI(72)
- #define EXYNOS5_IRQ_MIPI_HSI IRQ_SPI(73)
- #define EXYNOS5_IRQ_USB_HSOTG IRQ_SPI(74)
- #define EXYNOS5_IRQ_HSMMC0 IRQ_SPI(75)
- #define EXYNOS5_IRQ_HSMMC1 IRQ_SPI(76)
- #define EXYNOS5_IRQ_HSMMC2 IRQ_SPI(77)
- #define EXYNOS5_IRQ_HSMMC3 IRQ_SPI(78)
- #define EXYNOS5_IRQ_MIPICSI0 IRQ_SPI(79)
- #define EXYNOS5_IRQ_MIPICSI1 IRQ_SPI(80)
- #define EXYNOS5_IRQ_EFNFCON_DMA_ABORT IRQ_SPI(81)
|