diff options
author | Nick Mathewson <nickm@torproject.org> | 2007-11-02 16:02:26 +0000 |
---|---|---|
committer | Nick Mathewson <nickm@torproject.org> | 2007-11-02 16:02:26 +0000 |
commit | dfc689bda232de67ff3ed20b145e12e57dd5dd31 (patch) | |
tree | 0110247f06634530a9368f97d3f9ca242f303b21 /src | |
parent | e76581f97eb849a0e3de869828f4ff809d00e9ba (diff) | |
download | tor-dfc689bda232de67ff3ed20b145e12e57dd5dd31.tar.gz tor-dfc689bda232de67ff3ed20b145e12e57dd5dd31.zip |
r14652@tombo: nickm | 2007-11-02 12:02:13 -0400
If setting our rlimit to rlim_max or cap fails, fall back to OPEN_FILES if defiled. This makes Tor run on OSX 10.5, while allowing OSX to mend its ways in the future.
svn:r12341
Diffstat (limited to 'src')
-rw-r--r-- | src/common/compat.c | 33 |
1 files changed, 30 insertions, 3 deletions
diff --git a/src/common/compat.c b/src/common/compat.c index b46591701e..bc99a86d6e 100644 --- a/src/common/compat.c +++ b/src/common/compat.c @@ -94,6 +94,9 @@ const char compat_c_id[] = #ifdef HAVE_SYS_MMAN_H #include <sys/mman.h> #endif +#ifdef HAVE_SYS_SYSLIMITS_H +#include <sys/syslimits.h> +#endif #ifdef USE_BSOCKETS #include <bsocket.h> @@ -710,10 +713,34 @@ set_max_file_descriptors(unsigned long limit, unsigned long cap) (unsigned long)rlim.rlim_cur, (unsigned long)most); } rlim.rlim_cur = most; + if (setrlimit(RLIMIT_NOFILE, &rlim) != 0) { - log_warn(LD_CONFIG, "Could not set maximum number of file descriptors: %s", - strerror(errno)); - return -1; + int bad = 1; +#ifdef OPEN_MAX + if (errno == EINVAL && OPEN_MAX < rlim.rlim_cur) { + /* On some platforms, OPEN_MAX is the real limit, and getrlimit() is + * full of nasty lies. I'm looking at you, OSX 10.5.... */ + rlim.rlim_cur = OPEN_MAX; + if (setrlimit(RLIMIT_NOFILE, &rlim) == 0) { + if (rlim.rlim_cur < limit) { + log_warn(LD_CONFIG, "We are limited to %lu file descriptors by " + "OPEN_MAX, and ConnLimit is %lu. Changing ConnLimit; sorry.", + (unsigned long)OPEN_MAX, limit); + } else { + log_info(LD_CONFIG, "Dropped connection limit to OPEN_MAX (%lu); " + "Apparently, %lu was too high and rlimit lied to us.", + (unsigned long)OPEN_MAX, (unsigned long)most); + } + most = rlim.rlim_cur; + bad = 0; + } + } +#endif + if (bad) { + log_warn(LD_CONFIG, "Couldn't set maximum number of file descriptors: %s", + strerror(errno)); + return -1; + } } /* leave some overhead for logs, etc, */ limit = most; |