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
f9b65ba9
Commit
f9b65ba9
authored
Oct 11, 2012
by
Frédéric Yhuel
Committed by
Jean-Baptiste Kempf
Oct 12, 2012
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
demux/mp4: fix some memory leaks
Signed-off-by:
Jean-Baptiste Kempf
<
jb@videolan.org
>
parent
7b3d4c9e
Changes
2
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
33 additions
and
21 deletions
+33
-21
modules/demux/mp4/libmp4.c
modules/demux/mp4/libmp4.c
+2
-0
modules/demux/mp4/mp4.c
modules/demux/mp4/mp4.c
+31
-21
No files found.
modules/demux/mp4/libmp4.c
View file @
f9b65ba9
...
@@ -3507,10 +3507,12 @@ MP4_Box_t *MP4_BoxGetNextChunk( stream_t *s )
...
@@ -3507,10 +3507,12 @@ MP4_Box_t *MP4_BoxGetNextChunk( stream_t *s )
if
(
(
p_tmp_box
->
i_type
==
ATOM_uuid
&&
!
CmpUUID
(
&
p_tmp_box
->
i_uuid
,
&
SmooBoxUUID
))
)
if
(
(
p_tmp_box
->
i_type
==
ATOM_uuid
&&
!
CmpUUID
(
&
p_tmp_box
->
i_uuid
,
&
SmooBoxUUID
))
)
{
{
free
(
p_tmp_box
);
return
MP4_BoxGetSmooBox
(
s
);
return
MP4_BoxGetSmooBox
(
s
);
}
}
else
if
(
p_tmp_box
->
i_type
==
ATOM_ftyp
)
else
if
(
p_tmp_box
->
i_type
==
ATOM_ftyp
)
{
{
free
(
p_tmp_box
);
return
MP4_BoxGetRoot
(
s
);
return
MP4_BoxGetRoot
(
s
);
}
}
free
(
p_tmp_box
);
free
(
p_tmp_box
);
...
...
modules/demux/mp4/mp4.c
View file @
f9b65ba9
...
@@ -2663,6 +2663,20 @@ static void MP4_TrackCreate( demux_t *p_demux, mp4_track_t *p_track,
...
@@ -2663,6 +2663,20 @@ static void MP4_TrackCreate( demux_t *p_demux, mp4_track_t *p_track,
#endif
#endif
}
}
static
int
FreeAndResetChunk
(
mp4_chunk_t
*
ck
)
{
free
(
ck
->
p_sample_count_dts
);
free
(
ck
->
p_sample_delta_dts
);
free
(
ck
->
p_sample_count_pts
);
free
(
ck
->
p_sample_offset_pts
);
free
(
ck
->
p_sample_size
);
for
(
uint32_t
i
=
0
;
i
<
ck
->
i_sample_count
;
i
++
)
free
(
ck
->
p_sample_data
[
i
]
);
free
(
ck
->
p_sample_data
);
memset
(
ck
,
0
,
sizeof
(
mp4_chunk_t
)
);
return
VLC_SUCCESS
;
}
/****************************************************************************
/****************************************************************************
* MP4_TrackDestroy:
* MP4_TrackDestroy:
****************************************************************************
****************************************************************************
...
@@ -2690,6 +2704,8 @@ static void MP4_TrackDestroy( mp4_track_t *p_track )
...
@@ -2690,6 +2704,8 @@ static void MP4_TrackDestroy( mp4_track_t *p_track )
}
}
}
}
FREENULL
(
p_track
->
chunk
);
FREENULL
(
p_track
->
chunk
);
FreeAndResetChunk
(
p_track
->
cchunk
);
FREENULL
(
p_track
->
cchunk
);
if
(
!
p_track
->
i_sample_size
)
if
(
!
p_track
->
i_sample_size
)
{
{
...
@@ -3236,20 +3252,6 @@ static mp4_track_t *MP4_frg_GetTrack( demux_t *p_demux, const uint16_t tid )
...
@@ -3236,20 +3252,6 @@ static mp4_track_t *MP4_frg_GetTrack( demux_t *p_demux, const uint16_t tid )
return
NULL
;
return
NULL
;
}
}
static
int
FreeAndResetChunk
(
mp4_chunk_t
*
ck
)
{
free
(
ck
->
p_sample_count_dts
);
free
(
ck
->
p_sample_delta_dts
);
free
(
ck
->
p_sample_count_pts
);
free
(
ck
->
p_sample_offset_pts
);
free
(
ck
->
p_sample_size
);
for
(
uint32_t
i
=
0
;
i
<
ck
->
i_sample_count
;
i
++
)
free
(
ck
->
p_sample_data
[
i
]
);
free
(
ck
->
p_sample_data
);
memset
(
ck
,
0
,
sizeof
(
mp4_chunk_t
)
);
return
VLC_SUCCESS
;
}
static
void
FlushChunk
(
demux_t
*
p_demux
,
mp4_track_t
*
tk
)
static
void
FlushChunk
(
demux_t
*
p_demux
,
mp4_track_t
*
tk
)
{
{
msg_Dbg
(
p_demux
,
"Flushing chunk for track id %u"
,
tk
->
i_track_ID
);
msg_Dbg
(
p_demux
,
"Flushing chunk for track id %u"
,
tk
->
i_track_ID
);
...
@@ -3537,11 +3539,13 @@ static int MP4_frg_GetChunks( demux_t *p_demux, const unsigned i_tk_id )
...
@@ -3537,11 +3539,13 @@ static int MP4_frg_GetChunks( demux_t *p_demux, const unsigned i_tk_id )
if
(
!
p_chunk
)
if
(
!
p_chunk
)
return
VLC_EGENERIC
;
return
VLC_EGENERIC
;
if
(
!
p_chunk
->
p_first
)
goto
MP4_frg_GetChunks_Error
;
uint32_t
i_type
=
p_chunk
->
p_first
->
i_type
;
uint32_t
i_type
=
p_chunk
->
p_first
->
i_type
;
uint16_t
tid
=
0
;
uint16_t
tid
=
0
;
if
(
i_type
==
ATOM_uuid
||
i_type
==
ATOM_ftyp
)
if
(
i_type
==
ATOM_uuid
||
i_type
==
ATOM_ftyp
)
{
{
free
(
p_sys
->
p_root
);
MP4_BoxFree
(
p_demux
->
s
,
p_sys
->
p_root
);
p_sys
->
p_root
=
p_chunk
;
p_sys
->
p_root
=
p_chunk
;
if
(
i_type
==
ATOM_ftyp
)
/* DASH */
if
(
i_type
==
ATOM_ftyp
)
/* DASH */
...
@@ -3550,8 +3554,7 @@ static int MP4_frg_GetChunks( demux_t *p_demux, const unsigned i_tk_id )
...
@@ -3550,8 +3554,7 @@ static int MP4_frg_GetChunks( demux_t *p_demux, const unsigned i_tk_id )
if
(
!
p_tkhd
)
if
(
!
p_tkhd
)
{
{
msg_Warn
(
p_demux
,
"No tkhd found!"
);
msg_Warn
(
p_demux
,
"No tkhd found!"
);
free
(
p_chunk
);
goto
MP4_frg_GetChunks_Error
;
return
VLC_EGENERIC
;
}
}
tid
=
p_tkhd
->
data
.
p_tkhd
->
i_track_ID
;
tid
=
p_tkhd
->
data
.
p_tkhd
->
i_track_ID
;
}
}
...
@@ -3562,25 +3565,32 @@ static int MP4_frg_GetChunks( demux_t *p_demux, const unsigned i_tk_id )
...
@@ -3562,25 +3565,32 @@ static int MP4_frg_GetChunks( demux_t *p_demux, const unsigned i_tk_id )
if
(
!
p_stra
||
CmpUUID
(
&
p_stra
->
i_uuid
,
&
StraBoxUUID
)
)
if
(
!
p_stra
||
CmpUUID
(
&
p_stra
->
i_uuid
,
&
StraBoxUUID
)
)
{
{
msg_Warn
(
p_demux
,
"No StraBox found!"
);
msg_Warn
(
p_demux
,
"No StraBox found!"
);
free
(
p_chunk
);
goto
MP4_frg_GetChunks_Error
;
return
VLC_EGENERIC
;
}
}
tid
=
p_stra
->
data
.
p_stra
->
i_track_ID
;
tid
=
p_stra
->
data
.
p_stra
->
i_track_ID
;
}
}
p_track
=
MP4_frg_GetTrack
(
p_demux
,
tid
);
p_track
=
MP4_frg_GetTrack
(
p_demux
,
tid
);
if
(
!
p_track
)
if
(
!
p_track
)
return
VLC_EGENERIC
;
goto
MP4_frg_GetChunks_Error
;
p_track
->
b_codec_need_restart
=
true
;
p_track
->
b_codec_need_restart
=
true
;
return
MP4_frg_GetChunks
(
p_demux
,
i_tk_id
);
return
MP4_frg_GetChunks
(
p_demux
,
i_tk_id
);
}
}
if
(
MP4_frg_GetChunk
(
p_demux
,
p_chunk
,
(
unsigned
*
)
&
tid
)
!=
VLC_SUCCESS
)
if
(
MP4_frg_GetChunk
(
p_demux
,
p_chunk
,
(
unsigned
*
)
&
tid
)
!=
VLC_SUCCESS
)
return
VLC_EGENERIC
;
goto
MP4_frg_GetChunks_Error
;
MP4_BoxFree
(
p_demux
->
s
,
p_chunk
);
if
(
tid
==
i_tk_id
)
if
(
tid
==
i_tk_id
)
break
;
break
;
else
continue
;
MP4_frg_GetChunks_Error:
MP4_BoxFree
(
p_demux
->
s
,
p_chunk
);
return
VLC_EGENERIC
;
}
}
return
VLC_SUCCESS
;
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