#include <drm/drm_drv.h>
 #include <drm/drm_gem_framebuffer_helper.h>
 #include <drm/drm_gem_vram_helper.h>
-#include <drm/drm_irq.h>
 #include <drm/drm_managed.h>
 #include <drm/drm_vblank.h>
 
 
 DEFINE_DRM_GEM_FOPS(hibmc_fops);
 
-static irqreturn_t hibmc_drm_interrupt(int irq, void *arg)
+static irqreturn_t hibmc_interrupt(int irq, void *arg)
 {
        struct drm_device *dev = (struct drm_device *)arg;
        struct hibmc_drm_private *priv = to_hibmc_drm_private(dev);
        .dumb_create            = hibmc_dumb_create,
        .dumb_map_offset        = drm_gem_ttm_dumb_map_offset,
        .gem_prime_mmap         = drm_gem_prime_mmap,
-       .irq_handler            = hibmc_drm_interrupt,
 };
 
 static int __maybe_unused hibmc_pm_suspend(struct device *dev)
 
 static int hibmc_unload(struct drm_device *dev)
 {
+       struct hibmc_drm_private *priv = to_hibmc_drm_private(dev);
+       struct pci_dev *pdev = to_pci_dev(dev->dev);
+
        drm_atomic_helper_shutdown(dev);
 
-       drm_irq_uninstall(dev);
+       free_irq(pdev->irq, dev);
 
        pci_disable_msi(to_pci_dev(dev->dev));
 
        if (ret) {
                drm_warn(dev, "enabling MSI failed: %d\n", ret);
        } else {
-               ret = drm_irq_install(dev, pdev->irq);
+               /* PCI devices require shared interrupts. */
+               ret = request_irq(pdev->irq, hibmc_interrupt, IRQF_SHARED,
+                                 dev->driver->name, dev);
                if (ret)
                        drm_warn(dev, "install irq failed: %d\n", ret);
        }