Message ID | 1390846259-14915-9-git-send-email-daniel.vetter@ffwll.ch (mailing list archive) |
---|---|
State | New, archived |
Headers | show |
On Mon, 27 Jan 2014, Daniel Vetter <daniel.vetter@ffwll.ch> 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@intel.com> > Cc: Chris Wilson <chris@chris-wilson.co.uk> > Cc: Ben Widawsky <benjamin.widawsky@intel.com> > Signed-off-by: Daniel Vetter <daniel.vetter@ffwll.ch> > --- > 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@lists.freedesktop.org > http://lists.freedesktop.org/mailman/listinfo/intel-gfx
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);
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. Cc: Chris Wilson <chris@chris-wilson.co.uk> Cc: Ben Widawsky <benjamin.widawsky@intel.com> Signed-off-by: Daniel Vetter <daniel.vetter@ffwll.ch> --- drivers/gpu/drm/i915/i915_gem.c | 23 +++++++++++------------ 1 file changed, 11 insertions(+), 12 deletions(-)