Originally committed as revision 7581 to svn://svn.ffmpeg.org/ffmpeg/trunktags/v0.5
| @@ -23,11 +23,7 @@ | |||||
| #include <sys/types.h> | #include <sys/types.h> | ||||
| #include <sys/socket.h> | #include <sys/socket.h> | ||||
| #include <netinet/in.h> | #include <netinet/in.h> | ||||
| #ifndef __BEOS__ | |||||
| # include <arpa/inet.h> | |||||
| #else | |||||
| # include "barpainet.h" | |||||
| #endif | |||||
| #include <arpa/inet.h> | |||||
| #include <netdb.h> | #include <netdb.h> | ||||
| #include "base64.h" | #include "base64.h" | ||||
| @@ -26,12 +26,18 @@ | |||||
| * @file os_support.h | * @file os_support.h | ||||
| * miscellaneous OS support macros and functions. | * miscellaneous OS support macros and functions. | ||||
| * | * | ||||
| * - socklen_t typedef (BeOS, Innotek libc) | |||||
| * - usleep() (Win32, BeOS, OS/2) | * - usleep() (Win32, BeOS, OS/2) | ||||
| * - lseek() (Win32) | * - lseek() (Win32) | ||||
| * - floatf() (OS/2) | * - floatf() (OS/2) | ||||
| * - strcasecmp() (OS/2) | * - strcasecmp() (OS/2) | ||||
| * - closesocket() | |||||
| */ | */ | ||||
| #if defined(__BEOS__) || defined(__INNOTEK_LIBC__) | |||||
| typedef int socklen_t; | |||||
| #endif | |||||
| #ifdef __MINGW32__ | #ifdef __MINGW32__ | ||||
| __declspec(dllimport) void __stdcall Sleep(unsigned long dwMilliseconds); | __declspec(dllimport) void __stdcall Sleep(unsigned long dwMilliseconds); | ||||
| // # include <windows.h> | // # include <windows.h> | ||||
| @@ -40,9 +46,23 @@ __declspec(dllimport) void __stdcall Sleep(unsigned long dwMilliseconds); | |||||
| # define lseek(f,p,w) _lseeki64((f), (p), (w)) | # define lseek(f,p,w) _lseeki64((f), (p), (w)) | ||||
| #endif | #endif | ||||
| /* XXX: check for Winsock here */ | |||||
| #if 0 | |||||
| #define HAVE_CLOSESOCKET 1 | |||||
| #endif | |||||
| #ifdef __BEOS__ | #ifdef __BEOS__ | ||||
| # ifndef usleep | |||||
| # include <sys/socket.h> | |||||
| # include <netinet/in.h> | |||||
| /* not net_server ? */ | |||||
| # if IPPROTO_TCP != 6 | |||||
| # define HAVE_CLOSESOCKET 1 | |||||
| # endif | |||||
| # include <BeBuild.h> | |||||
| /* R5 didn't have usleep, fake it. Haiku and Zeta has it now. */ | |||||
| # if B_BEOS_VERSION <= B_BEOS_VERSION_5 | |||||
| # include <OS.h> | # include <OS.h> | ||||
| /* doesn't set errno but that's enough */ | |||||
| # define usleep(t) snooze((bigtime_t)(t)) | # define usleep(t) snooze((bigtime_t)(t)) | ||||
| # endif | # endif | ||||
| #endif | #endif | ||||
| @@ -53,4 +73,9 @@ static inline int usleep(unsigned int t) { return _sleep2(t / 1000); } | |||||
| static inline int strcasecmp(const char* s1, const char* s2) { return stricmp(s1,s2); } | static inline int strcasecmp(const char* s1, const char* s2) { return stricmp(s1,s2); } | ||||
| #endif | #endif | ||||
| /* most of the time closing a socket is just closing an fd */ | |||||
| #if HAVE_CLOSESOCKET != 1 | |||||
| #define closesocket close | |||||
| #endif | |||||
| #endif /* _OS_SUPPORT_H */ | #endif /* _OS_SUPPORT_H */ | ||||
| @@ -26,11 +26,7 @@ | |||||
| #include <sys/types.h> | #include <sys/types.h> | ||||
| #include <sys/socket.h> | #include <sys/socket.h> | ||||
| #include <netinet/in.h> | #include <netinet/in.h> | ||||
| #ifndef __BEOS__ | |||||
| # include <arpa/inet.h> | |||||
| #else | |||||
| # include "barpainet.h" | |||||
| #endif | |||||
| #include <arpa/inet.h> | |||||
| #include <netdb.h> | #include <netdb.h> | ||||
| #include "rtp_internal.h" | #include "rtp_internal.h" | ||||
| @@ -45,11 +45,7 @@ | |||||
| #include <sys/socket.h> | #include <sys/socket.h> | ||||
| #include <netinet/in.h> | #include <netinet/in.h> | ||||
| #include <assert.h> | #include <assert.h> | ||||
| #ifndef __BEOS__ | |||||
| # include <arpa/inet.h> | |||||
| #else | |||||
| # include "barpainet.h" | |||||
| #endif | |||||
| #include <arpa/inet.h> | |||||
| #include <netdb.h> | #include <netdb.h> | ||||
| #include "rtp_internal.h" | #include "rtp_internal.h" | ||||
| @@ -25,11 +25,7 @@ | |||||
| #include <sys/types.h> | #include <sys/types.h> | ||||
| #include <sys/socket.h> | #include <sys/socket.h> | ||||
| #include <netinet/in.h> | #include <netinet/in.h> | ||||
| #ifndef __BEOS__ | |||||
| # include <arpa/inet.h> | |||||
| #else | |||||
| # include "barpainet.h" | |||||
| #endif | |||||
| #include <arpa/inet.h> | |||||
| #include <netdb.h> | #include <netdb.h> | ||||
| #include <fcntl.h> | #include <fcntl.h> | ||||
| @@ -24,11 +24,7 @@ | |||||
| #include <sys/time.h> | #include <sys/time.h> | ||||
| #include <netinet/in.h> | #include <netinet/in.h> | ||||
| #include <sys/socket.h> | #include <sys/socket.h> | ||||
| #ifndef __BEOS__ | |||||
| # include <arpa/inet.h> | |||||
| #else | |||||
| # include "barpainet.h" | |||||
| #endif | |||||
| #include <arpa/inet.h> | |||||
| #include "rtp_internal.h" | #include "rtp_internal.h" | ||||
| @@ -23,14 +23,7 @@ | |||||
| #include <sys/types.h> | #include <sys/types.h> | ||||
| #include <sys/socket.h> | #include <sys/socket.h> | ||||
| #include <netinet/in.h> | #include <netinet/in.h> | ||||
| #if defined(__BEOS__) || defined(__INNOTEK_LIBC__) | |||||
| typedef int socklen_t; | |||||
| #endif | |||||
| #ifndef __BEOS__ | |||||
| # include <arpa/inet.h> | # include <arpa/inet.h> | ||||
| #else | |||||
| # include "barpainet.h" | |||||
| #endif | |||||
| #include <netdb.h> | #include <netdb.h> | ||||
| #include <sys/time.h> | #include <sys/time.h> | ||||
| #include <fcntl.h> | #include <fcntl.h> | ||||
| @@ -127,7 +120,7 @@ static int tcp_open(URLContext *h, const char *uri, int flags) | |||||
| ret = AVERROR_IO; | ret = AVERROR_IO; | ||||
| fail1: | fail1: | ||||
| if (fd >= 0) | if (fd >= 0) | ||||
| close(fd); | |||||
| closesocket(fd); | |||||
| av_free(s); | av_free(s); | ||||
| return ret; | return ret; | ||||
| } | } | ||||
| @@ -213,11 +206,7 @@ static int tcp_write(URLContext *h, uint8_t *buf, int size) | |||||
| static int tcp_close(URLContext *h) | static int tcp_close(URLContext *h) | ||||
| { | { | ||||
| TCPContext *s = h->priv_data; | TCPContext *s = h->priv_data; | ||||
| #ifdef CONFIG_BEOS_NETSERVER | |||||
| closesocket(s->fd); | closesocket(s->fd); | ||||
| #else | |||||
| close(s->fd); | |||||
| #endif | |||||
| av_free(s); | av_free(s); | ||||
| return 0; | return 0; | ||||
| } | } | ||||
| @@ -23,11 +23,7 @@ | |||||
| #include <sys/types.h> | #include <sys/types.h> | ||||
| #include <sys/socket.h> | #include <sys/socket.h> | ||||
| #include <netinet/in.h> | #include <netinet/in.h> | ||||
| #ifndef __BEOS__ | |||||
| # include <arpa/inet.h> | # include <arpa/inet.h> | ||||
| #else | |||||
| # include "barpainet.h" | |||||
| #endif | |||||
| #include <netdb.h> | #include <netdb.h> | ||||
| #ifndef IPV6_ADD_MEMBERSHIP | #ifndef IPV6_ADD_MEMBERSHIP | ||||
| @@ -214,11 +210,7 @@ static int udp_ipv6_set_local(URLContext *h) { | |||||
| fail: | fail: | ||||
| if (udp_fd >= 0) | if (udp_fd >= 0) | ||||
| #ifdef CONFIG_BEOS_NETSERVER | |||||
| closesocket(udp_fd); | closesocket(udp_fd); | ||||
| #else | |||||
| close(udp_fd); | |||||
| #endif | |||||
| if(res0) | if(res0) | ||||
| freeaddrinfo(res0); | freeaddrinfo(res0); | ||||
| return -1; | return -1; | ||||
| @@ -421,11 +413,7 @@ static int udp_open(URLContext *h, const char *uri, int flags) | |||||
| return 0; | return 0; | ||||
| fail: | fail: | ||||
| if (udp_fd >= 0) | if (udp_fd >= 0) | ||||
| #ifdef CONFIG_BEOS_NETSERVER | |||||
| closesocket(udp_fd); | closesocket(udp_fd); | ||||
| #else | |||||
| close(udp_fd); | |||||
| #endif | |||||
| av_free(s); | av_free(s); | ||||
| return AVERROR_IO; | return AVERROR_IO; | ||||
| } | } | ||||
| @@ -482,22 +470,20 @@ static int udp_close(URLContext *h) | |||||
| { | { | ||||
| UDPContext *s = h->priv_data; | UDPContext *s = h->priv_data; | ||||
| #ifndef CONFIG_BEOS_NETSERVER | |||||
| #ifndef CONFIG_IPV6 | #ifndef CONFIG_IPV6 | ||||
| #ifdef IP_DROP_MEMBERSHIP | |||||
| if (s->is_multicast && !(h->flags & URL_WRONLY)) { | if (s->is_multicast && !(h->flags & URL_WRONLY)) { | ||||
| if (setsockopt(s->udp_fd, IPPROTO_IP, IP_DROP_MEMBERSHIP, | if (setsockopt(s->udp_fd, IPPROTO_IP, IP_DROP_MEMBERSHIP, | ||||
| &s->mreq, sizeof(s->mreq)) < 0) { | &s->mreq, sizeof(s->mreq)) < 0) { | ||||
| perror("IP_DROP_MEMBERSHIP"); | perror("IP_DROP_MEMBERSHIP"); | ||||
| } | } | ||||
| } | } | ||||
| #endif | |||||
| #else | #else | ||||
| if (s->is_multicast && !(h->flags & URL_WRONLY)) | if (s->is_multicast && !(h->flags & URL_WRONLY)) | ||||
| udp_ipv6_leave_multicast_group(s->udp_fd, (struct sockaddr *)&s->dest_addr); | udp_ipv6_leave_multicast_group(s->udp_fd, (struct sockaddr *)&s->dest_addr); | ||||
| #endif | #endif | ||||
| close(s->udp_fd); | |||||
| #else | |||||
| closesocket(s->udp_fd); | closesocket(s->udp_fd); | ||||
| #endif | |||||
| av_free(s); | av_free(s); | ||||
| return 0; | return 0; | ||||
| } | } | ||||