diff options
Diffstat (limited to 'net-dns/pdns-recursor/files')
3 files changed, 0 insertions, 130 deletions
diff --git a/net-dns/pdns-recursor/files/pdns-recursor-3.1.7.2-error-message.patch b/net-dns/pdns-recursor/files/pdns-recursor-3.1.7.2-error-message.patch deleted file mode 100644 index 7fdf208037cd..000000000000 --- a/net-dns/pdns-recursor/files/pdns-recursor-3.1.7.2-error-message.patch +++ /dev/null @@ -1,11 +0,0 @@ ---- pdns-recursor-3.1.7.2/rec_channel.cc -+++ pdns-recursor-3.1.7.2/rec_channel.cc -@@ -100,7 +100,7 @@ - strcpy(remote.sun_path,(path+"/"+fname).c_str()); - if(::connect(d_fd, (sockaddr*)&remote, sizeof(remote)) < 0) { - unlink(d_local.sun_path); -- throw AhuException("Unable to connect to remote '"+path+fname+"': "+string(strerror(errno))); -+ throw AhuException("Unable to connect to remote '"+path+"/"+fname+"': "+string(strerror(errno))); - } - } - diff --git a/net-dns/pdns-recursor/files/pdns-recursor-3.5.3-fdlimit.patch b/net-dns/pdns-recursor/files/pdns-recursor-3.5.3-fdlimit.patch deleted file mode 100644 index 3b6e8e25d972..000000000000 --- a/net-dns/pdns-recursor/files/pdns-recursor-3.5.3-fdlimit.patch +++ /dev/null @@ -1,67 +0,0 @@ ---- pdns-recursor-3.5.3/misc.cc -+++ pdns-recursor-3.5.3/misc.cc -@@ -22,6 +22,7 @@ - #include <netdb.h> - #include <sys/time.h> - #include <time.h> -+#include <sys/resource.h> - #include <netinet/in.h> - #include <unistd.h> - #endif // WIN32 -@@ -697,3 +698,22 @@ - } while(!strchr(buffer, '\n')); - return true; - } -+ -+unsigned int getFilenumLimit(bool hardOrSoft) -+{ -+ struct rlimit rlim; -+ if(getrlimit(RLIMIT_NOFILE, &rlim) < 0) -+ unixDie("Requesting number of available file descriptors"); -+ return hardOrSoft ? rlim.rlim_max : rlim.rlim_cur; -+} -+ -+void setFilenumLimit(unsigned int lim) -+{ -+ struct rlimit rlim; -+ -+ if(getrlimit(RLIMIT_NOFILE, &rlim) < 0) -+ unixDie("Requesting number of available file descriptors"); -+ rlim.rlim_cur=lim; -+ if(setrlimit(RLIMIT_NOFILE, &rlim) < 0) -+ unixDie("Setting number of available file descriptors"); -+} ---- pdns-recursor-3.5.3/misc.hh -+++ pdns-recursor-3.5.3/misc.hh -@@ -445,4 +445,6 @@ - regex_t d_preg; - }; - -+unsigned int getFilenumLimit(bool hardOrSoft=0); -+void setFilenumLimit(unsigned int lim); - #endif ---- pdns-recursor-3.5.3/pdns_recursor.cc -+++ pdns-recursor-3.5.3/pdns_recursor.cc -@@ -1740,7 +1740,21 @@ - - g_tcpTimeout=::arg().asNum("client-tcp-timeout"); - g_maxTCPPerClient=::arg().asNum("max-tcp-per-client"); -- g_maxMThreads=::arg().asNum("max-mthreads"); -+ g_maxMThreads=::arg().asNum("max-mthreads"); -+ unsigned int availFDs=getFilenumLimit(); -+ if(g_maxMThreads * g_numThreads > availFDs) { -+ if(getFilenumLimit(true) >= g_maxMThreads * g_numThreads) { -+ setFilenumLimit(g_maxMThreads * g_numThreads); -+ L<<Logger::Warning<<"Raised soft limit on number of filedescriptors to "<<g_maxMThreads * g_numThreads<<" to match max-mthreads and threads settings"<<endl; -+ } -+ else { -+ int newval = getFilenumLimit(true) / g_numThreads; -+ L<<Logger::Warning<<"Insufficient number of filedescriptors available for max-mthreads*threads setting! ("<<availFDs<<" < "<<g_maxMThreads*g_numThreads<<"), reducing max-mthreads to "<<newval<<endl; -+ g_maxMThreads = newval; -+ } -+ -+ -+ } - - if(g_numThreads == 1) { - L<<Logger::Warning<<"Operating unthreaded"<<endl; diff --git a/net-dns/pdns-recursor/files/pdns-recursor-3.6.1-CVE-2014-8601.patch b/net-dns/pdns-recursor/files/pdns-recursor-3.6.1-CVE-2014-8601.patch deleted file mode 100644 index 44ccc2803848..000000000000 --- a/net-dns/pdns-recursor/files/pdns-recursor-3.6.1-CVE-2014-8601.patch +++ /dev/null @@ -1,52 +0,0 @@ -https://downloads.powerdns.com/patches/2014-02/3.6.1.patch - -diff --git a/pdns_recursor.cc b/pdns_recursor.cc -index f1ef93c..8e43d6e 100644 ---- a/pdns_recursor.cc -+++ b/pdns_recursor.cc -@@ -550,7 +550,14 @@ void startDoResolve(void *p) - - // if there is a RecursorLua active, and it 'took' the query in preResolve, we don't launch beginResolve - if(!t_pdl->get() || !(*t_pdl)->preresolve(dc->d_remote, g_listenSocketsAddresses[dc->d_socket], dc->d_mdp.d_qname, QType(dc->d_mdp.d_qtype), ret, res, &variableAnswer)) { -- res = sr.beginResolve(dc->d_mdp.d_qname, QType(dc->d_mdp.d_qtype), dc->d_mdp.d_qclass, ret); -+ try { -+ res = sr.beginResolve(dc->d_mdp.d_qname, QType(dc->d_mdp.d_qtype), dc->d_mdp.d_qclass, ret); -+ } -+ catch(ImmediateServFailException &e) { -+ L<<Logger::Error<<"Sending SERVFAIL during resolve of '"<<dc->d_mdp.d_qname<<"' because: "<<e.reason<<endl; -+ -+ res = RCode::ServFail; -+ } - - if(t_pdl->get()) { - if(res == RCode::NoError) { -diff --git a/syncres.cc b/syncres.cc -index 4dc78b4..d09e44b 100644 ---- a/syncres.cc -+++ b/syncres.cc -@@ -923,6 +923,7 @@ int SyncRes::doResolveAt(set<string, CIStringCompare> nameservers, string auth, - } - else { - s_outqueries++; d_outqueries++; -+ if(d_outqueries > 50) throw ImmediateServFailException("more than 50 queries sent while resolving "+qname); - TryTCP: - if(doTCP) { - LOG(prefix<<qname<<": using TCP with "<< remoteIP->toStringWithPort() <<endl); -diff --git a/syncres.hh b/syncres.hh -index 5182527..b22de89 100644 ---- a/syncres.hh -+++ b/syncres.hh -@@ -593,6 +593,13 @@ private: - static AtomicCounter s_currentConnections; //!< total number of current TCP connections - }; - -+class ImmediateServFailException -+{ -+public: -+ ImmediateServFailException(string r){reason=r;}; -+ -+ string reason; //! Print this to tell the user what went wrong -+}; - - struct RemoteKeeper - { |