diff mbox series

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

Message ID 1611990820-10877-1-git-send-email-lance.lmwang@gmail.com
State Accepted
Headers show
Series [FFmpeg-devel,v5,1/2] avformat/mxf: add platform local tag | expand

Checks

Context Check Description
andriy/x86_make success Make finished
andriy/x86_make_fate success Make fate finished
andriy/PPC64_make success Make finished
andriy/PPC64_make_fate success Make fate finished

Commit Message

Lance Wang Jan. 30, 2021, 7:13 a.m. UTC
From: Limin Wang <lance.lmwang@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)

Signed-off-by: Limin Wang <lance.lmwang@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(-)

Comments

Marton Balint Jan. 30, 2021, 8:59 p.m. UTC | #1
On Sat, 30 Jan 2021, lance.lmwang@gmail.com wrote:

> From: Limin Wang <lance.lmwang@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.

Regards,
Marton

>
> Signed-off-by: Limin Wang <lance.lmwang@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@ffmpeg.org
> https://ffmpeg.org/mailman/listinfo/ffmpeg-devel
>
> To unsubscribe, visit link above, or email
> ffmpeg-devel-request@ffmpeg.org with subject "unsubscribe".
Lance Wang Jan. 31, 2021, 12:36 a.m. UTC | #2
On Sat, Jan 30, 2021 at 09:59:16PM +0100, Marton Balint wrote:
> 
> 
> On Sat, 30 Jan 2021, lance.lmwang@gmail.com wrote:
> 
> > From: Limin Wang <lance.lmwang@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@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@ffmpeg.org
> > https://ffmpeg.org/mailman/listinfo/ffmpeg-devel
> > 
> > To unsubscribe, visit link above, or email
> > ffmpeg-devel-request@ffmpeg.org with subject "unsubscribe".
> _______________________________________________
> ffmpeg-devel mailing list
> ffmpeg-devel@ffmpeg.org
> https://ffmpeg.org/mailman/listinfo/ffmpeg-devel
> 
> To unsubscribe, visit link above, or email
> ffmpeg-devel-request@ffmpeg.org with subject "unsubscribe".
diff mbox series

Patch

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