]> xenbits.xensource.com Git - people/liuw/libxenctrl-split/mini-os.git/commitdiff
mini-os: fbfront shouldn't send unsolicited updates
authorKeir Fraser <keir.fraser@citrix.com>
Mon, 3 Mar 2008 11:04:53 +0000 (11:04 +0000)
committerKeir Fraser <keir.fraser@citrix.com>
Mon, 3 Mar 2008 11:04:53 +0000 (11:04 +0000)
Signed-off-by: Samuel Thibault <samuel.thibault@eu.citrix.com>
fbfront.c

index 4f5041ab6972c80d6d9dfd1c26262a7c59174d54..b7caf78f6a793094a35ee491760d8e57523acf3f 100644 (file)
--- a/fbfront.c
+++ b/fbfront.c
@@ -245,6 +245,7 @@ struct fbfront_dev {
 
     char *nodename;
     char *backend;
+    int request_update;
 
     char *data;
     int width;
@@ -379,7 +380,7 @@ done:
     printk("backend at %s\n", dev->backend);
 
     {
-        char path[strlen(dev->backend) + 1 + 6 + 1];
+        char path[strlen(dev->backend) + 1 + 14 + 1];
 
         snprintf(path, sizeof(path), "%s/state", dev->backend);
 
@@ -391,6 +392,9 @@ done:
 
         xenbus_unwatch_path(XBT_NIL, path);
 
+        snprintf(path, sizeof(path), "%s/request-update", dev->backend);
+        dev->request_update = xenbus_read_integer(path);
+
         err = xenbus_printf(XBT_NIL, nodename, "state", "%u", 4); /* connected */
     }
 
@@ -405,6 +409,9 @@ void fbfront_update(struct fbfront_dev *dev, int x, int y, int width, int height
     uint32_t prod;
     DEFINE_WAIT(w);
 
+    if (dev->request_update <= 0)
+        return;
+
     if (x < 0) {
         width += x;
         x = 0;