]> git.puffer.fish Git - mirror/frr.git/commitdiff
2005-01-05 Paul Jakma <paul@dishone.st>
authorpaul <paul>
Wed, 5 Jan 2005 08:14:13 +0000 (08:14 +0000)
committerpaul <paul>
Wed, 5 Jan 2005 08:14:13 +0000 (08:14 +0000)
* bgp_packet.c: (bgp_write) set socket to nonblock while writing
          this should be generalised. See bugzilla #102. Fix supplied by
  wawa@yandex-team.ru (Vladimir Ivanov).

bgpd/ChangeLog
bgpd/bgp_packet.c

index b9d0cd5923af85825279951d8643417d430555ff..79414defb81ddf2ee44f8a73ff32e1124baa682a 100644 (file)
@@ -1,3 +1,9 @@
+2005-01-05 Paul Jakma <paul@dishone.st>
+
+       * bgp_packet.c: (bgp_write) set socket to nonblock while writing
+          this should be generalised. See bugzilla #102. Fix supplied by
+         wawa@yandex-team.ru (Vladimir Ivanov).
+
 2004-12-08 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
 
        * *.c: Change level of debug messages to LOG_DEBUG.
index 4eb7050c0fb2811ba9eed506bab58e7a78a4f215..5640e2b7b02e03162c0aebfd925ee6e4b0e3eb5c 100644 (file)
@@ -566,10 +566,17 @@ bgp_write (struct thread *thread)
   while (1)
     {
       int writenum;
+      int val;
 
       s = bgp_write_packet (peer);
       if (! s)
        return 0;
+      
+      /* XXX: FIXME, the socket should be NONBLOCK from the start
+       * status shouldnt need to be toggled on each write
+       */
+      val = fcntl (peer->fd, F_GETFL, 0);
+      fcntl (peer->fd, F_SETFL, val|O_NONBLOCK);
 
       /* Number of bytes to be sent.  */
       writenum = stream_get_endp (s) - stream_get_getp (s);
@@ -577,6 +584,7 @@ bgp_write (struct thread *thread)
       /* Call write() system call.  */
       num = write (peer->fd, STREAM_PNT (s), writenum);
       write_errno = errno;
+      fcntl (peer->fd, F_SETFL, val);
       if (num <= 0)
        {
          /* Partial write. */