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
ad029c24
Commit
ad029c24
authored
Feb 23, 2012
by
Matthieu Bouron
Committed by
Michael Niedermayer
Mar 11, 2012
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
mxfdec: add timecode to metadata
Signed-off-by:
Michael Niedermayer
<
michaelni@gmx.at
>
parent
c3c2db49
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
61 additions
and
2 deletions
+61
-2
general.texi
doc/general.texi
+1
-1
mxfdec.c
libavformat/mxfdec.c
+60
-1
No files found.
doc/general.texi
View file @
ad029c24
...
@@ -883,7 +883,7 @@ performance on systems without hardware floating point support).
...
@@ -883,7 +883,7 @@ performance on systems without hardware floating point support).
@item GXF @tab X @tab X
@item GXF @tab X @tab X
@item MOV @tab X @tab
@item MOV @tab X @tab
@item MPEG1/2 @tab X @tab X
@item MPEG1/2 @tab X @tab X
@item MXF @tab
@tab X
@item MXF @tab
X
@tab X
@end multitable
@end multitable
@bye
@bye
libavformat/mxfdec.c
View file @
ad029c24
...
@@ -48,6 +48,7 @@
...
@@ -48,6 +48,7 @@
#include "libavutil/aes.h"
#include "libavutil/aes.h"
#include "libavutil/mathematics.h"
#include "libavutil/mathematics.h"
#include "libavcodec/bytestream.h"
#include "libavcodec/bytestream.h"
#include "libavutil/timecode.h"
#include "avformat.h"
#include "avformat.h"
#include "internal.h"
#include "internal.h"
#include "mxf.h"
#include "mxf.h"
...
@@ -113,6 +114,15 @@ typedef struct {
...
@@ -113,6 +114,15 @@ typedef struct {
int64_t
duration
;
int64_t
duration
;
}
MXFSequence
;
}
MXFSequence
;
typedef
struct
{
UID
uid
;
enum
MXFMetadataSetType
type
;
int
drop_frame
;
int
start_frame
;
struct
AVRational
rate
;
AVTimecode
tc
;
}
MXFTimecodeComponent
;
typedef
struct
{
typedef
struct
{
UID
uid
;
UID
uid
;
enum
MXFMetadataSetType
type
;
enum
MXFMetadataSetType
type
;
...
@@ -626,6 +636,23 @@ static int mxf_read_material_package(void *arg, AVIOContext *pb, int tag, int si
...
@@ -626,6 +636,23 @@ static int mxf_read_material_package(void *arg, AVIOContext *pb, int tag, int si
return
0
;
return
0
;
}
}
static
int
mxf_read_timecode_component
(
void
*
arg
,
AVIOContext
*
pb
,
int
tag
,
int
size
,
UID
uid
,
int64_t
klv_offset
)
{
MXFTimecodeComponent
*
mxf_timecode
=
arg
;
switch
(
tag
)
{
case
0x1501
:
mxf_timecode
->
start_frame
=
avio_rb64
(
pb
);
break
;
case
0x1502
:
mxf_timecode
->
rate
=
(
AVRational
){
avio_rb16
(
pb
),
1
};
break
;
case
0x1503
:
mxf_timecode
->
drop_frame
=
avio_r8
(
pb
);
break
;
}
return
0
;
}
static
int
mxf_read_track
(
void
*
arg
,
AVIOContext
*
pb
,
int
tag
,
int
size
,
UID
uid
,
int64_t
klv_offset
)
static
int
mxf_read_track
(
void
*
arg
,
AVIOContext
*
pb
,
int
tag
,
int
size
,
UID
uid
,
int64_t
klv_offset
)
{
{
MXFTrack
*
track
=
arg
;
MXFTrack
*
track
=
arg
;
...
@@ -1274,6 +1301,14 @@ static int mxf_is_intra_only(MXFDescriptor *descriptor)
...
@@ -1274,6 +1301,14 @@ static int mxf_is_intra_only(MXFDescriptor *descriptor)
&
descriptor
->
essence_codec_ul
)
->
id
!=
CODEC_ID_NONE
;
&
descriptor
->
essence_codec_ul
)
->
id
!=
CODEC_ID_NONE
;
}
}
static
int
mxf_add_timecode_metadata
(
AVDictionary
**
pm
,
const
char
*
key
,
AVTimecode
*
tc
)
{
char
buf
[
AV_TIMECODE_STR_SIZE
];
av_dict_set
(
pm
,
key
,
av_timecode_make_string
(
tc
,
buf
,
0
),
0
);
return
0
;
}
static
int
mxf_parse_structural_metadata
(
MXFContext
*
mxf
)
static
int
mxf_parse_structural_metadata
(
MXFContext
*
mxf
)
{
{
MXFPackage
*
material_package
=
NULL
;
MXFPackage
*
material_package
=
NULL
;
...
@@ -1298,25 +1333,48 @@ static int mxf_parse_structural_metadata(MXFContext *mxf)
...
@@ -1298,25 +1333,48 @@ static int mxf_parse_structural_metadata(MXFContext *mxf)
MXFTrack
*
temp_track
=
NULL
;
MXFTrack
*
temp_track
=
NULL
;
MXFDescriptor
*
descriptor
=
NULL
;
MXFDescriptor
*
descriptor
=
NULL
;
MXFStructuralComponent
*
component
=
NULL
;
MXFStructuralComponent
*
component
=
NULL
;
MXFTimecodeComponent
*
mxf_tc
=
NULL
;
UID
*
essence_container_ul
=
NULL
;
UID
*
essence_container_ul
=
NULL
;
const
MXFCodecUL
*
codec_ul
=
NULL
;
const
MXFCodecUL
*
codec_ul
=
NULL
;
const
MXFCodecUL
*
container_ul
=
NULL
;
const
MXFCodecUL
*
container_ul
=
NULL
;
const
MXFCodecUL
*
pix_fmt_ul
=
NULL
;
const
MXFCodecUL
*
pix_fmt_ul
=
NULL
;
AVStream
*
st
;
AVStream
*
st
;
AVTimecode
tc
;
int
flags
;
if
(
!
(
material_track
=
mxf_resolve_strong_ref
(
mxf
,
&
material_package
->
tracks_refs
[
i
],
Track
)))
{
if
(
!
(
material_track
=
mxf_resolve_strong_ref
(
mxf
,
&
material_package
->
tracks_refs
[
i
],
Track
)))
{
av_log
(
mxf
->
fc
,
AV_LOG_ERROR
,
"could not resolve material track strong ref
\n
"
);
av_log
(
mxf
->
fc
,
AV_LOG_ERROR
,
"could not resolve material track strong ref
\n
"
);
continue
;
continue
;
}
}
if
((
component
=
mxf_resolve_strong_ref
(
mxf
,
&
material_track
->
sequence_ref
,
TimecodeComponent
)))
{
mxf_tc
=
(
MXFTimecodeComponent
*
)
component
;
flags
=
mxf_tc
->
drop_frame
==
1
?
AV_TIMECODE_FLAG_DROPFRAME
:
0
;
if
(
av_timecode_init
(
&
tc
,
mxf_tc
->
rate
,
flags
,
mxf_tc
->
start_frame
,
mxf
)
==
0
)
{
mxf_add_timecode_metadata
(
&
mxf
->
fc
->
metadata
,
"timecode"
,
&
tc
);
}
}
if
(
!
(
material_track
->
sequence
=
mxf_resolve_strong_ref
(
mxf
,
&
material_track
->
sequence_ref
,
Sequence
)))
{
if
(
!
(
material_track
->
sequence
=
mxf_resolve_strong_ref
(
mxf
,
&
material_track
->
sequence_ref
,
Sequence
)))
{
av_log
(
mxf
->
fc
,
AV_LOG_ERROR
,
"could not resolve material track sequence strong ref
\n
"
);
av_log
(
mxf
->
fc
,
AV_LOG_ERROR
,
"could not resolve material track sequence strong ref
\n
"
);
continue
;
continue
;
}
}
for
(
j
=
0
;
j
<
material_track
->
sequence
->
structural_components_count
;
j
++
)
{
component
=
mxf_resolve_strong_ref
(
mxf
,
&
material_track
->
sequence
->
structural_components_refs
[
j
],
TimecodeComponent
);
if
(
!
component
)
continue
;
mxf_tc
=
(
MXFTimecodeComponent
*
)
component
;
flags
=
mxf_tc
->
drop_frame
==
1
?
AV_TIMECODE_FLAG_DROPFRAME
:
0
;
if
(
av_timecode_init
(
&
tc
,
mxf_tc
->
rate
,
flags
,
mxf_tc
->
start_frame
,
mxf
)
==
0
)
{
mxf_add_timecode_metadata
(
&
mxf
->
fc
->
metadata
,
"timecode"
,
&
tc
);
break
;
}
}
/* TODO: handle multiple source clips */
/* TODO: handle multiple source clips */
for
(
j
=
0
;
j
<
material_track
->
sequence
->
structural_components_count
;
j
++
)
{
for
(
j
=
0
;
j
<
material_track
->
sequence
->
structural_components_count
;
j
++
)
{
/* TODO: handle timecode component */
component
=
mxf_resolve_strong_ref
(
mxf
,
&
material_track
->
sequence
->
structural_components_refs
[
j
],
SourceClip
);
component
=
mxf_resolve_strong_ref
(
mxf
,
&
material_track
->
sequence
->
structural_components_refs
[
j
],
SourceClip
);
if
(
!
component
)
if
(
!
component
)
continue
;
continue
;
...
@@ -1515,6 +1573,7 @@ static const MXFMetadataReadTableEntry mxf_metadata_read_table[] = {
...
@@ -1515,6 +1573,7 @@ static const MXFMetadataReadTableEntry mxf_metadata_read_table[] = {
{
{
0x06
,
0x0E
,
0x2B
,
0x34
,
0x02
,
0x53
,
0x01
,
0x01
,
0x0d
,
0x01
,
0x01
,
0x01
,
0x01
,
0x01
,
0x47
,
0x00
},
mxf_read_generic_descriptor
,
sizeof
(
MXFDescriptor
),
Descriptor
},
/* AES3 */
{
{
0x06
,
0x0E
,
0x2B
,
0x34
,
0x02
,
0x53
,
0x01
,
0x01
,
0x0d
,
0x01
,
0x01
,
0x01
,
0x01
,
0x01
,
0x47
,
0x00
},
mxf_read_generic_descriptor
,
sizeof
(
MXFDescriptor
),
Descriptor
},
/* AES3 */
{
{
0x06
,
0x0E
,
0x2B
,
0x34
,
0x02
,
0x53
,
0x01
,
0x01
,
0x0d
,
0x01
,
0x01
,
0x01
,
0x01
,
0x01
,
0x3A
,
0x00
},
mxf_read_track
,
sizeof
(
MXFTrack
),
Track
},
/* Static Track */
{
{
0x06
,
0x0E
,
0x2B
,
0x34
,
0x02
,
0x53
,
0x01
,
0x01
,
0x0d
,
0x01
,
0x01
,
0x01
,
0x01
,
0x01
,
0x3A
,
0x00
},
mxf_read_track
,
sizeof
(
MXFTrack
),
Track
},
/* Static Track */
{
{
0x06
,
0x0E
,
0x2B
,
0x34
,
0x02
,
0x53
,
0x01
,
0x01
,
0x0d
,
0x01
,
0x01
,
0x01
,
0x01
,
0x01
,
0x3B
,
0x00
},
mxf_read_track
,
sizeof
(
MXFTrack
),
Track
},
/* Generic Track */
{
{
0x06
,
0x0E
,
0x2B
,
0x34
,
0x02
,
0x53
,
0x01
,
0x01
,
0x0d
,
0x01
,
0x01
,
0x01
,
0x01
,
0x01
,
0x3B
,
0x00
},
mxf_read_track
,
sizeof
(
MXFTrack
),
Track
},
/* Generic Track */
{
{
0x06
,
0x0E
,
0x2B
,
0x34
,
0x02
,
0x53
,
0x01
,
0x01
,
0x0d
,
0x01
,
0x01
,
0x01
,
0x01
,
0x01
,
0x14
,
0x00
},
mxf_read_timecode_component
,
sizeof
(
MXFTimecodeComponent
),
TimecodeComponent
},
{
{
0x06
,
0x0E
,
0x2B
,
0x34
,
0x02
,
0x53
,
0x01
,
0x01
,
0x0d
,
0x01
,
0x04
,
0x01
,
0x02
,
0x02
,
0x00
,
0x00
},
mxf_read_cryptographic_context
,
sizeof
(
MXFCryptoContext
),
CryptoContext
},
{
{
0x06
,
0x0E
,
0x2B
,
0x34
,
0x02
,
0x53
,
0x01
,
0x01
,
0x0d
,
0x01
,
0x04
,
0x01
,
0x02
,
0x02
,
0x00
,
0x00
},
mxf_read_cryptographic_context
,
sizeof
(
MXFCryptoContext
),
CryptoContext
},
{
{
0x06
,
0x0E
,
0x2B
,
0x34
,
0x02
,
0x53
,
0x01
,
0x01
,
0x0d
,
0x01
,
0x02
,
0x01
,
0x01
,
0x10
,
0x01
,
0x00
},
mxf_read_index_table_segment
,
sizeof
(
MXFIndexTableSegment
),
IndexTableSegment
},
{
{
0x06
,
0x0E
,
0x2B
,
0x34
,
0x02
,
0x53
,
0x01
,
0x01
,
0x0d
,
0x01
,
0x02
,
0x01
,
0x01
,
0x10
,
0x01
,
0x00
},
mxf_read_index_table_segment
,
sizeof
(
MXFIndexTableSegment
),
IndexTableSegment
},
{
{
0x00
,
0x00
,
0x00
,
0x00
,
0x00
,
0x00
,
0x00
,
0x00
,
0x00
,
0x00
,
0x00
,
0x00
,
0x00
,
0x00
,
0x00
,
0x00
},
NULL
,
0
,
AnyType
},
{
{
0x00
,
0x00
,
0x00
,
0x00
,
0x00
,
0x00
,
0x00
,
0x00
,
0x00
,
0x00
,
0x00
,
0x00
,
0x00
,
0x00
,
0x00
,
0x00
},
NULL
,
0
,
AnyType
},
...
...
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