mirror of
				https://github.com/qemu/qemu.git
				synced 2025-10-25 11:17:27 +00:00 
			
		
		
		
	Coalesce virtual console screen updates.
git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@6374 c046a42c-6fe2-441c-8c8c-71466251a162
This commit is contained in:
		
							parent
							
								
									6e60065f88
								
							
						
					
					
						commit
						14778c2064
					
				
							
								
								
									
										40
									
								
								console.c
									
									
									
									
									
								
							
							
						
						
									
										40
									
								
								console.c
									
									
									
									
									
								
							| @ -139,6 +139,11 @@ struct TextConsole { | |||||||
|     TextCell *cells; |     TextCell *cells; | ||||||
|     int text_x[2], text_y[2], cursor_invalidate; |     int text_x[2], text_y[2], cursor_invalidate; | ||||||
| 
 | 
 | ||||||
|  |     int update_x0; | ||||||
|  |     int update_y0; | ||||||
|  |     int update_x1; | ||||||
|  |     int update_y1; | ||||||
|  | 
 | ||||||
|     enum TTYState state; |     enum TTYState state; | ||||||
|     int esc_params[MAX_ESC_PARAMS]; |     int esc_params[MAX_ESC_PARAMS]; | ||||||
|     int nb_esc_params; |     int nb_esc_params; | ||||||
| @ -537,6 +542,18 @@ static inline void text_update_xy(TextConsole *s, int x, int y) | |||||||
|     s->text_y[1] = MAX(s->text_y[1], y); |     s->text_y[1] = MAX(s->text_y[1], y); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | static void invalidate_xy(TextConsole *s, int x, int y) | ||||||
|  | { | ||||||
|  |     if (s->update_x0 > x * FONT_WIDTH) | ||||||
|  |         s->update_x0 = x * FONT_WIDTH; | ||||||
|  |     if (s->update_y0 > y * FONT_HEIGHT) | ||||||
|  |         s->update_y0 = y * FONT_HEIGHT; | ||||||
|  |     if (s->update_x1 < (x + 1) * FONT_WIDTH) | ||||||
|  |         s->update_x1 = (x + 1) * FONT_WIDTH; | ||||||
|  |     if (s->update_y1 < (y + 1) * FONT_HEIGHT) | ||||||
|  |         s->update_y1 = (y + 1) * FONT_HEIGHT; | ||||||
|  | } | ||||||
|  | 
 | ||||||
| static void update_xy(TextConsole *s, int x, int y) | static void update_xy(TextConsole *s, int x, int y) | ||||||
| { | { | ||||||
|     TextCell *c; |     TextCell *c; | ||||||
| @ -556,8 +573,7 @@ static void update_xy(TextConsole *s, int x, int y) | |||||||
|             c = &s->cells[y1 * s->width + x]; |             c = &s->cells[y1 * s->width + x]; | ||||||
|             vga_putcharxy(s->ds, x, y2, c->ch, |             vga_putcharxy(s->ds, x, y2, c->ch, | ||||||
|                           &(c->t_attrib)); |                           &(c->t_attrib)); | ||||||
|             dpy_update(s->ds, x * FONT_WIDTH, y2 * FONT_HEIGHT, |             invalidate_xy(s, x, y2); | ||||||
|                        FONT_WIDTH, FONT_HEIGHT); |  | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| } | } | ||||||
| @ -591,8 +607,7 @@ static void console_show_cursor(TextConsole *s, int show) | |||||||
|             } else { |             } else { | ||||||
|                 vga_putcharxy(s->ds, x, y, c->ch, &(c->t_attrib)); |                 vga_putcharxy(s->ds, x, y, c->ch, &(c->t_attrib)); | ||||||
|             } |             } | ||||||
|             dpy_update(s->ds, x * FONT_WIDTH, y * FONT_HEIGHT, |             invalidate_xy(s, x, y); | ||||||
|                        FONT_WIDTH, FONT_HEIGHT); |  | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| } | } | ||||||
| @ -626,8 +641,8 @@ static void console_refresh(TextConsole *s) | |||||||
|         if (++y1 == s->total_height) |         if (++y1 == s->total_height) | ||||||
|             y1 = 0; |             y1 = 0; | ||||||
|     } |     } | ||||||
|     dpy_update(s->ds, 0, 0, ds_get_width(s->ds), ds_get_height(s->ds)); |  | ||||||
|     console_show_cursor(s, 1); |     console_show_cursor(s, 1); | ||||||
|  |     dpy_update(s->ds, 0, 0, ds_get_width(s->ds), ds_get_height(s->ds)); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| static void console_scroll(int ydelta) | static void console_scroll(int ydelta) | ||||||
| @ -703,8 +718,10 @@ static void console_put_lf(TextConsole *s) | |||||||
|             vga_fill_rect(s->ds, 0, (s->height - 1) * FONT_HEIGHT, |             vga_fill_rect(s->ds, 0, (s->height - 1) * FONT_HEIGHT, | ||||||
|                           s->width * FONT_WIDTH, FONT_HEIGHT, |                           s->width * FONT_WIDTH, FONT_HEIGHT, | ||||||
|                           color_table[0][s->t_attrib_default.bgcol]); |                           color_table[0][s->t_attrib_default.bgcol]); | ||||||
|             dpy_update(s->ds, 0, 0, |             s->update_x0 = 0; | ||||||
|                        s->width * FONT_WIDTH, s->height * FONT_HEIGHT); |             s->update_y0 = 0; | ||||||
|  |             s->update_x1 = s->width * FONT_WIDTH; | ||||||
|  |             s->update_y1 = s->height * FONT_HEIGHT; | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| } | } | ||||||
| @ -1062,11 +1079,20 @@ static int console_puts(CharDriverState *chr, const uint8_t *buf, int len) | |||||||
|     TextConsole *s = chr->opaque; |     TextConsole *s = chr->opaque; | ||||||
|     int i; |     int i; | ||||||
| 
 | 
 | ||||||
|  |     s->update_x0 = s->width * FONT_WIDTH; | ||||||
|  |     s->update_y0 = s->height * FONT_HEIGHT; | ||||||
|  |     s->update_x1 = 0; | ||||||
|  |     s->update_y1 = 0; | ||||||
|     console_show_cursor(s, 0); |     console_show_cursor(s, 0); | ||||||
|     for(i = 0; i < len; i++) { |     for(i = 0; i < len; i++) { | ||||||
|         console_putchar(s, buf[i]); |         console_putchar(s, buf[i]); | ||||||
|     } |     } | ||||||
|     console_show_cursor(s, 1); |     console_show_cursor(s, 1); | ||||||
|  |     if (ds_get_bits_per_pixel(s->ds) && s->update_x0 < s->update_x1) { | ||||||
|  |         dpy_update(s->ds, s->update_x0, s->update_y0, | ||||||
|  |                    s->update_x1 - s->update_x0, | ||||||
|  |                    s->update_y1 - s->update_y0); | ||||||
|  |     } | ||||||
|     return len; |     return len; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 pbrook
						pbrook