Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Contribute to GitLab
Sign in / Register
Toggle navigation
F
ffmpeg.wasm-core
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Linshizhi
ffmpeg.wasm-core
Commits
fc857294
Commit
fc857294
authored
Dec 16, 2011
by
Tomas Härdin
Committed by
Janne Grunau
Jan 22, 2012
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
mxfdec: Do not parse slices or DeltaEntryArrays.
The most recent demuxing/seeking code does not need them.
parent
f028d4d1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
10 additions
and
76 deletions
+10
-76
mxfdec.c
libavformat/mxfdec.c
+10
-76
No files found.
libavformat/mxfdec.c
View file @
fc857294
...
@@ -148,17 +148,12 @@ typedef struct {
...
@@ -148,17 +148,12 @@ typedef struct {
int
edit_unit_byte_count
;
int
edit_unit_byte_count
;
int
index_sid
;
int
index_sid
;
int
body_sid
;
int
body_sid
;
int
slice_count
;
AVRational
index_edit_rate
;
AVRational
index_edit_rate
;
uint64_t
index_start_position
;
uint64_t
index_start_position
;
uint64_t
index_duration
;
uint64_t
index_duration
;
int
*
slice
;
int
*
element_delta
;
int
nb_delta_entries
;
int8_t
*
temporal_offset_entries
;
int8_t
*
temporal_offset_entries
;
int
*
flag_entries
;
int
*
flag_entries
;
uint64_t
*
stream_offset_entries
;
uint64_t
*
stream_offset_entries
;
uint32_t
**
slice_offset_entries
;
int
nb_index_entries
;
int
nb_index_entries
;
}
MXFIndexTableSegment
;
}
MXFIndexTableSegment
;
...
@@ -666,39 +661,9 @@ static int mxf_read_source_package(void *arg, AVIOContext *pb, int tag, int size
...
@@ -666,39 +661,9 @@ static int mxf_read_source_package(void *arg, AVIOContext *pb, int tag, int size
return
0
;
return
0
;
}
}
static
int
mxf_read_delta_entry_array
(
AVIOContext
*
pb
,
MXFIndexTableSegment
*
segment
)
{
int
i
,
length
;
segment
->
nb_delta_entries
=
avio_rb32
(
pb
);
if
(
segment
->
nb_delta_entries
<
1
||
segment
->
nb_delta_entries
>
INT_MAX
>>
av_log2
(
sizeof
(
*
segment
->
slice
)))
return
AVERROR
(
ENOMEM
);
length
=
avio_rb32
(
pb
);
segment
->
slice
=
av_mallocz
(
segment
->
nb_delta_entries
*
sizeof
(
*
segment
->
slice
));
if
(
!
segment
->
slice
)
return
AVERROR
(
ENOMEM
);
segment
->
element_delta
=
av_mallocz
(
segment
->
nb_delta_entries
*
sizeof
(
*
segment
->
element_delta
));
if
(
!
segment
->
element_delta
)
{
av_freep
(
&
segment
->
slice
);
return
AVERROR
(
ENOMEM
);
}
for
(
i
=
0
;
i
<
segment
->
nb_delta_entries
;
i
++
)
{
avio_r8
(
pb
);
/* PosTableIndex */
segment
->
slice
[
i
]
=
avio_r8
(
pb
);
segment
->
element_delta
[
i
]
=
avio_rb32
(
pb
);
}
return
0
;
}
static
int
mxf_read_index_entry_array
(
AVIOContext
*
pb
,
MXFIndexTableSegment
*
segment
)
static
int
mxf_read_index_entry_array
(
AVIOContext
*
pb
,
MXFIndexTableSegment
*
segment
)
{
{
int
i
,
j
,
length
;
int
i
,
length
;
segment
->
nb_index_entries
=
avio_rb32
(
pb
);
segment
->
nb_index_entries
=
avio_rb32
(
pb
);
if
(
!
segment
->
nb_index_entries
)
if
(
!
segment
->
nb_index_entries
)
...
@@ -716,41 +681,23 @@ static int mxf_read_index_entry_array(AVIOContext *pb, MXFIndexTableSegment *seg
...
@@ -716,41 +681,23 @@ static int mxf_read_index_entry_array(AVIOContext *pb, MXFIndexTableSegment *seg
sizeof
(
*
segment
->
flag_entries
));
sizeof
(
*
segment
->
flag_entries
));
segment
->
stream_offset_entries
=
av_mallocz
(
segment
->
nb_index_entries
*
segment
->
stream_offset_entries
=
av_mallocz
(
segment
->
nb_index_entries
*
sizeof
(
*
segment
->
stream_offset_entries
));
sizeof
(
*
segment
->
stream_offset_entries
));
segment
->
slice_offset_entries
=
av_mallocz
(
segment
->
nb_index_entries
*
sizeof
(
*
segment
->
slice_offset_entries
));
if
(
!
segment
->
flag_entries
||
!
segment
->
stream_offset_entries
||
if
(
!
segment
->
flag_entries
||
!
segment
->
stream_offset_entries
||
!
segment
->
slice_offset_entries
||
!
segment
->
temporal_offset_entries
)
!
segment
->
temporal_offset_entries
)
{
goto
errmem
;
av_freep
(
&
segment
->
flag_entries
);
av_freep
(
&
segment
->
stream_offset_entries
);
av_freep
(
&
segment
->
temporal_offset_entries
);
return
AVERROR
(
ENOMEM
);
}
for
(
i
=
0
;
i
<
segment
->
nb_index_entries
;
i
++
)
{
for
(
i
=
0
;
i
<
segment
->
nb_index_entries
;
i
++
)
{
segment
->
temporal_offset_entries
[
i
]
=
avio_r8
(
pb
);
segment
->
temporal_offset_entries
[
i
]
=
avio_r8
(
pb
);
avio_r8
(
pb
);
/* KeyFrameOffset */
avio_r8
(
pb
);
/* KeyFrameOffset */
segment
->
flag_entries
[
i
]
=
avio_r8
(
pb
);
segment
->
flag_entries
[
i
]
=
avio_r8
(
pb
);
segment
->
stream_offset_entries
[
i
]
=
avio_rb64
(
pb
);
segment
->
stream_offset_entries
[
i
]
=
avio_rb64
(
pb
);
if
(
segment
->
slice_count
)
{
avio_skip
(
pb
,
length
-
11
);
segment
->
slice_offset_entries
[
i
]
=
av_mallocz
(
segment
->
slice_count
*
sizeof
(
**
segment
->
slice_offset_entries
));
if
(
!
segment
->
slice_offset_entries
[
i
])
goto
errmem
;
for
(
j
=
0
;
j
<
segment
->
slice_count
;
j
++
)
segment
->
slice_offset_entries
[
i
][
j
]
=
avio_rb32
(
pb
);
}
avio_skip
(
pb
,
length
-
11
-
4
*
segment
->
slice_count
);
}
}
return
0
;
return
0
;
errmem:
if
(
segment
->
slice_offset_entries
&&
segment
->
slice_count
)
{
for
(
i
=
0
;
i
<
segment
->
nb_index_entries
;
i
++
)
av_free
(
segment
->
slice_offset_entries
[
i
]);
}
av_freep
(
&
segment
->
flag_entries
);
av_freep
(
&
segment
->
stream_offset_entries
);
av_freep
(
&
segment
->
slice_offset_entries
);
av_freep
(
&
segment
->
temporal_offset_entries
);
return
AVERROR
(
ENOMEM
);
}
}
static
int
mxf_read_index_table_segment
(
void
*
arg
,
AVIOContext
*
pb
,
int
tag
,
int
size
,
UID
uid
,
int64_t
klv_offset
)
static
int
mxf_read_index_table_segment
(
void
*
arg
,
AVIOContext
*
pb
,
int
tag
,
int
size
,
UID
uid
,
int64_t
klv_offset
)
...
@@ -769,13 +716,6 @@ static int mxf_read_index_table_segment(void *arg, AVIOContext *pb, int tag, int
...
@@ -769,13 +716,6 @@ static int mxf_read_index_table_segment(void *arg, AVIOContext *pb, int tag, int
segment
->
body_sid
=
avio_rb32
(
pb
);
segment
->
body_sid
=
avio_rb32
(
pb
);
av_dlog
(
NULL
,
"BodySID %d
\n
"
,
segment
->
body_sid
);
av_dlog
(
NULL
,
"BodySID %d
\n
"
,
segment
->
body_sid
);
break
;
break
;
case
0x3F08
:
segment
->
slice_count
=
avio_r8
(
pb
);
av_dlog
(
NULL
,
"SliceCount %d
\n
"
,
segment
->
slice_count
);
break
;
case
0x3F09
:
av_dlog
(
NULL
,
"DeltaEntryArray found
\n
"
);
return
mxf_read_delta_entry_array
(
pb
,
segment
);
case
0x3F0A
:
case
0x3F0A
:
av_dlog
(
NULL
,
"IndexEntryArray found
\n
"
);
av_dlog
(
NULL
,
"IndexEntryArray found
\n
"
);
return
mxf_read_index_entry_array
(
pb
,
segment
);
return
mxf_read_index_entry_array
(
pb
,
segment
);
...
@@ -1935,7 +1875,7 @@ static int mxf_read_close(AVFormatContext *s)
...
@@ -1935,7 +1875,7 @@ static int mxf_read_close(AVFormatContext *s)
{
{
MXFContext
*
mxf
=
s
->
priv_data
;
MXFContext
*
mxf
=
s
->
priv_data
;
MXFIndexTableSegment
*
seg
;
MXFIndexTableSegment
*
seg
;
int
i
,
j
;
int
i
;
av_freep
(
&
mxf
->
packages_refs
);
av_freep
(
&
mxf
->
packages_refs
);
...
@@ -1956,15 +1896,9 @@ static int mxf_read_close(AVFormatContext *s)
...
@@ -1956,15 +1896,9 @@ static int mxf_read_close(AVFormatContext *s)
break
;
break
;
case
IndexTableSegment
:
case
IndexTableSegment
:
seg
=
(
MXFIndexTableSegment
*
)
mxf
->
metadata_sets
[
i
];
seg
=
(
MXFIndexTableSegment
*
)
mxf
->
metadata_sets
[
i
];
if
(
seg
->
slice_count
)
for
(
j
=
0
;
j
<
seg
->
nb_index_entries
;
j
++
)
av_freep
(
&
seg
->
slice_offset_entries
[
j
]);
av_freep
(
&
seg
->
slice
);
av_freep
(
&
seg
->
element_delta
);
av_freep
(
&
seg
->
temporal_offset_entries
);
av_freep
(
&
seg
->
temporal_offset_entries
);
av_freep
(
&
seg
->
flag_entries
);
av_freep
(
&
seg
->
flag_entries
);
av_freep
(
&
seg
->
stream_offset_entries
);
av_freep
(
&
seg
->
stream_offset_entries
);
av_freep
(
&
seg
->
slice_offset_entries
);
break
;
break
;
default:
default:
break
;
break
;
...
...
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