|
@@ -381,14 +381,26 @@ static void drm_events_release(struct drm_file *file_priv)
|
|
*/
|
|
*/
|
|
static void drm_legacy_dev_reinit(struct drm_device *dev)
|
|
static void drm_legacy_dev_reinit(struct drm_device *dev)
|
|
{
|
|
{
|
|
- if (drm_core_check_feature(dev, DRIVER_MODESET))
|
|
|
|
- return;
|
|
|
|
|
|
+ if (dev->irq_enabled)
|
|
|
|
+ drm_irq_uninstall(dev);
|
|
|
|
+
|
|
|
|
+ mutex_lock(&dev->struct_mutex);
|
|
|
|
+
|
|
|
|
+ drm_legacy_agp_clear(dev);
|
|
|
|
+
|
|
|
|
+ drm_legacy_sg_cleanup(dev);
|
|
|
|
+ drm_legacy_vma_flush(dev);
|
|
|
|
+ drm_legacy_dma_takedown(dev);
|
|
|
|
+
|
|
|
|
+ mutex_unlock(&dev->struct_mutex);
|
|
|
|
|
|
dev->sigdata.lock = NULL;
|
|
dev->sigdata.lock = NULL;
|
|
|
|
|
|
dev->context_flag = 0;
|
|
dev->context_flag = 0;
|
|
dev->last_context = 0;
|
|
dev->last_context = 0;
|
|
dev->if_version = 0;
|
|
dev->if_version = 0;
|
|
|
|
+
|
|
|
|
+ DRM_DEBUG("lastclose completed\n");
|
|
}
|
|
}
|
|
|
|
|
|
/*
|
|
/*
|
|
@@ -400,7 +412,7 @@ static void drm_legacy_dev_reinit(struct drm_device *dev)
|
|
*
|
|
*
|
|
* \sa drm_device
|
|
* \sa drm_device
|
|
*/
|
|
*/
|
|
-int drm_lastclose(struct drm_device * dev)
|
|
|
|
|
|
+void drm_lastclose(struct drm_device * dev)
|
|
{
|
|
{
|
|
DRM_DEBUG("\n");
|
|
DRM_DEBUG("\n");
|
|
|
|
|
|
@@ -408,23 +420,8 @@ int drm_lastclose(struct drm_device * dev)
|
|
dev->driver->lastclose(dev);
|
|
dev->driver->lastclose(dev);
|
|
DRM_DEBUG("driver lastclose completed\n");
|
|
DRM_DEBUG("driver lastclose completed\n");
|
|
|
|
|
|
- if (dev->irq_enabled && !drm_core_check_feature(dev, DRIVER_MODESET))
|
|
|
|
- drm_irq_uninstall(dev);
|
|
|
|
-
|
|
|
|
- mutex_lock(&dev->struct_mutex);
|
|
|
|
-
|
|
|
|
- drm_legacy_agp_clear(dev);
|
|
|
|
-
|
|
|
|
- drm_legacy_sg_cleanup(dev);
|
|
|
|
- drm_legacy_vma_flush(dev);
|
|
|
|
- drm_legacy_dma_takedown(dev);
|
|
|
|
-
|
|
|
|
- mutex_unlock(&dev->struct_mutex);
|
|
|
|
-
|
|
|
|
- drm_legacy_dev_reinit(dev);
|
|
|
|
-
|
|
|
|
- DRM_DEBUG("lastclose completed\n");
|
|
|
|
- return 0;
|
|
|
|
|
|
+ if (!drm_core_check_feature(dev, DRIVER_MODESET))
|
|
|
|
+ drm_legacy_dev_reinit(dev);
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
/**
|
|
@@ -445,7 +442,6 @@ int drm_release(struct inode *inode, struct file *filp)
|
|
struct drm_file *file_priv = filp->private_data;
|
|
struct drm_file *file_priv = filp->private_data;
|
|
struct drm_minor *minor = file_priv->minor;
|
|
struct drm_minor *minor = file_priv->minor;
|
|
struct drm_device *dev = minor->dev;
|
|
struct drm_device *dev = minor->dev;
|
|
- int retcode = 0;
|
|
|
|
|
|
|
|
mutex_lock(&drm_global_mutex);
|
|
mutex_lock(&drm_global_mutex);
|
|
|
|
|
|
@@ -538,7 +534,7 @@ int drm_release(struct inode *inode, struct file *filp)
|
|
*/
|
|
*/
|
|
|
|
|
|
if (!--dev->open_count) {
|
|
if (!--dev->open_count) {
|
|
- retcode = drm_lastclose(dev);
|
|
|
|
|
|
+ drm_lastclose(dev);
|
|
if (drm_device_is_unplugged(dev))
|
|
if (drm_device_is_unplugged(dev))
|
|
drm_put_dev(dev);
|
|
drm_put_dev(dev);
|
|
}
|
|
}
|
|
@@ -546,7 +542,7 @@ int drm_release(struct inode *inode, struct file *filp)
|
|
|
|
|
|
drm_minor_release(minor);
|
|
drm_minor_release(minor);
|
|
|
|
|
|
- return retcode;
|
|
|
|
|
|
+ return 0;
|
|
}
|
|
}
|
|
EXPORT_SYMBOL(drm_release);
|
|
EXPORT_SYMBOL(drm_release);
|
|
|
|
|