]> xenbits.xensource.com Git - people/dariof/xen.git/commitdiff
xenstore: let write_node() and some callers return errno
authorJuergen Gross <jgross@suse.com>
Tue, 28 Mar 2017 16:26:12 +0000 (18:26 +0200)
committerWei Liu <wei.liu2@citrix.com>
Mon, 3 Apr 2017 13:04:10 +0000 (14:04 +0100)
Instead of setting errno and returning true or false return the error
value directly.

In order to ensure all call sites have been changed according to the
modification rename the functions to xs_*.

Signed-off-by: Juergen Gross <jgross@suse.com>
Reviewed-by: Wei Liu <wei.liu2@citrix.com>
tools/xenstore/xenstored_core.c

index 739e8b2e149ded29fdc7916dbba8aeb859150fcd..4bcaac0a17fb6c8653ca208c9a97e2b3694c36a8 100644 (file)
@@ -433,7 +433,7 @@ static struct node *read_node(struct connection *conn, const void *ctx,
        return node;
 }
 
-static bool write_node(struct connection *conn, struct node *node)
+static int xs_write_node(struct connection *conn, struct node *node)
 {
        /*
         * conn will be null when this is called from manual_node.
@@ -475,10 +475,10 @@ static bool write_node(struct connection *conn, struct node *node)
                corrupt(conn, "Write of %s failed", key.dptr);
                goto error;
        }
-       return true;
+       return 0;
  error:
        errno = ENOSPC;
-       return false;
+       return errno;
 }
 
 static enum xs_perm_type perm_for_conn(struct connection *conn,
@@ -1022,7 +1022,7 @@ static struct node *create_node(struct connection *conn, const void *ctx,
        /* We write out the nodes down, setting destructor in case
         * something goes wrong. */
        for (i = node; i; i = i->parent) {
-               if (!write_node(conn, i)) {
+               if (xs_write_node(conn, i)) {
                        domain_entry_dec(conn, i);
                        return NULL;
                }
@@ -1062,7 +1062,7 @@ static int do_write(struct connection *conn, struct buffered_data *in)
        } else {
                node->data = in->buffer + offset;
                node->datalen = datalen;
-               if (!write_node(conn, node))
+               if (xs_write_node(conn, node))
                        return errno;
        }
 
@@ -1133,28 +1133,28 @@ static void memdel(void *mem, unsigned off, unsigned len, unsigned total)
 }
 
 
-static bool remove_child_entry(struct connection *conn, struct node *node,
-                              size_t offset)
+static int xs_remove_child_entry(struct connection *conn, struct node *node,
+                             size_t offset)
 {
        size_t childlen = strlen(node->children + offset);
        memdel(node->children, offset, childlen + 1, node->childlen);
        node->childlen -= childlen + 1;
-       return write_node(conn, node);
+       return xs_write_node(conn, node);
 }
 
 
-static bool delete_child(struct connection *conn,
-                        struct node *node, const char *childname)
+static int xs_delete_child(struct connection *conn,
+                       struct node *node, const char *childname)
 {
        unsigned int i;
 
        for (i = 0; i < node->childlen; i += strlen(node->children+i) + 1) {
                if (streq(node->children+i, childname)) {
-                       return remove_child_entry(conn, node, i);
+                       return xs_remove_child_entry(conn, node, i);
                }
        }
        corrupt(conn, "Can't find child '%s' in %s", childname, node->name);
-       return false;
+       return ENOENT;
 }
 
 
@@ -1174,7 +1174,7 @@ static int _rm(struct connection *conn, const void *ctx, struct node *node,
        if (!parent)
                return (errno == ENOMEM) ? ENOMEM : EINVAL;
 
-       if (!delete_child(conn, parent, basename(name)))
+       if (xs_delete_child(conn, parent, basename(name)))
                return EINVAL;
 
        delete_node(conn, node, true);
@@ -1278,7 +1278,7 @@ static int do_set_perms(struct connection *conn, struct buffered_data *in)
        node->num_perms = num;
        domain_entry_inc(conn, node);
 
-       if (!write_node(conn, node))
+       if (xs_write_node(conn, node))
                return errno;
 
        fire_watches(conn, in, name, false);
@@ -1538,7 +1538,7 @@ static void manual_node(const char *name, const char *child)
        if (child)
                node->childlen = strlen(child) + 1;
 
-       if (!write_node(NULL, node))
+       if (xs_write_node(NULL, node))
                barf_perror("Could not create initial node %s", name);
        talloc_free(node);
 }
@@ -1677,7 +1677,7 @@ static int check_store_(const char *name, struct hashtable *reachable)
                                            childname);
 
                                        if (recovery) {
-                                               remove_child_entry(NULL, node,
+                                               xs_remove_child_entry(NULL, node,
                                                                   i);
                                                i -= childlen + 1;
                                        }
@@ -1699,7 +1699,7 @@ static int check_store_(const char *name, struct hashtable *reachable)
                                    childname);
 
                                if (recovery) {
-                                       remove_child_entry(NULL, node, i);
+                                       xs_remove_child_entry(NULL, node, i);
                                        i -= childlen + 1;
                                }
                        } else {