aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDaniel Vetter <daniel.vetter@ffwll.ch>2013-12-16 05:21:15 -0500
committerDaniel Vetter <daniel.vetter@ffwll.ch>2014-04-23 04:32:44 -0400
commit7c1a38e391745cca72627979e5e02924bed5b43d (patch)
tree8eb813777bf5d2ef1d13061ad1c557d55f76a4f8
parent2177a2182f3f375f64d9938dd884895c3872c380 (diff)
drm/irq: track the irq installed in drm_irq_install in dev->irq
To get rid of the dev->bus->get_irq callback we need to pass in the desired irq explicitly into drm_irq_install. To avoid having to do the same for drm_irq_unistall just track it internally. That leaves drivers with less room to botch things up. v2: Add the hunk lost in an earlier patch to this one (Thierry). v3: Fix up the totally fumbled logic in drm_irq_install and use the local variable consistently. Spotted by both Thierry and Laurent. Shame on me for failing to properly test the rebase version of this patch ... Cc: Thierry Reding <thierry.reding@gmail.com> Cc: Laurent Pinchart <laurent.pinchart@ideasonboard.com> Reviewed-by: Thierry Reding <treding@nvidia.com> Signed-off-by: Daniel Vetter <daniel.vetter@ffwll.ch>
-rw-r--r--drivers/gpu/drm/drm_irq.c18
-rw-r--r--include/drm/drmP.h2
2 files changed, 13 insertions, 7 deletions
diff --git a/drivers/gpu/drm/drm_irq.c b/drivers/gpu/drm/drm_irq.c
index 589e865832cd..7cf407bbfed5 100644
--- a/drivers/gpu/drm/drm_irq.c
+++ b/drivers/gpu/drm/drm_irq.c
@@ -249,14 +249,16 @@ static inline int drm_dev_to_irq(struct drm_device *dev)
249 */ 249 */
250int drm_irq_install(struct drm_device *dev) 250int drm_irq_install(struct drm_device *dev)
251{ 251{
252 int ret; 252 int ret, irq;
253 unsigned long sh_flags = 0; 253 unsigned long sh_flags = 0;
254 char *irqname; 254 char *irqname;
255 255
256 irq = drm_dev_to_irq(dev);
257
256 if (!drm_core_check_feature(dev, DRIVER_HAVE_IRQ)) 258 if (!drm_core_check_feature(dev, DRIVER_HAVE_IRQ))
257 return -EINVAL; 259 return -EINVAL;
258 260
259 if (drm_dev_to_irq(dev) == 0) 261 if (irq == 0)
260 return -EINVAL; 262 return -EINVAL;
261 263
262 /* Driver must have been initialized */ 264 /* Driver must have been initialized */
@@ -267,7 +269,7 @@ int drm_irq_install(struct drm_device *dev)
267 return -EBUSY; 269 return -EBUSY;
268 dev->irq_enabled = true; 270 dev->irq_enabled = true;
269 271
270 DRM_DEBUG("irq=%d\n", drm_dev_to_irq(dev)); 272 DRM_DEBUG("irq=%d\n", irq);
271 273
272 /* Before installing handler */ 274 /* Before installing handler */
273 if (dev->driver->irq_preinstall) 275 if (dev->driver->irq_preinstall)
@@ -282,7 +284,7 @@ int drm_irq_install(struct drm_device *dev)
282 else 284 else
283 irqname = dev->driver->name; 285 irqname = dev->driver->name;
284 286
285 ret = request_irq(drm_dev_to_irq(dev), dev->driver->irq_handler, 287 ret = request_irq(irq, dev->driver->irq_handler,
286 sh_flags, irqname, dev); 288 sh_flags, irqname, dev);
287 289
288 if (ret < 0) { 290 if (ret < 0) {
@@ -301,7 +303,9 @@ int drm_irq_install(struct drm_device *dev)
301 dev->irq_enabled = false; 303 dev->irq_enabled = false;
302 if (!drm_core_check_feature(dev, DRIVER_MODESET)) 304 if (!drm_core_check_feature(dev, DRIVER_MODESET))
303 vga_client_register(dev->pdev, NULL, NULL, NULL); 305 vga_client_register(dev->pdev, NULL, NULL, NULL);
304 free_irq(drm_dev_to_irq(dev), dev); 306 free_irq(irq, dev);
307 } else {
308 dev->irq = irq;
305 } 309 }
306 310
307 return ret; 311 return ret;
@@ -344,7 +348,7 @@ int drm_irq_uninstall(struct drm_device *dev)
344 if (!irq_enabled) 348 if (!irq_enabled)
345 return -EINVAL; 349 return -EINVAL;
346 350
347 DRM_DEBUG("irq=%d\n", drm_dev_to_irq(dev)); 351 DRM_DEBUG("irq=%d\n", dev->irq);
348 352
349 if (!drm_core_check_feature(dev, DRIVER_MODESET)) 353 if (!drm_core_check_feature(dev, DRIVER_MODESET))
350 vga_client_register(dev->pdev, NULL, NULL, NULL); 354 vga_client_register(dev->pdev, NULL, NULL, NULL);
@@ -352,7 +356,7 @@ int drm_irq_uninstall(struct drm_device *dev)
352 if (dev->driver->irq_uninstall) 356 if (dev->driver->irq_uninstall)
353 dev->driver->irq_uninstall(dev); 357 dev->driver->irq_uninstall(dev);
354 358
355 free_irq(drm_dev_to_irq(dev), dev); 359 free_irq(dev->irq, dev);
356 360
357 return 0; 361 return 0;
358} 362}
diff --git a/include/drm/drmP.h b/include/drm/drmP.h
index 85682d959c7e..8e8c392d6fa8 100644
--- a/include/drm/drmP.h
+++ b/include/drm/drmP.h
@@ -1107,6 +1107,8 @@ struct drm_device {
1107 /** \name Context support */ 1107 /** \name Context support */
1108 /*@{ */ 1108 /*@{ */
1109 bool irq_enabled; /**< True if irq handler is enabled */ 1109 bool irq_enabled; /**< True if irq handler is enabled */
1110 int irq;
1111
1110 __volatile__ long context_flag; /**< Context swapping flag */ 1112 __volatile__ long context_flag; /**< Context swapping flag */
1111 int last_context; /**< Last current context */ 1113 int last_context; /**< Last current context */
1112 /*@} */ 1114 /*@} */