Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
V
vlc-1.1
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-1.1
Commits
0bb78675
Commit
0bb78675
authored
Jul 29, 2009
by
Rémi Duraffort
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
variables: fix a segfault and memory leak when TriggerCallback is called (crash
introduced by
afce97e9
).
parent
120876d1
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
11 additions
and
11 deletions
+11
-11
src/misc/variables.c
src/misc/variables.c
+11
-11
No files found.
src/misc/variables.c
View file @
0bb78675
...
...
@@ -162,7 +162,7 @@ static void CheckValue ( variable_t *, vlc_value_t * );
static
int
InheritValue
(
vlc_object_t
*
,
const
char
*
,
vlc_value_t
*
,
int
);
static
int
TriggerCallback
(
vlc_object_t
*
,
variable_t
*
,
const
char
*
,
static
int
TriggerCallback
(
vlc_object_t
*
,
variable_t
*
*
,
const
char
*
,
vlc_value_t
);
/**
...
...
@@ -714,7 +714,7 @@ int __var_GetAndSet( vlc_object_t *p_this, const char *psz_name, int i_action,
/* Deal with callbacks.*/
if
(
p_var
->
i_entries
)
i_ret
=
TriggerCallback
(
p_this
,
p_var
,
psz_name
,
oldval
);
i_ret
=
TriggerCallback
(
p_this
,
&
p_var
,
psz_name
,
oldval
);
vlc_mutex_unlock
(
&
p_priv
->
var_lock
);
...
...
@@ -787,7 +787,7 @@ int var_SetChecked( vlc_object_t *p_this, const char *psz_name,
/* Deal with callbacks */
if
(
p_var
->
i_entries
)
i_ret
=
TriggerCallback
(
p_this
,
p_var
,
psz_name
,
oldval
);
i_ret
=
TriggerCallback
(
p_this
,
&
p_var
,
psz_name
,
oldval
);
/* Free data if needed */
p_var
->
ops
->
pf_free
(
&
oldval
);
...
...
@@ -973,7 +973,7 @@ int __var_TriggerCallback( vlc_object_t *p_this, const char *psz_name )
/* Deal with callbacks. Tell we're in a callback, release the lock,
* call stored functions, retake the lock. */
if
(
p_var
->
i_entries
)
i_ret
=
TriggerCallback
(
p_this
,
p_var
,
psz_name
,
p_var
->
val
);
i_ret
=
TriggerCallback
(
p_this
,
&
p_var
,
psz_name
,
p_var
->
val
);
vlc_mutex_unlock
(
&
p_priv
->
var_lock
);
return
i_ret
;
...
...
@@ -1472,21 +1472,21 @@ static int InheritValue( vlc_object_t *p_this, const char *psz_name,
* Tell we're in a callback, release the lock, call stored functions,
* retake the lock.
**********************************************************************/
static
int
TriggerCallback
(
vlc_object_t
*
p_this
,
variable_t
*
p_var
,
static
int
TriggerCallback
(
vlc_object_t
*
p_this
,
variable_t
*
*
p
p_var
,
const
char
*
psz_name
,
vlc_value_t
oldval
)
{
int
i_var
;
int
i_entries
=
p_var
->
i_entries
;
callback_entry_t
*
p_entries
=
p_var
->
p_entries
;
int
i_entries
=
(
*
pp_var
)
->
i_entries
;
callback_entry_t
*
p_entries
=
(
*
pp_var
)
->
p_entries
;
vlc_object_internals_t
*
p_priv
=
vlc_internals
(
p_this
);
p_var
->
b_incallback
=
true
;
(
*
pp_var
)
->
b_incallback
=
true
;
vlc_mutex_unlock
(
&
p_priv
->
var_lock
);
/* The real calls */
for
(
;
i_entries
--
;
)
{
p_entries
[
i_entries
].
pf_callback
(
p_this
,
psz_name
,
oldval
,
p_var
->
val
,
p_entries
[
i_entries
].
pf_callback
(
p_this
,
psz_name
,
oldval
,
(
*
pp_var
)
->
val
,
p_entries
[
i_entries
].
p_data
);
}
...
...
@@ -1499,8 +1499,8 @@ static int TriggerCallback( vlc_object_t *p_this, variable_t *p_var,
return
VLC_ENOVAR
;
}
p_var
=
&
p_priv
->
p_vars
[
i_var
];
p_var
->
b_incallback
=
false
;
*
p
p_var
=
&
p_priv
->
p_vars
[
i_var
];
(
*
pp_var
)
->
b_incallback
=
false
;
vlc_cond_broadcast
(
&
p_priv
->
var_wait
);
return
VLC_SUCCESS
;
...
...
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