diff options
| author | Thomas Gleixner <tglx@linutronix.de> | 2010-05-10 11:59:37 +0200 | 
|---|---|---|
| committer | Thomas Gleixner <tglx@linutronix.de> | 2010-05-10 14:20:42 +0200 | 
| commit | dbb6be6d5e974c42bbecd183effaa0df69e1dd8b (patch) | |
| tree | 5735cb47e70853d057a9881dd0ce44b83e88fa63 /drivers/gpu/drm/i915/intel_overlay.c | |
| parent | 6a867a395558a7f882d041783e4cdea6744ca2bf (diff) | |
| parent | b57f95a38233a2e73b679bea4a5453a1cc2a1cc9 (diff) | |
| download | olio-linux-3.10-dbb6be6d5e974c42bbecd183effaa0df69e1dd8b.tar.xz olio-linux-3.10-dbb6be6d5e974c42bbecd183effaa0df69e1dd8b.zip  | |
Merge branch 'linus' into timers/core
Reason: Further posix_cpu_timer patches depend on mainline changes
Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
Diffstat (limited to 'drivers/gpu/drm/i915/intel_overlay.c')
| -rw-r--r-- | drivers/gpu/drm/i915/intel_overlay.c | 19 | 
1 files changed, 12 insertions, 7 deletions
diff --git a/drivers/gpu/drm/i915/intel_overlay.c b/drivers/gpu/drm/i915/intel_overlay.c index d355d1d527e..6d524a1fc27 100644 --- a/drivers/gpu/drm/i915/intel_overlay.c +++ b/drivers/gpu/drm/i915/intel_overlay.c @@ -724,7 +724,7 @@ int intel_overlay_do_put_image(struct intel_overlay *overlay,  	int ret, tmp_width;  	struct overlay_registers *regs;  	bool scale_changed = false; -	struct drm_i915_gem_object *bo_priv = new_bo->driver_private; +	struct drm_i915_gem_object *bo_priv = to_intel_bo(new_bo);  	struct drm_device *dev = overlay->dev;  	BUG_ON(!mutex_is_locked(&dev->struct_mutex)); @@ -809,7 +809,7 @@ int intel_overlay_do_put_image(struct intel_overlay *overlay,  	intel_overlay_continue(overlay, scale_changed);  	overlay->old_vid_bo = overlay->vid_bo; -	overlay->vid_bo = new_bo->driver_private; +	overlay->vid_bo = to_intel_bo(new_bo);  	return 0; @@ -1068,14 +1068,18 @@ int intel_overlay_put_image(struct drm_device *dev, void *data,  	drmmode_obj = drm_mode_object_find(dev, put_image_rec->crtc_id,                          DRM_MODE_OBJECT_CRTC); -	if (!drmmode_obj) -		return -ENOENT; +	if (!drmmode_obj) { +		ret = -ENOENT; +		goto out_free; +	}  	crtc = to_intel_crtc(obj_to_crtc(drmmode_obj));  	new_bo = drm_gem_object_lookup(dev, file_priv,  			put_image_rec->bo_handle); -	if (!new_bo) -		return -ENOENT; +	if (!new_bo) { +		ret = -ENOENT; +		goto out_free; +	}  	mutex_lock(&dev->mode_config.mutex);  	mutex_lock(&dev->struct_mutex); @@ -1165,6 +1169,7 @@ out_unlock:  	mutex_unlock(&dev->struct_mutex);  	mutex_unlock(&dev->mode_config.mutex);  	drm_gem_object_unreference_unlocked(new_bo); +out_free:  	kfree(params);  	return ret; @@ -1339,7 +1344,7 @@ void intel_setup_overlay(struct drm_device *dev)  	reg_bo = drm_gem_object_alloc(dev, PAGE_SIZE);  	if (!reg_bo)  		goto out_free; -	overlay->reg_bo = reg_bo->driver_private; +	overlay->reg_bo = to_intel_bo(reg_bo);  	if (OVERLAY_NONPHYSICAL(dev)) {  		ret = i915_gem_object_pin(reg_bo, PAGE_SIZE);  |