Commit 49947b14 authored by Laurent Aimar's avatar Laurent Aimar

* http: fixed a segfault while using it more than once.

parent fe4a517f
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
* httpd.h * httpd.h
***************************************************************************** *****************************************************************************
* Copyright (C) 2001-2003 VideoLAN * Copyright (C) 2001-2003 VideoLAN
* $Id: httpd.h,v 1.2 2003/02/25 17:17:43 fenrir Exp $ * $Id: httpd.h,v 1.3 2003/03/06 11:09:56 fenrir Exp $
* *
* Authors: Laurent Aimar <fenrir@via.ecp.fr> * Authors: Laurent Aimar <fenrir@via.ecp.fr>
* *
...@@ -76,6 +76,7 @@ static inline httpd_t* httpd_Find( vlc_object_t *p_this, vlc_bool_t b_create ) ...@@ -76,6 +76,7 @@ static inline httpd_t* httpd_Find( vlc_object_t *p_this, vlc_bool_t b_create )
p_httpd = vlc_object_find( p_this, VLC_OBJECT_HTTPD, FIND_ANYWHERE ); p_httpd = vlc_object_find( p_this, VLC_OBJECT_HTTPD, FIND_ANYWHERE );
if( !p_httpd ) if( !p_httpd )
{ {
msg_Info(p_this, "creating new http daemon" );
if( !b_create ) if( !b_create )
{ {
return( NULL ); return( NULL );
...@@ -98,6 +99,7 @@ static inline httpd_t* httpd_Find( vlc_object_t *p_this, vlc_bool_t b_create ) ...@@ -98,6 +99,7 @@ static inline httpd_t* httpd_Find( vlc_object_t *p_this, vlc_bool_t b_create )
} }
vlc_object_yield( p_httpd ); vlc_object_yield( p_httpd );
vlc_object_attach( p_httpd, p_this->p_vlc );
} }
return( p_httpd ); return( p_httpd );
...@@ -106,6 +108,10 @@ static inline httpd_t* httpd_Find( vlc_object_t *p_this, vlc_bool_t b_create ) ...@@ -106,6 +108,10 @@ static inline httpd_t* httpd_Find( vlc_object_t *p_this, vlc_bool_t b_create )
static inline void httpd_Release( httpd_t *p_httpd ) static inline void httpd_Release( httpd_t *p_httpd )
{ {
vlc_object_release( p_httpd ); vlc_object_release( p_httpd );
if( p_httpd->i_refcount <= 0 )
{
vlc_object_detach( p_httpd );
}
} }
......
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
* httpd.c * httpd.c
***************************************************************************** *****************************************************************************
* Copyright (C) 2001-2003 VideoLAN * Copyright (C) 2001-2003 VideoLAN
* $Id: httpd.c,v 1.6 2003/03/03 14:21:08 gbazin Exp $ * $Id: httpd.c,v 1.7 2003/03/06 11:09:56 fenrir Exp $
* *
* Authors: Laurent Aimar <fenrir@via.ecp.fr> * Authors: Laurent Aimar <fenrir@via.ecp.fr>
* *
...@@ -438,7 +438,7 @@ static httpd_host_t *_RegisterHost( httpd_sys_t *p_httpt, char *psz_host_addr, i ...@@ -438,7 +438,7 @@ static httpd_host_t *_RegisterHost( httpd_sys_t *p_httpt, char *psz_host_addr, i
/* yes, increment ref count and succed */ /* yes, increment ref count and succed */
p_httpt->host[i]->i_ref++; p_httpt->host[i]->i_ref++;
vlc_mutex_unlock( &p_httpt->host_lock ); vlc_mutex_unlock( &p_httpt->host_lock );
return NULL; return( p_httpt->host[i] );
} }
/* need to add a new listening socket */ /* need to add a new listening socket */
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment