|
@@ -1007,11 +1007,15 @@ void msm_gem_describe_objects(struct list_head *list, struct seq_file *m)
|
|
|
void msm_gem_free_object(struct drm_gem_object *obj)
|
|
|
{
|
|
|
struct msm_gem_object *msm_obj = to_msm_bo(obj);
|
|
|
+ struct drm_device *dev = obj->dev;
|
|
|
+ struct msm_drm_private *priv = dev->dev_private;
|
|
|
|
|
|
/* object should not be on active list: */
|
|
|
WARN_ON(is_active(msm_obj));
|
|
|
|
|
|
+ mutex_lock(&priv->mm_lock);
|
|
|
list_del(&msm_obj->mm_list);
|
|
|
+ mutex_unlock(&priv->mm_lock);
|
|
|
|
|
|
mutex_lock(&msm_obj->lock);
|
|
|
|
|
@@ -1118,14 +1122,9 @@ static int msm_gem_new_impl(struct drm_device *dev,
|
|
|
msm_obj->in_active_list = 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;
|
|
|
|