Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
V
vlc
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Redmine
Redmine
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Operations
Operations
Metrics
Environments
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
videolan
vlc
Commits
33e3f3de
Commit
33e3f3de
authored
Mar 19, 2008
by
Pierre d'Herbemont
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
input: Get rid of Destroy(), and move sout keeping code to the destructor.
parent
68ed0898
Changes
3
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
33 additions
and
37 deletions
+33
-37
src/input/input.c
src/input/input.c
+26
-33
src/input/input_internal.h
src/input/input_internal.h
+2
-1
src/input/vlm.c
src/input/vlm.c
+5
-3
No files found.
src/input/input.c
View file @
33e3f3de
...
...
@@ -64,7 +64,6 @@ static int Init ( input_thread_t *p_input );
static
void
Error
(
input_thread_t
*
p_input
);
static
void
End
(
input_thread_t
*
p_input
);
static
void
MainLoop
(
input_thread_t
*
p_input
);
static
void
Destroy
(
input_thread_t
*
p_input
,
sout_instance_t
**
pp_sout
);
static
inline
int
ControlPopNoLock
(
input_thread_t
*
,
int
*
,
vlc_value_t
*
);
static
void
ControlReduce
(
input_thread_t
*
);
...
...
@@ -169,6 +168,7 @@ static input_thread_t *Create( vlc_object_t *p_parent, input_item_t *p_item,
TAB_INIT
(
p_input
->
p
->
i_attachment
,
p_input
->
p
->
attachment
);
p_input
->
p
->
p_es_out
=
NULL
;
p_input
->
p
->
p_sout
=
NULL
;
p_input
->
p
->
b_owns_its_sout
=
VLC_TRUE
;
p_input
->
p
->
b_sout_keep
=
VLC_FALSE
;
p_input
->
p
->
b_out_pace_control
=
VLC_FALSE
;
p_input
->
i_pts_delay
=
0
;
...
...
@@ -278,7 +278,10 @@ static input_thread_t *Create( vlc_object_t *p_parent, input_item_t *p_item,
/* */
if
(
p_sout
)
{
p_input
->
p
->
p_sout
=
p_sout
;
p_input
->
p
->
b_owns_its_sout
=
VLC_FALSE
;
}
/* Attach only once we are ready */
vlc_object_attach
(
p_input
,
p_parent
);
...
...
@@ -289,37 +292,21 @@ static input_thread_t *Create( vlc_object_t *p_parent, input_item_t *p_item,
return
p_input
;
}
/* FIXME: This function should go away and only vlc_object_release()
* should be needed */
static
void
Destroy
(
input_thread_t
*
p_input
,
sout_instance_t
**
pp_sout
)
/**
* Input destructor (called when the object's refcount reaches 0).
*/
static
void
Destructor
(
input_thread_t
*
p_input
)
{
vlc_object_detach
(
p_input
);
input_thread_private_t
*
priv
=
p_input
->
p
;
if
(
pp_sout
)
*
pp_sout
=
NULL
;
if
(
priv
->
p_sout
)
if
(
priv
->
b_owns_its_sout
&&
priv
->
p_sout
)
{
if
(
pp_sout
)
*
pp_sout
=
priv
->
p_sout
;
else
if
(
priv
->
b_sout_keep
)
if
(
priv
->
b_sout_keep
)
SoutKeep
(
priv
->
p_sout
);
else
{
sout_DeleteInstance
(
priv
->
p_sout
);
priv
->
p_sout
=
NULL
;
}
}
vlc_object_release
(
p_input
);
}
/**
* Input destructor (called when the object's refcount reaches 0).
*/
static
void
Destructor
(
input_thread_t
*
p_input
)
{
input_thread_private_t
*
priv
=
p_input
->
p
;
vlc_mutex_destroy
(
&
priv
->
lock_control
);
free
(
priv
);
}
...
...
@@ -363,7 +350,8 @@ input_thread_t *__input_CreateThreadExtended( vlc_object_t *p_parent,
{
input_ChangeState
(
p_input
,
ERROR_S
);
msg_Err
(
p_input
,
"cannot create input thread"
);
Destroy
(
p_input
,
&
p_sout
);
vlc_object_detach
(
p_input
);
vlc_object_release
(
p_input
);
return
NULL
;
}
...
...
@@ -406,7 +394,8 @@ int __input_Read( vlc_object_t *p_parent, input_item_t *p_item,
{
input_ChangeState
(
p_input
,
ERROR_S
);
msg_Err
(
p_input
,
"cannot create input thread"
);
Destroy
(
p_input
,
NULL
);
vlc_object_detach
(
p_input
);
vlc_object_release
(
p_input
);
return
VLC_EGENERIC
;
}
}
...
...
@@ -433,7 +422,8 @@ int __input_Preparse( vlc_object_t *p_parent, input_item_t *p_item )
if
(
!
Init
(
p_input
)
)
End
(
p_input
);
Destroy
(
p_input
,
NULL
);
vlc_object_detach
(
p_input
);
vlc_object_release
(
p_input
);
return
VLC_SUCCESS
;
}
...
...
@@ -482,6 +472,12 @@ void input_StopThread( input_thread_t *p_input )
input_ControlPush
(
p_input
,
INPUT_CONTROL_SET_DIE
,
NULL
);
}
sout_instance_t
*
input_DetachSout
(
input_thread_t
*
p_input
)
{
p_input
->
p
->
b_owns_its_sout
=
VLC_FALSE
;
return
p_input
->
p
->
p_sout
;
}
/**
* Clean up a dead input thread
* This function does not return until the thread is effectively cancelled.
...
...
@@ -489,17 +485,13 @@ void input_StopThread( input_thread_t *p_input )
* \param the input thread to kill
*/
void
input_DestroyThread
(
input_thread_t
*
p_input
)
{
input_DestroyThreadExtended
(
p_input
,
NULL
);
}
void
input_DestroyThreadExtended
(
input_thread_t
*
p_input
,
sout_instance_t
**
pp_sout
)
{
/* Join the thread */
vlc_thread_join
(
p_input
);
/* */
Destroy
(
p_input
,
pp_sout
);
vlc_object_detach
(
p_input
);
vlc_object_release
(
p_input
);
}
/*****************************************************************************
...
...
@@ -595,7 +587,8 @@ static int RunAndDestroy( input_thread_t *p_input )
exit:
/* Release memory */
Destroy
(
p_input
,
NULL
);
vlc_object_detach
(
p_input
);
vlc_object_release
(
p_input
);
return
0
;
}
...
...
src/input/input_internal.h
View file @
33e3f3de
...
...
@@ -106,6 +106,7 @@ struct input_thread_private_t
sout_instance_t
*
p_sout
;
/* XXX Move it to es_out ? */
vlc_bool_t
b_sout_keep
;
vlc_bool_t
b_out_pace_control
;
/* idem ? */
vlc_bool_t
b_owns_its_sout
;
/* Main input properties */
input_source_t
input
;
...
...
@@ -342,7 +343,7 @@ input_stats_t *stats_NewInputStats( input_thread_t *p_input );
#define input_CreateThreadExtended(a,b,c,d) __input_CreateThreadExtended(VLC_OBJECT(a),b,c,d)
input_thread_t
*
__input_CreateThreadExtended
(
vlc_object_t
*
,
input_item_t
*
,
const
char
*
,
sout_instance_t
*
);
void
input_DestroyThreadExtended
(
input_thread_t
*
p_input
,
sout_instance_t
**
);
sout_instance_t
*
input_DetachSout
(
input_thread_t
*
p_input
);
/* var.c */
void
input_ControlVarInit
(
input_thread_t
*
);
...
...
src/input/vlm.c
View file @
33e3f3de
...
...
@@ -2282,7 +2282,7 @@ static int vlm_OnMediaUpdate( vlm_t *p_vlm, vlm_media_sys_t *p_media )
msleep
(
100000
);
input_StopThread
(
p_input
);
input_DestroyThread
Extended
(
p_input
,
NULL
);
input_DestroyThread
(
p_input
);
}
free
(
psz_output
);
free
(
psz_header
);
...
...
@@ -2518,7 +2518,8 @@ static void vlm_MediaInstanceDelete( vlm_media_instance_sys_t *p_instance )
if
(
p_instance
->
p_input
)
{
input_StopThread
(
p_instance
->
p_input
);
input_DestroyThreadExtended
(
p_instance
->
p_input
,
&
p_instance
->
p_sout
);
p_instance
->
p_sout
=
input_DetachSout
(
p_instance
->
p_input
);
input_DestroyThread
(
p_instance
->
p_input
);
}
if
(
p_instance
->
p_sout
)
sout_DeleteInstance
(
p_instance
->
p_sout
);
...
...
@@ -2601,7 +2602,8 @@ static int vlm_ControlMediaInstanceStart( vlm_t *p_vlm, int64_t id, const char *
}
input_StopThread
(
p_instance
->
p_input
);
input_DestroyThreadExtended
(
p_instance
->
p_input
,
&
p_instance
->
p_sout
);
p_instance
->
p_sout
=
input_DetachSout
(
p_instance
->
p_input
);
input_DestroyThread
(
p_instance
->
p_input
);
if
(
!
p_instance
->
b_sout_keep
&&
p_instance
->
p_sout
)
{
sout_DeleteInstance
(
p_instance
->
p_sout
);
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment