On Mon, 27 Jan 2014, Daniel Vetter <daniel.vetter@xxxxxxxx> wrote: > This is prep work for reworking the object_pin logic. Atm > it still does a (now redundant) lookup of the vma. The next > patch will fix this. > > Split out from Chris vma-bind rework. Reviewed-by: Jani Nikula <jani.nikula@xxxxxxxxx> > Cc: Chris Wilson <chris@xxxxxxxxxxxxxxxxxx> > Cc: Ben Widawsky <benjamin.widawsky@xxxxxxxxx> > Signed-off-by: Daniel Vetter <daniel.vetter@xxxxxxxx> > --- > drivers/gpu/drm/i915/i915_gem.c | 23 +++++++++++------------ > 1 file changed, 11 insertions(+), 12 deletions(-) > > diff --git a/drivers/gpu/drm/i915/i915_gem.c b/drivers/gpu/drm/i915/i915_gem.c > index 680b300d7454..a3534246fbca 100644 > --- a/drivers/gpu/drm/i915/i915_gem.c > +++ b/drivers/gpu/drm/i915/i915_gem.c > @@ -3236,7 +3236,7 @@ static void i915_gem_verify_gtt(struct drm_device *dev) > /** > * Finds free space in the GTT aperture and binds the object there. > */ > -static int > +static struct i915_vma * > i915_gem_object_bind_to_vm(struct drm_i915_gem_object *obj, > struct i915_address_space *vm, > unsigned alignment, > @@ -3266,7 +3266,7 @@ i915_gem_object_bind_to_vm(struct drm_i915_gem_object *obj, > unfenced_alignment; > if (flags & PIN_MAPPABLE && alignment & (fence_alignment - 1)) { > DRM_ERROR("Invalid object alignment requested %u\n", alignment); > - return -EINVAL; > + return ERR_PTR(-EINVAL); > } > > size = flags & PIN_MAPPABLE ? fence_size : obj->base.size; > @@ -3279,20 +3279,18 @@ i915_gem_object_bind_to_vm(struct drm_i915_gem_object *obj, > obj->base.size, > flags & PIN_MAPPABLE ? "mappable" : "total", > gtt_max); > - return -E2BIG; > + return ERR_PTR(-E2BIG); > } > > ret = i915_gem_object_get_pages(obj); > if (ret) > - return ret; > + return ERR_PTR(ret); > > i915_gem_object_pin_pages(obj); > > vma = i915_gem_obj_lookup_or_create_vma(obj, vm); > - if (IS_ERR(vma)) { > - ret = PTR_ERR(vma); > + if (IS_ERR(vma)) > goto err_unpin; > - } > > search_free: > ret = drm_mm_insert_node_in_range_generic(&vm->mm, &vma->node, > @@ -3336,15 +3334,16 @@ search_free: > > trace_i915_vma_bind(vma, flags); > i915_gem_verify_gtt(dev); > - return 0; > + return vma; > > err_remove_node: > drm_mm_remove_node(&vma->node); > err_free_vma: > i915_gem_vma_destroy(vma); > + vma = ERR_PTR(ret); > err_unpin: > i915_gem_object_unpin_pages(obj); > - return ret; > + return vma; > } > > bool > @@ -3891,10 +3890,10 @@ i915_gem_object_pin(struct drm_i915_gem_object *obj, > } > > if (!i915_gem_obj_bound(obj, vm)) { > - ret = i915_gem_object_bind_to_vm(obj, vm, alignment, flags); > - if (ret) > - return ret; > > + vma = i915_gem_object_bind_to_vm(obj, vm, alignment, flags); > + if (IS_ERR(vma)) > + return PTR_ERR(vma); > } > > vma = i915_gem_obj_to_vma(obj, vm); > -- > 1.8.5.2 > > _______________________________________________ > Intel-gfx mailing list > Intel-gfx@xxxxxxxxxxxxxxxxxxxxx > http://lists.freedesktop.org/mailman/listinfo/intel-gfx -- Jani Nikula, Intel Open Source Technology Center _______________________________________________ Intel-gfx mailing list Intel-gfx@xxxxxxxxxxxxxxxxxxxxx http://lists.freedesktop.org/mailman/listinfo/intel-gfx