Hello,

Since I have moved the call
MHD_get_daemon_info( MHD_DAEMON_INFO_CURRENT_CONNECTIONS )
to    MHD_NotifyConnectionCallback()   no segfaults did occur.
Could this be true? Maybe update the documentation?

Thanks a lot
Markus



Am Samstag, den 18.07.2015, 17:25 +0200 schrieb Markus Doppelbauer:

> Hi,
> 
> Maybe it is not allowed to call
> MHD_get_daemon_info( MHD_DAEMON_INFO_CURRENT_CONNECTIONS )
> at any time from any thread? Maybe only from
> MHD_NotifyConnectionCallback()  ?
> 
> Thanks a lot
> Markus
> 
> 
> 
> Am Samstag, den 18.07.2015, 17:18 +0200 schrieb Markus Doppelbauer:
> 
> > Hi,
> > 
> > Sorry - I can't provide a testcase - I only have the coredumps.
> > IMHO the problem is, that two threads work in the same critical
> > section    MHD_cleanup_connections()
> > 
> > #1 MHD-Thread from microhttpd/daemon.c:2937     from
> > MHD_select_thread()
> > #2 Worker-thread from microhttpd/daemon.c:4630    from
> > MHD_get_daemon_info( MHD_DAEMON_INFO_CURRENT_CONNECTIONS )
> > 
> > Both threads meet each other in       MHD_cleanup_connections()
> > Down below an other core-dump. In that case the worker-thread
> > crashed.
> > 
> > Thanks a lot
> > Markus
> > 
> > 
> > 
> > # Main-Thread after MHD_quiesce_daemon()
> > 
> > #1  0x0000003bd6e33e05 in abort () from /lib64/libc.so.6
> > No symbol table info available.
> > #2  0x0000003bd6e70537 in __libc_message () from /lib64/libc.so.6
> > No symbol table info available.
> > #3  0x0000003bd6e75e66 in malloc_printerr () from /lib64/libc.so.6
> > No symbol table info available.
> > #4  0x000000000045fc2a in MHD_cleanup_connections (daemon=0x28d8bf0)
> > at microhttpd/daemon.c:2038
> >         pos = 0x7fb4f00009c0
> > #5  0x000000000045ff54 in MHD_get_daemon_info (daemon=0x28cf9f0,
> > info_type=<value optimized out>) at microhttpd/daemon.c:4630
> >         i = <value optimized out>
> > 
> > # MHD-Thread
> > 
> > #0  0x0000003bd720e264 in __lll_lock_wait ()
> > from /lib64/libpthread.so.0
> > No symbol table info available.
> > #1  0x0000003bd7209508 in _L_lock_854 () from /lib64/libpthread.so.0
> > No symbol table info available.
> > #2  0x0000003bd72093d7 in pthread_mutex_lock ()
> > from /lib64/libpthread.so.0
> > No symbol table info available.
> > #3  0x00000000006c73fe in http_NotifyConnectionCallback
> > (cls=0x7fff32d7a1e0, connection=<value optimized out>,
> > socket_context=<value optimized out>, toe=<value optimized out>) at
> > global/daemon.cpp:1782
> >         daemonqueue = 0x7fff32d7a1e0
> > #4  0x000000000045fc5a in MHD_cleanup_connections (daemon=0x28d8bf0)
> > at microhttpd/daemon.c:2046
> >         pos = 0x7fb4f00009c0
> > #5  0x0000000000463a25 in MHD_select_thread (cls=0x28d8bf0) at
> > microhttpd/daemon.c:2937
> >         daemon = 0x28d8bf0
> > #6  0x0000003bd72079d1 in start_thread ()
> > from /lib64/libpthread.so.0
> > No symbol table info available.
> > #7  0x0000003bd6ee88fd in clone () from /lib64/libc.so.6
> > No symbol table info available.
> > 
> > 
> > 
> > 
> > 
> > 
> > 
> > 
> > Am Samstag, den 18.07.2015, 16:31 +0200 schrieb Christian Grothoff: 
> > 
> > > Hi!
> > > 
> > > I'm sorry, but I still don't even see how the race could happen.
> > > I checked all calls to MHD_pool_destroy, and the respective connection
> > > is always in 1 of 3 disjoint ownership states:
> > > 
> > > 1) never aliased, about to be freed (failures during connection setup)
> > > 2) 'active' connection, going down without keep-alive, pool is freed
> > >    'early' during the handler thread (technically not necessary, we
> > >    could keep it around until case (3), but that'd keep the RAM busy
> > >    longer than necessary).  This should only happen from the thread
> > >    that handles everything wrt. this connection.
> > > 3) MHD_cleanup_connections going over all connections that are really
> > >    dead; here, a lock is used.
> > > 
> > > Note that in 1&2, MHD_cleanup_connections() would never touch that pool,
> > > as it is not in the respective DLL.
> > > 
> > > So sorry, I cannot reproduce your issue.  Again, a testcase would be
> > > very helpful...
> > > 
> > > As for the need of the info call to invoke cleanup: it is necessary, as
> > > otherwise the counter could be way off (I think especially in the case
> > > you describe, it could cause non-termination to not call cleanup).
> > > 
> > > Now, the MHD_pool_destroy in connection.c, that one should be truly
> > > harmless to remove, so you could safely play with that...
> > > 
> > > 
> > > Happy hacking!
> > > 
> > > -Christian
> > > 
> > > On 07/17/2015 09:57 AM, Markus Doppelbauer wrote:
> > > > Sorry the NULL patch is the wrong fix - it makes it only more
> > > > unlikely to double-free() the pool. The scheduler could interrupt
> > > > right before "pos->pool = NULL".
> > > > 
> > > > Maybe the only solution is either to protect "MHD_cleanup_connections()"
> > > > with a mutex or to remove the call to "MHD_cleanup_connections()"
> > > > in "MHD_DAEMON_INFO_CURRENT_CONNECTIONS".
> > > > 
> > > > Thanks a lot
> > > > Markus
> > > > 
> > > > 
> > > > 
> > > > Am Donnerstag, den 16.07.2015, 22:13 +0200 schrieb Markus Doppelbauer:
> > > >> Hello,
> > > >>
> > > >> Maybe simply nullify "pos->pool" after MHD_pool_destroy()"?
> > > >> Should avoid this double-free().
> > > >>
> > > >> Or is there a chance to get the number of open connections
> > > >> without calling "MHD_cleanup_connections()"?
> > > >>
> > > >> Thanks a lot
> > > >> Markus
> > > >>
> > > >>
> > > >>             }
> > > >>         }
> > > >>         MHD_pool_destroy (pos->pool);
> > > >> +       pos->pool = NULL;
> > > >>   #if HTTPS_SUPPORT
> > > >>         if (NULL != pos->tls_session)
> > > >>         gnutls_deinit (pos->tls_session);
> > > >>
> > > > 
> > > 
> > 
> > 
> 
> 


Reply via email to