|
|
3116d3 |
commit ba675ed25a26fd425ffd19b02cf18babf4291b4f
|
|
|
3116d3 |
Author: Mark Wielaard <mark@klomp.org>
|
|
|
3116d3 |
Date: Thu May 5 23:59:57 2022 +0200
|
|
|
3116d3 |
|
|
|
3116d3 |
debuginfod: Try without MHD_USE_DUAL_STACK if MHD_start_daemon fails
|
|
|
3116d3 |
|
|
|
3116d3 |
On a systems that have ipv6 disabled debuginfod doesn't start up
|
|
|
3116d3 |
anymore because libhttpd MHD_USE_DUAL_STACK only works if it can
|
|
|
3116d3 |
open an ipv6 socket. If MHD_start_daemon with MHD_USE_DUAL_STACK
|
|
|
3116d3 |
fails try again without that flag set.
|
|
|
3116d3 |
|
|
|
3116d3 |
https://sourceware.org/bugzilla/show_bug.cgi?id=29122
|
|
|
3116d3 |
|
|
|
3116d3 |
Signed-off-by: Mark Wielaard <mark@klomp.org>
|
|
|
3116d3 |
|
|
|
3116d3 |
diff --git a/debuginfod/debuginfod.cxx b/debuginfod/debuginfod.cxx
|
|
|
3116d3 |
index 4aaf41c0..c02540f1 100644
|
|
|
3116d3 |
--- a/debuginfod/debuginfod.cxx
|
|
|
3116d3 |
+++ b/debuginfod/debuginfod.cxx
|
|
|
3116d3 |
@@ -3899,40 +3899,67 @@ main (int argc, char *argv[])
|
|
|
3116d3 |
}
|
|
|
3116d3 |
}
|
|
|
3116d3 |
|
|
|
3116d3 |
- // Start httpd server threads. Use a single dual-homed pool.
|
|
|
3116d3 |
- MHD_Daemon *d46 = MHD_start_daemon ((connection_pool ? 0 : MHD_USE_THREAD_PER_CONNECTION)
|
|
|
3116d3 |
+ unsigned int mhd_flags = ((connection_pool
|
|
|
3116d3 |
+ ? 0 : MHD_USE_THREAD_PER_CONNECTION)
|
|
|
3116d3 |
#if MHD_VERSION >= 0x00095300
|
|
|
3116d3 |
- | MHD_USE_INTERNAL_POLLING_THREAD
|
|
|
3116d3 |
+ | MHD_USE_INTERNAL_POLLING_THREAD
|
|
|
3116d3 |
#else
|
|
|
3116d3 |
- | MHD_USE_SELECT_INTERNALLY
|
|
|
3116d3 |
+ | MHD_USE_SELECT_INTERNALLY
|
|
|
3116d3 |
#endif
|
|
|
3116d3 |
+ | MHD_USE_DUAL_STACK
|
|
|
3116d3 |
#ifdef MHD_USE_EPOLL
|
|
|
3116d3 |
- | MHD_USE_EPOLL
|
|
|
3116d3 |
+ | MHD_USE_EPOLL
|
|
|
3116d3 |
#endif
|
|
|
3116d3 |
- | MHD_USE_DUAL_STACK
|
|
|
3116d3 |
#if MHD_VERSION >= 0x00095200
|
|
|
3116d3 |
- | MHD_USE_ITC
|
|
|
3116d3 |
+ | MHD_USE_ITC
|
|
|
3116d3 |
#endif
|
|
|
3116d3 |
- | MHD_USE_DEBUG, /* report errors to stderr */
|
|
|
3116d3 |
- http_port,
|
|
|
3116d3 |
- NULL, NULL, /* default accept policy */
|
|
|
3116d3 |
- handler_cb, NULL, /* handler callback */
|
|
|
3116d3 |
- MHD_OPTION_EXTERNAL_LOGGER, error_cb, NULL,
|
|
|
3116d3 |
- (connection_pool ? MHD_OPTION_THREAD_POOL_SIZE : MHD_OPTION_END),
|
|
|
3116d3 |
- (connection_pool ? (int)connection_pool : MHD_OPTION_END),
|
|
|
3116d3 |
- MHD_OPTION_END);
|
|
|
3116d3 |
+ | MHD_USE_DEBUG); /* report errors to stderr */
|
|
|
3116d3 |
|
|
|
3116d3 |
+ // Start httpd server threads. Use a single dual-homed pool.
|
|
|
3116d3 |
+ MHD_Daemon *d46 = MHD_start_daemon (mhd_flags, http_port,
|
|
|
3116d3 |
+ NULL, NULL, /* default accept policy */
|
|
|
3116d3 |
+ handler_cb, NULL, /* handler callback */
|
|
|
3116d3 |
+ MHD_OPTION_EXTERNAL_LOGGER,
|
|
|
3116d3 |
+ error_cb, NULL,
|
|
|
3116d3 |
+ (connection_pool
|
|
|
3116d3 |
+ ? MHD_OPTION_THREAD_POOL_SIZE
|
|
|
3116d3 |
+ : MHD_OPTION_END),
|
|
|
3116d3 |
+ (connection_pool
|
|
|
3116d3 |
+ ? (int)connection_pool
|
|
|
3116d3 |
+ : MHD_OPTION_END),
|
|
|
3116d3 |
+ MHD_OPTION_END);
|
|
|
3116d3 |
+
|
|
|
3116d3 |
+ MHD_Daemon *d4 = NULL;
|
|
|
3116d3 |
if (d46 == NULL)
|
|
|
3116d3 |
{
|
|
|
3116d3 |
- sqlite3 *database = db;
|
|
|
3116d3 |
- sqlite3 *databaseq = dbq;
|
|
|
3116d3 |
- db = dbq = 0; // for signal_handler not to freak
|
|
|
3116d3 |
- sqlite3_close (databaseq);
|
|
|
3116d3 |
- sqlite3_close (database);
|
|
|
3116d3 |
- error (EXIT_FAILURE, 0, "cannot start http server at port %d", http_port);
|
|
|
3116d3 |
- }
|
|
|
3116d3 |
+ // Cannot use dual_stack, use ipv4 only
|
|
|
3116d3 |
+ mhd_flags &= ~(MHD_USE_DUAL_STACK);
|
|
|
3116d3 |
+ d4 = MHD_start_daemon (mhd_flags, http_port,
|
|
|
3116d3 |
+ NULL, NULL, /* default accept policy */
|
|
|
3116d3 |
+ handler_cb, NULL, /* handler callback */
|
|
|
3116d3 |
+ MHD_OPTION_EXTERNAL_LOGGER,
|
|
|
3116d3 |
+ error_cb, NULL,
|
|
|
3116d3 |
+ (connection_pool
|
|
|
3116d3 |
+ ? MHD_OPTION_THREAD_POOL_SIZE
|
|
|
3116d3 |
+ : MHD_OPTION_END),
|
|
|
3116d3 |
+ (connection_pool
|
|
|
3116d3 |
+ ? (int)connection_pool
|
|
|
3116d3 |
+ : MHD_OPTION_END),
|
|
|
3116d3 |
+ MHD_OPTION_END);
|
|
|
3116d3 |
+ if (d4 == NULL)
|
|
|
3116d3 |
+ {
|
|
|
3116d3 |
+ sqlite3 *database = db;
|
|
|
3116d3 |
+ sqlite3 *databaseq = dbq;
|
|
|
3116d3 |
+ db = dbq = 0; // for signal_handler not to freak
|
|
|
3116d3 |
+ sqlite3_close (databaseq);
|
|
|
3116d3 |
+ sqlite3_close (database);
|
|
|
3116d3 |
+ error (EXIT_FAILURE, 0, "cannot start http server at port %d",
|
|
|
3116d3 |
+ http_port);
|
|
|
3116d3 |
+ }
|
|
|
3116d3 |
|
|
|
3116d3 |
- obatched(clog) << "started http server on IPv4 IPv6 "
|
|
|
3116d3 |
+ }
|
|
|
3116d3 |
+ obatched(clog) << "started http server on"
|
|
|
3116d3 |
+ << (d4 != NULL ? " IPv4 " : " IPv4 IPv6 ")
|
|
|
3116d3 |
<< "port=" << http_port << endl;
|
|
|
3116d3 |
|
|
|
3116d3 |
// add maxigroom sql if -G given
|
|
|
3116d3 |
@@ -4053,6 +4080,7 @@ main (int argc, char *argv[])
|
|
|
3116d3 |
|
|
|
3116d3 |
/* Stop all the web service threads. */
|
|
|
3116d3 |
if (d46) MHD_stop_daemon (d46);
|
|
|
3116d3 |
+ if (d4) MHD_stop_daemon (d4);
|
|
|
3116d3 |
|
|
|
3116d3 |
if (! passive_p)
|
|
|
3116d3 |
{
|