summaryrefslogtreecommitdiff
path: root/src/common
diff options
context:
space:
mode:
authorFlavioJS <FlavioJS@54d463be-8e91-2dee-dedb-b68131a5f0ec>2008-06-16 05:07:56 +0000
committerFlavioJS <FlavioJS@54d463be-8e91-2dee-dedb-b68131a5f0ec>2008-06-16 05:07:56 +0000
commit583bd00e1ec300316c38f83e82563083f83d7618 (patch)
treef4a013160c71155c3a663d44e18876d8e908db92 /src/common
parentc4c16e065a4be69d0f3c10b0c91cc17014361c9a (diff)
downloadhercules-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.h4
-rw-r--r--src/common/socket.c11
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);
}
}
}