[FFmpeg-devel] [PATCH v5 1/2] avformat/mxf: add platform local tag

lance.lmwang at gmail.com lance.lmwang at gmail.com
Sun Jan 31 02:36:43 EET 2021


On Sat, Jan 30, 2021 at 09:59:16PM +0100, Marton Balint wrote:
> 
> 
> On Sat, 30 Jan 2021, lance.lmwang at gmail.com wrote:
> 
> > From: Limin Wang <lance.lmwang at gmail.com>
> > 
> > Please check the string of platform with below command:
> > ./ffmpeg -i ../fate-suite/mxf/Sony-00001.mxf -c:v copy -c:a copy out.mxf
> > ./ffmpeg -i out.mxf
> > ....
> > application_platform: Lavf58.65.101 (linux)
> 
> I think this should simply be Lavf (linux), and the version should be stored
> in ToolkitVersion instead.

I agree. Then I prefer to to read and show ToolkitVersion tag in mxfdec first.
how about to use below format for the tag:
...
toolkit_version : 58.65.101

> 
> Regards,
> Marton
> 
> > 
> > Signed-off-by: Limin Wang <lance.lmwang at gmail.com>
> > ---
> > configure                               | 1 +
> > libavformat/mxfenc.c                    | 4 ++++
> > tests/ref/fate/copy-trac4914            | 2 +-
> > tests/ref/fate/mxf-d10-user-comments    | 2 +-
> > tests/ref/fate/mxf-opatom-user-comments | 2 +-
> > tests/ref/fate/mxf-reel_name            | 2 +-
> > tests/ref/fate/mxf-user-comments        | 2 +-
> > tests/ref/fate/time_base                | 2 +-
> > tests/ref/lavf/mxf                      | 6 +++---
> > tests/ref/lavf/mxf_d10                  | 2 +-
> > tests/ref/lavf/mxf_dv25                 | 2 +-
> > tests/ref/lavf/mxf_dvcpro50             | 2 +-
> > tests/ref/lavf/mxf_opatom               | 2 +-
> > tests/ref/lavf/mxf_opatom_audio         | 2 +-
> > 14 files changed, 19 insertions(+), 14 deletions(-)
> > 
> > diff --git a/configure b/configure
> > index df298b4..a092a6b 100755
> > --- a/configure
> > +++ b/configure
> > @@ -7579,6 +7579,7 @@ cat > $TMPH <<EOF
> > #define FFMPEG_DATADIR "$(eval c_escape $datadir)"
> > #define AVCONV_DATADIR "$(eval c_escape $datadir)"
> > #define CC_IDENT "$(c_escape ${cc_ident:-Unknown compiler})"
> > +#define OS_NAME $target_os
> > #define av_restrict $restrict_keyword
> > #define EXTERN_PREFIX "${extern_prefix}"
> > #define EXTERN_ASM ${extern_prefix}
> > diff --git a/libavformat/mxfenc.c b/libavformat/mxfenc.c
> > index 0c464d4..2cf443f 100644
> > --- a/libavformat/mxfenc.c
> > +++ b/libavformat/mxfenc.c
> > @@ -719,6 +719,7 @@ static void store_version(AVFormatContext *s){
> >     avio_wb16(pb, 0); // release
> > }
> > 
> > +#define PLATFROM_IDENT    "Lavf" AV_STRINGIFY(LIBAVFORMAT_VERSION (OS_NAME))
> > static void mxf_write_identification(AVFormatContext *s)
> > {
> >     MXFContext *mxf = s->priv_data;
> > @@ -726,6 +727,7 @@ static void mxf_write_identification(AVFormatContext *s)
> >     const char *company = "FFmpeg";
> >     const char *product = s->oformat != &ff_mxf_opatom_muxer ? "OP1a Muxer" : "OPAtom Muxer";
> >     const char *version;
> > +    const char *platform = s->flags & AVFMT_FLAG_BITEXACT ? "Lavf" : PLATFROM_IDENT;
> >     int length;
> > 
> >     mxf_write_metadata_key(pb, 0x013000);
> > @@ -735,6 +737,7 @@ static void mxf_write_identification(AVFormatContext *s)
> >         "0.0.0" : AV_STRINGIFY(LIBAVFORMAT_VERSION);
> >     length = 100 +mxf_utf16_local_tag_length(company) +
> >                   mxf_utf16_local_tag_length(product) +
> > +                  mxf_utf16_local_tag_length(platform) +
> >                   mxf_utf16_local_tag_length(version);
> >     klv_encode_ber_length(pb, length);
> > 
> > @@ -753,6 +756,7 @@ static void mxf_write_identification(AVFormatContext *s)
> >     store_version(s);
> > 
> >     mxf_write_local_tag_utf16(pb, 0x3C04, version); // Version String
> > +    mxf_write_local_tag_utf16(pb, 0x3C08, platform); // Platform
> > 
> >     // write product uid
> >     mxf_write_local_tag(pb, 16, 0x3C05);
> > diff --git a/tests/ref/fate/copy-trac4914 b/tests/ref/fate/copy-trac4914
> > index e8f8afb..743dc8c 100644
> > --- a/tests/ref/fate/copy-trac4914
> > +++ b/tests/ref/fate/copy-trac4914
> > @@ -1,4 +1,4 @@
> > -5d58a32f21b78169d925845f783054e6 *tests/data/fate/copy-trac4914.mxf
> > +f5150fb82c1bb5a90906fce93dcc3f76 *tests/data/fate/copy-trac4914.mxf
> > 561721 tests/data/fate/copy-trac4914.mxf
> > #tb 0: 1001/30000
> > #media_type 0: video
> > diff --git a/tests/ref/fate/mxf-d10-user-comments b/tests/ref/fate/mxf-d10-user-comments
> > index 3b9d9d2..c35add0 100644
> > --- a/tests/ref/fate/mxf-d10-user-comments
> > +++ b/tests/ref/fate/mxf-d10-user-comments
> > @@ -1 +1 @@
> > -fe9b43f5b6e7737fe2670b660fd3d860
> > +7bb9f39e8e05724525154de17f0235d8
> > diff --git a/tests/ref/fate/mxf-opatom-user-comments b/tests/ref/fate/mxf-opatom-user-comments
> > index be57eb4..ec4fdff 100644
> > --- a/tests/ref/fate/mxf-opatom-user-comments
> > +++ b/tests/ref/fate/mxf-opatom-user-comments
> > @@ -1 +1 @@
> > -9b3d7201c37c5783702774e46e0da141
> > +8475bebf3448a972ae89ba59309fd7d6
> > diff --git a/tests/ref/fate/mxf-reel_name b/tests/ref/fate/mxf-reel_name
> > index acda8fe..d50f0f6 100644
> > --- a/tests/ref/fate/mxf-reel_name
> > +++ b/tests/ref/fate/mxf-reel_name
> > @@ -1 +1 @@
> > -422d6ed4821e7bbecbcdecc553abc6e4
> > +ce49a0361d3f79106e1952d387eace51
> > diff --git a/tests/ref/fate/mxf-user-comments b/tests/ref/fate/mxf-user-comments
> > index 3b77db9..5fcdc58 100644
> > --- a/tests/ref/fate/mxf-user-comments
> > +++ b/tests/ref/fate/mxf-user-comments
> > @@ -1 +1 @@
> > -c77b632dbcdacd6466e1ec794917556e
> > +956f653cd75e1a319569caec9df81b4f
> > diff --git a/tests/ref/fate/time_base b/tests/ref/fate/time_base
> > index d3c9795..28815d0 100644
> > --- a/tests/ref/fate/time_base
> > +++ b/tests/ref/fate/time_base
> > @@ -1 +1 @@
> > -e5c9da6972b6f6e7b15bcbbf20a9dbd1
> > +78ac0348027b75d73acb8bea14e67a59
> > diff --git a/tests/ref/lavf/mxf b/tests/ref/lavf/mxf
> > index 1b1fe1a..21bf2be 100644
> > --- a/tests/ref/lavf/mxf
> > +++ b/tests/ref/lavf/mxf
> > @@ -1,9 +1,9 @@
> > -1703da2e9f0ca49a5f0bcbcc6944c9c0 *tests/data/lavf/lavf.mxf
> > +8938d5c4a396ff1b24d10d4f917ae1c9 *tests/data/lavf/lavf.mxf
> > 526393 tests/data/lavf/lavf.mxf
> > tests/data/lavf/lavf.mxf CRC=0x8dddfaab
> > -b44c4f138f1a87256211c3112dd52c87 *tests/data/lavf/lavf.mxf
> > +93ea2cfdf5dda7fffdc0d2fdcfb6a9a4 *tests/data/lavf/lavf.mxf
> > 561721 tests/data/lavf/lavf.mxf
> > tests/data/lavf/lavf.mxf CRC=0x96ff1b48
> > -9ede3c95054c30eb815fbe598a1f097b *tests/data/lavf/lavf.mxf
> > +87bdf844ae34bcc758e44419e80177a0 *tests/data/lavf/lavf.mxf
> > 526393 tests/data/lavf/lavf.mxf
> > tests/data/lavf/lavf.mxf CRC=0x8dddfaab
> > diff --git a/tests/ref/lavf/mxf_d10 b/tests/ref/lavf/mxf_d10
> > index 19e6f20..47ef244 100644
> > --- a/tests/ref/lavf/mxf_d10
> > +++ b/tests/ref/lavf/mxf_d10
> > @@ -1,3 +1,3 @@
> > -c72f1f3d6ce555f96946c421f705f880 *tests/data/lavf/lavf.mxf_d10
> > +7f16902e28718c2a92bc082400a1c6ee *tests/data/lavf/lavf.mxf_d10
> > 5332013 tests/data/lavf/lavf.mxf_d10
> > tests/data/lavf/lavf.mxf_d10 CRC=0x6c74d488
> > diff --git a/tests/ref/lavf/mxf_dv25 b/tests/ref/lavf/mxf_dv25
> > index 2951538..92509cf 100644
> > --- a/tests/ref/lavf/mxf_dv25
> > +++ b/tests/ref/lavf/mxf_dv25
> > @@ -1,3 +1,3 @@
> > -5048796729fba47e9614a177c370e850 *tests/data/lavf/lavf.mxf_dv25
> > +106e33eb1634595623f0334e92204b65 *tests/data/lavf/lavf.mxf_dv25
> > 3834413 tests/data/lavf/lavf.mxf_dv25
> > tests/data/lavf/lavf.mxf_dv25 CRC=0xbdaf7f52
> > diff --git a/tests/ref/lavf/mxf_dvcpro50 b/tests/ref/lavf/mxf_dvcpro50
> > index 9df2fc9..2d569b0 100644
> > --- a/tests/ref/lavf/mxf_dvcpro50
> > +++ b/tests/ref/lavf/mxf_dvcpro50
> > @@ -1,3 +1,3 @@
> > -7023122fc4bcd5c12de6a33cc78ce9b8 *tests/data/lavf/lavf.mxf_dvcpro50
> > +3d5a303c22666996700f0e8f6e4cb938 *tests/data/lavf/lavf.mxf_dvcpro50
> > 7431213 tests/data/lavf/lavf.mxf_dvcpro50
> > tests/data/lavf/lavf.mxf_dvcpro50 CRC=0xe3bbe4b4
> > diff --git a/tests/ref/lavf/mxf_opatom b/tests/ref/lavf/mxf_opatom
> > index bff36e0..61e7555 100644
> > --- a/tests/ref/lavf/mxf_opatom
> > +++ b/tests/ref/lavf/mxf_opatom
> > @@ -1,3 +1,3 @@
> > -8a4c5680b0955d4e2abecfb1c37a56d4 *tests/data/lavf/lavf.mxf_opatom
> > +5d235c127ace64b1f4fe6c79a7ca8be6 *tests/data/lavf/lavf.mxf_opatom
> > 4717625 tests/data/lavf/lavf.mxf_opatom
> > tests/data/lavf/lavf.mxf_opatom CRC=0xf55aa22a
> > diff --git a/tests/ref/lavf/mxf_opatom_audio b/tests/ref/lavf/mxf_opatom_audio
> > index 5c65a37..97362e7 100644
> > --- a/tests/ref/lavf/mxf_opatom_audio
> > +++ b/tests/ref/lavf/mxf_opatom_audio
> > @@ -1,3 +1,3 @@
> > -697f4eb4a472909945222d7750145f80 *tests/data/lavf/lavf.mxf_opatom_audio
> > +c356a3fdd49a1e015961678e837c12bb *tests/data/lavf/lavf.mxf_opatom_audio
> > 102969 tests/data/lavf/lavf.mxf_opatom_audio
> > tests/data/lavf/lavf.mxf_opatom_audio CRC=0xd155c6ff
> > -- 
> > 1.8.3.1
> > 
> > _______________________________________________
> > ffmpeg-devel mailing list
> > ffmpeg-devel at ffmpeg.org
> > https://ffmpeg.org/mailman/listinfo/ffmpeg-devel
> > 
> > To unsubscribe, visit link above, or email
> > ffmpeg-devel-request at ffmpeg.org with subject "unsubscribe".
> _______________________________________________
> ffmpeg-devel mailing list
> ffmpeg-devel at ffmpeg.org
> https://ffmpeg.org/mailman/listinfo/ffmpeg-devel
> 
> To unsubscribe, visit link above, or email
> ffmpeg-devel-request at ffmpeg.org with subject "unsubscribe".

-- 
Thanks,
Limin Wang


More information about the ffmpeg-devel mailing list