vconn-stream: Always call the stream's run function from vconn_stream_run().
authorBen Pfaff <blp@nicira.com>
Fri, 8 Jul 2011 16:11:55 +0000 (09:11 -0700)
committerBen Pfaff <blp@nicira.com>
Fri, 8 Jul 2011 16:11:55 +0000 (09:11 -0700)
The stream's run function ensures that data buffered in the stream itself
gets pushed to the network.  Only the SSL stream class has such a run
function, which means that SSL stream data failed to be pushed to the
remote peer in a timely manner in some cases.

Many thanks to Alex Yip for narrowing this down.

Reported-by: Alex Yip <alex@nicira.com>
Tested-by: Alex Yip <alex@nicira.com>
Bug #6221.

lib/vconn-stream.c

index 39f1c94df3169a601d1f5eeacbe5ed12993d209e..a9890b594b30231c0f739df8982f29a1deb8f660 100644 (file)
@@ -227,6 +227,7 @@ vconn_stream_run(struct vconn *vconn)
     struct vconn_stream *s = vconn_stream_cast(vconn);
     ssize_t retval;
 
+    stream_run(s->stream);
     if (!s->txbuf) {
         return;
     }
@@ -252,6 +253,7 @@ vconn_stream_run_wait(struct vconn *vconn)
 {
     struct vconn_stream *s = vconn_stream_cast(vconn);
 
+    stream_run_wait(s->stream);
     if (s->txbuf) {
         stream_send_wait(s->stream);
     }