From: Wim Taymans Date: Mon, 15 Mar 2010 10:38:23 +0000 (+0100) Subject: rtspsrc: don't forget to send keepalive messages X-Git-Tag: 1.19.3~509^2~8980 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=ba6dbaecfc4beb7d9749cb613defcf6c4c05e522;p=platform%2Fupstream%2Fgstreamer.git rtspsrc: don't forget to send keepalive messages When we operate in TCP mode, still send keepalive messages when we need to. Fixes #612696 --- diff --git a/gst/rtsp/gstrtspsrc.c b/gst/rtsp/gstrtspsrc.c index 59302b1c41..2c68756b71 100644 --- a/gst/rtsp/gstrtspsrc.c +++ b/gst/rtsp/gstrtspsrc.c @@ -3014,8 +3014,17 @@ gst_rtspsrc_loop_interleaved (GstRTSPSrc * src) /* get the next timeout interval */ gst_rtsp_connection_next_timeout (src->connection, &tv_timeout); - GST_DEBUG_OBJECT (src, "doing receive with timeout %d seconds", - (gint) tv_timeout.tv_sec); + /* see if the timeout period expired */ + if ((tv_timeout.tv_sec | tv_timeout.tv_usec) == 0) { + GST_DEBUG_OBJECT (src, "timout, sending keep-alive"); + /* send keep-alive, ignore the result, a warning will be posted. */ + gst_rtspsrc_send_keep_alive (src); + /* get new timeout */ + gst_rtsp_connection_next_timeout (src->connection, &tv_timeout); + } + + GST_DEBUG_OBJECT (src, "doing receive with timeout %ld seconds, %ld usec", + tv_timeout.tv_sec, tv_timeout.tv_usec); /* protect the connection with the connection lock so that we can see when * we are finished doing server communication */