drm/i915: Propagate error from drm_gem_object_init()
Propagate the real error from drm_gem_object_init(). Note this also fixes some confusion in the error return from i915_gem_alloc_object... v2: (Matthew Auld) - updated new users of gem_alloc_object from latest drm-nightly - replaced occurrences of IS_ERR_OR_NULL() with IS_ERR() v3: (Joonas Lahtinen) - fix double "From:" in commit message - add goto teardown path v4: (Matthew Auld) - rebase with i915_gem_alloc_object name change Signed-off-by: Matthew Auld <matthew.auld@intel.com> Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk> Reviewed-by: Joonas Lahtinen <joonas.lahtinen@linux.intel.com> Link: http://patchwork.freedesktop.org/patch/msgid/1461587533-8841-1-git-send-email-matthew.auld@intel.com [Joonas: Removed spurious " = NULL" from _init() function] Signed-off-by: Joonas Lahtinen <joonas.lahtinen@linux.intel.com>
This commit is contained in:
committed by
Joonas Lahtinen
parent
bcbdb6d011
commit
fe3db79b0b
@@ -672,9 +672,10 @@ intel_init_pipe_control(struct intel_engine_cs *engine)
|
||||
WARN_ON(engine->scratch.obj);
|
||||
|
||||
engine->scratch.obj = i915_gem_object_create(engine->dev, 4096);
|
||||
if (engine->scratch.obj == NULL) {
|
||||
if (IS_ERR(engine->scratch.obj)) {
|
||||
DRM_ERROR("Failed to allocate seqno page\n");
|
||||
ret = -ENOMEM;
|
||||
ret = PTR_ERR(engine->scratch.obj);
|
||||
engine->scratch.obj = NULL;
|
||||
goto err;
|
||||
}
|
||||
|
||||
@@ -2033,9 +2034,9 @@ static int init_status_page(struct intel_engine_cs *engine)
|
||||
int ret;
|
||||
|
||||
obj = i915_gem_object_create(engine->dev, 4096);
|
||||
if (obj == NULL) {
|
||||
if (IS_ERR(obj)) {
|
||||
DRM_ERROR("Failed to allocate status page\n");
|
||||
return -ENOMEM;
|
||||
return PTR_ERR(obj);
|
||||
}
|
||||
|
||||
ret = i915_gem_object_set_cache_level(obj, I915_CACHE_LLC);
|
||||
@@ -2174,8 +2175,8 @@ static int intel_alloc_ringbuffer_obj(struct drm_device *dev,
|
||||
obj = i915_gem_object_create_stolen(dev, ringbuf->size);
|
||||
if (obj == NULL)
|
||||
obj = i915_gem_object_create(dev, ringbuf->size);
|
||||
if (obj == NULL)
|
||||
return -ENOMEM;
|
||||
if (IS_ERR(obj))
|
||||
return PTR_ERR(obj);
|
||||
|
||||
/* mark ring buffers as read-only from GPU side by default */
|
||||
obj->gt_ro = 1;
|
||||
@@ -2787,7 +2788,7 @@ int intel_init_render_ring_buffer(struct drm_device *dev)
|
||||
if (INTEL_INFO(dev)->gen >= 8) {
|
||||
if (i915_semaphore_is_enabled(dev)) {
|
||||
obj = i915_gem_object_create(dev, 4096);
|
||||
if (obj == NULL) {
|
||||
if (IS_ERR(obj)) {
|
||||
DRM_ERROR("Failed to allocate semaphore bo. Disabling semaphores\n");
|
||||
i915.semaphores = 0;
|
||||
} else {
|
||||
@@ -2896,9 +2897,9 @@ int intel_init_render_ring_buffer(struct drm_device *dev)
|
||||
/* Workaround batchbuffer to combat CS tlb bug. */
|
||||
if (HAS_BROKEN_CS_TLB(dev)) {
|
||||
obj = i915_gem_object_create(dev, I830_WA_SIZE);
|
||||
if (obj == NULL) {
|
||||
if (IS_ERR(obj)) {
|
||||
DRM_ERROR("Failed to allocate batch bo\n");
|
||||
return -ENOMEM;
|
||||
return PTR_ERR(obj);
|
||||
}
|
||||
|
||||
ret = i915_gem_obj_ggtt_pin(obj, 0, 0);
|
||||
|
||||
Reference in New Issue
Block a user