|
@@ -1017,11 +1017,15 @@ void msm_gem_free_object(struct drm_gem_object *obj)
|
|
static void free_object(struct msm_gem_object *msm_obj)
|
|
static void free_object(struct msm_gem_object *msm_obj)
|
|
{
|
|
{
|
|
struct drm_gem_object *obj = &msm_obj->base;
|
|
struct drm_gem_object *obj = &msm_obj->base;
|
|
|
|
+ struct drm_device *dev = obj->dev;
|
|
|
|
+ struct msm_drm_private *priv = dev->dev_private;
|
|
|
|
|
|
/* object should not be on active list: */
|
|
/* object should not be on active list: */
|
|
WARN_ON(is_active(msm_obj));
|
|
WARN_ON(is_active(msm_obj));
|
|
|
|
|
|
|
|
+ mutex_lock(&priv->mm_lock);
|
|
list_del(&msm_obj->mm_list);
|
|
list_del(&msm_obj->mm_list);
|
|
|
|
+ mutex_unlock(&priv->mm_lock);
|
|
|
|
|
|
mutex_lock(&msm_obj->lock);
|
|
mutex_lock(&msm_obj->lock);
|
|
|
|
|
|
@@ -1149,14 +1153,9 @@ static int msm_gem_new_impl(struct drm_device *dev,
|
|
msm_obj->in_active_list = false;
|
|
msm_obj->in_active_list = false;
|
|
msm_obj->obj_dirty = false;
|
|
msm_obj->obj_dirty = false;
|
|
|
|
|
|
- if (struct_mutex_locked) {
|
|
|
|
- WARN_ON(!mutex_is_locked(&dev->struct_mutex));
|
|
|
|
- list_add_tail(&msm_obj->mm_list, &priv->inactive_list);
|
|
|
|
- } else {
|
|
|
|
- mutex_lock(&dev->struct_mutex);
|
|
|
|
- list_add_tail(&msm_obj->mm_list, &priv->inactive_list);
|
|
|
|
- mutex_unlock(&dev->struct_mutex);
|
|
|
|
- }
|
|
|
|
|
|
+ mutex_lock(&priv->mm_lock);
|
|
|
|
+ list_add_tail(&msm_obj->mm_list, &priv->inactive_list);
|
|
|
|
+ mutex_unlock(&priv->mm_lock);
|
|
|
|
|
|
*obj = &msm_obj->base;
|
|
*obj = &msm_obj->base;
|
|
|
|
|