forked from rpms/kernel
		
	Add patches to fix qxl locking issues (rhbz 1238803 1249850)
This commit is contained in:
		
							parent
							
								
									041f36f18e
								
							
						
					
					
						commit
						fd00410ea8
					
				
							
								
								
									
										53
									
								
								drm-qxl-avoid-buffer-reservation-in-qxl_crtc_page_fl.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										53
									
								
								drm-qxl-avoid-buffer-reservation-in-qxl_crtc_page_fl.patch
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,53 @@ | |||||||
|  | From fc6c6a4dde53bf68c519c0079b5957a24b7bad2b Mon Sep 17 00:00:00 2001 | ||||||
|  | From: Frediano Ziglio <fziglio@redhat.com> | ||||||
|  | Date: Thu, 24 Sep 2015 14:25:14 +0100 | ||||||
|  | Subject: [PATCH 1/2] drm/qxl: avoid buffer reservation in qxl_crtc_page_flip | ||||||
|  | 
 | ||||||
|  | This avoid a dependency lock error. | ||||||
|  | According to https://lwn.net/Articles/548909/ users of WW mutex API | ||||||
|  | should avoid using different context. | ||||||
|  | When a buffer is reserved with qxl_bo_reserve a ww_mutex_lock without | ||||||
|  | context is used. However during qxl_draw_dirty_fb different locks | ||||||
|  | with specific context are used. | ||||||
|  | This is detected during a machine booting with a debug kernel with lock | ||||||
|  | dependency checking enabled. | ||||||
|  | Like many other function in this file to avoid this problem object | ||||||
|  | pinning is used. Once the object is pinned is not necessary to keep | ||||||
|  | the lock so it can be released avoiding the locking problem. | ||||||
|  | 
 | ||||||
|  | Signed-off-by: Frediano Ziglio <fziglio@redhat.com> | ||||||
|  | ---
 | ||||||
|  |  drivers/gpu/drm/qxl/qxl_display.c | 10 +++++++++- | ||||||
|  |  1 file changed, 9 insertions(+), 1 deletion(-) | ||||||
|  | 
 | ||||||
|  | diff --git a/drivers/gpu/drm/qxl/qxl_display.c b/drivers/gpu/drm/qxl/qxl_display.c
 | ||||||
|  | index 4649bd2ed340..183aea1abebc 100644
 | ||||||
|  | --- a/drivers/gpu/drm/qxl/qxl_display.c
 | ||||||
|  | +++ b/drivers/gpu/drm/qxl/qxl_display.c
 | ||||||
|  | @@ -244,6 +244,10 @@ static int qxl_crtc_page_flip(struct drm_crtc *crtc,
 | ||||||
|  |  	ret = qxl_bo_reserve(bo, false); | ||||||
|  |  	if (ret) | ||||||
|  |  		return ret; | ||||||
|  | +	ret = qxl_bo_pin(bo, bo->type, NULL);
 | ||||||
|  | +	qxl_bo_unreserve(bo);
 | ||||||
|  | +	if (ret)
 | ||||||
|  | +		return ret;
 | ||||||
|  |   | ||||||
|  |  	qxl_draw_dirty_fb(qdev, qfb_src, bo, 0, 0, | ||||||
|  |  			  &norect, one_clip_rect, inc); | ||||||
|  | @@ -257,7 +261,11 @@ static int qxl_crtc_page_flip(struct drm_crtc *crtc,
 | ||||||
|  |  	} | ||||||
|  |  	drm_vblank_put(dev, qcrtc->index); | ||||||
|  |   | ||||||
|  | -	qxl_bo_unreserve(bo);
 | ||||||
|  | +	ret = qxl_bo_reserve(bo, false);
 | ||||||
|  | +	if (!ret) {
 | ||||||
|  | +		qxl_bo_unpin(bo);
 | ||||||
|  | +		qxl_bo_unreserve(bo);
 | ||||||
|  | +	}
 | ||||||
|  |   | ||||||
|  |  	return 0; | ||||||
|  |  } | ||||||
|  | -- 
 | ||||||
|  | 2.4.3 | ||||||
|  | 
 | ||||||
							
								
								
									
										42
									
								
								drm-qxl-avoid-dependency-lock.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										42
									
								
								drm-qxl-avoid-dependency-lock.patch
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,42 @@ | |||||||
|  | From 364222966c6cb48898b83f9a912bff4cedcda2cd Mon Sep 17 00:00:00 2001 | ||||||
|  | From: Frediano Ziglio <fziglio@redhat.com> | ||||||
|  | Date: Thu, 24 Sep 2015 14:25:15 +0100 | ||||||
|  | Subject: [PATCH 2/2] drm/qxl: avoid dependency lock | ||||||
|  | 
 | ||||||
|  | qxl_bo_unref calls drm_gem_object_unreference_unlocked which | ||||||
|  | locks dev->struct_mutex. However this lock could be already | ||||||
|  | locked if the call came from qxl_gem_object_free. | ||||||
|  | As we don't need to call qxl_bo_ref/qxl_bo_unref cause | ||||||
|  | qxl_release_list_add will hold a reference by itself avoid | ||||||
|  | to call them and the possible deadlock. | ||||||
|  | 
 | ||||||
|  | Signed-off-by: Frediano Ziglio <fziglio@redhat.com> | ||||||
|  | ---
 | ||||||
|  |  drivers/gpu/drm/qxl/qxl_release.c | 4 +--- | ||||||
|  |  1 file changed, 1 insertion(+), 3 deletions(-) | ||||||
|  | 
 | ||||||
|  | diff --git a/drivers/gpu/drm/qxl/qxl_release.c b/drivers/gpu/drm/qxl/qxl_release.c
 | ||||||
|  | index b66ec331c17c..4efa8e261baf 100644
 | ||||||
|  | --- a/drivers/gpu/drm/qxl/qxl_release.c
 | ||||||
|  | +++ b/drivers/gpu/drm/qxl/qxl_release.c
 | ||||||
|  | @@ -307,7 +307,7 @@ int qxl_alloc_surface_release_reserved(struct qxl_device *qdev,
 | ||||||
|  |  		idr_ret = qxl_release_alloc(qdev, QXL_RELEASE_SURFACE_CMD, release); | ||||||
|  |  		if (idr_ret < 0) | ||||||
|  |  			return idr_ret; | ||||||
|  | -		bo = qxl_bo_ref(to_qxl_bo(entry->tv.bo));
 | ||||||
|  | +		bo = to_qxl_bo(entry->tv.bo);
 | ||||||
|  |   | ||||||
|  |  		(*release)->release_offset = create_rel->release_offset + 64; | ||||||
|  |   | ||||||
|  | @@ -316,8 +316,6 @@ int qxl_alloc_surface_release_reserved(struct qxl_device *qdev,
 | ||||||
|  |  		info = qxl_release_map(qdev, *release); | ||||||
|  |  		info->id = idr_ret; | ||||||
|  |  		qxl_release_unmap(qdev, *release, info); | ||||||
|  | -
 | ||||||
|  | -		qxl_bo_unref(&bo);
 | ||||||
|  |  		return 0; | ||||||
|  |  	} | ||||||
|  |   | ||||||
|  | -- 
 | ||||||
|  | 2.4.3 | ||||||
|  | 
 | ||||||
| @ -592,6 +592,10 @@ Patch520: ARM-dts-Fix-Makefile-target-for-sun4i-a10-itead-itea.patch | |||||||
| #rhbz 1262434 | #rhbz 1262434 | ||||||
| Patch521: Revert-Input-synaptics-fix-handling-of-disabling-ges.patch | Patch521: Revert-Input-synaptics-fix-handling-of-disabling-ges.patch | ||||||
| 
 | 
 | ||||||
|  | #rhbz 1238803 1249850 | ||||||
|  | Patch522: drm-qxl-avoid-buffer-reservation-in-qxl_crtc_page_fl.patch | ||||||
|  | Patch523: drm-qxl-avoid-dependency-lock.patch | ||||||
|  | 
 | ||||||
| Patch904: kdbus.patch | Patch904: kdbus.patch | ||||||
| 
 | 
 | ||||||
| # END OF PATCH DEFINITIONS | # END OF PATCH DEFINITIONS | ||||||
| @ -2037,6 +2041,9 @@ fi | |||||||
| # | # | ||||||
| #  | #  | ||||||
| %changelog | %changelog | ||||||
|  | * Mon Oct 05 2015 Josh Boyer <jwboyer@fedoraproject.org> | ||||||
|  | - Add patches to fix qxl locking issues (rhbz 1238803 1249850) | ||||||
|  | 
 | ||||||
| * Sun Oct  4 2015 Peter Robinson <pbrobinson@fedoraproject.org> | * Sun Oct  4 2015 Peter Robinson <pbrobinson@fedoraproject.org> | ||||||
| - Add support for BeagleBone Green | - Add support for BeagleBone Green | ||||||
| 
 | 
 | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user