diff options
author | rnoland <rnoland@FreeBSD.org> | 2009-02-28 02:37:55 +0000 |
---|---|---|
committer | rnoland <rnoland@FreeBSD.org> | 2009-02-28 02:37:55 +0000 |
commit | ddd5c68e843d2a001ea8e2dea8a1df60e8b9c96f (patch) | |
tree | e6ddfaf5a2ddb8d00739616a566b685c59b9fa61 /sys/dev/drm/drm_drv.c | |
parent | e9bc5839af5067790590a780d1d396234ee550e9 (diff) | |
download | FreeBSD-src-ddd5c68e843d2a001ea8e2dea8a1df60e8b9c96f.zip FreeBSD-src-ddd5c68e843d2a001ea8e2dea8a1df60e8b9c96f.tar.gz |
Initialize the vblank structures at load time. Previously we did this
at irq install/uninstall time, but when we vt switch, we uninstall the
irq handler. When the irq handler is reinstalled, the modeset ioctl
happens first. The modeset ioctl is supposed to tell us that we can
disable vblank interrupts if there are no active consumers. This will
fail after a vt switch until another modeset ioctl is called via dpms
or xrandr. Leading to cases where either interrupts are on and can't
be disabled, or worse, no interrupts at all.
MFC after: 2 weeks
Diffstat (limited to 'sys/dev/drm/drm_drv.c')
-rw-r--r-- | sys/dev/drm/drm_drv.c | 2 |
1 files changed, 2 insertions, 0 deletions
diff --git a/sys/dev/drm/drm_drv.c b/sys/dev/drm/drm_drv.c index 0b22491..a753f91 100644 --- a/sys/dev/drm/drm_drv.c +++ b/sys/dev/drm/drm_drv.c @@ -523,6 +523,8 @@ static void drm_unload(struct drm_device *dev) DRM_DEBUG("mtrr_del = %d", retcode); } + drm_vblank_cleanup(dev); + DRM_LOCK(); drm_lastclose(dev); DRM_UNLOCK(); |