From 4df9597c8484e2884c8e69929c12131fdd27e7f4 Mon Sep 17 00:00:00 2001 From: Alfredo Tupone Date: Fri, 21 Jun 2024 22:59:10 +0200 Subject: [PATCH] c-ares is using threads --- src/net/AresHandler.cxx | 28 +++++++++++++++++++++++++++- 1 file changed, 27 insertions(+), 1 deletion(-) diff --git a/src/net/AresHandler.cxx b/src/net/AresHandler.cxx index 6cea1d0dac..6cda81158c 100644 --- a/src/net/AresHandler.cxx +++ b/src/net/AresHandler.cxx @@ -16,8 +16,10 @@ /* system implementation headers */ #include #include +#include bool AresHandler::globallyInited = false; +std::mutex callback_mutex; AresHandler::AresHandler(int _index) : index(_index), status(None) @@ -28,7 +30,15 @@ AresHandler::AresHandler(int _index) /* ask for local "hosts" lookups too */ static char lookups[] = "fb"; struct ares_options opts; + memset(&opts, 0, sizeof(opts)); + int flags = 0; + opts.lookups = lookups; + flags |= ARES_OPT_LOOKUPS; +#if ARES_VERSION_MAJOR >= 1 && ARES_VERSION_MINOR >= 26 + opts.evsys = ARES_EVSYS_DEFAULT; + flags |= ARES_OPT_EVENT_THREAD; +#endif /* start up our resolver */ if (!globallyInited) @@ -42,7 +52,7 @@ AresHandler::AresHandler(int _index) } /* start up our resolver */ - int code = ares_init_options (&aresChannel, &opts, ARES_OPT_LOOKUPS); + int code = ares_init_options (&aresChannel, &opts, flags); aresFailed = (code != ARES_SUCCESS); if (aresFailed) { @@ -129,6 +139,9 @@ void AresHandler::callback(int callbackStatus, struct hostent *hostent) { if (callbackStatus == ARES_EDESTRUCTION) return; + + const std::lock_guard lock(callback_mutex); + if (callbackStatus != ARES_SUCCESS) { logDebugMessage(1,"Player [%d] failed to resolve: error %d\n", index, @@ -150,17 +163,29 @@ void AresHandler::callback(int callbackStatus, struct hostent *hostent) const char *AresHandler::getHostname() { + const std::lock_guard lock(callback_mutex); + return hostName.c_str(); } AresHandler::ResolutionStatus AresHandler::getHostAddress(struct in_addr *clientAddr) { + const std::lock_guard lock(callback_mutex); + if (status == HbNSucceeded) memcpy(clientAddr, &hostAddress, sizeof(hostAddress)); return status; } +#if ARES_VERSION_MAJOR >= 1 && ARES_VERSION_MINOR >= 26 +void AresHandler::setFd(fd_set *, fd_set *, int &) +{ +} +void AresHandler::process(fd_set *, fd_set *) +{ +} +#else void AresHandler::setFd(fd_set *read_set, fd_set *write_set, int &maxFile) { if (aresFailed) @@ -176,6 +201,7 @@ void AresHandler::process(fd_set *read_set, fd_set *write_set) return; ares_process(aresChannel, read_set, write_set); } +#endif // Local Variables: *** // mode: C++ ***