diff options
Diffstat (limited to 'drivers/video/console/vgacon.c')
-rw-r--r-- | drivers/video/console/vgacon.c | 39 |
1 files changed, 19 insertions, 20 deletions
diff --git a/drivers/video/console/vgacon.c b/drivers/video/console/vgacon.c index 6df29a62d720..448d209a0bf2 100644 --- a/drivers/video/console/vgacon.c +++ b/drivers/video/console/vgacon.c | |||
@@ -239,8 +239,7 @@ static void vgacon_restore_screen(struct vc_data *c) | |||
239 | 239 | ||
240 | static int vgacon_scrolldelta(struct vc_data *c, int lines) | 240 | static int vgacon_scrolldelta(struct vc_data *c, int lines) |
241 | { | 241 | { |
242 | int start, end, count, soff, diff; | 242 | int start, end, count, soff; |
243 | void *d, *s; | ||
244 | 243 | ||
245 | if (!lines) { | 244 | if (!lines) { |
246 | c->vc_visible_origin = c->vc_origin; | 245 | c->vc_visible_origin = c->vc_origin; |
@@ -287,29 +286,29 @@ static int vgacon_scrolldelta(struct vc_data *c, int lines) | |||
287 | if (count > c->vc_rows) | 286 | if (count > c->vc_rows) |
288 | count = c->vc_rows; | 287 | count = c->vc_rows; |
289 | 288 | ||
290 | diff = c->vc_rows - count; | 289 | if (count) { |
290 | int copysize; | ||
291 | 291 | ||
292 | d = (void *) c->vc_origin; | 292 | int diff = c->vc_rows - count; |
293 | s = (void *) c->vc_screenbuf; | 293 | void *d = (void *) c->vc_origin; |
294 | void *s = (void *) c->vc_screenbuf; | ||
294 | 295 | ||
295 | while (count--) { | 296 | count *= c->vc_size_row; |
296 | scr_memcpyw(d, vgacon_scrollback + soff, c->vc_size_row); | 297 | /* how much memory to end of buffer left? */ |
297 | d += c->vc_size_row; | 298 | copysize = min(count, vgacon_scrollback_size - soff); |
298 | soff += c->vc_size_row; | 299 | scr_memcpyw(d, vgacon_scrollback + soff, copysize); |
300 | d += copysize; | ||
301 | count -= copysize; | ||
299 | 302 | ||
300 | if (soff >= vgacon_scrollback_size) | 303 | if (count) { |
301 | soff = 0; | 304 | scr_memcpyw(d, vgacon_scrollback, count); |
302 | } | 305 | d += count; |
306 | } | ||
303 | 307 | ||
304 | if (diff == c->vc_rows) { | 308 | if (diff) |
309 | scr_memcpyw(d, s, diff * c->vc_size_row); | ||
310 | } else | ||
305 | vgacon_cursor(c, CM_MOVE); | 311 | vgacon_cursor(c, CM_MOVE); |
306 | } else { | ||
307 | while (diff--) { | ||
308 | scr_memcpyw(d, s, c->vc_size_row); | ||
309 | d += c->vc_size_row; | ||
310 | s += c->vc_size_row; | ||
311 | } | ||
312 | } | ||
313 | 312 | ||
314 | return 1; | 313 | return 1; |
315 | } | 314 | } |