Interrupt of type IRQ_TYPE_NONE is not allowed for GIC interrupts and
generates an error:
        genirq: Setting trigger mode 0 for irq 16 failed (gic_set_type+0x0/0x68)

The GIC requires shared interrupts to be edge rising or level high.
Platform declares support for both.  Choose level high everywhere.

Reported-by: Marek Szyprowski <m.szyprow...@samsung.com>
Reported-by: Geert Uytterhoeven <ge...@linux-m68k.org>
Reported-by: Alban Browaeys <alban.browa...@gmail.com>
Cc: Marc Zyngier <marc.zyng...@arm.com>
Signed-off-by: Krzysztof Kozlowski <k...@kernel.org>
---
 arch/arm/boot/dts/exynos3250-pinctrl.dtsi | 20 +++++--
 arch/arm/boot/dts/exynos3250.dtsi         | 93 ++++++++++++++++++-------------
 2 files changed, 71 insertions(+), 42 deletions(-)

diff --git a/arch/arm/boot/dts/exynos3250-pinctrl.dtsi 
b/arch/arm/boot/dts/exynos3250-pinctrl.dtsi
index 40ea7de44933..9ee16ab30608 100644
--- a/arch/arm/boot/dts/exynos3250-pinctrl.dtsi
+++ b/arch/arm/boot/dts/exynos3250-pinctrl.dtsi
@@ -374,8 +374,14 @@
 
                interrupt-controller;
                interrupt-parent = <&gic>;
-               interrupts = <0 32 0>, <0 33 0>, <0 34 0>, <0 35 0>,
-                               <0 36 0>, <0 37 0>, <0 38 0>, <0 39 0>;
+               interrupts = <0 32 IRQ_TYPE_LEVEL_HIGH>,
+                            <0 33 IRQ_TYPE_LEVEL_HIGH>,
+                            <0 34 IRQ_TYPE_LEVEL_HIGH>,
+                            <0 35 IRQ_TYPE_LEVEL_HIGH>,
+                            <0 36 IRQ_TYPE_LEVEL_HIGH>,
+                            <0 37 IRQ_TYPE_LEVEL_HIGH>,
+                            <0 38 IRQ_TYPE_LEVEL_HIGH>,
+                            <0 39 IRQ_TYPE_LEVEL_HIGH>;
                #interrupt-cells = <2>;
        };
 
@@ -385,8 +391,14 @@
 
                interrupt-controller;
                interrupt-parent = <&gic>;
-               interrupts = <0 40 0>, <0 41 0>, <0 42 0>, <0 43 0>,
-                               <0 44 0>, <0 45 0>, <0 46 0>, <0 47 0>;
+               interrupts = <0 40 IRQ_TYPE_LEVEL_HIGH>,
+                            <0 41 IRQ_TYPE_LEVEL_HIGH>,
+                            <0 42 IRQ_TYPE_LEVEL_HIGH>,
+                            <0 43 IRQ_TYPE_LEVEL_HIGH>,
+                            <0 44 IRQ_TYPE_LEVEL_HIGH>,
+                            <0 45 IRQ_TYPE_LEVEL_HIGH>,
+                            <0 46 IRQ_TYPE_LEVEL_HIGH>,
+                            <0 47 IRQ_TYPE_LEVEL_HIGH>;
                #interrupt-cells = <2>;
        };
 
diff --git a/arch/arm/boot/dts/exynos3250.dtsi 
b/arch/arm/boot/dts/exynos3250.dtsi
index e9d2556c0dfd..9703d81d1eb3 100644
--- a/arch/arm/boot/dts/exynos3250.dtsi
+++ b/arch/arm/boot/dts/exynos3250.dtsi
@@ -20,6 +20,7 @@
 #include "exynos4-cpu-thermal.dtsi"
 #include "exynos-syscon-restart.dtsi"
 #include <dt-bindings/clock/exynos3250.h>
+#include <dt-bindings/interrupt-controller/irq.h>
 
 / {
        compatible = "samsung,exynos3250";
@@ -211,7 +212,8 @@
                rtc: rtc@10070000 {
                        compatible = "samsung,s3c6410-rtc";
                        reg = <0x10070000 0x100>;
-                       interrupts = <0 73 0>, <0 74 0>;
+                       interrupts = <0 73 IRQ_TYPE_LEVEL_HIGH>,
+                                    <0 74 IRQ_TYPE_LEVEL_HIGH>;
                        interrupt-parent = <&pmu_system_controller>;
                        status = "disabled";
                };
@@ -219,7 +221,7 @@
                tmu: tmu@100C0000 {
                        compatible = "samsung,exynos3250-tmu";
                        reg = <0x100C0000 0x100>;
-                       interrupts = <0 216 0>;
+                       interrupts = <0 216 IRQ_TYPE_LEVEL_HIGH>;
                        clocks = <&cmu CLK_TMU_APBIF>;
                        clock-names = "tmu_apbif";
                        #include "exynos4412-tmu-sensor-conf.dtsi"
@@ -240,8 +242,14 @@
                mct@10050000 {
                        compatible = "samsung,exynos4210-mct";
                        reg = <0x10050000 0x800>;
-                       interrupts = <0 218 0>, <0 219 0>, <0 220 0>, <0 221 0>,
-                                    <0 223 0>, <0 226 0>, <0 227 0>, <0 228 0>;
+                       interrupts = <0 218 IRQ_TYPE_LEVEL_HIGH>,
+                                    <0 219 IRQ_TYPE_LEVEL_HIGH>,
+                                    <0 220 IRQ_TYPE_LEVEL_HIGH>,
+                                    <0 221 IRQ_TYPE_LEVEL_HIGH>,
+                                    <0 223 IRQ_TYPE_LEVEL_HIGH>,
+                                    <0 226 IRQ_TYPE_LEVEL_HIGH>,
+                                    <0 227 IRQ_TYPE_LEVEL_HIGH>,
+                                    <0 228 IRQ_TYPE_LEVEL_HIGH>;
                        clocks = <&cmu CLK_FIN_PLL>, <&cmu CLK_MCT>;
                        clock-names = "fin_pll", "mct";
                };
@@ -249,24 +257,24 @@
                pinctrl_1: pinctrl@11000000 {
                        compatible = "samsung,exynos3250-pinctrl";
                        reg = <0x11000000 0x1000>;
-                       interrupts = <0 225 0>;
+                       interrupts = <0 225 IRQ_TYPE_LEVEL_HIGH>;
 
                        wakeup-interrupt-controller {
                                compatible = "samsung,exynos4210-wakeup-eint";
-                               interrupts = <0 48 0>;
+                               interrupts = <0 48 IRQ_TYPE_LEVEL_HIGH>;
                        };
                };
 
                pinctrl_0: pinctrl@11400000 {
                        compatible = "samsung,exynos3250-pinctrl";
                        reg = <0x11400000 0x1000>;
-                       interrupts = <0 240 0>;
+                       interrupts = <0 240 IRQ_TYPE_LEVEL_HIGH>;
                };
 
                jpeg: codec@11830000 {
                        compatible = "samsung,exynos3250-jpeg";
                        reg = <0x11830000 0x1000>;
-                       interrupts = <0 171 0>;
+                       interrupts = <0 171 IRQ_TYPE_LEVEL_HIGH>;
                        clocks = <&cmu CLK_JPEG>, <&cmu CLK_SCLK_JPEG>;
                        clock-names = "jpeg", "sclk";
                        power-domains = <&pd_cam>;
@@ -280,7 +288,8 @@
                sysmmu_jpeg: sysmmu@11A60000 {
                        compatible = "samsung,exynos-sysmmu";
                        reg = <0x11a60000 0x1000>;
-                       interrupts = <0 156 0>, <0 161 0>;
+                       interrupts = <0 156 IRQ_TYPE_LEVEL_HIGH>,
+                                    <0 161 IRQ_TYPE_LEVEL_HIGH>;
                        clock-names = "sysmmu", "master";
                        clocks = <&cmu CLK_SMMUJPEG>, <&cmu CLK_JPEG>;
                        power-domains = <&pd_cam>;
@@ -291,7 +300,9 @@
                        compatible = "samsung,exynos3250-fimd";
                        reg = <0x11c00000 0x30000>;
                        interrupt-names = "fifo", "vsync", "lcd_sys";
-                       interrupts = <0 84 0>, <0 85 0>, <0 86 0>;
+                       interrupts = <0 84 IRQ_TYPE_LEVEL_HIGH>,
+                                    <0 85 IRQ_TYPE_LEVEL_HIGH>,
+                                    <0 86 IRQ_TYPE_LEVEL_HIGH>;
                        clocks = <&cmu CLK_SCLK_FIMD0>, <&cmu CLK_FIMD0>;
                        clock-names = "sclk_fimd", "fimd";
                        power-domains = <&pd_lcd0>;
@@ -303,7 +314,7 @@
                dsi_0: dsi@11C80000 {
                        compatible = "samsung,exynos3250-mipi-dsi";
                        reg = <0x11C80000 0x10000>;
-                       interrupts = <0 83 0>;
+                       interrupts = <0 83 IRQ_TYPE_LEVEL_HIGH>;
                        samsung,phy-type = <0>;
                        power-domains = <&pd_lcd0>;
                        phys = <&mipi_phy 1>;
@@ -318,7 +329,8 @@
                sysmmu_fimd0: sysmmu@11E20000 {
                        compatible = "samsung,exynos-sysmmu";
                        reg = <0x11e20000 0x1000>;
-                       interrupts = <0 80 0>, <0 81 0>;
+                       interrupts = <0 80 IRQ_TYPE_LEVEL_HIGH>,
+                                    <0 81 IRQ_TYPE_LEVEL_HIGH>;
                        clock-names = "sysmmu", "master";
                        clocks = <&cmu CLK_SMMUFIMD0>, <&cmu CLK_FIMD0>;
                        power-domains = <&pd_lcd0>;
@@ -328,7 +340,7 @@
                hsotg: hsotg@12480000 {
                        compatible = "snps,dwc2";
                        reg = <0x12480000 0x20000>;
-                       interrupts = <0 141 0>;
+                       interrupts = <0 141 IRQ_TYPE_LEVEL_HIGH>;
                        clocks = <&cmu CLK_USBOTG>;
                        clock-names = "otg";
                        phys = <&exynos_usbphy 0>;
@@ -339,7 +351,7 @@
                mshc_0: mshc@12510000 {
                        compatible = "samsung,exynos5420-dw-mshc";
                        reg = <0x12510000 0x1000>;
-                       interrupts = <0 142 0>;
+                       interrupts = <0 142 IRQ_TYPE_LEVEL_HIGH>;
                        clocks = <&cmu CLK_SDMMC0>, <&cmu CLK_SCLK_MMC0>;
                        clock-names = "biu", "ciu";
                        fifo-depth = <0x80>;
@@ -351,7 +363,7 @@
                mshc_1: mshc@12520000 {
                        compatible = "samsung,exynos5420-dw-mshc";
                        reg = <0x12520000 0x1000>;
-                       interrupts = <0 143 0>;
+                       interrupts = <0 143 IRQ_TYPE_LEVEL_HIGH>;
                        clocks = <&cmu CLK_SDMMC1>, <&cmu CLK_SCLK_MMC1>;
                        clock-names = "biu", "ciu";
                        fifo-depth = <0x80>;
@@ -363,7 +375,7 @@
                mshc_2: mshc@12530000 {
                        compatible = "samsung,exynos5250-dw-mshc";
                        reg = <0x12530000 0x1000>;
-                       interrupts = <0 144 0>;
+                       interrupts = <0 144 IRQ_TYPE_LEVEL_HIGH>;
                        clocks = <&cmu CLK_SDMMC2>, <&cmu CLK_SCLK_MMC2>;
                        clock-names = "biu", "ciu";
                        fifo-depth = <0x80>;
@@ -391,7 +403,7 @@
                        pdma0: pdma@12680000 {
                                compatible = "arm,pl330", "arm,primecell";
                                reg = <0x12680000 0x1000>;
-                               interrupts = <0 138 0>;
+                               interrupts = <0 138 IRQ_TYPE_LEVEL_HIGH>;
                                clocks = <&cmu CLK_PDMA0>;
                                clock-names = "apb_pclk";
                                #dma-cells = <1>;
@@ -402,7 +414,7 @@
                        pdma1: pdma@12690000 {
                                compatible = "arm,pl330", "arm,primecell";
                                reg = <0x12690000 0x1000>;
-                               interrupts = <0 139 0>;
+                               interrupts = <0 139 IRQ_TYPE_LEVEL_HIGH>;
                                clocks = <&cmu CLK_PDMA1>;
                                clock-names = "apb_pclk";
                                #dma-cells = <1>;
@@ -415,7 +427,7 @@
                        compatible = "samsung,exynos3250-adc",
                                     "samsung,exynos-adc-v2";
                        reg = <0x126C0000 0x100>;
-                       interrupts = <0 137 0>;
+                       interrupts = <0 137 IRQ_TYPE_LEVEL_HIGH>;
                        clock-names = "adc", "sclk";
                        clocks = <&cmu CLK_TSADC>, <&cmu CLK_SCLK_TSADC>;
                        #io-channel-cells = <1>;
@@ -427,7 +439,7 @@
                mfc: codec@13400000 {
                        compatible = "samsung,mfc-v7";
                        reg = <0x13400000 0x10000>;
-                       interrupts = <0 102 0>;
+                       interrupts = <0 102 IRQ_TYPE_LEVEL_HIGH>;
                        clock-names = "mfc", "sclk_mfc";
                        clocks = <&cmu CLK_MFC>, <&cmu CLK_SCLK_MFC>;
                        power-domains = <&pd_mfc>;
@@ -437,7 +449,8 @@
                sysmmu_mfc: sysmmu@13620000 {
                        compatible = "samsung,exynos-sysmmu";
                        reg = <0x13620000 0x1000>;
-                       interrupts = <0 96 0>, <0 98 0>;
+                       interrupts = <0 96 IRQ_TYPE_LEVEL_HIGH>,
+                                    <0 98 IRQ_TYPE_LEVEL_HIGH>;
                        clock-names = "sysmmu", "master";
                        clocks = <&cmu CLK_SMMUMFC_L>, <&cmu CLK_MFC>;
                        power-domains = <&pd_mfc>;
@@ -447,7 +460,7 @@
                serial_0: serial@13800000 {
                        compatible = "samsung,exynos4210-uart";
                        reg = <0x13800000 0x100>;
-                       interrupts = <0 109 0>;
+                       interrupts = <0 109 IRQ_TYPE_LEVEL_HIGH>;
                        clocks = <&cmu CLK_UART0>, <&cmu CLK_SCLK_UART0>;
                        clock-names = "uart", "clk_uart_baud0";
                        pinctrl-names = "default";
@@ -458,7 +471,7 @@
                serial_1: serial@13810000 {
                        compatible = "samsung,exynos4210-uart";
                        reg = <0x13810000 0x100>;
-                       interrupts = <0 110 0>;
+                       interrupts = <0 110 IRQ_TYPE_LEVEL_HIGH>;
                        clocks = <&cmu CLK_UART1>, <&cmu CLK_SCLK_UART1>;
                        clock-names = "uart", "clk_uart_baud0";
                        pinctrl-names = "default";
@@ -469,7 +482,7 @@
                serial_2: serial@13820000 {
                        compatible = "samsung,exynos4210-uart";
                        reg = <0x13820000 0x100>;
-                       interrupts = <0 111 0>;
+                       interrupts = <0 111 IRQ_TYPE_LEVEL_HIGH>;
                        clocks = <&cmu CLK_UART2>, <&cmu CLK_SCLK_UART2>;
                        clock-names = "uart", "clk_uart_baud0";
                        pinctrl-names = "default";
@@ -482,7 +495,7 @@
                        #size-cells = <0>;
                        compatible = "samsung,s3c2440-i2c";
                        reg = <0x13860000 0x100>;
-                       interrupts = <0 113 0>;
+                       interrupts = <0 113 IRQ_TYPE_LEVEL_HIGH>;
                        clocks = <&cmu CLK_I2C0>;
                        clock-names = "i2c";
                        pinctrl-names = "default";
@@ -495,7 +508,7 @@
                        #size-cells = <0>;
                        compatible = "samsung,s3c2440-i2c";
                        reg = <0x13870000 0x100>;
-                       interrupts = <0 114 0>;
+                       interrupts = <0 114 IRQ_TYPE_LEVEL_HIGH>;
                        clocks = <&cmu CLK_I2C1>;
                        clock-names = "i2c";
                        pinctrl-names = "default";
@@ -508,7 +521,7 @@
                        #size-cells = <0>;
                        compatible = "samsung,s3c2440-i2c";
                        reg = <0x13880000 0x100>;
-                       interrupts = <0 115 0>;
+                       interrupts = <0 115 IRQ_TYPE_LEVEL_HIGH>;
                        clocks = <&cmu CLK_I2C2>;
                        clock-names = "i2c";
                        pinctrl-names = "default";
@@ -521,7 +534,7 @@
                        #size-cells = <0>;
                        compatible = "samsung,s3c2440-i2c";
                        reg = <0x13890000 0x100>;
-                       interrupts = <0 116 0>;
+                       interrupts = <0 116 IRQ_TYPE_LEVEL_HIGH>;
                        clocks = <&cmu CLK_I2C3>;
                        clock-names = "i2c";
                        pinctrl-names = "default";
@@ -534,7 +547,7 @@
                        #size-cells = <0>;
                        compatible = "samsung,s3c2440-i2c";
                        reg = <0x138A0000 0x100>;
-                       interrupts = <0 117 0>;
+                       interrupts = <0 117 IRQ_TYPE_LEVEL_HIGH>;
                        clocks = <&cmu CLK_I2C4>;
                        clock-names = "i2c";
                        pinctrl-names = "default";
@@ -547,7 +560,7 @@
                        #size-cells = <0>;
                        compatible = "samsung,s3c2440-i2c";
                        reg = <0x138B0000 0x100>;
-                       interrupts = <0 118 0>;
+                       interrupts = <0 118 IRQ_TYPE_LEVEL_HIGH>;
                        clocks = <&cmu CLK_I2C5>;
                        clock-names = "i2c";
                        pinctrl-names = "default";
@@ -560,7 +573,7 @@
                        #size-cells = <0>;
                        compatible = "samsung,s3c2440-i2c";
                        reg = <0x138C0000 0x100>;
-                       interrupts = <0 119 0>;
+                       interrupts = <0 119 IRQ_TYPE_LEVEL_HIGH>;
                        clocks = <&cmu CLK_I2C6>;
                        clock-names = "i2c";
                        pinctrl-names = "default";
@@ -573,7 +586,7 @@
                        #size-cells = <0>;
                        compatible = "samsung,s3c2440-i2c";
                        reg = <0x138D0000 0x100>;
-                       interrupts = <0 120 0>;
+                       interrupts = <0 120 IRQ_TYPE_LEVEL_HIGH>;
                        clocks = <&cmu CLK_I2C7>;
                        clock-names = "i2c";
                        pinctrl-names = "default";
@@ -584,7 +597,7 @@
                spi_0: spi@13920000 {
                        compatible = "samsung,exynos4210-spi";
                        reg = <0x13920000 0x100>;
-                       interrupts = <0 121 0>;
+                       interrupts = <0 121 IRQ_TYPE_LEVEL_HIGH>;
                        dmas = <&pdma0 7>, <&pdma0 6>;
                        dma-names = "tx", "rx";
                        #address-cells = <1>;
@@ -600,7 +613,7 @@
                spi_1: spi@13930000 {
                        compatible = "samsung,exynos4210-spi";
                        reg = <0x13930000 0x100>;
-                       interrupts = <0 122 0>;
+                       interrupts = <0 122 IRQ_TYPE_LEVEL_HIGH>;
                        dmas = <&pdma1 7>, <&pdma1 6>;
                        dma-names = "tx", "rx";
                        #address-cells = <1>;
@@ -616,7 +629,7 @@
                i2s2: i2s@13970000 {
                        compatible = "samsung,s3c6410-i2s";
                        reg = <0x13970000 0x100>;
-                       interrupts = <0 126 0>;
+                       interrupts = <0 126 IRQ_TYPE_LEVEL_HIGH>;
                        clocks = <&cmu CLK_I2S>, <&cmu CLK_SCLK_I2S>;
                        clock-names = "iis", "i2s_opclk0";
                        dmas = <&pdma0 14>, <&pdma0 13>;
@@ -629,15 +642,19 @@
                pwm: pwm@139D0000 {
                        compatible = "samsung,exynos4210-pwm";
                        reg = <0x139D0000 0x1000>;
-                       interrupts = <0 104 0>, <0 105 0>, <0 106 0>,
-                                    <0 107 0>, <0 108 0>;
+                       interrupts = <0 104 IRQ_TYPE_LEVEL_HIGH>,
+                                    <0 105 IRQ_TYPE_LEVEL_HIGH>,
+                                    <0 106 IRQ_TYPE_LEVEL_HIGH>,
+                                    <0 107 IRQ_TYPE_LEVEL_HIGH>,
+                                    <0 108 IRQ_TYPE_LEVEL_HIGH>;
                        #pwm-cells = <3>;
                        status = "disabled";
                };
 
                pmu {
                        compatible = "arm,cortex-a7-pmu";
-                       interrupts = <0 18 0>, <0 19 0>;
+                       interrupts = <0 18 IRQ_TYPE_LEVEL_HIGH>,
+                                    <0 19 IRQ_TYPE_LEVEL_HIGH>;
                };
 
                ppmu_dmc0: ppmu_dmc0@106a0000 {
-- 
2.7.4

Reply via email to