Commit 96e3e928 authored by Greg Turner's avatar Greg Turner Committed by Alexandre Julliard

Accept time_t argument in WS_setsockopt/WS_SO_RCVTIMEO; translate to

struct timeval for edification of setsockopt.
parent e9119c19
...@@ -2670,6 +2670,7 @@ int WINAPI WS_setsockopt(SOCKET s, int level, int optname, ...@@ -2670,6 +2670,7 @@ int WINAPI WS_setsockopt(SOCKET s, int level, int optname,
{ {
struct linger linger; struct linger linger;
int woptval; int woptval;
struct timeval tval;
/* Is a privileged and useless operation, so we don't. */ /* Is a privileged and useless operation, so we don't. */
if ((optname == WS_SO_DEBUG) && (level == WS_SOL_SOCKET)) { if ((optname == WS_SO_DEBUG) && (level == WS_SOL_SOCKET)) {
...@@ -2704,6 +2705,21 @@ int WINAPI WS_setsockopt(SOCKET s, int level, int optname, ...@@ -2704,6 +2705,21 @@ int WINAPI WS_setsockopt(SOCKET s, int level, int optname,
optval= (char*) &woptval; optval= (char*) &woptval;
optlen=sizeof(int); optlen=sizeof(int);
} }
if (level == SOL_SOCKET && optname == SO_RCVTIMEO && optlen < sizeof(struct timeval)) {
if (optlen == sizeof(time_t)) {
/* Apparently WinSock will accept a shortened struct timeval.
FIXME: should we do the same for SO_SNDTIMEO? */
WARN("Short struct timeval in SO_RCVTIMEO: assuming time_t\n");
tval.tv_sec = *(time_t*)optval;
tval.tv_usec = 0;
optlen = sizeof(struct timeval);
optval = (char*)&tval;
} else {
WARN("SO_RCVTIMEO for %d bytes is too small: ignored\n", optlen);
close(fd);
return 0;
}
}
} }
if(optname == SO_RCVBUF && *(int*)optval < 2048) { if(optname == SO_RCVBUF && *(int*)optval < 2048) {
WARN("SO_RCVBF for %d bytes is too small: ignored\n", *(int*)optval ); WARN("SO_RCVBF for %d bytes is too small: ignored\n", *(int*)optval );
......
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