diff options
author | Owain Ainsworth <oga@cvs.openbsd.org> | 2008-11-06 14:25:22 +0000 |
---|---|---|
committer | Owain Ainsworth <oga@cvs.openbsd.org> | 2008-11-06 14:25:22 +0000 |
commit | abf5f1d4b7d40778eb2602b330302040dc5779c0 (patch) | |
tree | b18a402fbc01a15743d1e7aa124ca971e6eb743d | |
parent | fa394b24c2e8f15ecab7e5c278cb1dfa0169dc47 (diff) |
Remove the drm_locked_tasklet interface. The only consumer that used it
was the i915 vblank swap ioctl, which just went kaput.
-rw-r--r-- | sys/dev/pci/drm/drm_drv.c | 1 | ||||
-rw-r--r-- | sys/dev/pci/drm/drm_irq.c | 44 | ||||
-rw-r--r-- | sys/dev/pci/drm/drm_lock.c | 8 |
3 files changed, 0 insertions, 53 deletions
diff --git a/sys/dev/pci/drm/drm_drv.c b/sys/dev/pci/drm/drm_drv.c index ce21f383d5a..367c317f7f7 100644 --- a/sys/dev/pci/drm/drm_drv.c +++ b/sys/dev/pci/drm/drm_drv.c @@ -203,7 +203,6 @@ drm_attach(struct device *parent, struct device *kdev, rw_init(&dev->dev_lock, "drmdevlk"); mtx_init(&dev->drw_lock, IPL_NONE); - mtx_init(&dev->tsk_lock, IPL_BIO); mtx_init(&dev->lock.spinlock, IPL_NONE); id_entry = drm_find_description(PCI_VENDOR(pa->pa_id), diff --git a/sys/dev/pci/drm/drm_irq.c b/sys/dev/pci/drm/drm_irq.c index 2e749dc58d6..c2afd1a3972 100644 --- a/sys/dev/pci/drm/drm_irq.c +++ b/sys/dev/pci/drm/drm_irq.c @@ -36,7 +36,6 @@ #include "drm.h" irqreturn_t drm_irq_handler_wrap(DRM_IRQ_ARGS); -void drm_locked_task(void *, void *); void drm_update_vblank_count(struct drm_device *, int); void vblank_disable(void *); @@ -404,46 +403,3 @@ drm_handle_vblank(struct drm_device *dev, int crtc) atomic_inc(&dev->vblank[crtc].vbl_count); wakeup(&dev->vblank[crtc]); } - -void -drm_locked_task(void *context, void *pending) -{ - struct drm_device *dev = context; - void (*func)(struct drm_device *); - - DRM_SPINLOCK(&dev->tsk_lock); - mtx_enter(&dev->lock.spinlock); - func = dev->locked_task_call; - if (func == NULL || - drm_lock_take(&dev->lock, DRM_KERNEL_CONTEXT) == 0) { - mtx_leave(&dev->lock.spinlock); - DRM_SPINUNLOCK(&dev->tsk_lock); - return; - } - - dev->lock.file_priv = NULL; /* kernel owned */ - dev->lock.lock_time = jiffies; - mtx_leave(&dev->lock.spinlock); - dev->locked_task_call = NULL; - DRM_SPINUNLOCK(&dev->tsk_lock); - - (*func)(dev); - - drm_lock_free(&dev->lock, DRM_KERNEL_CONTEXT); -} - -void -drm_locked_tasklet(struct drm_device *dev, void (*tasklet)(struct drm_device *)) -{ - DRM_SPINLOCK(&dev->tsk_lock); - if (dev->locked_task_call != NULL) { - DRM_SPINUNLOCK(&dev->tsk_lock); - return; - } - - dev->locked_task_call = tasklet; - DRM_SPINUNLOCK(&dev->tsk_lock); - - if (workq_add_task(NULL, 0, drm_locked_task, dev, NULL) == ENOMEM) - DRM_ERROR("error adding task to workq\n"); -} diff --git a/sys/dev/pci/drm/drm_lock.c b/sys/dev/pci/drm/drm_lock.c index 17552372f37..d949de2ef38 100644 --- a/sys/dev/pci/drm/drm_lock.c +++ b/sys/dev/pci/drm/drm_lock.c @@ -154,7 +154,6 @@ int drm_unlock(struct drm_device *dev, void *data, struct drm_file *file_priv) { struct drm_lock *lock = data; - void (*func)(struct drm_device *); if (lock->context == DRM_KERNEL_CONTEXT) { DRM_ERROR("Process %d using kernel context %d\n", @@ -168,13 +167,6 @@ drm_unlock(struct drm_device *dev, void *data, struct drm_file *file_priv) _DRM_LOCKING_CONTEXT(dev->lock.hw_lock->lock) != lock->context) return EINVAL; - mtx_enter(&dev->tsk_lock); - func = dev->locked_task_call; - dev->locked_task_call = NULL; - mtx_leave(&dev->tsk_lock); - if (func != NULL) - (*func)(dev); - if (drm_lock_free(&dev->lock, lock->context)) { DRM_ERROR("\n"); } |