modesetting: Update the cursor without hiding it
In the new KMS APIs, the legacy drmModeSetCursor ioctl actually waits for a vblank after changing the cursor image before returning, meaning that the X server, in attempting to hide the cursor before updating its image, actually makes that hide *visible* for a full vblank. It's unknown why the X server does this by default, but turn it off. If we're with a legacy driver that doesn't support the modern drmModeSetCursor by waiting for a vblank before returning, we're going to get a tiny bit of tearing on the cursor plane. But between tearing with a new cursor image and tearing with a blank cursor image, I'd rather the former. The only proper solution to this is an atomic ioctl that page flips all planes, including the cursor plane, at vblank time and at the same time. Signed-off-by: Keith Packard <keithp@keithp.com> Reviewed-by: Keith Packard <keithp@keithp.com>
This commit is contained in:
		
							parent
							
								
									b058dec281
								
							
						
					
					
						commit
						4e12d7b6f4
					
				|  | @ -1077,6 +1077,7 @@ ScreenInit(ScreenPtr pScreen, int argc, char **argv) | ||||||
|     if (!ms->drmmode.sw_cursor) |     if (!ms->drmmode.sw_cursor) | ||||||
|         xf86_cursors_init(pScreen, ms->cursor_width, ms->cursor_height, |         xf86_cursors_init(pScreen, ms->cursor_width, ms->cursor_height, | ||||||
|                           HARDWARE_CURSOR_SOURCE_MASK_INTERLEAVE_64 | |                           HARDWARE_CURSOR_SOURCE_MASK_INTERLEAVE_64 | | ||||||
|  |                           HARDWARE_CURSOR_UPDATE_UNHIDDEN | | ||||||
|                           HARDWARE_CURSOR_ARGB); |                           HARDWARE_CURSOR_ARGB); | ||||||
| 
 | 
 | ||||||
|     /* Must force it before EnterVT, so we are in control of VT and
 |     /* Must force it before EnterVT, so we are in control of VT and
 | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue