]> git.ipfire.org Git - thirdparty/bird.git/commitdiff
Fixed a couple of nasty CLI bugs which were triggered on long or multi-part
authorMartin Mares <mj@ucw.cz>
Thu, 27 Apr 2000 22:35:08 +0000 (22:35 +0000)
committerMartin Mares <mj@ucw.cz>
Thu, 27 Apr 2000 22:35:08 +0000 (22:35 +0000)
outputs. It took a whole evening to hunt them down, but now the CLI seems
to work fine.

Now I run three BGP connections with several thousand routes!

nest/cli.c
sysdep/unix/io.c
sysdep/unix/main.c

index f7432a5526682ce500679717d8880959d80ad2c0..fb2b6797ac0a343ef515d5e5eacfcd1ac0c8ba7f 100644 (file)
@@ -29,13 +29,13 @@ cli_alloc_out(cli *c, int size)
            c->tx_write->next = o;
          else
            c->tx_buf = o;
-         o->next = NULL;
          o->wpos = o->outpos = o->buf;
          o->end = o->buf + CLI_TX_BUF_SIZE;
        }
       c->tx_write = o;
       if (!c->tx_pos)
        c->tx_pos = o;
+      o->next = NULL;
     }
   o->wpos += size;
   return o->wpos - size;
@@ -123,7 +123,6 @@ cli_free_out(cli *c)
 
   if (o = c->tx_buf)
     {
-      c->tx_write = c->tx_pos = NULL;
       o->wpos = o->outpos = o->buf;
       while (p = o->next)
        {
@@ -131,6 +130,7 @@ cli_free_out(cli *c)
          mb_free(p);
        }
     }
+  c->tx_write = c->tx_pos = NULL;
   c->async_msg_size = 0;
 }
 
@@ -175,7 +175,7 @@ cli_command(struct cli *c)
     cli_printf(c, 9001, f.err_msg);
 }
 
-static int
+static void
 cli_event(void *data)
 {
   cli *c = data;
@@ -193,7 +193,7 @@ cli_event(void *data)
     {
       err = cli_get_command(c);
       if (!err)
-       return 0;
+       return;
       if (err < 0)
        cli_printf(c, 9000, "Command too long");
       else
@@ -202,9 +202,8 @@ cli_event(void *data)
   if (cli_write(c))
     {
       cli_free_out(c);
-      return 1;
+      ev_schedule(c->event);
     }
-  return 0;
 }
 
 cli *
index 35af2df8bfcb7a29d197a6b797faed68ba5726be..895f5373fc988f01a0b8c497abf3f124ea46da1d 100644 (file)
@@ -870,7 +870,7 @@ sk_write(sock *s)
     case SK_DELETED:
       return;
     default:
-      while (s->ttx != s->tbuf && sk_maybe_write(s) > 0)
+      while (s->ttx != s->tpos && sk_maybe_write(s) > 0)
        s->tx_hook(s);
     }
 }
index 621d85ca4613b61a619c40e0d872111abea51eb8..06d1d1dcb1e16e36bda577989a3fe580f6bdf98b 100644 (file)
@@ -179,9 +179,10 @@ cli_write(cli *c)
       struct cli_out *o = c->tx_pos;
       c->tx_pos = o->next;
       s->tbuf = o->outpos;
-      return sk_send(s, o->wpos - o->outpos);
+      if (sk_send(s, o->wpos - o->outpos) > 0)
+       ev_schedule(c->event);
     }
-  return 1;
+  return !c->tx_pos;
 }
 
 int