diff options
author | FlavioJS <FlavioJS@54d463be-8e91-2dee-dedb-b68131a5f0ec> | 2008-06-16 05:07:56 +0000 |
---|---|---|
committer | FlavioJS <FlavioJS@54d463be-8e91-2dee-dedb-b68131a5f0ec> | 2008-06-16 05:07:56 +0000 |
commit | 583bd00e1ec300316c38f83e82563083f83d7618 (patch) | |
tree | f4a013160c71155c3a663d44e18876d8e908db92 /src/common | |
parent | c4c16e065a4be69d0f3c10b0c91cc17014361c9a (diff) | |
download | hercules-583bd00e1ec300316c38f83e82563083f83d7618.tar.gz hercules-583bd00e1ec300316c38f83e82563083f83d7618.tar.bz2 hercules-583bd00e1ec300316c38f83e82563083f83d7618.tar.xz hercules-583bd00e1ec300316c38f83e82563083f83d7618.zip |
* Made the socket limit not be set in cygwin, which has bogus behavior. (bugreport:1684)
* Made the socket limit be set to the maximum allowed value when setting to FD_SETSIZE fails.
git-svn-id: https://rathena.svn.sourceforge.net/svnroot/rathena/trunk@12839 54d463be-8e91-2dee-dedb-b68131a5f0ec
Diffstat (limited to 'src/common')
-rw-r--r-- | src/common/cbasetypes.h | 4 | ||||
-rw-r--r-- | src/common/socket.c | 11 |
2 files changed, 13 insertions, 2 deletions
diff --git a/src/common/cbasetypes.h b/src/common/cbasetypes.h index 2a2d958ff..f94e9c6e7 100644 --- a/src/common/cbasetypes.h +++ b/src/common/cbasetypes.h @@ -33,6 +33,10 @@ #define MINGW #endif +#if (defined(__CYGWIN__) || defined(__CYGWIN32__)) && !defined(CYGWIN) +#define CYGWIN +#endif + // __APPLE__ is the only predefined macro on MacOS X #if defined(__APPLE__) #define __DARWIN__ diff --git a/src/common/socket.c b/src/common/socket.c index 7addc271b..022a4ae72 100644 --- a/src/common/socket.c +++ b/src/common/socket.c @@ -1204,7 +1204,9 @@ void socket_init(void) return; } } -#elif defined(HAVE_SETRLIMIT) +#elif defined(HAVE_SETRLIMIT) && !defined(CYGWIN) + // NOTE: getrlimit and setrlimit have bogus behaviour in cygwin. + // "Number of fds is virtually unlimited in cygwin" (sys/param.h) {// set socket limit to FD_SETSIZE struct rlimit rlp; if( 0 == getrlimit(RLIMIT_NOFILE, &rlp) ) @@ -1215,8 +1217,13 @@ void socket_init(void) rlp.rlim_max = FD_SETSIZE; if( 0 != setrlimit(RLIMIT_NOFILE, &rlp) ) {// failed + // set to maximum allowed getrlimit(RLIMIT_NOFILE, &rlp); - ShowWarning("socket_init: %s - failed to set socket limit to %d (current limit %d).\n", strerror(errno), FD_SETSIZE, (int)rlp.rlim_cur); + rlp.rlim_cur = rlp.rlim_max; + setrlimit(RLIMIT_NOFILE, &rlp); + // report limit + getrlimit(RLIMIT_NOFILE, &rlp); + ShowWarning("socket_init: failed to set socket limit to %d (current limit %d).\n", FD_SETSIZE, (int)rlp.rlim_cur); } } } |