Lines Matching refs:mo
67 struct i915_mmu_object *mo = container_of(work, typeof(*mo), work); in cancel_userptr() local
68 struct drm_i915_gem_object *obj = mo->obj; in cancel_userptr()
97 static void add_object(struct i915_mmu_object *mo) in add_object() argument
99 if (mo->attached) in add_object()
102 interval_tree_insert(&mo->it, &mo->mn->objects); in add_object()
103 mo->attached = true; in add_object()
106 static void del_object(struct i915_mmu_object *mo) in del_object() argument
108 if (!mo->attached) in del_object()
111 interval_tree_remove(&mo->it, &mo->mn->objects); in del_object()
112 mo->attached = false; in del_object()
123 struct i915_mmu_object *mo; in i915_gem_userptr_mn_invalidate_range_start() local
149 mo = container_of(it, struct i915_mmu_object, it); in i915_gem_userptr_mn_invalidate_range_start()
150 if (kref_get_unless_zero(&mo->obj->base.refcount)) in i915_gem_userptr_mn_invalidate_range_start()
151 queue_work(mn->wq, &mo->work); in i915_gem_userptr_mn_invalidate_range_start()
153 list_add(&mo->link, &cancelled); in i915_gem_userptr_mn_invalidate_range_start()
156 list_for_each_entry(mo, &cancelled, link) in i915_gem_userptr_mn_invalidate_range_start()
157 del_object(mo); in i915_gem_userptr_mn_invalidate_range_start()
196 struct i915_mmu_object *mo; in i915_gem_userptr_release__mmu_notifier() local
198 mo = obj->userptr.mmu_object; in i915_gem_userptr_release__mmu_notifier()
199 if (mo == NULL) in i915_gem_userptr_release__mmu_notifier()
202 spin_lock(&mo->mn->lock); in i915_gem_userptr_release__mmu_notifier()
203 del_object(mo); in i915_gem_userptr_release__mmu_notifier()
204 spin_unlock(&mo->mn->lock); in i915_gem_userptr_release__mmu_notifier()
205 kfree(mo); in i915_gem_userptr_release__mmu_notifier()
256 struct i915_mmu_object *mo; in i915_gem_userptr_init__mmu_notifier() local
268 mo = kzalloc(sizeof(*mo), GFP_KERNEL); in i915_gem_userptr_init__mmu_notifier()
269 if (mo == NULL) in i915_gem_userptr_init__mmu_notifier()
272 mo->mn = mn; in i915_gem_userptr_init__mmu_notifier()
273 mo->obj = obj; in i915_gem_userptr_init__mmu_notifier()
274 mo->it.start = obj->userptr.ptr; in i915_gem_userptr_init__mmu_notifier()
275 mo->it.last = obj->userptr.ptr + obj->base.size - 1; in i915_gem_userptr_init__mmu_notifier()
276 INIT_WORK(&mo->work, cancel_userptr); in i915_gem_userptr_init__mmu_notifier()
278 obj->userptr.mmu_object = mo; in i915_gem_userptr_init__mmu_notifier()