diff options
-rw-r--r-- | arch/arm/mach-omap1/board-fsample.c | 2 | ||||
-rw-r--r-- | arch/arm/mach-omap1/board-h2.c | 2 | ||||
-rw-r--r-- | arch/arm/mach-omap1/board-h3.c | 2 | ||||
-rw-r--r-- | arch/arm/mach-omap1/board-innovator.c | 4 | ||||
-rw-r--r-- | arch/arm/mach-omap1/board-osk.c | 2 | ||||
-rw-r--r-- | arch/arm/mach-omap1/board-perseus2.c | 2 | ||||
-rw-r--r-- | arch/arm/mach-omap1/board-voiceblue.c | 2 | ||||
-rw-r--r-- | arch/arm/mach-omap2/board-2430sdp.c | 2 | ||||
-rw-r--r-- | arch/arm/mach-omap2/board-apollon.c | 2 | ||||
-rw-r--r-- | arch/arm/mach-pxa/idp.c | 2 | ||||
-rw-r--r-- | arch/arm/mach-pxa/littleton.c | 2 | ||||
-rw-r--r-- | arch/arm/mach-pxa/lubbock.c | 2 | ||||
-rw-r--r-- | arch/arm/mach-pxa/mainstone.c | 2 | ||||
-rw-r--r-- | arch/arm/mach-pxa/zylonite.c | 2 | ||||
-rw-r--r-- | arch/arm/plat-omap/debug-devices.c | 2 | ||||
-rw-r--r-- | drivers/net/smc91x.c | 19 | ||||
-rw-r--r-- | drivers/net/smc91x.h | 21 |
17 files changed, 36 insertions, 36 deletions
diff --git a/arch/arm/mach-omap1/board-fsample.c b/arch/arm/mach-omap1/board-fsample.c index d5f6ea14fc7b..f550b19e1ecd 100644 --- a/arch/arm/mach-omap1/board-fsample.c +++ b/arch/arm/mach-omap1/board-fsample.c | |||
@@ -76,7 +76,7 @@ static struct resource smc91x_resources[] = { | |||
76 | [1] = { | 76 | [1] = { |
77 | .start = INT_730_MPU_EXT_NIRQ, | 77 | .start = INT_730_MPU_EXT_NIRQ, |
78 | .end = 0, | 78 | .end = 0, |
79 | .flags = IORESOURCE_IRQ, | 79 | .flags = IORESOURCE_IRQ | IORESOURCE_IRQ_HIGHEDGE, |
80 | }, | 80 | }, |
81 | }; | 81 | }; |
82 | 82 | ||
diff --git a/arch/arm/mach-omap1/board-h2.c b/arch/arm/mach-omap1/board-h2.c index 130681201c19..60c4057e19ed 100644 --- a/arch/arm/mach-omap1/board-h2.c +++ b/arch/arm/mach-omap1/board-h2.c | |||
@@ -209,7 +209,7 @@ static struct resource h2_smc91x_resources[] = { | |||
209 | [1] = { | 209 | [1] = { |
210 | .start = OMAP_GPIO_IRQ(0), | 210 | .start = OMAP_GPIO_IRQ(0), |
211 | .end = OMAP_GPIO_IRQ(0), | 211 | .end = OMAP_GPIO_IRQ(0), |
212 | .flags = IORESOURCE_IRQ, | 212 | .flags = IORESOURCE_IRQ | IORESOURCE_IRQ_LOWEDGE, |
213 | }, | 213 | }, |
214 | }; | 214 | }; |
215 | 215 | ||
diff --git a/arch/arm/mach-omap1/board-h3.c b/arch/arm/mach-omap1/board-h3.c index 4f84ae273a1f..15b502e6ecfe 100644 --- a/arch/arm/mach-omap1/board-h3.c +++ b/arch/arm/mach-omap1/board-h3.c | |||
@@ -208,7 +208,7 @@ static struct resource smc91x_resources[] = { | |||
208 | [1] = { | 208 | [1] = { |
209 | .start = OMAP_GPIO_IRQ(40), | 209 | .start = OMAP_GPIO_IRQ(40), |
210 | .end = OMAP_GPIO_IRQ(40), | 210 | .end = OMAP_GPIO_IRQ(40), |
211 | .flags = IORESOURCE_IRQ, | 211 | .flags = IORESOURCE_IRQ | IORESOURCE_IRQ_LOWEDGE, |
212 | }, | 212 | }, |
213 | }; | 213 | }; |
214 | 214 | ||
diff --git a/arch/arm/mach-omap1/board-innovator.c b/arch/arm/mach-omap1/board-innovator.c index 7e63a41e37c6..7d2d8af155a3 100644 --- a/arch/arm/mach-omap1/board-innovator.c +++ b/arch/arm/mach-omap1/board-innovator.c | |||
@@ -202,7 +202,7 @@ static struct resource innovator1510_smc91x_resources[] = { | |||
202 | [1] = { | 202 | [1] = { |
203 | .start = OMAP1510_INT_ETHER, | 203 | .start = OMAP1510_INT_ETHER, |
204 | .end = OMAP1510_INT_ETHER, | 204 | .end = OMAP1510_INT_ETHER, |
205 | .flags = IORESOURCE_IRQ, | 205 | .flags = IORESOURCE_IRQ | IORESOURCE_IRQ_HIGHEDGE, |
206 | }, | 206 | }, |
207 | }; | 207 | }; |
208 | 208 | ||
@@ -269,7 +269,7 @@ static struct resource innovator1610_smc91x_resources[] = { | |||
269 | [1] = { | 269 | [1] = { |
270 | .start = OMAP_GPIO_IRQ(0), | 270 | .start = OMAP_GPIO_IRQ(0), |
271 | .end = OMAP_GPIO_IRQ(0), | 271 | .end = OMAP_GPIO_IRQ(0), |
272 | .flags = IORESOURCE_IRQ, | 272 | .flags = IORESOURCE_IRQ | IORESOURCE_IRQ_LOWEDGE, |
273 | }, | 273 | }, |
274 | }; | 274 | }; |
275 | 275 | ||
diff --git a/arch/arm/mach-omap1/board-osk.c b/arch/arm/mach-omap1/board-osk.c index 5db182da322b..1fe9ba3b8c28 100644 --- a/arch/arm/mach-omap1/board-osk.c +++ b/arch/arm/mach-omap1/board-osk.c | |||
@@ -111,7 +111,7 @@ static struct resource osk5912_smc91x_resources[] = { | |||
111 | [1] = { | 111 | [1] = { |
112 | .start = OMAP_GPIO_IRQ(0), | 112 | .start = OMAP_GPIO_IRQ(0), |
113 | .end = OMAP_GPIO_IRQ(0), | 113 | .end = OMAP_GPIO_IRQ(0), |
114 | .flags = IORESOURCE_IRQ, | 114 | .flags = IORESOURCE_IRQ | IORESOURCE_IRQ_HIGHEDGE, |
115 | }, | 115 | }, |
116 | }; | 116 | }; |
117 | 117 | ||
diff --git a/arch/arm/mach-omap1/board-perseus2.c b/arch/arm/mach-omap1/board-perseus2.c index e44437e10eef..534dcfb9d263 100644 --- a/arch/arm/mach-omap1/board-perseus2.c +++ b/arch/arm/mach-omap1/board-perseus2.c | |||
@@ -75,7 +75,7 @@ static struct resource smc91x_resources[] = { | |||
75 | [1] = { | 75 | [1] = { |
76 | .start = INT_730_MPU_EXT_NIRQ, | 76 | .start = INT_730_MPU_EXT_NIRQ, |
77 | .end = 0, | 77 | .end = 0, |
78 | .flags = IORESOURCE_IRQ, | 78 | .flags = IORESOURCE_IRQ | IORESOURCE_IRQ_HIGHEDGE, |
79 | }, | 79 | }, |
80 | }; | 80 | }; |
81 | 81 | ||
diff --git a/arch/arm/mach-omap1/board-voiceblue.c b/arch/arm/mach-omap1/board-voiceblue.c index 214dd19889ac..c82a1cd20ad4 100644 --- a/arch/arm/mach-omap1/board-voiceblue.c +++ b/arch/arm/mach-omap1/board-voiceblue.c | |||
@@ -117,7 +117,7 @@ static struct resource voiceblue_smc91x_resources[] = { | |||
117 | [1] = { | 117 | [1] = { |
118 | .start = OMAP_GPIO_IRQ(8), | 118 | .start = OMAP_GPIO_IRQ(8), |
119 | .end = OMAP_GPIO_IRQ(8), | 119 | .end = OMAP_GPIO_IRQ(8), |
120 | .flags = IORESOURCE_IRQ, | 120 | .flags = IORESOURCE_IRQ | IORESOURCE_IRQ_HIGHEDGE, |
121 | }, | 121 | }, |
122 | }; | 122 | }; |
123 | 123 | ||
diff --git a/arch/arm/mach-omap2/board-2430sdp.c b/arch/arm/mach-omap2/board-2430sdp.c index 7e76fbf19b5d..64235dee5614 100644 --- a/arch/arm/mach-omap2/board-2430sdp.c +++ b/arch/arm/mach-omap2/board-2430sdp.c | |||
@@ -104,7 +104,7 @@ static struct resource sdp2430_smc91x_resources[] = { | |||
104 | [1] = { | 104 | [1] = { |
105 | .start = OMAP_GPIO_IRQ(OMAP24XX_ETHR_GPIO_IRQ), | 105 | .start = OMAP_GPIO_IRQ(OMAP24XX_ETHR_GPIO_IRQ), |
106 | .end = OMAP_GPIO_IRQ(OMAP24XX_ETHR_GPIO_IRQ), | 106 | .end = OMAP_GPIO_IRQ(OMAP24XX_ETHR_GPIO_IRQ), |
107 | .flags = IORESOURCE_IRQ, | 107 | .flags = IORESOURCE_IRQ | IORESOURCE_IRQ_HIGHEDGE, |
108 | }, | 108 | }, |
109 | }; | 109 | }; |
110 | 110 | ||
diff --git a/arch/arm/mach-omap2/board-apollon.c b/arch/arm/mach-omap2/board-apollon.c index 3bb49c17c858..401a53c1ca6e 100644 --- a/arch/arm/mach-omap2/board-apollon.c +++ b/arch/arm/mach-omap2/board-apollon.c | |||
@@ -127,7 +127,7 @@ static struct resource apollon_smc91x_resources[] = { | |||
127 | [1] = { | 127 | [1] = { |
128 | .start = OMAP_GPIO_IRQ(APOLLON_ETHR_GPIO_IRQ), | 128 | .start = OMAP_GPIO_IRQ(APOLLON_ETHR_GPIO_IRQ), |
129 | .end = OMAP_GPIO_IRQ(APOLLON_ETHR_GPIO_IRQ), | 129 | .end = OMAP_GPIO_IRQ(APOLLON_ETHR_GPIO_IRQ), |
130 | .flags = IORESOURCE_IRQ, | 130 | .flags = IORESOURCE_IRQ | IORESOURCE_IRQ_HIGHEDGE, |
131 | }, | 131 | }, |
132 | }; | 132 | }; |
133 | 133 | ||
diff --git a/arch/arm/mach-pxa/idp.c b/arch/arm/mach-pxa/idp.c index 465108da2851..0a9434432c55 100644 --- a/arch/arm/mach-pxa/idp.c +++ b/arch/arm/mach-pxa/idp.c | |||
@@ -54,7 +54,7 @@ static struct resource smc91x_resources[] = { | |||
54 | [1] = { | 54 | [1] = { |
55 | .start = IRQ_GPIO(4), | 55 | .start = IRQ_GPIO(4), |
56 | .end = IRQ_GPIO(4), | 56 | .end = IRQ_GPIO(4), |
57 | .flags = IORESOURCE_IRQ, | 57 | .flags = IORESOURCE_IRQ | IORESOURCE_IRQ_HIGHEDGE, |
58 | } | 58 | } |
59 | }; | 59 | }; |
60 | 60 | ||
diff --git a/arch/arm/mach-pxa/littleton.c b/arch/arm/mach-pxa/littleton.c index e408a3a89bba..0a4b54c21314 100644 --- a/arch/arm/mach-pxa/littleton.c +++ b/arch/arm/mach-pxa/littleton.c | |||
@@ -87,7 +87,7 @@ static struct resource smc91x_resources[] = { | |||
87 | [1] = { | 87 | [1] = { |
88 | .start = IRQ_GPIO(mfp_to_gpio(MFP_PIN_GPIO90)), | 88 | .start = IRQ_GPIO(mfp_to_gpio(MFP_PIN_GPIO90)), |
89 | .end = IRQ_GPIO(mfp_to_gpio(MFP_PIN_GPIO90)), | 89 | .end = IRQ_GPIO(mfp_to_gpio(MFP_PIN_GPIO90)), |
90 | .flags = IORESOURCE_IRQ, | 90 | .flags = IORESOURCE_IRQ | IRQF_TRIGGER_FALLING, |
91 | } | 91 | } |
92 | }; | 92 | }; |
93 | 93 | ||
diff --git a/arch/arm/mach-pxa/lubbock.c b/arch/arm/mach-pxa/lubbock.c index a75594bf68b5..e7ae4bb3e361 100644 --- a/arch/arm/mach-pxa/lubbock.c +++ b/arch/arm/mach-pxa/lubbock.c | |||
@@ -196,7 +196,7 @@ static struct resource smc91x_resources[] = { | |||
196 | [1] = { | 196 | [1] = { |
197 | .start = LUBBOCK_ETH_IRQ, | 197 | .start = LUBBOCK_ETH_IRQ, |
198 | .end = LUBBOCK_ETH_IRQ, | 198 | .end = LUBBOCK_ETH_IRQ, |
199 | .flags = IORESOURCE_IRQ, | 199 | .flags = IORESOURCE_IRQ | IORESOURCE_IRQ_HIGHEDGE, |
200 | }, | 200 | }, |
201 | [2] = { | 201 | [2] = { |
202 | .name = "smc91x-attrib", | 202 | .name = "smc91x-attrib", |
diff --git a/arch/arm/mach-pxa/mainstone.c b/arch/arm/mach-pxa/mainstone.c index 06e13608a2c9..ac78dbd6a634 100644 --- a/arch/arm/mach-pxa/mainstone.c +++ b/arch/arm/mach-pxa/mainstone.c | |||
@@ -156,7 +156,7 @@ static struct resource smc91x_resources[] = { | |||
156 | [1] = { | 156 | [1] = { |
157 | .start = MAINSTONE_IRQ(3), | 157 | .start = MAINSTONE_IRQ(3), |
158 | .end = MAINSTONE_IRQ(3), | 158 | .end = MAINSTONE_IRQ(3), |
159 | .flags = IORESOURCE_IRQ, | 159 | .flags = IORESOURCE_IRQ | IORESOURCE_IRQ_HIGHEDGE, |
160 | } | 160 | } |
161 | }; | 161 | }; |
162 | 162 | ||
diff --git a/arch/arm/mach-pxa/zylonite.c b/arch/arm/mach-pxa/zylonite.c index b49c69d024c7..7731d50dd86c 100644 --- a/arch/arm/mach-pxa/zylonite.c +++ b/arch/arm/mach-pxa/zylonite.c | |||
@@ -47,7 +47,7 @@ static struct resource smc91x_resources[] = { | |||
47 | [1] = { | 47 | [1] = { |
48 | .start = -1, /* for run-time assignment */ | 48 | .start = -1, /* for run-time assignment */ |
49 | .end = -1, | 49 | .end = -1, |
50 | .flags = IORESOURCE_IRQ, | 50 | .flags = IORESOURCE_IRQ | IORESOURCE_IRQ_HIGHEDGE, |
51 | } | 51 | } |
52 | }; | 52 | }; |
53 | 53 | ||
diff --git a/arch/arm/plat-omap/debug-devices.c b/arch/arm/plat-omap/debug-devices.c index 83a5f8b91857..f455233af082 100644 --- a/arch/arm/plat-omap/debug-devices.c +++ b/arch/arm/plat-omap/debug-devices.c | |||
@@ -29,7 +29,7 @@ static struct resource smc91x_resources[] = { | |||
29 | .flags = IORESOURCE_MEM, | 29 | .flags = IORESOURCE_MEM, |
30 | }, | 30 | }, |
31 | [1] = { | 31 | [1] = { |
32 | .flags = IORESOURCE_IRQ, | 32 | .flags = IORESOURCE_IRQ | IORESOURCE_IRQ_LOWEDGE, |
33 | }, | 33 | }, |
34 | }; | 34 | }; |
35 | 35 | ||
diff --git a/drivers/net/smc91x.c b/drivers/net/smc91x.c index 7da7589d45dd..4020e9e955b3 100644 --- a/drivers/net/smc91x.c +++ b/drivers/net/smc91x.c | |||
@@ -1775,7 +1775,8 @@ static int __init smc_findirq(void __iomem *ioaddr) | |||
1775 | * o actually GRAB the irq. | 1775 | * o actually GRAB the irq. |
1776 | * o GRAB the region | 1776 | * o GRAB the region |
1777 | */ | 1777 | */ |
1778 | static int __init smc_probe(struct net_device *dev, void __iomem *ioaddr) | 1778 | static int __init smc_probe(struct net_device *dev, void __iomem *ioaddr, |
1779 | unsigned long irq_flags) | ||
1779 | { | 1780 | { |
1780 | struct smc_local *lp = netdev_priv(dev); | 1781 | struct smc_local *lp = netdev_priv(dev); |
1781 | static int version_printed = 0; | 1782 | static int version_printed = 0; |
@@ -1941,7 +1942,7 @@ static int __init smc_probe(struct net_device *dev, void __iomem *ioaddr) | |||
1941 | } | 1942 | } |
1942 | 1943 | ||
1943 | /* Grab the IRQ */ | 1944 | /* Grab the IRQ */ |
1944 | retval = request_irq(dev->irq, &smc_interrupt, SMC_IRQ_FLAGS, dev->name, dev); | 1945 | retval = request_irq(dev->irq, &smc_interrupt, irq_flags, dev->name, dev); |
1945 | if (retval) | 1946 | if (retval) |
1946 | goto err_out; | 1947 | goto err_out; |
1947 | 1948 | ||
@@ -2123,8 +2124,9 @@ static void smc_release_datacs(struct platform_device *pdev, struct net_device * | |||
2123 | static int smc_drv_probe(struct platform_device *pdev) | 2124 | static int smc_drv_probe(struct platform_device *pdev) |
2124 | { | 2125 | { |
2125 | struct net_device *ndev; | 2126 | struct net_device *ndev; |
2126 | struct resource *res; | 2127 | struct resource *res, *ires; |
2127 | unsigned int __iomem *addr; | 2128 | unsigned int __iomem *addr; |
2129 | unsigned long irq_flags = SMC_IRQ_FLAGS; | ||
2128 | int ret; | 2130 | int ret; |
2129 | 2131 | ||
2130 | res = platform_get_resource_byname(pdev, IORESOURCE_MEM, "smc91x-regs"); | 2132 | res = platform_get_resource_byname(pdev, IORESOURCE_MEM, "smc91x-regs"); |
@@ -2150,12 +2152,17 @@ static int smc_drv_probe(struct platform_device *pdev) | |||
2150 | SET_NETDEV_DEV(ndev, &pdev->dev); | 2152 | SET_NETDEV_DEV(ndev, &pdev->dev); |
2151 | 2153 | ||
2152 | ndev->dma = (unsigned char)-1; | 2154 | ndev->dma = (unsigned char)-1; |
2153 | ndev->irq = platform_get_irq(pdev, 0); | 2155 | |
2154 | if (ndev->irq < 0) { | 2156 | ires = platform_get_resource(pdev, IORESOURCE_IRQ, 0); |
2157 | if (!ires) { | ||
2155 | ret = -ENODEV; | 2158 | ret = -ENODEV; |
2156 | goto out_free_netdev; | 2159 | goto out_free_netdev; |
2157 | } | 2160 | } |
2158 | 2161 | ||
2162 | ndev->irq = ires->start; | ||
2163 | if (SMC_IRQ_FLAGS == -1) | ||
2164 | irq_flags = ires->flags & IRQF_TRIGGER_MASK; | ||
2165 | |||
2159 | ret = smc_request_attrib(pdev); | 2166 | ret = smc_request_attrib(pdev); |
2160 | if (ret) | 2167 | if (ret) |
2161 | goto out_free_netdev; | 2168 | goto out_free_netdev; |
@@ -2181,7 +2188,7 @@ static int smc_drv_probe(struct platform_device *pdev) | |||
2181 | #endif | 2188 | #endif |
2182 | 2189 | ||
2183 | platform_set_drvdata(pdev, ndev); | 2190 | platform_set_drvdata(pdev, ndev); |
2184 | ret = smc_probe(ndev, addr); | 2191 | ret = smc_probe(ndev, addr, irq_flags); |
2185 | if (ret != 0) | 2192 | if (ret != 0) |
2186 | goto out_iounmap; | 2193 | goto out_iounmap; |
2187 | 2194 | ||
diff --git a/drivers/net/smc91x.h b/drivers/net/smc91x.h index 07b7f7120e37..1d97eaeb02bd 100644 --- a/drivers/net/smc91x.h +++ b/drivers/net/smc91x.h | |||
@@ -54,6 +54,7 @@ | |||
54 | #define SMC_outw(v, a, r) writew(v, (a) + (r)) | 54 | #define SMC_outw(v, a, r) writew(v, (a) + (r)) |
55 | #define SMC_insw(a, r, p, l) readsw((a) + (r), p, l) | 55 | #define SMC_insw(a, r, p, l) readsw((a) + (r), p, l) |
56 | #define SMC_outsw(a, r, p, l) writesw((a) + (r), p, l) | 56 | #define SMC_outsw(a, r, p, l) writesw((a) + (r), p, l) |
57 | #define SMC_IRQ_FLAGS (-1) /* from resource */ | ||
57 | 58 | ||
58 | #elif defined(CONFIG_BLACKFIN) | 59 | #elif defined(CONFIG_BLACKFIN) |
59 | 60 | ||
@@ -158,7 +159,7 @@ | |||
158 | #define SMC_outw(v, a, r) writew(v, (a) + (r)) | 159 | #define SMC_outw(v, a, r) writew(v, (a) + (r)) |
159 | #define SMC_outsw(a, r, p, l) writesw((a) + (r), p, l) | 160 | #define SMC_outsw(a, r, p, l) writesw((a) + (r), p, l) |
160 | 161 | ||
161 | #define SMC_IRQ_FLAGS (0) | 162 | #define SMC_IRQ_FLAGS (-1) |
162 | 163 | ||
163 | #elif defined(CONFIG_SA1100_ASSABET) | 164 | #elif defined(CONFIG_SA1100_ASSABET) |
164 | 165 | ||
@@ -177,6 +178,7 @@ | |||
177 | #define SMC_outb(v, a, r) writeb(v, (a) + (r)) | 178 | #define SMC_outb(v, a, r) writeb(v, (a) + (r)) |
178 | #define SMC_insb(a, r, p, l) readsb((a) + (r), p, (l)) | 179 | #define SMC_insb(a, r, p, l) readsb((a) + (r), p, (l)) |
179 | #define SMC_outsb(a, r, p, l) writesb((a) + (r), p, (l)) | 180 | #define SMC_outsb(a, r, p, l) writesb((a) + (r), p, (l)) |
181 | #define SMC_IRQ_FLAGS (-1) /* from resource */ | ||
180 | 182 | ||
181 | #elif defined(CONFIG_MACH_LOGICPD_PXA270) | 183 | #elif defined(CONFIG_MACH_LOGICPD_PXA270) |
182 | 184 | ||
@@ -210,6 +212,7 @@ | |||
210 | #define SMC_outl(v, a, r) writel(v, (a) + (r)) | 212 | #define SMC_outl(v, a, r) writel(v, (a) + (r)) |
211 | #define SMC_insl(a, r, p, l) readsl((a) + (r), p, l) | 213 | #define SMC_insl(a, r, p, l) readsl((a) + (r), p, l) |
212 | #define SMC_outsl(a, r, p, l) writesl((a) + (r), p, l) | 214 | #define SMC_outsl(a, r, p, l) writesl((a) + (r), p, l) |
215 | #define SMC_IRQ_FLAGS (-1) /* from resource */ | ||
213 | 216 | ||
214 | /* We actually can't write halfwords properly if not word aligned */ | 217 | /* We actually can't write halfwords properly if not word aligned */ |
215 | static inline void | 218 | static inline void |
@@ -238,6 +241,7 @@ SMC_outw(u16 val, void __iomem *ioaddr, int reg) | |||
238 | #define SMC_outsw(a, r, p, l) outsw((a) + (r), p, l) | 241 | #define SMC_outsw(a, r, p, l) outsw((a) + (r), p, l) |
239 | #define SMC_outb(v, a, r) writeb(v, (a) + (r)) | 242 | #define SMC_outb(v, a, r) writeb(v, (a) + (r)) |
240 | #define SMC_outw(v, a, r) writew(v, (a) + (r)) | 243 | #define SMC_outw(v, a, r) writew(v, (a) + (r)) |
244 | #define SMC_IRQ_FLAGS (-1) /* from resource */ | ||
241 | 245 | ||
242 | #elif defined(CONFIG_ARCH_OMAP) | 246 | #elif defined(CONFIG_ARCH_OMAP) |
243 | 247 | ||
@@ -252,17 +256,7 @@ SMC_outw(u16 val, void __iomem *ioaddr, int reg) | |||
252 | #define SMC_outw(v, a, r) writew(v, (a) + (r)) | 256 | #define SMC_outw(v, a, r) writew(v, (a) + (r)) |
253 | #define SMC_insw(a, r, p, l) readsw((a) + (r), p, l) | 257 | #define SMC_insw(a, r, p, l) readsw((a) + (r), p, l) |
254 | #define SMC_outsw(a, r, p, l) writesw((a) + (r), p, l) | 258 | #define SMC_outsw(a, r, p, l) writesw((a) + (r), p, l) |
255 | 259 | #define SMC_IRQ_FLAGS (-1) /* from resource */ | |
256 | #include <asm/mach-types.h> | ||
257 | #include <asm/arch/cpu.h> | ||
258 | |||
259 | #define SMC_IRQ_FLAGS (( \ | ||
260 | machine_is_omap_h2() \ | ||
261 | || machine_is_omap_h3() \ | ||
262 | || machine_is_omap_h4() \ | ||
263 | || (machine_is_omap_innovator() && !cpu_is_omap1510()) \ | ||
264 | ) ? IRQF_TRIGGER_FALLING : IRQF_TRIGGER_RISING) | ||
265 | |||
266 | 260 | ||
267 | #elif defined(CONFIG_SH_SH4202_MICRODEV) | 261 | #elif defined(CONFIG_SH_SH4202_MICRODEV) |
268 | 262 | ||
@@ -453,8 +447,7 @@ static inline void LPD7_SMC_outsw (unsigned char* a, int r, | |||
453 | #define SMC_outl(v, a, r) writel(v, (a) + (r)) | 447 | #define SMC_outl(v, a, r) writel(v, (a) + (r)) |
454 | #define SMC_insl(a, r, p, l) readsl((a) + (r), p, l) | 448 | #define SMC_insl(a, r, p, l) readsl((a) + (r), p, l) |
455 | #define SMC_outsl(a, r, p, l) writesl((a) + (r), p, l) | 449 | #define SMC_outsl(a, r, p, l) writesl((a) + (r), p, l) |
456 | 450 | #define SMC_IRQ_FLAGS (-1) /* from resource */ | |
457 | #define SMC_IRQ_FLAGS (0) | ||
458 | 451 | ||
459 | #else | 452 | #else |
460 | 453 | ||