From c53b157b0e88d50d3a60d438be22d97bbbcee6d1 Mon Sep 17 00:00:00 2001 From: blogic Date: Tue, 11 Sep 2007 17:34:52 +0000 Subject: fixes bug that causes mp3 stream to hang is server is not fast enough git-svn-id: svn://svn.openwrt.org/openwrt/trunk@8754 3c298f89-4303-0410-b956-a3cf2f4a3e73 --- package/fonera-mp3/src/lib/mp3_stream.c | 12 ++++++------ 1 file changed, 6 insertions(+), 6 deletions(-) (limited to 'package/fonera-mp3/src/lib') diff --git a/package/fonera-mp3/src/lib/mp3_stream.c b/package/fonera-mp3/src/lib/mp3_stream.c index 0dd3437e3..f6f214a99 100644 --- a/package/fonera-mp3/src/lib/mp3_stream.c +++ b/package/fonera-mp3/src/lib/mp3_stream.c @@ -173,15 +173,15 @@ int mp3_stream_setup(unsigned char *url, unsigned int type, unsigned char *ip, ip); printf("Sending request :\n%s\n", icy_request); send(mp3_stream.sockfd, icy_request, strlen(icy_request), 0); - //wait 200 ms ??!? some icecast servers seem to not push data to us fast enough ?!?!? - poll(0,0,200); - if ((mp3_stream.numbytes=recv(mp3_stream.sockfd, mp3_stream.buf, MAX_PACKET_SIZE-1, 0)) == -1) { - perror("recv"); - return MP3_ERROR; + mp3_stream.numbytes = 0; + while(mp3_stream.numbytes < MAX_PACKET_SIZE-1) { + if ((mp3_stream.numbytes += recv(mp3_stream.sockfd, &mp3_stream.buf[mp3_stream.numbytes], MAX_PACKET_SIZE - 1 - mp3_stream.numbytes, 0)) == -1) { + perror("recv"); + return MP3_ERROR; + } } mp3_stream.buf[mp3_stream.numbytes] = '\0'; printf("numbytes = %d\n", mp3_stream.numbytes); - printf("------\n%s\n---------\n", mp3_stream.buf); unsigned char *p = strstr(mp3_stream.buf, "\r\n\r\n"); if(p) { *p = '\0'; -- cgit v1.2.3