mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-10-31 16:54:21 +00:00 
			
		
		
		
	drm/vbox: Convert to Linux IRQ interfaces
Drop the DRM IRQ midlayer in favor of Linux IRQ interfaces. DRM's IRQ helpers are mostly useful for UMS drivers. Modern KMS drivers don't benefit from using it. Signed-off-by: Thomas Zimmermann <tzimmermann@suse.de> Acked-by: Sam Ravnborg <sam@ravnborg.org> Link: https://patchwork.freedesktop.org/patch/msgid/20210706075011.9009-1-tzimmermann@suse.de
This commit is contained in:
		
							parent
							
								
									48bd858084
								
							
						
					
					
						commit
						db20ea679d
					
				
					 3 changed files with 11 additions and 7 deletions
				
			
		|  | @ -184,7 +184,6 @@ static const struct drm_driver driver = { | |||
| 	.lastclose = drm_fb_helper_lastclose, | ||||
| 
 | ||||
| 	.fops = &vbox_fops, | ||||
| 	.irq_handler = vbox_irq_handler, | ||||
| 	.name = DRIVER_NAME, | ||||
| 	.desc = DRIVER_DESC, | ||||
| 	.date = DRIVER_DATE, | ||||
|  |  | |||
|  | @ -145,7 +145,6 @@ void vbox_mm_fini(struct vbox_private *vbox); | |||
| int vbox_irq_init(struct vbox_private *vbox); | ||||
| void vbox_irq_fini(struct vbox_private *vbox); | ||||
| void vbox_report_hotplug(struct vbox_private *vbox); | ||||
| irqreturn_t vbox_irq_handler(int irq, void *arg); | ||||
| 
 | ||||
| /* vbox_hgsmi.c */ | ||||
| void *hgsmi_buffer_alloc(struct gen_pool *guest_pool, size_t size, | ||||
|  |  | |||
|  | @ -10,7 +10,8 @@ | |||
|  */ | ||||
| 
 | ||||
| #include <linux/pci.h> | ||||
| #include <drm/drm_irq.h> | ||||
| 
 | ||||
| #include <drm/drm_drv.h> | ||||
| #include <drm/drm_probe_helper.h> | ||||
| 
 | ||||
| #include "vbox_drv.h" | ||||
|  | @ -31,7 +32,7 @@ void vbox_report_hotplug(struct vbox_private *vbox) | |||
| 	schedule_work(&vbox->hotplug_work); | ||||
| } | ||||
| 
 | ||||
| irqreturn_t vbox_irq_handler(int irq, void *arg) | ||||
| static irqreturn_t vbox_irq_handler(int irq, void *arg) | ||||
| { | ||||
| 	struct drm_device *dev = (struct drm_device *)arg; | ||||
| 	struct vbox_private *vbox = to_vbox_dev(dev); | ||||
|  | @ -170,16 +171,21 @@ static void vbox_hotplug_worker(struct work_struct *work) | |||
| 
 | ||||
| int vbox_irq_init(struct vbox_private *vbox) | ||||
| { | ||||
| 	struct pci_dev *pdev = to_pci_dev(vbox->ddev.dev); | ||||
| 	struct drm_device *dev = &vbox->ddev; | ||||
| 	struct pci_dev *pdev = to_pci_dev(dev->dev); | ||||
| 
 | ||||
| 	INIT_WORK(&vbox->hotplug_work, vbox_hotplug_worker); | ||||
| 	vbox_update_mode_hints(vbox); | ||||
| 
 | ||||
| 	return drm_irq_install(&vbox->ddev, pdev->irq); | ||||
| 	/* PCI devices require shared interrupts. */ | ||||
| 	return request_irq(pdev->irq, vbox_irq_handler, IRQF_SHARED, dev->driver->name, dev); | ||||
| } | ||||
| 
 | ||||
| void vbox_irq_fini(struct vbox_private *vbox) | ||||
| { | ||||
| 	drm_irq_uninstall(&vbox->ddev); | ||||
| 	struct drm_device *dev = &vbox->ddev; | ||||
| 	struct pci_dev *pdev = to_pci_dev(dev->dev); | ||||
| 
 | ||||
| 	free_irq(pdev->irq, dev); | ||||
| 	flush_work(&vbox->hotplug_work); | ||||
| } | ||||
|  |  | |||
		Loading…
	
	Add table
		
		Reference in a new issue
	
	 Thomas Zimmermann
						Thomas Zimmermann