]> git.sesse.net Git - vlc/commitdiff
Fix hang in live555 when sending RTSP OPTIONS by letting readSocket() timeout after...
authorJean-Paul Saman <jpsaman@videolan.org>
Mon, 10 Dec 2007 10:03:13 +0000 (10:03 +0000)
committerJean-Paul Saman <jpsaman@videolan.org>
Mon, 10 Dec 2007 10:03:13 +0000 (10:03 +0000)
extras/contrib/src/Patches/live.patch
modules/demux/live555.cpp

index a53bf9dc88e0dbcf8be5fd0af560fb90d4c76303..208db1bc11fc4527e54411cd9eb4eb866abb67f3 100644 (file)
@@ -114,3 +114,26 @@ diff -ru live/groupsock/NetInterface.cpp live-patched/groupsock/NetInterface.cpp
  }
  
  Boolean RTSPClient::parseGetParameterHeader(char const* line, 
+--- live/liveMedia/RTSPClient.cpp      2007-04-28 16:02:39.000000000 +0200
++++ live-patched/liveMedia/RTSPClient.cpp      2007-12-10 10:42:00.000000000 +0100
+@@ -2074,7 +2076,8 @@ Boolean RTSPClient::getResponse(char con
+ unsigned RTSPClient::getResponse1(char*& responseBuffer,
+                                 unsigned responseBufferSize) {
+   struct sockaddr_in fromAddress;
+-  
++  struct timeval timeout;
++
+   if (responseBufferSize == 0) return 0; // just in case...
+   responseBuffer[0] = '\0'; // ditto
+@@ -2084,7 +2087,9 @@ unsigned RTSPClient::getResponse1(char*&
+   Boolean success = False;
+   while (1) {
+     unsigned char firstByte;
+-    if (readSocket(envir(), fInputSocketNum, &firstByte, 1, fromAddress)
++    timeout.tv_sec = 5;
++    timeout.tv_usec = 0;
++    if (readSocket(envir(), fInputSocketNum, &firstByte, 1, fromAddress, &timeout)
+       != 1) break;
+     if (firstByte != '$') {
+       // Normal case: This is the start of a regular response; use it:
index 81ebcd58f30e04db2b1517351ea283f01f2b2267..7133bdde3a7aa6d22cd018d4224208fb6f58a686 100644 (file)
@@ -552,6 +552,12 @@ describe:
             if( p_sys->rtsp ) RTSPClient::close( p_sys->rtsp );
             goto createnew;
         }
+        else
+        {
+            msg_Info( p_demux, "connection timeout, retrying" );
+            if( p_sys->rtsp ) RTSPClient::close( p_sys->rtsp );
+            goto createnew;
+        }
         i_ret = VLC_EGENERIC;
     }
     if( psz_url ) free( psz_url );