ui/vnc: optimize setting in vnc_dpy_update()
Signed-off-by: Peter Lieven <pl@kamp.de> Reviewed-by: Wenchao Xia <xiawenc@linux.vnet.ibm.com> Signed-off-by: Gerd Hoffmann <kraxel@redhat.com>
This commit is contained in:
		
							parent
							
								
									863d7c9105
								
							
						
					
					
						commit
						919372251c
					
				
							
								
								
									
										16
									
								
								ui/vnc.c
									
									
									
									
									
								
							
							
						
						
									
										16
									
								
								ui/vnc.c
									
									
									
									
									
								
							| @ -430,30 +430,24 @@ static int vnc_refresh_server_surface(VncDisplay *vd); | ||||
| static void vnc_dpy_update(DisplayChangeListener *dcl, | ||||
|                            int x, int y, int w, int h) | ||||
| { | ||||
|     int i; | ||||
|     VncDisplay *vd = container_of(dcl, VncDisplay, dcl); | ||||
|     struct VncSurface *s = &vd->guest; | ||||
|     int width = surface_width(vd->ds); | ||||
|     int height = surface_height(vd->ds); | ||||
| 
 | ||||
|     h += y; | ||||
| 
 | ||||
|     /* round x down to ensure the loop only spans one 16-pixel block per,
 | ||||
|        iteration.  otherwise, if (x % 16) != 0, the last iteration may span | ||||
|        two 16-pixel blocks but we only mark the first as dirty | ||||
|     */ | ||||
|     /* this is needed this to ensure we updated all affected
 | ||||
|      * blocks if x % VNC_DIRTY_PIXELS_PER_BIT != 0 */ | ||||
|     w += (x % VNC_DIRTY_PIXELS_PER_BIT); | ||||
|     x -= (x % VNC_DIRTY_PIXELS_PER_BIT); | ||||
| 
 | ||||
|     x = MIN(x, width); | ||||
|     y = MIN(y, height); | ||||
|     w = MIN(x + w, width) - x; | ||||
|     h = MIN(h, height); | ||||
|     h = MIN(y + h, height); | ||||
| 
 | ||||
|     for (; y < h; y++) { | ||||
|         for (i = 0; i < w; i += VNC_DIRTY_PIXELS_PER_BIT) { | ||||
|             set_bit((x + i) / VNC_DIRTY_PIXELS_PER_BIT, s->dirty[y]); | ||||
|         } | ||||
|         bitmap_set(s->dirty[y], x / VNC_DIRTY_PIXELS_PER_BIT, | ||||
|                    DIV_ROUND_UP(w, VNC_DIRTY_PIXELS_PER_BIT)); | ||||
|     } | ||||
| } | ||||
| 
 | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 Peter Lieven
						Peter Lieven