|   | 
      | 
  
  
      | 
      | 
  
 
     | 
    | 
  
  
     | 
    | 
  
  
    |   | 
      | 
  
  
    | 
         
xen-changelog
[Xen-changelog] [xen-unstable] [XEN] Fix read_console_ring() when	passed
 
# HG changeset patch
# User kaf24@xxxxxxxxxxxxxxxxxxxx
# Node ID 92f071926e6edbd87e83cf117aaeb45cd5775c9b
# Parent  a936c9c3ea60cc0ed8aa712c00a19d377cc76d0f
[XEN] Fix read_console_ring() when passed a small buffer.
From: Akio Takebe <takebe_akio@xxxxxxxxxxxxxx>
Signed-off-by: Keir Fraser <keir@xxxxxxxxxxxxx>
---
 xen/drivers/char/console.c |    7 +++++--
 1 files changed, 5 insertions(+), 2 deletions(-)
diff -r a936c9c3ea60 -r 92f071926e6e xen/drivers/char/console.c
--- a/xen/drivers/char/console.c        Mon Jun 12 09:57:23 2006 +0100
+++ b/xen/drivers/char/console.c        Mon Jun 12 10:05:55 2006 +0100
@@ -230,7 +230,7 @@ long read_console_ring(XEN_GUEST_HANDLE(
     sofar = 0;
 
     c = conringc;
-    while ( c != conringp )
+    while ( (c != conringp) && (sofar < max) )
     {
         idx = CONRING_IDX_MASK(c);
         len = conringp - c;
@@ -247,7 +247,10 @@ long read_console_ring(XEN_GUEST_HANDLE(
     if ( clear )
     {
         spin_lock_irqsave(&console_lock, flags);
-        conringc = conringp;
+        if ( (conringp - c) > CONRING_SIZE )
+            conringc = conringp - CONRING_SIZE;
+        else
+            conringc = c;
         spin_unlock_irqrestore(&console_lock, flags);
     }
 
_______________________________________________
Xen-changelog mailing list
Xen-changelog@xxxxxxxxxxxxxxxxxxx
http://lists.xensource.com/xen-changelog
 |   
 
| <Prev in Thread] | 
Current Thread | 
[Next in Thread> |  
- [Xen-changelog] [xen-unstable] [XEN] Fix read_console_ring() when	passed a small buffer.,
Xen patchbot-unstable <=
  
 |  
  
 | 
    | 
  
  
    |   | 
    |