------------------------------------------------------------
revno: 53
revision-id: [EMAIL PROTECTED]
parent: [EMAIL PROTECTED]
committer: Andrew Tridgell <[EMAIL PROTECTED]>
branch nick: tridge
timestamp: Wed 2007-02-07 13:26:07 +1100
message:
  merged from samba4 ctdb
modified:
  common/ctdb.c                  ctdb.c-20061127094323-t50f58d65iaao5of-2
  tcp/tcp_io.c                   tcp_io.c-20061128004937-x70q1cu5xzg5g2tm-3
=== modified file 'common/ctdb.c'
--- a/common/ctdb.c     2007-01-23 00:38:45 +0000
+++ b/common/ctdb.c     2007-02-07 02:26:07 +0000
@@ -175,6 +175,7 @@
 static void ctdb_recv_pkt(struct ctdb_context *ctdb, uint8_t *data, uint32_t 
length)
 {
        struct ctdb_req_header *hdr;
+
        if (length < sizeof(*hdr)) {
                ctdb_set_error(ctdb, "Bad packet length %d\n", length);
                return;
@@ -229,7 +230,7 @@
 }
 
 /*
-  called by the transport layer when a node is dead
+  called by the transport layer when a node is connected
 */
 static void ctdb_node_connected(struct ctdb_node *node)
 {

=== modified file 'tcp/tcp_io.c'
--- a/tcp/tcp_io.c      2007-01-23 00:38:45 +0000
+++ b/tcp/tcp_io.c      2007-02-07 02:26:07 +0000
@@ -38,13 +38,6 @@
        struct ctdb_tcp_node *tnode = talloc_get_type(node->private, 
                                                      struct ctdb_tcp_node);
 
-       /* flush the queue */
-       while (tnode->queue) {
-               struct ctdb_tcp_packet *pkt = tnode->queue;
-               DLIST_REMOVE(tnode->queue, pkt);
-               talloc_free(pkt);
-       }
-
        /* start a new connect cycle to try to re-establish the
           link */
        talloc_free(tnode->fde);
@@ -68,6 +61,7 @@
                   always an error, as we have separate read and write
                   sockets. In future we may combine them, but for now it must
                   mean that the socket is dead, so we try to reconnect */
+               node->ctdb->upcalls->node_dead(node);
                talloc_free(tnode->fde);
                close(tnode->fd);
                tnode->fd = -1;
@@ -170,10 +164,9 @@
                in->ctdb->upcalls->recv_pkt(in->ctdb, d2, len);
                data += len;
                nread -= len;           
-               return;
        }
 
-       if (nread < 4 || *(uint32_t *)data > nread) {
+       if (nread > 0) {
                /* we have only part of a packet */
                if (data_base == data) {
                        in->partial.data = data;

Reply via email to