[vlc-devel] commit: invmem: fix potential memleaks. ( Rémi Duraffort )
git version control
git at videolan.org
Sat May 30 00:32:47 CEST 2009
vlc | branch: master | Rémi Duraffort <ivoire at videolan.org> | Tue May 26 23:16:30 2009 +0200| [ebbecd97a42a02e7ea6e68103b9bb29052e4700b] | committer: Jean-Baptiste Kempf
invmem: fix potential memleaks.
> http://git.videolan.org/gitweb.cgi/vlc.git/?a=commit;h=ebbecd97a42a02e7ea6e68103b9bb29052e4700b
---
modules/codec/invmem.c | 8 +++++---
1 files changed, 5 insertions(+), 3 deletions(-)
diff --git a/modules/codec/invmem.c b/modules/codec/invmem.c
index 2990644..c63947c 100644
--- a/modules/codec/invmem.c
+++ b/modules/codec/invmem.c
@@ -120,15 +120,16 @@ static int OpenDecoder( vlc_object_t *p_this )
}
/* Allocate the memory needed to store the decoder's structure */
- if( ( p_dec->p_sys = p_sys =
- (decoder_sys_t *)malloc(sizeof(decoder_sys_t)) ) == NULL )
+ if( ( p_dec->p_sys = p_sys = malloc(sizeof(decoder_sys_t)) ) == NULL )
return VLC_ENOMEM;
// get parametrs
p_sys->i_width = var_CreateGetInteger( p_this, "invmem-width" );
p_sys->i_height = var_CreateGetInteger( p_this, "invmem-height" );
- if (p_sys->i_width == 0 || p_sys->i_height == 0) {
+ if( p_sys->i_width == 0 || p_sys->i_height == 0 )
+ {
msg_Err( p_dec, "--vmem-width and --vmem-height must be > 0" );
+ free( p_sys );
return VLC_EGENERIC;
}
@@ -147,6 +148,7 @@ static int OpenDecoder( vlc_object_t *p_this )
if( !p_sys->pf_lock || !p_sys->pf_unlock )
{
msg_Err( p_dec, "Invalid lock or unlock callbacks" );
+ free( p_sys );
return VLC_EGENERIC;
}
More information about the vlc-devel
mailing list