Commit a6e14512 authored by michael's avatar michael

support url_read which reads less then requested patch by (Leon van...

support url_read which reads less then requested patch by (Leon van Stuivenberg <l dot vanstuivenberg at chello dot nl>)
this is needed for compatibility with tcp.c 1.10


git-svn-id: file:///var/local/repositories/ffmpeg/trunk@2911 9553f0bf-9b14-0410-a0b8-cfaf0461ba5b
parent c5760371
...@@ -562,6 +562,20 @@ void rtsp_parse_line(RTSPHeader *reply, const char *buf) ...@@ -562,6 +562,20 @@ void rtsp_parse_line(RTSPHeader *reply, const char *buf)
} }
} }
static int url_readbuf(URLContext *h, unsigned char *buf, int size)
{
int ret, len;
len = 0;
while (len < size) {
ret = url_read(h, buf+len, size-len);
if (ret < 1)
return ret;
len += ret;
}
return len;
}
/* skip a RTP/TCP interleaved packet */ /* skip a RTP/TCP interleaved packet */
static void rtsp_skip_packet(AVFormatContext *s) static void rtsp_skip_packet(AVFormatContext *s)
{ {
...@@ -569,7 +583,7 @@ static void rtsp_skip_packet(AVFormatContext *s) ...@@ -569,7 +583,7 @@ static void rtsp_skip_packet(AVFormatContext *s)
int ret, len, len1; int ret, len, len1;
uint8_t buf[1024]; uint8_t buf[1024];
ret = url_read(rt->rtsp_hd, buf, 3); ret = url_readbuf(rt->rtsp_hd, buf, 3);
if (ret != 3) if (ret != 3)
return; return;
len = (buf[1] << 8) | buf[2]; len = (buf[1] << 8) | buf[2];
...@@ -581,7 +595,7 @@ static void rtsp_skip_packet(AVFormatContext *s) ...@@ -581,7 +595,7 @@ static void rtsp_skip_packet(AVFormatContext *s)
len1 = len; len1 = len;
if (len1 > sizeof(buf)) if (len1 > sizeof(buf))
len1 = sizeof(buf); len1 = sizeof(buf);
ret = url_read(rt->rtsp_hd, buf, len1); ret = url_readbuf(rt->rtsp_hd, buf, len1);
if (ret != len1) if (ret != len1)
return; return;
len -= len1; len -= len1;
...@@ -621,7 +635,7 @@ static void rtsp_send_cmd(AVFormatContext *s, ...@@ -621,7 +635,7 @@ static void rtsp_send_cmd(AVFormatContext *s,
for(;;) { for(;;) {
q = buf; q = buf;
for(;;) { for(;;) {
if (url_read(rt->rtsp_hd, &ch, 1) != 1) if (url_readbuf(rt->rtsp_hd, &ch, 1) != 1)
break; break;
if (ch == '\n') if (ch == '\n')
break; break;
...@@ -661,7 +675,7 @@ static void rtsp_send_cmd(AVFormatContext *s, ...@@ -661,7 +675,7 @@ static void rtsp_send_cmd(AVFormatContext *s,
if (content_length > 0) { if (content_length > 0) {
/* leave some room for a trailing '\0' (useful for simple parsing) */ /* leave some room for a trailing '\0' (useful for simple parsing) */
content = av_malloc(content_length + 1); content = av_malloc(content_length + 1);
url_read(rt->rtsp_hd, content, content_length); (void)url_readbuf(rt->rtsp_hd, content, content_length);
content[content_length] = '\0'; content[content_length] = '\0';
} }
if (content_ptr) if (content_ptr)
...@@ -921,7 +935,7 @@ static int tcp_read_packet(AVFormatContext *s, RTSPStream **prtsp_st, ...@@ -921,7 +935,7 @@ static int tcp_read_packet(AVFormatContext *s, RTSPStream **prtsp_st,
#endif #endif
redo: redo:
for(;;) { for(;;) {
ret = url_read(rt->rtsp_hd, buf, 1); ret = url_readbuf(rt->rtsp_hd, buf, 1);
#ifdef DEBUG_RTP_TCP #ifdef DEBUG_RTP_TCP
printf("ret=%d c=%02x [%c]\n", ret, buf[0], buf[0]); printf("ret=%d c=%02x [%c]\n", ret, buf[0], buf[0]);
#endif #endif
...@@ -930,7 +944,7 @@ static int tcp_read_packet(AVFormatContext *s, RTSPStream **prtsp_st, ...@@ -930,7 +944,7 @@ static int tcp_read_packet(AVFormatContext *s, RTSPStream **prtsp_st,
if (buf[0] == '$') if (buf[0] == '$')
break; break;
} }
ret = url_read(rt->rtsp_hd, buf, 3); ret = url_readbuf(rt->rtsp_hd, buf, 3);
if (ret != 3) if (ret != 3)
return -1; return -1;
id = buf[0]; id = buf[0];
...@@ -941,7 +955,7 @@ static int tcp_read_packet(AVFormatContext *s, RTSPStream **prtsp_st, ...@@ -941,7 +955,7 @@ static int tcp_read_packet(AVFormatContext *s, RTSPStream **prtsp_st,
if (len > buf_size || len < 12) if (len > buf_size || len < 12)
goto redo; goto redo;
/* get the data */ /* get the data */
ret = url_read(rt->rtsp_hd, buf, len); ret = url_readbuf(rt->rtsp_hd, buf, len);
if (ret != len) if (ret != len)
return -1; return -1;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment